diff --git a/common/source/java/ch/systemsx/cisd/common/parser/TabFileLoader.java b/common/source/java/ch/systemsx/cisd/common/parser/TabFileLoader.java
index 4dea725e2cd3588043d5536ff6a167ff22fc5fa0..f692d96507b09296a41252ba494b35c1457e74a9 100644
--- a/common/source/java/ch/systemsx/cisd/common/parser/TabFileLoader.java
+++ b/common/source/java/ch/systemsx/cisd/common/parser/TabFileLoader.java
@@ -265,7 +265,7 @@ public class TabFileLoader<T>
         {
             ILine<String> line = lineIterator.next();
             String text = line.getText();
-            if (DEFAULT_SECTION.equals(text))
+            if (DEFAULT_SECTION.equals(text.trim()))
             {
                 break;
             }
@@ -414,7 +414,7 @@ public class TabFileLoader<T>
     private static boolean startsDefaultSection(ILine<String> line)
     {
         String text = line.getText();
-        return DEFAULT_SECTION.equals(text);
+        return DEFAULT_SECTION.equals(text.trim());
     }
 
     private static boolean startsWithComment(ILine<String> line)
diff --git a/datastore_server/source/java/ch/systemsx/cisd/etlserver/SampleRegisteringDropbox.java b/datastore_server/source/java/ch/systemsx/cisd/etlserver/SampleRegisteringDropbox.java
index d4003a07b25b8aca035691f9470c8c7c16296bed..f0690ef2a3bb54189ca094cb7422e6d0c4bc96b8 100644
--- a/datastore_server/source/java/ch/systemsx/cisd/etlserver/SampleRegisteringDropbox.java
+++ b/datastore_server/source/java/ch/systemsx/cisd/etlserver/SampleRegisteringDropbox.java
@@ -108,7 +108,7 @@ public class SampleRegisteringDropbox implements IDataSetHandler
                     new NamedInputStream(new FileInputStream(file), file.getName());
             BatchSamplesOperation info =
                     SampleUploadSectionsParser.prepareSamples(sampleType, Arrays.asList(stream),
-                            defaultSpaceIdentifierOrNull, sampleCodeGeneratorOrNull, true,
+                            defaultSpaceIdentifierOrNull, sampleCodeGeneratorOrNull, true, null,
                             BatchOperationKind.REGISTRATION);
             logSamplesExtracted(file, info);
             service.registerSamples(info.getSamples(), userOrNull);
diff --git a/openbis/.settings/.gitignore b/openbis/.settings/.gitignore
deleted file mode 100644
index e69de29bb2d1d6434b8b29ae775ad8c2e48c5391..0000000000000000000000000000000000000000
diff --git a/openbis/.settings/org.eclipse.jdt.ui.prefs b/openbis/.settings/org.eclipse.jdt.ui.prefs
new file mode 100644
index 0000000000000000000000000000000000000000..954b0282f418a61dee15bbddd3720a6fbf0028ab
--- /dev/null
+++ b/openbis/.settings/org.eclipse.jdt.ui.prefs
@@ -0,0 +1,55 @@
+#Wed Apr 20 13:05:19 CEST 2011
+eclipse.preferences.version=1
+editor_save_participant_org.eclipse.jdt.ui.postsavelistener.cleanup=true
+sp_cleanup.add_default_serial_version_id=true
+sp_cleanup.add_generated_serial_version_id=false
+sp_cleanup.add_missing_annotations=true
+sp_cleanup.add_missing_deprecated_annotations=true
+sp_cleanup.add_missing_methods=false
+sp_cleanup.add_missing_nls_tags=false
+sp_cleanup.add_missing_override_annotations=true
+sp_cleanup.add_missing_override_annotations_interface_methods=true
+sp_cleanup.add_serial_version_id=false
+sp_cleanup.always_use_blocks=true
+sp_cleanup.always_use_parentheses_in_expressions=false
+sp_cleanup.always_use_this_for_non_static_field_access=false
+sp_cleanup.always_use_this_for_non_static_method_access=false
+sp_cleanup.convert_to_enhanced_for_loop=false
+sp_cleanup.correct_indentation=false
+sp_cleanup.format_source_code=true
+sp_cleanup.format_source_code_changes_only=false
+sp_cleanup.make_local_variable_final=false
+sp_cleanup.make_parameters_final=false
+sp_cleanup.make_private_fields_final=true
+sp_cleanup.make_type_abstract_if_missing_method=false
+sp_cleanup.make_variable_declarations_final=true
+sp_cleanup.never_use_blocks=false
+sp_cleanup.never_use_parentheses_in_expressions=true
+sp_cleanup.on_save_use_additional_actions=false
+sp_cleanup.organize_imports=true
+sp_cleanup.qualify_static_field_accesses_with_declaring_class=false
+sp_cleanup.qualify_static_member_accesses_through_instances_with_declaring_class=true
+sp_cleanup.qualify_static_member_accesses_through_subtypes_with_declaring_class=true
+sp_cleanup.qualify_static_member_accesses_with_declaring_class=false
+sp_cleanup.qualify_static_method_accesses_with_declaring_class=false
+sp_cleanup.remove_private_constructors=true
+sp_cleanup.remove_trailing_whitespaces=false
+sp_cleanup.remove_trailing_whitespaces_all=true
+sp_cleanup.remove_trailing_whitespaces_ignore_empty=false
+sp_cleanup.remove_unnecessary_casts=true
+sp_cleanup.remove_unnecessary_nls_tags=false
+sp_cleanup.remove_unused_imports=false
+sp_cleanup.remove_unused_local_variables=false
+sp_cleanup.remove_unused_private_fields=true
+sp_cleanup.remove_unused_private_members=false
+sp_cleanup.remove_unused_private_methods=true
+sp_cleanup.remove_unused_private_types=true
+sp_cleanup.sort_members=false
+sp_cleanup.sort_members_all=false
+sp_cleanup.use_blocks=false
+sp_cleanup.use_blocks_only_for_return_and_throw=false
+sp_cleanup.use_parentheses_in_expressions=false
+sp_cleanup.use_this_for_non_static_field_access=false
+sp_cleanup.use_this_for_non_static_field_access_only_if_necessary=true
+sp_cleanup.use_this_for_non_static_method_access=false
+sp_cleanup.use_this_for_non_static_method_access_only_if_necessary=true
diff --git a/openbis/results.txt b/openbis/results.txt
new file mode 100644
index 0000000000000000000000000000000000000000..9ebdbb4e845eaed00dfbc16baeefa585faa9f379
--- /dev/null
+++ b/openbis/results.txt
@@ -0,0 +1,31526 @@
+./source/sql/postgresql/026/.svn/text-base/function-026.sql.svn-base:$$ LANGUAGE 'plpgsql';
+./source/sql/postgresql/026/.svn/text-base/function-026.sql.svn-base:$$ LANGUAGE 'plpgsql';
+./source/sql/postgresql/026/.svn/text-base/function-026.sql.svn-base:$$ LANGUAGE 'plpgsql';
+./source/sql/postgresql/026/.svn/text-base/function-026.sql.svn-base:$$ LANGUAGE 'plpgsql';
+./source/sql/postgresql/026/function-026.sql:$$ LANGUAGE 'plpgsql';
+./source/sql/postgresql/026/function-026.sql:$$ LANGUAGE 'plpgsql';
+./source/sql/postgresql/026/function-026.sql:$$ LANGUAGE 'plpgsql';
+./source/sql/postgresql/026/function-026.sql:$$ LANGUAGE 'plpgsql';
+./source/sql/postgresql/027/.svn/text-base/function-027.sql.svn-base:$$ LANGUAGE 'plpgsql';
+./source/sql/postgresql/027/.svn/text-base/function-027.sql.svn-base:$$ LANGUAGE 'plpgsql';
+./source/sql/postgresql/027/.svn/text-base/function-027.sql.svn-base:$$ LANGUAGE 'plpgsql';
+./source/sql/postgresql/027/.svn/text-base/function-027.sql.svn-base:$$ LANGUAGE 'plpgsql';
+./source/sql/postgresql/027/function-027.sql:$$ LANGUAGE 'plpgsql';
+./source/sql/postgresql/027/function-027.sql:$$ LANGUAGE 'plpgsql';
+./source/sql/postgresql/027/function-027.sql:$$ LANGUAGE 'plpgsql';
+./source/sql/postgresql/027/function-027.sql:$$ LANGUAGE 'plpgsql';
+./source/sql/postgresql/028/.svn/text-base/function-028.sql.svn-base:$$ LANGUAGE 'plpgsql';
+./source/sql/postgresql/028/.svn/text-base/function-028.sql.svn-base:$$ LANGUAGE 'plpgsql';
+./source/sql/postgresql/028/.svn/text-base/function-028.sql.svn-base:$$ LANGUAGE 'plpgsql';
+./source/sql/postgresql/028/.svn/text-base/function-028.sql.svn-base:$$ LANGUAGE 'plpgsql';
+./source/sql/postgresql/028/function-028.sql:$$ LANGUAGE 'plpgsql';
+./source/sql/postgresql/028/function-028.sql:$$ LANGUAGE 'plpgsql';
+./source/sql/postgresql/028/function-028.sql:$$ LANGUAGE 'plpgsql';
+./source/sql/postgresql/028/function-028.sql:$$ LANGUAGE 'plpgsql';
+./source/sql/postgresql/029/.svn/text-base/function-029.sql.svn-base:$$ LANGUAGE 'plpgsql';
+./source/sql/postgresql/029/.svn/text-base/function-029.sql.svn-base:$$ LANGUAGE 'plpgsql';
+./source/sql/postgresql/029/.svn/text-base/function-029.sql.svn-base:$$ LANGUAGE 'plpgsql';
+./source/sql/postgresql/029/.svn/text-base/function-029.sql.svn-base:$$ LANGUAGE 'plpgsql';
+./source/sql/postgresql/029/.svn/text-base/function-029.sql.svn-base:$$ LANGUAGE 'plpgsql';
+./source/sql/postgresql/029/.svn/text-base/function-029.sql.svn-base:$$ LANGUAGE 'plpgsql';
+./source/sql/postgresql/029/.svn/text-base/function-029.sql.svn-base:$$ LANGUAGE 'plpgsql';
+./source/sql/postgresql/029/function-029.sql:$$ LANGUAGE 'plpgsql';
+./source/sql/postgresql/029/function-029.sql:$$ LANGUAGE 'plpgsql';
+./source/sql/postgresql/029/function-029.sql:$$ LANGUAGE 'plpgsql';
+./source/sql/postgresql/029/function-029.sql:$$ LANGUAGE 'plpgsql';
+./source/sql/postgresql/029/function-029.sql:$$ LANGUAGE 'plpgsql';
+./source/sql/postgresql/029/function-029.sql:$$ LANGUAGE 'plpgsql';
+./source/sql/postgresql/029/function-029.sql:$$ LANGUAGE 'plpgsql';
+./source/sql/postgresql/030/.svn/text-base/function-030.sql.svn-base:$$ LANGUAGE 'plpgsql';
+./source/sql/postgresql/030/.svn/text-base/function-030.sql.svn-base:$$ LANGUAGE 'plpgsql';
+./source/sql/postgresql/030/.svn/text-base/function-030.sql.svn-base:$$ LANGUAGE 'plpgsql';
+./source/sql/postgresql/030/.svn/text-base/function-030.sql.svn-base:$$ LANGUAGE 'plpgsql';
+./source/sql/postgresql/030/.svn/text-base/function-030.sql.svn-base:$$ LANGUAGE 'plpgsql';
+./source/sql/postgresql/030/.svn/text-base/function-030.sql.svn-base:$$ LANGUAGE 'plpgsql';
+./source/sql/postgresql/030/.svn/text-base/function-030.sql.svn-base:$$ LANGUAGE 'plpgsql';
+./source/sql/postgresql/030/.svn/text-base/function-030.sql.svn-base:$$ LANGUAGE 'plpgsql';
+./source/sql/postgresql/030/function-030.sql:$$ LANGUAGE 'plpgsql';
+./source/sql/postgresql/030/function-030.sql:$$ LANGUAGE 'plpgsql';
+./source/sql/postgresql/030/function-030.sql:$$ LANGUAGE 'plpgsql';
+./source/sql/postgresql/030/function-030.sql:$$ LANGUAGE 'plpgsql';
+./source/sql/postgresql/030/function-030.sql:$$ LANGUAGE 'plpgsql';
+./source/sql/postgresql/030/function-030.sql:$$ LANGUAGE 'plpgsql';
+./source/sql/postgresql/030/function-030.sql:$$ LANGUAGE 'plpgsql';
+./source/sql/postgresql/030/function-030.sql:$$ LANGUAGE 'plpgsql';
+./source/sql/postgresql/031/.svn/text-base/function-031.sql.svn-base:$$ LANGUAGE 'plpgsql';
+./source/sql/postgresql/031/.svn/text-base/function-031.sql.svn-base:$$ LANGUAGE 'plpgsql';
+./source/sql/postgresql/031/.svn/text-base/function-031.sql.svn-base:$$ LANGUAGE 'plpgsql';
+./source/sql/postgresql/031/.svn/text-base/function-031.sql.svn-base:$$ LANGUAGE 'plpgsql';
+./source/sql/postgresql/031/.svn/text-base/function-031.sql.svn-base:$$ LANGUAGE 'plpgsql';
+./source/sql/postgresql/031/.svn/text-base/function-031.sql.svn-base:$$ LANGUAGE 'plpgsql';
+./source/sql/postgresql/031/.svn/text-base/function-031.sql.svn-base:$$ LANGUAGE 'plpgsql';
+./source/sql/postgresql/031/.svn/text-base/function-031.sql.svn-base:$$ LANGUAGE 'plpgsql';
+./source/sql/postgresql/031/function-031.sql:$$ LANGUAGE 'plpgsql';
+./source/sql/postgresql/031/function-031.sql:$$ LANGUAGE 'plpgsql';
+./source/sql/postgresql/031/function-031.sql:$$ LANGUAGE 'plpgsql';
+./source/sql/postgresql/031/function-031.sql:$$ LANGUAGE 'plpgsql';
+./source/sql/postgresql/031/function-031.sql:$$ LANGUAGE 'plpgsql';
+./source/sql/postgresql/031/function-031.sql:$$ LANGUAGE 'plpgsql';
+./source/sql/postgresql/031/function-031.sql:$$ LANGUAGE 'plpgsql';
+./source/sql/postgresql/031/function-031.sql:$$ LANGUAGE 'plpgsql';
+./source/sql/postgresql/032/.svn/text-base/function-032.sql.svn-base:$$ LANGUAGE 'plpgsql';
+./source/sql/postgresql/032/.svn/text-base/function-032.sql.svn-base:$$ LANGUAGE 'plpgsql';
+./source/sql/postgresql/032/.svn/text-base/function-032.sql.svn-base:$$ LANGUAGE 'plpgsql';
+./source/sql/postgresql/032/.svn/text-base/function-032.sql.svn-base:$$ LANGUAGE 'plpgsql';
+./source/sql/postgresql/032/.svn/text-base/function-032.sql.svn-base:$$ LANGUAGE 'plpgsql';
+./source/sql/postgresql/032/.svn/text-base/function-032.sql.svn-base:$$ LANGUAGE 'plpgsql';
+./source/sql/postgresql/032/.svn/text-base/function-032.sql.svn-base:$$ LANGUAGE 'plpgsql';
+./source/sql/postgresql/032/.svn/text-base/function-032.sql.svn-base:$$ LANGUAGE 'plpgsql';
+./source/sql/postgresql/032/function-032.sql:$$ LANGUAGE 'plpgsql';
+./source/sql/postgresql/032/function-032.sql:$$ LANGUAGE 'plpgsql';
+./source/sql/postgresql/032/function-032.sql:$$ LANGUAGE 'plpgsql';
+./source/sql/postgresql/032/function-032.sql:$$ LANGUAGE 'plpgsql';
+./source/sql/postgresql/032/function-032.sql:$$ LANGUAGE 'plpgsql';
+./source/sql/postgresql/032/function-032.sql:$$ LANGUAGE 'plpgsql';
+./source/sql/postgresql/032/function-032.sql:$$ LANGUAGE 'plpgsql';
+./source/sql/postgresql/032/function-032.sql:$$ LANGUAGE 'plpgsql';
+./source/sql/postgresql/033/.svn/text-base/function-033.sql.svn-base:$$ LANGUAGE 'plpgsql';
+./source/sql/postgresql/033/.svn/text-base/function-033.sql.svn-base:$$ LANGUAGE 'plpgsql';
+./source/sql/postgresql/033/.svn/text-base/function-033.sql.svn-base:$$ LANGUAGE 'plpgsql';
+./source/sql/postgresql/033/.svn/text-base/function-033.sql.svn-base:$$ LANGUAGE 'plpgsql';
+./source/sql/postgresql/033/.svn/text-base/function-033.sql.svn-base:$$ LANGUAGE 'plpgsql';
+./source/sql/postgresql/033/.svn/text-base/function-033.sql.svn-base:$$ LANGUAGE 'plpgsql';
+./source/sql/postgresql/033/.svn/text-base/function-033.sql.svn-base:$$ LANGUAGE 'plpgsql';
+./source/sql/postgresql/033/.svn/text-base/function-033.sql.svn-base:$$ LANGUAGE 'plpgsql';
+./source/sql/postgresql/033/function-033.sql:$$ LANGUAGE 'plpgsql';
+./source/sql/postgresql/033/function-033.sql:$$ LANGUAGE 'plpgsql';
+./source/sql/postgresql/033/function-033.sql:$$ LANGUAGE 'plpgsql';
+./source/sql/postgresql/033/function-033.sql:$$ LANGUAGE 'plpgsql';
+./source/sql/postgresql/033/function-033.sql:$$ LANGUAGE 'plpgsql';
+./source/sql/postgresql/033/function-033.sql:$$ LANGUAGE 'plpgsql';
+./source/sql/postgresql/033/function-033.sql:$$ LANGUAGE 'plpgsql';
+./source/sql/postgresql/033/function-033.sql:$$ LANGUAGE 'plpgsql';
+./source/sql/postgresql/034/.svn/text-base/function-034.sql.svn-base:$$ LANGUAGE 'plpgsql';
+./source/sql/postgresql/034/.svn/text-base/function-034.sql.svn-base:$$ LANGUAGE 'plpgsql';
+./source/sql/postgresql/034/.svn/text-base/function-034.sql.svn-base:$$ LANGUAGE 'plpgsql';
+./source/sql/postgresql/034/.svn/text-base/function-034.sql.svn-base:$$ LANGUAGE 'plpgsql';
+./source/sql/postgresql/034/.svn/text-base/function-034.sql.svn-base:$$ LANGUAGE 'plpgsql';
+./source/sql/postgresql/034/.svn/text-base/function-034.sql.svn-base:$$ LANGUAGE 'plpgsql';
+./source/sql/postgresql/034/.svn/text-base/function-034.sql.svn-base:$$ LANGUAGE 'plpgsql';
+./source/sql/postgresql/034/.svn/text-base/function-034.sql.svn-base:$$ LANGUAGE 'plpgsql';
+./source/sql/postgresql/034/function-034.sql:$$ LANGUAGE 'plpgsql';
+./source/sql/postgresql/034/function-034.sql:$$ LANGUAGE 'plpgsql';
+./source/sql/postgresql/034/function-034.sql:$$ LANGUAGE 'plpgsql';
+./source/sql/postgresql/034/function-034.sql:$$ LANGUAGE 'plpgsql';
+./source/sql/postgresql/034/function-034.sql:$$ LANGUAGE 'plpgsql';
+./source/sql/postgresql/034/function-034.sql:$$ LANGUAGE 'plpgsql';
+./source/sql/postgresql/034/function-034.sql:$$ LANGUAGE 'plpgsql';
+./source/sql/postgresql/034/function-034.sql:$$ LANGUAGE 'plpgsql';
+./source/sql/postgresql/035/.svn/text-base/function-035.sql.svn-base:$$ LANGUAGE 'plpgsql';
+./source/sql/postgresql/035/.svn/text-base/function-035.sql.svn-base:$$ LANGUAGE 'plpgsql';
+./source/sql/postgresql/035/.svn/text-base/function-035.sql.svn-base:$$ LANGUAGE 'plpgsql';
+./source/sql/postgresql/035/.svn/text-base/function-035.sql.svn-base:$$ LANGUAGE 'plpgsql';
+./source/sql/postgresql/035/.svn/text-base/function-035.sql.svn-base:$$ LANGUAGE 'plpgsql';
+./source/sql/postgresql/035/.svn/text-base/function-035.sql.svn-base:$$ LANGUAGE 'plpgsql';
+./source/sql/postgresql/035/.svn/text-base/function-035.sql.svn-base:$$ LANGUAGE 'plpgsql';
+./source/sql/postgresql/035/.svn/text-base/function-035.sql.svn-base:$$ LANGUAGE 'plpgsql';
+./source/sql/postgresql/035/function-035.sql:$$ LANGUAGE 'plpgsql';
+./source/sql/postgresql/035/function-035.sql:$$ LANGUAGE 'plpgsql';
+./source/sql/postgresql/035/function-035.sql:$$ LANGUAGE 'plpgsql';
+./source/sql/postgresql/035/function-035.sql:$$ LANGUAGE 'plpgsql';
+./source/sql/postgresql/035/function-035.sql:$$ LANGUAGE 'plpgsql';
+./source/sql/postgresql/035/function-035.sql:$$ LANGUAGE 'plpgsql';
+./source/sql/postgresql/035/function-035.sql:$$ LANGUAGE 'plpgsql';
+./source/sql/postgresql/035/function-035.sql:$$ LANGUAGE 'plpgsql';
+./source/sql/postgresql/036/.svn/text-base/function-036.sql.svn-base:$$ LANGUAGE 'plpgsql';
+./source/sql/postgresql/036/.svn/text-base/function-036.sql.svn-base:$$ LANGUAGE 'plpgsql';
+./source/sql/postgresql/036/.svn/text-base/function-036.sql.svn-base:$$ LANGUAGE 'plpgsql';
+./source/sql/postgresql/036/.svn/text-base/function-036.sql.svn-base:$$ LANGUAGE 'plpgsql';
+./source/sql/postgresql/036/.svn/text-base/function-036.sql.svn-base:$$ LANGUAGE 'plpgsql';
+./source/sql/postgresql/036/.svn/text-base/function-036.sql.svn-base:$$ LANGUAGE 'plpgsql';
+./source/sql/postgresql/036/.svn/text-base/function-036.sql.svn-base:$$ LANGUAGE 'plpgsql';
+./source/sql/postgresql/036/.svn/text-base/function-036.sql.svn-base:$$ LANGUAGE 'plpgsql';
+./source/sql/postgresql/036/function-036.sql:$$ LANGUAGE 'plpgsql';
+./source/sql/postgresql/036/function-036.sql:$$ LANGUAGE 'plpgsql';
+./source/sql/postgresql/036/function-036.sql:$$ LANGUAGE 'plpgsql';
+./source/sql/postgresql/036/function-036.sql:$$ LANGUAGE 'plpgsql';
+./source/sql/postgresql/036/function-036.sql:$$ LANGUAGE 'plpgsql';
+./source/sql/postgresql/036/function-036.sql:$$ LANGUAGE 'plpgsql';
+./source/sql/postgresql/036/function-036.sql:$$ LANGUAGE 'plpgsql';
+./source/sql/postgresql/036/function-036.sql:$$ LANGUAGE 'plpgsql';
+./source/sql/postgresql/037/.svn/text-base/function-037.sql.svn-base:$$ LANGUAGE 'plpgsql';
+./source/sql/postgresql/037/.svn/text-base/function-037.sql.svn-base:$$ LANGUAGE 'plpgsql';
+./source/sql/postgresql/037/.svn/text-base/function-037.sql.svn-base:$$ LANGUAGE 'plpgsql';
+./source/sql/postgresql/037/.svn/text-base/function-037.sql.svn-base:$$ LANGUAGE 'plpgsql';
+./source/sql/postgresql/037/.svn/text-base/function-037.sql.svn-base:$$ LANGUAGE 'plpgsql';
+./source/sql/postgresql/037/.svn/text-base/function-037.sql.svn-base:$$ LANGUAGE 'plpgsql';
+./source/sql/postgresql/037/.svn/text-base/function-037.sql.svn-base:$$ LANGUAGE 'plpgsql';
+./source/sql/postgresql/037/.svn/text-base/function-037.sql.svn-base:$$ LANGUAGE 'plpgsql';
+./source/sql/postgresql/037/function-037.sql:$$ LANGUAGE 'plpgsql';
+./source/sql/postgresql/037/function-037.sql:$$ LANGUAGE 'plpgsql';
+./source/sql/postgresql/037/function-037.sql:$$ LANGUAGE 'plpgsql';
+./source/sql/postgresql/037/function-037.sql:$$ LANGUAGE 'plpgsql';
+./source/sql/postgresql/037/function-037.sql:$$ LANGUAGE 'plpgsql';
+./source/sql/postgresql/037/function-037.sql:$$ LANGUAGE 'plpgsql';
+./source/sql/postgresql/037/function-037.sql:$$ LANGUAGE 'plpgsql';
+./source/sql/postgresql/037/function-037.sql:$$ LANGUAGE 'plpgsql';
+./source/sql/postgresql/038/.svn/text-base/function-038.sql.svn-base:$$ LANGUAGE 'plpgsql';
+./source/sql/postgresql/038/.svn/text-base/function-038.sql.svn-base:$$ LANGUAGE 'plpgsql';
+./source/sql/postgresql/038/.svn/text-base/function-038.sql.svn-base:$$ LANGUAGE 'plpgsql';
+./source/sql/postgresql/038/.svn/text-base/function-038.sql.svn-base:$$ LANGUAGE 'plpgsql';
+./source/sql/postgresql/038/.svn/text-base/function-038.sql.svn-base:$$ LANGUAGE 'plpgsql';
+./source/sql/postgresql/038/.svn/text-base/function-038.sql.svn-base:$$ LANGUAGE 'plpgsql';
+./source/sql/postgresql/038/.svn/text-base/function-038.sql.svn-base:$$ LANGUAGE 'plpgsql';
+./source/sql/postgresql/038/.svn/text-base/function-038.sql.svn-base:$$ LANGUAGE 'plpgsql';
+./source/sql/postgresql/038/function-038.sql:$$ LANGUAGE 'plpgsql';
+./source/sql/postgresql/038/function-038.sql:$$ LANGUAGE 'plpgsql';
+./source/sql/postgresql/038/function-038.sql:$$ LANGUAGE 'plpgsql';
+./source/sql/postgresql/038/function-038.sql:$$ LANGUAGE 'plpgsql';
+./source/sql/postgresql/038/function-038.sql:$$ LANGUAGE 'plpgsql';
+./source/sql/postgresql/038/function-038.sql:$$ LANGUAGE 'plpgsql';
+./source/sql/postgresql/038/function-038.sql:$$ LANGUAGE 'plpgsql';
+./source/sql/postgresql/038/function-038.sql:$$ LANGUAGE 'plpgsql';
+./source/sql/postgresql/039/.svn/text-base/function-039.sql.svn-base:$$ LANGUAGE 'plpgsql';
+./source/sql/postgresql/039/.svn/text-base/function-039.sql.svn-base:$$ LANGUAGE 'plpgsql';
+./source/sql/postgresql/039/.svn/text-base/function-039.sql.svn-base:$$ LANGUAGE 'plpgsql';
+./source/sql/postgresql/039/.svn/text-base/function-039.sql.svn-base:$$ LANGUAGE 'plpgsql';
+./source/sql/postgresql/039/.svn/text-base/function-039.sql.svn-base:$$ LANGUAGE 'plpgsql';
+./source/sql/postgresql/039/.svn/text-base/function-039.sql.svn-base:$$ LANGUAGE 'plpgsql';
+./source/sql/postgresql/039/.svn/text-base/function-039.sql.svn-base:$$ LANGUAGE 'plpgsql';
+./source/sql/postgresql/039/.svn/text-base/function-039.sql.svn-base:$$ LANGUAGE 'plpgsql';
+./source/sql/postgresql/039/function-039.sql:$$ LANGUAGE 'plpgsql';
+./source/sql/postgresql/039/function-039.sql:$$ LANGUAGE 'plpgsql';
+./source/sql/postgresql/039/function-039.sql:$$ LANGUAGE 'plpgsql';
+./source/sql/postgresql/039/function-039.sql:$$ LANGUAGE 'plpgsql';
+./source/sql/postgresql/039/function-039.sql:$$ LANGUAGE 'plpgsql';
+./source/sql/postgresql/039/function-039.sql:$$ LANGUAGE 'plpgsql';
+./source/sql/postgresql/039/function-039.sql:$$ LANGUAGE 'plpgsql';
+./source/sql/postgresql/039/function-039.sql:$$ LANGUAGE 'plpgsql';
+./source/sql/postgresql/040/.svn/text-base/function-040.sql.svn-base:$$ LANGUAGE 'plpgsql';
+./source/sql/postgresql/040/.svn/text-base/function-040.sql.svn-base:$$ LANGUAGE 'plpgsql';
+./source/sql/postgresql/040/.svn/text-base/function-040.sql.svn-base:$$ LANGUAGE 'plpgsql';
+./source/sql/postgresql/040/.svn/text-base/function-040.sql.svn-base:$$ LANGUAGE 'plpgsql';
+./source/sql/postgresql/040/.svn/text-base/function-040.sql.svn-base:$$ LANGUAGE 'plpgsql';
+./source/sql/postgresql/040/.svn/text-base/function-040.sql.svn-base:$$ LANGUAGE 'plpgsql';
+./source/sql/postgresql/040/.svn/text-base/function-040.sql.svn-base:$$ LANGUAGE 'plpgsql';
+./source/sql/postgresql/040/.svn/text-base/function-040.sql.svn-base:$$ LANGUAGE 'plpgsql';
+./source/sql/postgresql/040/function-040.sql:$$ LANGUAGE 'plpgsql';
+./source/sql/postgresql/040/function-040.sql:$$ LANGUAGE 'plpgsql';
+./source/sql/postgresql/040/function-040.sql:$$ LANGUAGE 'plpgsql';
+./source/sql/postgresql/040/function-040.sql:$$ LANGUAGE 'plpgsql';
+./source/sql/postgresql/040/function-040.sql:$$ LANGUAGE 'plpgsql';
+./source/sql/postgresql/040/function-040.sql:$$ LANGUAGE 'plpgsql';
+./source/sql/postgresql/040/function-040.sql:$$ LANGUAGE 'plpgsql';
+./source/sql/postgresql/040/function-040.sql:$$ LANGUAGE 'plpgsql';
+./source/sql/postgresql/041/.svn/text-base/function-041.sql.svn-base:$$ LANGUAGE 'plpgsql';
+./source/sql/postgresql/041/.svn/text-base/function-041.sql.svn-base:$$ LANGUAGE 'plpgsql';
+./source/sql/postgresql/041/.svn/text-base/function-041.sql.svn-base:$$ LANGUAGE 'plpgsql';
+./source/sql/postgresql/041/.svn/text-base/function-041.sql.svn-base:$$ LANGUAGE 'plpgsql';
+./source/sql/postgresql/041/.svn/text-base/function-041.sql.svn-base:$$ LANGUAGE 'plpgsql';
+./source/sql/postgresql/041/.svn/text-base/function-041.sql.svn-base:$$ LANGUAGE 'plpgsql';
+./source/sql/postgresql/041/.svn/text-base/function-041.sql.svn-base:$$ LANGUAGE 'plpgsql';
+./source/sql/postgresql/041/.svn/text-base/function-041.sql.svn-base:$$ LANGUAGE 'plpgsql';
+./source/sql/postgresql/041/.svn/text-base/function-041.sql.svn-base:$$ LANGUAGE 'plpgsql';
+./source/sql/postgresql/041/.svn/text-base/function-041.sql.svn-base:$$ LANGUAGE 'plpgsql';
+./source/sql/postgresql/041/function-041.sql:$$ LANGUAGE 'plpgsql';
+./source/sql/postgresql/041/function-041.sql:$$ LANGUAGE 'plpgsql';
+./source/sql/postgresql/041/function-041.sql:$$ LANGUAGE 'plpgsql';
+./source/sql/postgresql/041/function-041.sql:$$ LANGUAGE 'plpgsql';
+./source/sql/postgresql/041/function-041.sql:$$ LANGUAGE 'plpgsql';
+./source/sql/postgresql/041/function-041.sql:$$ LANGUAGE 'plpgsql';
+./source/sql/postgresql/041/function-041.sql:$$ LANGUAGE 'plpgsql';
+./source/sql/postgresql/041/function-041.sql:$$ LANGUAGE 'plpgsql';
+./source/sql/postgresql/041/function-041.sql:$$ LANGUAGE 'plpgsql';
+./source/sql/postgresql/041/function-041.sql:$$ LANGUAGE 'plpgsql';
+./source/sql/postgresql/042/.svn/text-base/function-042.sql.svn-base:$$ LANGUAGE 'plpgsql';
+./source/sql/postgresql/042/.svn/text-base/function-042.sql.svn-base:$$ LANGUAGE 'plpgsql';
+./source/sql/postgresql/042/.svn/text-base/function-042.sql.svn-base:$$ LANGUAGE 'plpgsql';
+./source/sql/postgresql/042/.svn/text-base/function-042.sql.svn-base:$$ LANGUAGE 'plpgsql';
+./source/sql/postgresql/042/.svn/text-base/function-042.sql.svn-base:$$ LANGUAGE 'plpgsql';
+./source/sql/postgresql/042/.svn/text-base/function-042.sql.svn-base:$$ LANGUAGE 'plpgsql';
+./source/sql/postgresql/042/.svn/text-base/function-042.sql.svn-base:$$ LANGUAGE 'plpgsql';
+./source/sql/postgresql/042/.svn/text-base/function-042.sql.svn-base:$$ LANGUAGE 'plpgsql';
+./source/sql/postgresql/042/.svn/text-base/function-042.sql.svn-base:$$ LANGUAGE 'plpgsql';
+./source/sql/postgresql/042/.svn/text-base/function-042.sql.svn-base:$$ LANGUAGE 'plpgsql';
+./source/sql/postgresql/042/function-042.sql:$$ LANGUAGE 'plpgsql';
+./source/sql/postgresql/042/function-042.sql:$$ LANGUAGE 'plpgsql';
+./source/sql/postgresql/042/function-042.sql:$$ LANGUAGE 'plpgsql';
+./source/sql/postgresql/042/function-042.sql:$$ LANGUAGE 'plpgsql';
+./source/sql/postgresql/042/function-042.sql:$$ LANGUAGE 'plpgsql';
+./source/sql/postgresql/042/function-042.sql:$$ LANGUAGE 'plpgsql';
+./source/sql/postgresql/042/function-042.sql:$$ LANGUAGE 'plpgsql';
+./source/sql/postgresql/042/function-042.sql:$$ LANGUAGE 'plpgsql';
+./source/sql/postgresql/042/function-042.sql:$$ LANGUAGE 'plpgsql';
+./source/sql/postgresql/042/function-042.sql:$$ LANGUAGE 'plpgsql';
+./source/sql/postgresql/043/.svn/text-base/function-043.sql.svn-base:$$ LANGUAGE 'plpgsql';
+./source/sql/postgresql/043/.svn/text-base/function-043.sql.svn-base:$$ LANGUAGE 'plpgsql';
+./source/sql/postgresql/043/.svn/text-base/function-043.sql.svn-base:$$ LANGUAGE 'plpgsql';
+./source/sql/postgresql/043/.svn/text-base/function-043.sql.svn-base:$$ LANGUAGE 'plpgsql';
+./source/sql/postgresql/043/.svn/text-base/function-043.sql.svn-base:$$ LANGUAGE 'plpgsql';
+./source/sql/postgresql/043/.svn/text-base/function-043.sql.svn-base:$$ LANGUAGE 'plpgsql';
+./source/sql/postgresql/043/.svn/text-base/function-043.sql.svn-base:$$ LANGUAGE 'plpgsql';
+./source/sql/postgresql/043/.svn/text-base/function-043.sql.svn-base:$$ LANGUAGE 'plpgsql';
+./source/sql/postgresql/043/.svn/text-base/function-043.sql.svn-base:$$ LANGUAGE 'plpgsql';
+./source/sql/postgresql/043/.svn/text-base/function-043.sql.svn-base:$$ LANGUAGE 'plpgsql';
+./source/sql/postgresql/043/function-043.sql:$$ LANGUAGE 'plpgsql';
+./source/sql/postgresql/043/function-043.sql:$$ LANGUAGE 'plpgsql';
+./source/sql/postgresql/043/function-043.sql:$$ LANGUAGE 'plpgsql';
+./source/sql/postgresql/043/function-043.sql:$$ LANGUAGE 'plpgsql';
+./source/sql/postgresql/043/function-043.sql:$$ LANGUAGE 'plpgsql';
+./source/sql/postgresql/043/function-043.sql:$$ LANGUAGE 'plpgsql';
+./source/sql/postgresql/043/function-043.sql:$$ LANGUAGE 'plpgsql';
+./source/sql/postgresql/043/function-043.sql:$$ LANGUAGE 'plpgsql';
+./source/sql/postgresql/043/function-043.sql:$$ LANGUAGE 'plpgsql';
+./source/sql/postgresql/043/function-043.sql:$$ LANGUAGE 'plpgsql';
+./source/sql/postgresql/044/.svn/text-base/function-044.sql.svn-base:$$ LANGUAGE 'plpgsql';
+./source/sql/postgresql/044/.svn/text-base/function-044.sql.svn-base:$$ LANGUAGE 'plpgsql';
+./source/sql/postgresql/044/.svn/text-base/function-044.sql.svn-base:$$ LANGUAGE 'plpgsql';
+./source/sql/postgresql/044/.svn/text-base/function-044.sql.svn-base:$$ LANGUAGE 'plpgsql';
+./source/sql/postgresql/044/.svn/text-base/function-044.sql.svn-base:$$ LANGUAGE 'plpgsql';
+./source/sql/postgresql/044/.svn/text-base/function-044.sql.svn-base:$$ LANGUAGE 'plpgsql';
+./source/sql/postgresql/044/.svn/text-base/function-044.sql.svn-base:$$ LANGUAGE 'plpgsql';
+./source/sql/postgresql/044/.svn/text-base/function-044.sql.svn-base:$$ LANGUAGE 'plpgsql';
+./source/sql/postgresql/044/.svn/text-base/function-044.sql.svn-base:$$ LANGUAGE 'plpgsql';
+./source/sql/postgresql/044/.svn/text-base/function-044.sql.svn-base:$$ LANGUAGE 'plpgsql';
+./source/sql/postgresql/044/function-044.sql:$$ LANGUAGE 'plpgsql';
+./source/sql/postgresql/044/function-044.sql:$$ LANGUAGE 'plpgsql';
+./source/sql/postgresql/044/function-044.sql:$$ LANGUAGE 'plpgsql';
+./source/sql/postgresql/044/function-044.sql:$$ LANGUAGE 'plpgsql';
+./source/sql/postgresql/044/function-044.sql:$$ LANGUAGE 'plpgsql';
+./source/sql/postgresql/044/function-044.sql:$$ LANGUAGE 'plpgsql';
+./source/sql/postgresql/044/function-044.sql:$$ LANGUAGE 'plpgsql';
+./source/sql/postgresql/044/function-044.sql:$$ LANGUAGE 'plpgsql';
+./source/sql/postgresql/044/function-044.sql:$$ LANGUAGE 'plpgsql';
+./source/sql/postgresql/044/function-044.sql:$$ LANGUAGE 'plpgsql';
+./source/sql/postgresql/045/.svn/text-base/function-045.sql.svn-base:$$ LANGUAGE 'plpgsql';
+./source/sql/postgresql/045/.svn/text-base/function-045.sql.svn-base:$$ LANGUAGE 'plpgsql';
+./source/sql/postgresql/045/.svn/text-base/function-045.sql.svn-base:$$ LANGUAGE 'plpgsql';
+./source/sql/postgresql/045/.svn/text-base/function-045.sql.svn-base:$$ LANGUAGE 'plpgsql';
+./source/sql/postgresql/045/.svn/text-base/function-045.sql.svn-base:$$ LANGUAGE 'plpgsql';
+./source/sql/postgresql/045/.svn/text-base/function-045.sql.svn-base:$$ LANGUAGE 'plpgsql';
+./source/sql/postgresql/045/.svn/text-base/function-045.sql.svn-base:$$ LANGUAGE 'plpgsql';
+./source/sql/postgresql/045/.svn/text-base/function-045.sql.svn-base:$$ LANGUAGE 'plpgsql';
+./source/sql/postgresql/045/.svn/text-base/function-045.sql.svn-base:$$ LANGUAGE 'plpgsql';
+./source/sql/postgresql/045/.svn/text-base/function-045.sql.svn-base:$$ LANGUAGE 'plpgsql';
+./source/sql/postgresql/045/function-045.sql:$$ LANGUAGE 'plpgsql';
+./source/sql/postgresql/045/function-045.sql:$$ LANGUAGE 'plpgsql';
+./source/sql/postgresql/045/function-045.sql:$$ LANGUAGE 'plpgsql';
+./source/sql/postgresql/045/function-045.sql:$$ LANGUAGE 'plpgsql';
+./source/sql/postgresql/045/function-045.sql:$$ LANGUAGE 'plpgsql';
+./source/sql/postgresql/045/function-045.sql:$$ LANGUAGE 'plpgsql';
+./source/sql/postgresql/045/function-045.sql:$$ LANGUAGE 'plpgsql';
+./source/sql/postgresql/045/function-045.sql:$$ LANGUAGE 'plpgsql';
+./source/sql/postgresql/045/function-045.sql:$$ LANGUAGE 'plpgsql';
+./source/sql/postgresql/045/function-045.sql:$$ LANGUAGE 'plpgsql';
+./source/sql/postgresql/046/.svn/text-base/function-046.sql.svn-base:$$ LANGUAGE 'plpgsql';
+./source/sql/postgresql/046/.svn/text-base/function-046.sql.svn-base:$$ LANGUAGE 'plpgsql';
+./source/sql/postgresql/046/.svn/text-base/function-046.sql.svn-base:$$ LANGUAGE 'plpgsql';
+./source/sql/postgresql/046/.svn/text-base/function-046.sql.svn-base:$$ LANGUAGE 'plpgsql';
+./source/sql/postgresql/046/.svn/text-base/function-046.sql.svn-base:$$ LANGUAGE 'plpgsql';
+./source/sql/postgresql/046/.svn/text-base/function-046.sql.svn-base:$$ LANGUAGE 'plpgsql';
+./source/sql/postgresql/046/.svn/text-base/function-046.sql.svn-base:$$ LANGUAGE 'plpgsql';
+./source/sql/postgresql/046/.svn/text-base/function-046.sql.svn-base:$$ LANGUAGE 'plpgsql';
+./source/sql/postgresql/046/.svn/text-base/function-046.sql.svn-base:$$ LANGUAGE 'plpgsql';
+./source/sql/postgresql/046/.svn/text-base/function-046.sql.svn-base:$$ LANGUAGE 'plpgsql';
+./source/sql/postgresql/046/function-046.sql:$$ LANGUAGE 'plpgsql';
+./source/sql/postgresql/046/function-046.sql:$$ LANGUAGE 'plpgsql';
+./source/sql/postgresql/046/function-046.sql:$$ LANGUAGE 'plpgsql';
+./source/sql/postgresql/046/function-046.sql:$$ LANGUAGE 'plpgsql';
+./source/sql/postgresql/046/function-046.sql:$$ LANGUAGE 'plpgsql';
+./source/sql/postgresql/046/function-046.sql:$$ LANGUAGE 'plpgsql';
+./source/sql/postgresql/046/function-046.sql:$$ LANGUAGE 'plpgsql';
+./source/sql/postgresql/046/function-046.sql:$$ LANGUAGE 'plpgsql';
+./source/sql/postgresql/046/function-046.sql:$$ LANGUAGE 'plpgsql';
+./source/sql/postgresql/046/function-046.sql:$$ LANGUAGE 'plpgsql';
+./source/sql/postgresql/047/.svn/text-base/function-047.sql.svn-base:$$ LANGUAGE 'plpgsql';
+./source/sql/postgresql/047/.svn/text-base/function-047.sql.svn-base:$$ LANGUAGE 'plpgsql';
+./source/sql/postgresql/047/.svn/text-base/function-047.sql.svn-base:$$ LANGUAGE 'plpgsql';
+./source/sql/postgresql/047/.svn/text-base/function-047.sql.svn-base:$$ LANGUAGE 'plpgsql';
+./source/sql/postgresql/047/.svn/text-base/function-047.sql.svn-base:$$ LANGUAGE 'plpgsql';
+./source/sql/postgresql/047/.svn/text-base/function-047.sql.svn-base:$$ LANGUAGE 'plpgsql';
+./source/sql/postgresql/047/.svn/text-base/function-047.sql.svn-base:$$ LANGUAGE 'plpgsql';
+./source/sql/postgresql/047/.svn/text-base/function-047.sql.svn-base:$$ LANGUAGE 'plpgsql';
+./source/sql/postgresql/047/.svn/text-base/function-047.sql.svn-base:$$ LANGUAGE 'plpgsql';
+./source/sql/postgresql/047/.svn/text-base/function-047.sql.svn-base:$$ LANGUAGE 'plpgsql';
+./source/sql/postgresql/047/function-047.sql:$$ LANGUAGE 'plpgsql';
+./source/sql/postgresql/047/function-047.sql:$$ LANGUAGE 'plpgsql';
+./source/sql/postgresql/047/function-047.sql:$$ LANGUAGE 'plpgsql';
+./source/sql/postgresql/047/function-047.sql:$$ LANGUAGE 'plpgsql';
+./source/sql/postgresql/047/function-047.sql:$$ LANGUAGE 'plpgsql';
+./source/sql/postgresql/047/function-047.sql:$$ LANGUAGE 'plpgsql';
+./source/sql/postgresql/047/function-047.sql:$$ LANGUAGE 'plpgsql';
+./source/sql/postgresql/047/function-047.sql:$$ LANGUAGE 'plpgsql';
+./source/sql/postgresql/047/function-047.sql:$$ LANGUAGE 'plpgsql';
+./source/sql/postgresql/047/function-047.sql:$$ LANGUAGE 'plpgsql';
+./source/sql/postgresql/048/.svn/text-base/function-048.sql.svn-base:$$ LANGUAGE 'plpgsql';
+./source/sql/postgresql/048/.svn/text-base/function-048.sql.svn-base:$$ LANGUAGE 'plpgsql';
+./source/sql/postgresql/048/.svn/text-base/function-048.sql.svn-base:$$ LANGUAGE 'plpgsql';
+./source/sql/postgresql/048/.svn/text-base/function-048.sql.svn-base:$$ LANGUAGE 'plpgsql';
+./source/sql/postgresql/048/.svn/text-base/function-048.sql.svn-base:$$ LANGUAGE 'plpgsql';
+./source/sql/postgresql/048/.svn/text-base/function-048.sql.svn-base:$$ LANGUAGE 'plpgsql';
+./source/sql/postgresql/048/.svn/text-base/function-048.sql.svn-base:$$ LANGUAGE 'plpgsql';
+./source/sql/postgresql/048/.svn/text-base/function-048.sql.svn-base:$$ LANGUAGE 'plpgsql';
+./source/sql/postgresql/048/.svn/text-base/function-048.sql.svn-base:$$ LANGUAGE 'plpgsql';
+./source/sql/postgresql/048/.svn/text-base/function-048.sql.svn-base:$$ LANGUAGE 'plpgsql';
+./source/sql/postgresql/048/function-048.sql:$$ LANGUAGE 'plpgsql';
+./source/sql/postgresql/048/function-048.sql:$$ LANGUAGE 'plpgsql';
+./source/sql/postgresql/048/function-048.sql:$$ LANGUAGE 'plpgsql';
+./source/sql/postgresql/048/function-048.sql:$$ LANGUAGE 'plpgsql';
+./source/sql/postgresql/048/function-048.sql:$$ LANGUAGE 'plpgsql';
+./source/sql/postgresql/048/function-048.sql:$$ LANGUAGE 'plpgsql';
+./source/sql/postgresql/048/function-048.sql:$$ LANGUAGE 'plpgsql';
+./source/sql/postgresql/048/function-048.sql:$$ LANGUAGE 'plpgsql';
+./source/sql/postgresql/048/function-048.sql:$$ LANGUAGE 'plpgsql';
+./source/sql/postgresql/048/function-048.sql:$$ LANGUAGE 'plpgsql';
+./source/sql/postgresql/049/.svn/text-base/function-049.sql.svn-base:$$ LANGUAGE 'plpgsql';
+./source/sql/postgresql/049/.svn/text-base/function-049.sql.svn-base:$$ LANGUAGE 'plpgsql';
+./source/sql/postgresql/049/.svn/text-base/function-049.sql.svn-base:$$ LANGUAGE 'plpgsql';
+./source/sql/postgresql/049/.svn/text-base/function-049.sql.svn-base:$$ LANGUAGE 'plpgsql';
+./source/sql/postgresql/049/.svn/text-base/function-049.sql.svn-base:$$ LANGUAGE 'plpgsql';
+./source/sql/postgresql/049/.svn/text-base/function-049.sql.svn-base:$$ LANGUAGE 'plpgsql';
+./source/sql/postgresql/049/.svn/text-base/function-049.sql.svn-base:$$ LANGUAGE 'plpgsql';
+./source/sql/postgresql/049/.svn/text-base/function-049.sql.svn-base:$$ LANGUAGE 'plpgsql';
+./source/sql/postgresql/049/.svn/text-base/function-049.sql.svn-base:$$ LANGUAGE 'plpgsql';
+./source/sql/postgresql/049/.svn/text-base/function-049.sql.svn-base:$$ LANGUAGE 'plpgsql';
+./source/sql/postgresql/049/function-049.sql:$$ LANGUAGE 'plpgsql';
+./source/sql/postgresql/049/function-049.sql:$$ LANGUAGE 'plpgsql';
+./source/sql/postgresql/049/function-049.sql:$$ LANGUAGE 'plpgsql';
+./source/sql/postgresql/049/function-049.sql:$$ LANGUAGE 'plpgsql';
+./source/sql/postgresql/049/function-049.sql:$$ LANGUAGE 'plpgsql';
+./source/sql/postgresql/049/function-049.sql:$$ LANGUAGE 'plpgsql';
+./source/sql/postgresql/049/function-049.sql:$$ LANGUAGE 'plpgsql';
+./source/sql/postgresql/049/function-049.sql:$$ LANGUAGE 'plpgsql';
+./source/sql/postgresql/049/function-049.sql:$$ LANGUAGE 'plpgsql';
+./source/sql/postgresql/049/function-049.sql:$$ LANGUAGE 'plpgsql';
+./source/sql/postgresql/050/.svn/text-base/function-050.sql.svn-base:$$ LANGUAGE 'plpgsql';
+./source/sql/postgresql/050/.svn/text-base/function-050.sql.svn-base:$$ LANGUAGE 'plpgsql';
+./source/sql/postgresql/050/.svn/text-base/function-050.sql.svn-base:$$ LANGUAGE 'plpgsql';
+./source/sql/postgresql/050/.svn/text-base/function-050.sql.svn-base:$$ LANGUAGE 'plpgsql';
+./source/sql/postgresql/050/.svn/text-base/function-050.sql.svn-base:$$ LANGUAGE 'plpgsql';
+./source/sql/postgresql/050/.svn/text-base/function-050.sql.svn-base:$$ LANGUAGE 'plpgsql';
+./source/sql/postgresql/050/.svn/text-base/function-050.sql.svn-base:$$ LANGUAGE 'plpgsql';
+./source/sql/postgresql/050/.svn/text-base/function-050.sql.svn-base:$$ LANGUAGE 'plpgsql';
+./source/sql/postgresql/050/.svn/text-base/function-050.sql.svn-base:$$ LANGUAGE 'plpgsql';
+./source/sql/postgresql/050/.svn/text-base/function-050.sql.svn-base:$$ LANGUAGE 'plpgsql';
+./source/sql/postgresql/050/function-050.sql:$$ LANGUAGE 'plpgsql';
+./source/sql/postgresql/050/function-050.sql:$$ LANGUAGE 'plpgsql';
+./source/sql/postgresql/050/function-050.sql:$$ LANGUAGE 'plpgsql';
+./source/sql/postgresql/050/function-050.sql:$$ LANGUAGE 'plpgsql';
+./source/sql/postgresql/050/function-050.sql:$$ LANGUAGE 'plpgsql';
+./source/sql/postgresql/050/function-050.sql:$$ LANGUAGE 'plpgsql';
+./source/sql/postgresql/050/function-050.sql:$$ LANGUAGE 'plpgsql';
+./source/sql/postgresql/050/function-050.sql:$$ LANGUAGE 'plpgsql';
+./source/sql/postgresql/050/function-050.sql:$$ LANGUAGE 'plpgsql';
+./source/sql/postgresql/050/function-050.sql:$$ LANGUAGE 'plpgsql';
+./source/sql/postgresql/051/.svn/text-base/function-051.sql.svn-base:$$ LANGUAGE 'plpgsql';
+./source/sql/postgresql/051/.svn/text-base/function-051.sql.svn-base:$$ LANGUAGE 'plpgsql';
+./source/sql/postgresql/051/.svn/text-base/function-051.sql.svn-base:$$ LANGUAGE 'plpgsql';
+./source/sql/postgresql/051/.svn/text-base/function-051.sql.svn-base:$$ LANGUAGE 'plpgsql';
+./source/sql/postgresql/051/.svn/text-base/function-051.sql.svn-base:$$ LANGUAGE 'plpgsql';
+./source/sql/postgresql/051/.svn/text-base/function-051.sql.svn-base:$$ LANGUAGE 'plpgsql';
+./source/sql/postgresql/051/.svn/text-base/function-051.sql.svn-base:$$ LANGUAGE 'plpgsql';
+./source/sql/postgresql/051/.svn/text-base/function-051.sql.svn-base:$$ LANGUAGE 'plpgsql';
+./source/sql/postgresql/051/.svn/text-base/function-051.sql.svn-base:$$ LANGUAGE 'plpgsql';
+./source/sql/postgresql/051/.svn/text-base/function-051.sql.svn-base:$$ LANGUAGE 'plpgsql';
+./source/sql/postgresql/051/function-051.sql:$$ LANGUAGE 'plpgsql';
+./source/sql/postgresql/051/function-051.sql:$$ LANGUAGE 'plpgsql';
+./source/sql/postgresql/051/function-051.sql:$$ LANGUAGE 'plpgsql';
+./source/sql/postgresql/051/function-051.sql:$$ LANGUAGE 'plpgsql';
+./source/sql/postgresql/051/function-051.sql:$$ LANGUAGE 'plpgsql';
+./source/sql/postgresql/051/function-051.sql:$$ LANGUAGE 'plpgsql';
+./source/sql/postgresql/051/function-051.sql:$$ LANGUAGE 'plpgsql';
+./source/sql/postgresql/051/function-051.sql:$$ LANGUAGE 'plpgsql';
+./source/sql/postgresql/051/function-051.sql:$$ LANGUAGE 'plpgsql';
+./source/sql/postgresql/051/function-051.sql:$$ LANGUAGE 'plpgsql';
+./source/sql/postgresql/052/.svn/text-base/function-052.sql.svn-base:$$ LANGUAGE 'plpgsql';
+./source/sql/postgresql/052/.svn/text-base/function-052.sql.svn-base:$$ LANGUAGE 'plpgsql';
+./source/sql/postgresql/052/.svn/text-base/function-052.sql.svn-base:$$ LANGUAGE 'plpgsql';
+./source/sql/postgresql/052/.svn/text-base/function-052.sql.svn-base:$$ LANGUAGE 'plpgsql';
+./source/sql/postgresql/052/.svn/text-base/function-052.sql.svn-base:$$ LANGUAGE 'plpgsql';
+./source/sql/postgresql/052/.svn/text-base/function-052.sql.svn-base:$$ LANGUAGE 'plpgsql';
+./source/sql/postgresql/052/.svn/text-base/function-052.sql.svn-base:$$ LANGUAGE 'plpgsql';
+./source/sql/postgresql/052/.svn/text-base/function-052.sql.svn-base:$$ LANGUAGE 'plpgsql';
+./source/sql/postgresql/052/.svn/text-base/function-052.sql.svn-base:$$ LANGUAGE 'plpgsql';
+./source/sql/postgresql/052/.svn/text-base/function-052.sql.svn-base:$$ LANGUAGE 'plpgsql';
+./source/sql/postgresql/052/function-052.sql:$$ LANGUAGE 'plpgsql';
+./source/sql/postgresql/052/function-052.sql:$$ LANGUAGE 'plpgsql';
+./source/sql/postgresql/052/function-052.sql:$$ LANGUAGE 'plpgsql';
+./source/sql/postgresql/052/function-052.sql:$$ LANGUAGE 'plpgsql';
+./source/sql/postgresql/052/function-052.sql:$$ LANGUAGE 'plpgsql';
+./source/sql/postgresql/052/function-052.sql:$$ LANGUAGE 'plpgsql';
+./source/sql/postgresql/052/function-052.sql:$$ LANGUAGE 'plpgsql';
+./source/sql/postgresql/052/function-052.sql:$$ LANGUAGE 'plpgsql';
+./source/sql/postgresql/052/function-052.sql:$$ LANGUAGE 'plpgsql';
+./source/sql/postgresql/052/function-052.sql:$$ LANGUAGE 'plpgsql';
+./source/sql/postgresql/053/.svn/text-base/function-053.sql.svn-base:$$ LANGUAGE 'plpgsql';
+./source/sql/postgresql/053/.svn/text-base/function-053.sql.svn-base:$$ LANGUAGE 'plpgsql';
+./source/sql/postgresql/053/.svn/text-base/function-053.sql.svn-base:$$ LANGUAGE 'plpgsql';
+./source/sql/postgresql/053/.svn/text-base/function-053.sql.svn-base:$$ LANGUAGE 'plpgsql';
+./source/sql/postgresql/053/.svn/text-base/function-053.sql.svn-base:$$ LANGUAGE 'plpgsql';
+./source/sql/postgresql/053/.svn/text-base/function-053.sql.svn-base:$$ LANGUAGE 'plpgsql';
+./source/sql/postgresql/053/.svn/text-base/function-053.sql.svn-base:$$ LANGUAGE 'plpgsql';
+./source/sql/postgresql/053/.svn/text-base/function-053.sql.svn-base:$$ LANGUAGE 'plpgsql';
+./source/sql/postgresql/053/.svn/text-base/function-053.sql.svn-base:$$ LANGUAGE 'plpgsql';
+./source/sql/postgresql/053/.svn/text-base/function-053.sql.svn-base:$$ LANGUAGE 'plpgsql';
+./source/sql/postgresql/053/.svn/text-base/function-053.sql.svn-base:$$ LANGUAGE 'plpgsql';
+./source/sql/postgresql/053/function-053.sql:$$ LANGUAGE 'plpgsql';
+./source/sql/postgresql/053/function-053.sql:$$ LANGUAGE 'plpgsql';
+./source/sql/postgresql/053/function-053.sql:$$ LANGUAGE 'plpgsql';
+./source/sql/postgresql/053/function-053.sql:$$ LANGUAGE 'plpgsql';
+./source/sql/postgresql/053/function-053.sql:$$ LANGUAGE 'plpgsql';
+./source/sql/postgresql/053/function-053.sql:$$ LANGUAGE 'plpgsql';
+./source/sql/postgresql/053/function-053.sql:$$ LANGUAGE 'plpgsql';
+./source/sql/postgresql/053/function-053.sql:$$ LANGUAGE 'plpgsql';
+./source/sql/postgresql/053/function-053.sql:$$ LANGUAGE 'plpgsql';
+./source/sql/postgresql/053/function-053.sql:$$ LANGUAGE 'plpgsql';
+./source/sql/postgresql/053/function-053.sql:$$ LANGUAGE 'plpgsql';
+./source/sql/postgresql/054/.svn/text-base/function-054.sql.svn-base:$$ LANGUAGE 'plpgsql';
+./source/sql/postgresql/054/.svn/text-base/function-054.sql.svn-base:$$ LANGUAGE 'plpgsql';
+./source/sql/postgresql/054/.svn/text-base/function-054.sql.svn-base:$$ LANGUAGE 'plpgsql';
+./source/sql/postgresql/054/.svn/text-base/function-054.sql.svn-base:$$ LANGUAGE 'plpgsql';
+./source/sql/postgresql/054/.svn/text-base/function-054.sql.svn-base:$$ LANGUAGE 'plpgsql';
+./source/sql/postgresql/054/.svn/text-base/function-054.sql.svn-base:$$ LANGUAGE 'plpgsql';
+./source/sql/postgresql/054/.svn/text-base/function-054.sql.svn-base:$$ LANGUAGE 'plpgsql';
+./source/sql/postgresql/054/.svn/text-base/function-054.sql.svn-base:$$ LANGUAGE 'plpgsql';
+./source/sql/postgresql/054/.svn/text-base/function-054.sql.svn-base:$$ LANGUAGE 'plpgsql';
+./source/sql/postgresql/054/function-054.sql:$$ LANGUAGE 'plpgsql';
+./source/sql/postgresql/054/function-054.sql:$$ LANGUAGE 'plpgsql';
+./source/sql/postgresql/054/function-054.sql:$$ LANGUAGE 'plpgsql';
+./source/sql/postgresql/054/function-054.sql:$$ LANGUAGE 'plpgsql';
+./source/sql/postgresql/054/function-054.sql:$$ LANGUAGE 'plpgsql';
+./source/sql/postgresql/054/function-054.sql:$$ LANGUAGE 'plpgsql';
+./source/sql/postgresql/054/function-054.sql:$$ LANGUAGE 'plpgsql';
+./source/sql/postgresql/054/function-054.sql:$$ LANGUAGE 'plpgsql';
+./source/sql/postgresql/054/function-054.sql:$$ LANGUAGE 'plpgsql';
+./source/sql/postgresql/055/.svn/text-base/function-055.sql.svn-base:$$ LANGUAGE 'plpgsql';
+./source/sql/postgresql/055/.svn/text-base/function-055.sql.svn-base:$$ LANGUAGE 'plpgsql';
+./source/sql/postgresql/055/.svn/text-base/function-055.sql.svn-base:$$ LANGUAGE 'plpgsql';
+./source/sql/postgresql/055/.svn/text-base/function-055.sql.svn-base:$$ LANGUAGE 'plpgsql';
+./source/sql/postgresql/055/.svn/text-base/function-055.sql.svn-base:$$ LANGUAGE 'plpgsql';
+./source/sql/postgresql/055/.svn/text-base/function-055.sql.svn-base:$$ LANGUAGE 'plpgsql';
+./source/sql/postgresql/055/.svn/text-base/function-055.sql.svn-base:$$ LANGUAGE 'plpgsql';
+./source/sql/postgresql/055/.svn/text-base/function-055.sql.svn-base:$$ LANGUAGE 'plpgsql';
+./source/sql/postgresql/055/.svn/text-base/function-055.sql.svn-base:$$ LANGUAGE 'plpgsql';
+./source/sql/postgresql/055/function-055.sql:$$ LANGUAGE 'plpgsql';
+./source/sql/postgresql/055/function-055.sql:$$ LANGUAGE 'plpgsql';
+./source/sql/postgresql/055/function-055.sql:$$ LANGUAGE 'plpgsql';
+./source/sql/postgresql/055/function-055.sql:$$ LANGUAGE 'plpgsql';
+./source/sql/postgresql/055/function-055.sql:$$ LANGUAGE 'plpgsql';
+./source/sql/postgresql/055/function-055.sql:$$ LANGUAGE 'plpgsql';
+./source/sql/postgresql/055/function-055.sql:$$ LANGUAGE 'plpgsql';
+./source/sql/postgresql/055/function-055.sql:$$ LANGUAGE 'plpgsql';
+./source/sql/postgresql/055/function-055.sql:$$ LANGUAGE 'plpgsql';
+./source/sql/postgresql/056/.svn/text-base/function-056.sql.svn-base:$$ LANGUAGE 'plpgsql';
+./source/sql/postgresql/056/.svn/text-base/function-056.sql.svn-base:$$ LANGUAGE 'plpgsql';
+./source/sql/postgresql/056/.svn/text-base/function-056.sql.svn-base:$$ LANGUAGE 'plpgsql';
+./source/sql/postgresql/056/.svn/text-base/function-056.sql.svn-base:$$ LANGUAGE 'plpgsql';
+./source/sql/postgresql/056/.svn/text-base/function-056.sql.svn-base:$$ LANGUAGE 'plpgsql';
+./source/sql/postgresql/056/.svn/text-base/function-056.sql.svn-base:$$ LANGUAGE 'plpgsql';
+./source/sql/postgresql/056/.svn/text-base/function-056.sql.svn-base:$$ LANGUAGE 'plpgsql';
+./source/sql/postgresql/056/.svn/text-base/function-056.sql.svn-base:$$ LANGUAGE 'plpgsql';
+./source/sql/postgresql/056/.svn/text-base/function-056.sql.svn-base:$$ LANGUAGE 'plpgsql';
+./source/sql/postgresql/056/function-056.sql:$$ LANGUAGE 'plpgsql';
+./source/sql/postgresql/056/function-056.sql:$$ LANGUAGE 'plpgsql';
+./source/sql/postgresql/056/function-056.sql:$$ LANGUAGE 'plpgsql';
+./source/sql/postgresql/056/function-056.sql:$$ LANGUAGE 'plpgsql';
+./source/sql/postgresql/056/function-056.sql:$$ LANGUAGE 'plpgsql';
+./source/sql/postgresql/056/function-056.sql:$$ LANGUAGE 'plpgsql';
+./source/sql/postgresql/056/function-056.sql:$$ LANGUAGE 'plpgsql';
+./source/sql/postgresql/056/function-056.sql:$$ LANGUAGE 'plpgsql';
+./source/sql/postgresql/056/function-056.sql:$$ LANGUAGE 'plpgsql';
+./source/sql/postgresql/057/.svn/text-base/function-057.sql.svn-base:$$ LANGUAGE 'plpgsql';
+./source/sql/postgresql/057/.svn/text-base/function-057.sql.svn-base:$$ LANGUAGE 'plpgsql';
+./source/sql/postgresql/057/.svn/text-base/function-057.sql.svn-base:$$ LANGUAGE 'plpgsql';
+./source/sql/postgresql/057/.svn/text-base/function-057.sql.svn-base:$$ LANGUAGE 'plpgsql';
+./source/sql/postgresql/057/.svn/text-base/function-057.sql.svn-base:$$ LANGUAGE 'plpgsql';
+./source/sql/postgresql/057/.svn/text-base/function-057.sql.svn-base:$$ LANGUAGE 'plpgsql';
+./source/sql/postgresql/057/.svn/text-base/function-057.sql.svn-base:$$ LANGUAGE 'plpgsql';
+./source/sql/postgresql/057/.svn/text-base/function-057.sql.svn-base:$$ LANGUAGE 'plpgsql';
+./source/sql/postgresql/057/.svn/text-base/function-057.sql.svn-base:$$ LANGUAGE 'plpgsql';
+./source/sql/postgresql/057/function-057.sql:$$ LANGUAGE 'plpgsql';
+./source/sql/postgresql/057/function-057.sql:$$ LANGUAGE 'plpgsql';
+./source/sql/postgresql/057/function-057.sql:$$ LANGUAGE 'plpgsql';
+./source/sql/postgresql/057/function-057.sql:$$ LANGUAGE 'plpgsql';
+./source/sql/postgresql/057/function-057.sql:$$ LANGUAGE 'plpgsql';
+./source/sql/postgresql/057/function-057.sql:$$ LANGUAGE 'plpgsql';
+./source/sql/postgresql/057/function-057.sql:$$ LANGUAGE 'plpgsql';
+./source/sql/postgresql/057/function-057.sql:$$ LANGUAGE 'plpgsql';
+./source/sql/postgresql/057/function-057.sql:$$ LANGUAGE 'plpgsql';
+./source/sql/postgresql/058/.svn/text-base/function-058.sql.svn-base:$$ LANGUAGE 'plpgsql';
+./source/sql/postgresql/058/.svn/text-base/function-058.sql.svn-base:$$ LANGUAGE 'plpgsql';
+./source/sql/postgresql/058/.svn/text-base/function-058.sql.svn-base:$$ LANGUAGE 'plpgsql';
+./source/sql/postgresql/058/.svn/text-base/function-058.sql.svn-base:$$ LANGUAGE 'plpgsql';
+./source/sql/postgresql/058/.svn/text-base/function-058.sql.svn-base:$$ LANGUAGE 'plpgsql';
+./source/sql/postgresql/058/.svn/text-base/function-058.sql.svn-base:$$ LANGUAGE 'plpgsql';
+./source/sql/postgresql/058/.svn/text-base/function-058.sql.svn-base:$$ LANGUAGE 'plpgsql';
+./source/sql/postgresql/058/.svn/text-base/function-058.sql.svn-base:$$ LANGUAGE 'plpgsql';
+./source/sql/postgresql/058/.svn/text-base/function-058.sql.svn-base:$$ LANGUAGE 'plpgsql';
+./source/sql/postgresql/058/function-058.sql:$$ LANGUAGE 'plpgsql';
+./source/sql/postgresql/058/function-058.sql:$$ LANGUAGE 'plpgsql';
+./source/sql/postgresql/058/function-058.sql:$$ LANGUAGE 'plpgsql';
+./source/sql/postgresql/058/function-058.sql:$$ LANGUAGE 'plpgsql';
+./source/sql/postgresql/058/function-058.sql:$$ LANGUAGE 'plpgsql';
+./source/sql/postgresql/058/function-058.sql:$$ LANGUAGE 'plpgsql';
+./source/sql/postgresql/058/function-058.sql:$$ LANGUAGE 'plpgsql';
+./source/sql/postgresql/058/function-058.sql:$$ LANGUAGE 'plpgsql';
+./source/sql/postgresql/058/function-058.sql:$$ LANGUAGE 'plpgsql';
+./source/sql/postgresql/059/.svn/text-base/function-059.sql.svn-base:$$ LANGUAGE 'plpgsql';
+./source/sql/postgresql/059/.svn/text-base/function-059.sql.svn-base:$$ LANGUAGE 'plpgsql';
+./source/sql/postgresql/059/.svn/text-base/function-059.sql.svn-base:$$ LANGUAGE 'plpgsql';
+./source/sql/postgresql/059/.svn/text-base/function-059.sql.svn-base:$$ LANGUAGE 'plpgsql';
+./source/sql/postgresql/059/.svn/text-base/function-059.sql.svn-base:$$ LANGUAGE 'plpgsql';
+./source/sql/postgresql/059/.svn/text-base/function-059.sql.svn-base:$$ LANGUAGE 'plpgsql';
+./source/sql/postgresql/059/.svn/text-base/function-059.sql.svn-base:$$ LANGUAGE 'plpgsql';
+./source/sql/postgresql/059/.svn/text-base/function-059.sql.svn-base:$$ LANGUAGE 'plpgsql';
+./source/sql/postgresql/059/.svn/text-base/function-059.sql.svn-base:$$ LANGUAGE 'plpgsql';
+./source/sql/postgresql/059/.svn/text-base/function-059.sql.svn-base:$$ LANGUAGE 'plpgsql';
+./source/sql/postgresql/059/function-059.sql:$$ LANGUAGE 'plpgsql';
+./source/sql/postgresql/059/function-059.sql:$$ LANGUAGE 'plpgsql';
+./source/sql/postgresql/059/function-059.sql:$$ LANGUAGE 'plpgsql';
+./source/sql/postgresql/059/function-059.sql:$$ LANGUAGE 'plpgsql';
+./source/sql/postgresql/059/function-059.sql:$$ LANGUAGE 'plpgsql';
+./source/sql/postgresql/059/function-059.sql:$$ LANGUAGE 'plpgsql';
+./source/sql/postgresql/059/function-059.sql:$$ LANGUAGE 'plpgsql';
+./source/sql/postgresql/059/function-059.sql:$$ LANGUAGE 'plpgsql';
+./source/sql/postgresql/059/function-059.sql:$$ LANGUAGE 'plpgsql';
+./source/sql/postgresql/059/function-059.sql:$$ LANGUAGE 'plpgsql';
+./source/sql/postgresql/060/.svn/text-base/function-060.sql.svn-base:$$ LANGUAGE 'plpgsql';
+./source/sql/postgresql/060/.svn/text-base/function-060.sql.svn-base:$$ LANGUAGE 'plpgsql';
+./source/sql/postgresql/060/.svn/text-base/function-060.sql.svn-base:$$ LANGUAGE 'plpgsql';
+./source/sql/postgresql/060/.svn/text-base/function-060.sql.svn-base:$$ LANGUAGE 'plpgsql';
+./source/sql/postgresql/060/.svn/text-base/function-060.sql.svn-base:$$ LANGUAGE 'plpgsql';
+./source/sql/postgresql/060/.svn/text-base/function-060.sql.svn-base:$$ LANGUAGE 'plpgsql';
+./source/sql/postgresql/060/.svn/text-base/function-060.sql.svn-base:$$ LANGUAGE 'plpgsql';
+./source/sql/postgresql/060/.svn/text-base/function-060.sql.svn-base:$$ LANGUAGE 'plpgsql';
+./source/sql/postgresql/060/.svn/text-base/function-060.sql.svn-base:$$ LANGUAGE 'plpgsql';
+./source/sql/postgresql/060/function-060.sql:$$ LANGUAGE 'plpgsql';
+./source/sql/postgresql/060/function-060.sql:$$ LANGUAGE 'plpgsql';
+./source/sql/postgresql/060/function-060.sql:$$ LANGUAGE 'plpgsql';
+./source/sql/postgresql/060/function-060.sql:$$ LANGUAGE 'plpgsql';
+./source/sql/postgresql/060/function-060.sql:$$ LANGUAGE 'plpgsql';
+./source/sql/postgresql/060/function-060.sql:$$ LANGUAGE 'plpgsql';
+./source/sql/postgresql/060/function-060.sql:$$ LANGUAGE 'plpgsql';
+./source/sql/postgresql/060/function-060.sql:$$ LANGUAGE 'plpgsql';
+./source/sql/postgresql/060/function-060.sql:$$ LANGUAGE 'plpgsql';
+./source/sql/postgresql/061/.svn/text-base/function-061.sql.svn-base:$$ LANGUAGE 'plpgsql';
+./source/sql/postgresql/061/.svn/text-base/function-061.sql.svn-base:$$ LANGUAGE 'plpgsql';
+./source/sql/postgresql/061/.svn/text-base/function-061.sql.svn-base:$$ LANGUAGE 'plpgsql';
+./source/sql/postgresql/061/.svn/text-base/function-061.sql.svn-base:$$ LANGUAGE 'plpgsql';
+./source/sql/postgresql/061/.svn/text-base/function-061.sql.svn-base:$$ LANGUAGE 'plpgsql';
+./source/sql/postgresql/061/.svn/text-base/function-061.sql.svn-base:$$ LANGUAGE 'plpgsql';
+./source/sql/postgresql/061/.svn/text-base/function-061.sql.svn-base:$$ LANGUAGE 'plpgsql';
+./source/sql/postgresql/061/.svn/text-base/function-061.sql.svn-base:$$ LANGUAGE 'plpgsql';
+./source/sql/postgresql/061/.svn/text-base/function-061.sql.svn-base:$$ LANGUAGE 'plpgsql';
+./source/sql/postgresql/061/function-061.sql:$$ LANGUAGE 'plpgsql';
+./source/sql/postgresql/061/function-061.sql:$$ LANGUAGE 'plpgsql';
+./source/sql/postgresql/061/function-061.sql:$$ LANGUAGE 'plpgsql';
+./source/sql/postgresql/061/function-061.sql:$$ LANGUAGE 'plpgsql';
+./source/sql/postgresql/061/function-061.sql:$$ LANGUAGE 'plpgsql';
+./source/sql/postgresql/061/function-061.sql:$$ LANGUAGE 'plpgsql';
+./source/sql/postgresql/061/function-061.sql:$$ LANGUAGE 'plpgsql';
+./source/sql/postgresql/061/function-061.sql:$$ LANGUAGE 'plpgsql';
+./source/sql/postgresql/061/function-061.sql:$$ LANGUAGE 'plpgsql';
+./source/sql/postgresql/062/.svn/text-base/function-062.sql.svn-base:$$ LANGUAGE 'plpgsql';
+./source/sql/postgresql/062/.svn/text-base/function-062.sql.svn-base:$$ LANGUAGE 'plpgsql';
+./source/sql/postgresql/062/.svn/text-base/function-062.sql.svn-base:$$ LANGUAGE 'plpgsql';
+./source/sql/postgresql/062/.svn/text-base/function-062.sql.svn-base:$$ LANGUAGE 'plpgsql';
+./source/sql/postgresql/062/.svn/text-base/function-062.sql.svn-base:$$ LANGUAGE 'plpgsql';
+./source/sql/postgresql/062/.svn/text-base/function-062.sql.svn-base:$$ LANGUAGE 'plpgsql';
+./source/sql/postgresql/062/.svn/text-base/function-062.sql.svn-base:$$ LANGUAGE 'plpgsql';
+./source/sql/postgresql/062/.svn/text-base/function-062.sql.svn-base:$$ LANGUAGE 'plpgsql';
+./source/sql/postgresql/062/.svn/text-base/function-062.sql.svn-base:$$ LANGUAGE 'plpgsql';
+./source/sql/postgresql/062/function-062.sql:$$ LANGUAGE 'plpgsql';
+./source/sql/postgresql/062/function-062.sql:$$ LANGUAGE 'plpgsql';
+./source/sql/postgresql/062/function-062.sql:$$ LANGUAGE 'plpgsql';
+./source/sql/postgresql/062/function-062.sql:$$ LANGUAGE 'plpgsql';
+./source/sql/postgresql/062/function-062.sql:$$ LANGUAGE 'plpgsql';
+./source/sql/postgresql/062/function-062.sql:$$ LANGUAGE 'plpgsql';
+./source/sql/postgresql/062/function-062.sql:$$ LANGUAGE 'plpgsql';
+./source/sql/postgresql/062/function-062.sql:$$ LANGUAGE 'plpgsql';
+./source/sql/postgresql/062/function-062.sql:$$ LANGUAGE 'plpgsql';
+./source/sql/postgresql/063/.svn/text-base/function-063.sql.svn-base:$$ LANGUAGE 'plpgsql';
+./source/sql/postgresql/063/.svn/text-base/function-063.sql.svn-base:$$ LANGUAGE 'plpgsql';
+./source/sql/postgresql/063/.svn/text-base/function-063.sql.svn-base:$$ LANGUAGE 'plpgsql';
+./source/sql/postgresql/063/.svn/text-base/function-063.sql.svn-base:$$ LANGUAGE 'plpgsql';
+./source/sql/postgresql/063/.svn/text-base/function-063.sql.svn-base:$$ LANGUAGE 'plpgsql';
+./source/sql/postgresql/063/.svn/text-base/function-063.sql.svn-base:$$ LANGUAGE 'plpgsql';
+./source/sql/postgresql/063/.svn/text-base/function-063.sql.svn-base:$$ LANGUAGE 'plpgsql';
+./source/sql/postgresql/063/.svn/text-base/function-063.sql.svn-base:$$ LANGUAGE 'plpgsql';
+./source/sql/postgresql/063/.svn/text-base/function-063.sql.svn-base:$$ LANGUAGE 'plpgsql';
+./source/sql/postgresql/063/function-063.sql:$$ LANGUAGE 'plpgsql';
+./source/sql/postgresql/063/function-063.sql:$$ LANGUAGE 'plpgsql';
+./source/sql/postgresql/063/function-063.sql:$$ LANGUAGE 'plpgsql';
+./source/sql/postgresql/063/function-063.sql:$$ LANGUAGE 'plpgsql';
+./source/sql/postgresql/063/function-063.sql:$$ LANGUAGE 'plpgsql';
+./source/sql/postgresql/063/function-063.sql:$$ LANGUAGE 'plpgsql';
+./source/sql/postgresql/063/function-063.sql:$$ LANGUAGE 'plpgsql';
+./source/sql/postgresql/063/function-063.sql:$$ LANGUAGE 'plpgsql';
+./source/sql/postgresql/063/function-063.sql:$$ LANGUAGE 'plpgsql';
+./source/sql/postgresql/064/.svn/text-base/function-064.sql.svn-base:$$ LANGUAGE 'plpgsql';
+./source/sql/postgresql/064/.svn/text-base/function-064.sql.svn-base:$$ LANGUAGE 'plpgsql';
+./source/sql/postgresql/064/.svn/text-base/function-064.sql.svn-base:$$ LANGUAGE 'plpgsql';
+./source/sql/postgresql/064/.svn/text-base/function-064.sql.svn-base:$$ LANGUAGE 'plpgsql';
+./source/sql/postgresql/064/.svn/text-base/function-064.sql.svn-base:$$ LANGUAGE 'plpgsql';
+./source/sql/postgresql/064/.svn/text-base/function-064.sql.svn-base:$$ LANGUAGE 'plpgsql';
+./source/sql/postgresql/064/.svn/text-base/function-064.sql.svn-base:$$ LANGUAGE 'plpgsql';
+./source/sql/postgresql/064/.svn/text-base/function-064.sql.svn-base:$$ LANGUAGE 'plpgsql';
+./source/sql/postgresql/064/.svn/text-base/function-064.sql.svn-base:$$ LANGUAGE 'plpgsql';
+./source/sql/postgresql/064/function-064.sql:$$ LANGUAGE 'plpgsql';
+./source/sql/postgresql/064/function-064.sql:$$ LANGUAGE 'plpgsql';
+./source/sql/postgresql/064/function-064.sql:$$ LANGUAGE 'plpgsql';
+./source/sql/postgresql/064/function-064.sql:$$ LANGUAGE 'plpgsql';
+./source/sql/postgresql/064/function-064.sql:$$ LANGUAGE 'plpgsql';
+./source/sql/postgresql/064/function-064.sql:$$ LANGUAGE 'plpgsql';
+./source/sql/postgresql/064/function-064.sql:$$ LANGUAGE 'plpgsql';
+./source/sql/postgresql/064/function-064.sql:$$ LANGUAGE 'plpgsql';
+./source/sql/postgresql/064/function-064.sql:$$ LANGUAGE 'plpgsql';
+./source/sql/postgresql/065/.svn/text-base/function-065.sql.svn-base:$$ LANGUAGE 'plpgsql';
+./source/sql/postgresql/065/.svn/text-base/function-065.sql.svn-base:$$ LANGUAGE 'plpgsql';
+./source/sql/postgresql/065/.svn/text-base/function-065.sql.svn-base:$$ LANGUAGE 'plpgsql';
+./source/sql/postgresql/065/.svn/text-base/function-065.sql.svn-base:$$ LANGUAGE 'plpgsql';
+./source/sql/postgresql/065/.svn/text-base/function-065.sql.svn-base:$$ LANGUAGE 'plpgsql';
+./source/sql/postgresql/065/.svn/text-base/function-065.sql.svn-base:$$ LANGUAGE 'plpgsql';
+./source/sql/postgresql/065/.svn/text-base/function-065.sql.svn-base:$$ LANGUAGE 'plpgsql';
+./source/sql/postgresql/065/.svn/text-base/function-065.sql.svn-base:$$ LANGUAGE 'plpgsql';
+./source/sql/postgresql/065/.svn/text-base/function-065.sql.svn-base:$$ LANGUAGE 'plpgsql';
+./source/sql/postgresql/065/function-065.sql:$$ LANGUAGE 'plpgsql';
+./source/sql/postgresql/065/function-065.sql:$$ LANGUAGE 'plpgsql';
+./source/sql/postgresql/065/function-065.sql:$$ LANGUAGE 'plpgsql';
+./source/sql/postgresql/065/function-065.sql:$$ LANGUAGE 'plpgsql';
+./source/sql/postgresql/065/function-065.sql:$$ LANGUAGE 'plpgsql';
+./source/sql/postgresql/065/function-065.sql:$$ LANGUAGE 'plpgsql';
+./source/sql/postgresql/065/function-065.sql:$$ LANGUAGE 'plpgsql';
+./source/sql/postgresql/065/function-065.sql:$$ LANGUAGE 'plpgsql';
+./source/sql/postgresql/065/function-065.sql:$$ LANGUAGE 'plpgsql';
+./source/sql/postgresql/066/.svn/text-base/function-066.sql.svn-base:$$ LANGUAGE 'plpgsql';
+./source/sql/postgresql/066/.svn/text-base/function-066.sql.svn-base:$$ LANGUAGE 'plpgsql';
+./source/sql/postgresql/066/.svn/text-base/function-066.sql.svn-base:$$ LANGUAGE 'plpgsql';
+./source/sql/postgresql/066/.svn/text-base/function-066.sql.svn-base:$$ LANGUAGE 'plpgsql';
+./source/sql/postgresql/066/.svn/text-base/function-066.sql.svn-base:$$ LANGUAGE 'plpgsql';
+./source/sql/postgresql/066/.svn/text-base/function-066.sql.svn-base:$$ LANGUAGE 'plpgsql';
+./source/sql/postgresql/066/.svn/text-base/function-066.sql.svn-base:$$ LANGUAGE 'plpgsql';
+./source/sql/postgresql/066/.svn/text-base/function-066.sql.svn-base:$$ LANGUAGE 'plpgsql';
+./source/sql/postgresql/066/.svn/text-base/function-066.sql.svn-base:$$ LANGUAGE 'plpgsql';
+./source/sql/postgresql/066/function-066.sql:$$ LANGUAGE 'plpgsql';
+./source/sql/postgresql/066/function-066.sql:$$ LANGUAGE 'plpgsql';
+./source/sql/postgresql/066/function-066.sql:$$ LANGUAGE 'plpgsql';
+./source/sql/postgresql/066/function-066.sql:$$ LANGUAGE 'plpgsql';
+./source/sql/postgresql/066/function-066.sql:$$ LANGUAGE 'plpgsql';
+./source/sql/postgresql/066/function-066.sql:$$ LANGUAGE 'plpgsql';
+./source/sql/postgresql/066/function-066.sql:$$ LANGUAGE 'plpgsql';
+./source/sql/postgresql/066/function-066.sql:$$ LANGUAGE 'plpgsql';
+./source/sql/postgresql/066/function-066.sql:$$ LANGUAGE 'plpgsql';
+./source/sql/postgresql/067/.svn/text-base/function-067.sql.svn-base:$$ LANGUAGE 'plpgsql';
+./source/sql/postgresql/067/.svn/text-base/function-067.sql.svn-base:$$ LANGUAGE 'plpgsql';
+./source/sql/postgresql/067/.svn/text-base/function-067.sql.svn-base:$$ LANGUAGE 'plpgsql';
+./source/sql/postgresql/067/.svn/text-base/function-067.sql.svn-base:$$ LANGUAGE 'plpgsql';
+./source/sql/postgresql/067/.svn/text-base/function-067.sql.svn-base:$$ LANGUAGE 'plpgsql';
+./source/sql/postgresql/067/.svn/text-base/function-067.sql.svn-base:$$ LANGUAGE 'plpgsql';
+./source/sql/postgresql/067/.svn/text-base/function-067.sql.svn-base:$$ LANGUAGE 'plpgsql';
+./source/sql/postgresql/067/.svn/text-base/function-067.sql.svn-base:$$ LANGUAGE 'plpgsql';
+./source/sql/postgresql/067/.svn/text-base/function-067.sql.svn-base:$$ LANGUAGE 'plpgsql';
+./source/sql/postgresql/067/function-067.sql:$$ LANGUAGE 'plpgsql';
+./source/sql/postgresql/067/function-067.sql:$$ LANGUAGE 'plpgsql';
+./source/sql/postgresql/067/function-067.sql:$$ LANGUAGE 'plpgsql';
+./source/sql/postgresql/067/function-067.sql:$$ LANGUAGE 'plpgsql';
+./source/sql/postgresql/067/function-067.sql:$$ LANGUAGE 'plpgsql';
+./source/sql/postgresql/067/function-067.sql:$$ LANGUAGE 'plpgsql';
+./source/sql/postgresql/067/function-067.sql:$$ LANGUAGE 'plpgsql';
+./source/sql/postgresql/067/function-067.sql:$$ LANGUAGE 'plpgsql';
+./source/sql/postgresql/067/function-067.sql:$$ LANGUAGE 'plpgsql';
+./source/sql/postgresql/068/.svn/text-base/function-068.sql.svn-base:$$ LANGUAGE 'plpgsql';
+./source/sql/postgresql/068/.svn/text-base/function-068.sql.svn-base:$$ LANGUAGE 'plpgsql';
+./source/sql/postgresql/068/.svn/text-base/function-068.sql.svn-base:$$ LANGUAGE 'plpgsql';
+./source/sql/postgresql/068/.svn/text-base/function-068.sql.svn-base:$$ LANGUAGE 'plpgsql';
+./source/sql/postgresql/068/.svn/text-base/function-068.sql.svn-base:$$ LANGUAGE 'plpgsql';
+./source/sql/postgresql/068/.svn/text-base/function-068.sql.svn-base:$$ LANGUAGE 'plpgsql';
+./source/sql/postgresql/068/.svn/text-base/function-068.sql.svn-base:$$ LANGUAGE 'plpgsql';
+./source/sql/postgresql/068/.svn/text-base/function-068.sql.svn-base:$$ LANGUAGE 'plpgsql';
+./source/sql/postgresql/068/.svn/text-base/function-068.sql.svn-base:$$ LANGUAGE 'plpgsql';
+./source/sql/postgresql/068/function-068.sql:$$ LANGUAGE 'plpgsql';
+./source/sql/postgresql/068/function-068.sql:$$ LANGUAGE 'plpgsql';
+./source/sql/postgresql/068/function-068.sql:$$ LANGUAGE 'plpgsql';
+./source/sql/postgresql/068/function-068.sql:$$ LANGUAGE 'plpgsql';
+./source/sql/postgresql/068/function-068.sql:$$ LANGUAGE 'plpgsql';
+./source/sql/postgresql/068/function-068.sql:$$ LANGUAGE 'plpgsql';
+./source/sql/postgresql/068/function-068.sql:$$ LANGUAGE 'plpgsql';
+./source/sql/postgresql/068/function-068.sql:$$ LANGUAGE 'plpgsql';
+./source/sql/postgresql/068/function-068.sql:$$ LANGUAGE 'plpgsql';
+./source/sql/postgresql/069/.svn/text-base/function-069.sql.svn-base:$$ LANGUAGE 'plpgsql';
+./source/sql/postgresql/069/.svn/text-base/function-069.sql.svn-base:$$ LANGUAGE 'plpgsql';
+./source/sql/postgresql/069/.svn/text-base/function-069.sql.svn-base:$$ LANGUAGE 'plpgsql';
+./source/sql/postgresql/069/.svn/text-base/function-069.sql.svn-base:$$ LANGUAGE 'plpgsql';
+./source/sql/postgresql/069/.svn/text-base/function-069.sql.svn-base:$$ LANGUAGE 'plpgsql';
+./source/sql/postgresql/069/.svn/text-base/function-069.sql.svn-base:$$ LANGUAGE 'plpgsql';
+./source/sql/postgresql/069/.svn/text-base/function-069.sql.svn-base:$$ LANGUAGE 'plpgsql';
+./source/sql/postgresql/069/.svn/text-base/function-069.sql.svn-base:$$ LANGUAGE 'plpgsql';
+./source/sql/postgresql/069/.svn/text-base/function-069.sql.svn-base:$$ LANGUAGE 'plpgsql';
+./source/sql/postgresql/069/function-069.sql:$$ LANGUAGE 'plpgsql';
+./source/sql/postgresql/069/function-069.sql:$$ LANGUAGE 'plpgsql';
+./source/sql/postgresql/069/function-069.sql:$$ LANGUAGE 'plpgsql';
+./source/sql/postgresql/069/function-069.sql:$$ LANGUAGE 'plpgsql';
+./source/sql/postgresql/069/function-069.sql:$$ LANGUAGE 'plpgsql';
+./source/sql/postgresql/069/function-069.sql:$$ LANGUAGE 'plpgsql';
+./source/sql/postgresql/069/function-069.sql:$$ LANGUAGE 'plpgsql';
+./source/sql/postgresql/069/function-069.sql:$$ LANGUAGE 'plpgsql';
+./source/sql/postgresql/069/function-069.sql:$$ LANGUAGE 'plpgsql';
+./source/sql/postgresql/070/.svn/text-base/function-070.sql.svn-base:$$ LANGUAGE 'plpgsql';
+./source/sql/postgresql/070/.svn/text-base/function-070.sql.svn-base:$$ LANGUAGE 'plpgsql';
+./source/sql/postgresql/070/.svn/text-base/function-070.sql.svn-base:$$ LANGUAGE 'plpgsql';
+./source/sql/postgresql/070/.svn/text-base/function-070.sql.svn-base:$$ LANGUAGE 'plpgsql';
+./source/sql/postgresql/070/.svn/text-base/function-070.sql.svn-base:$$ LANGUAGE 'plpgsql';
+./source/sql/postgresql/070/.svn/text-base/function-070.sql.svn-base:$$ LANGUAGE 'plpgsql';
+./source/sql/postgresql/070/.svn/text-base/function-070.sql.svn-base:$$ LANGUAGE 'plpgsql';
+./source/sql/postgresql/070/.svn/text-base/function-070.sql.svn-base:$$ LANGUAGE 'plpgsql';
+./source/sql/postgresql/070/.svn/text-base/function-070.sql.svn-base:$$ LANGUAGE 'plpgsql';
+./source/sql/postgresql/070/function-070.sql:$$ LANGUAGE 'plpgsql';
+./source/sql/postgresql/070/function-070.sql:$$ LANGUAGE 'plpgsql';
+./source/sql/postgresql/070/function-070.sql:$$ LANGUAGE 'plpgsql';
+./source/sql/postgresql/070/function-070.sql:$$ LANGUAGE 'plpgsql';
+./source/sql/postgresql/070/function-070.sql:$$ LANGUAGE 'plpgsql';
+./source/sql/postgresql/070/function-070.sql:$$ LANGUAGE 'plpgsql';
+./source/sql/postgresql/070/function-070.sql:$$ LANGUAGE 'plpgsql';
+./source/sql/postgresql/070/function-070.sql:$$ LANGUAGE 'plpgsql';
+./source/sql/postgresql/070/function-070.sql:$$ LANGUAGE 'plpgsql';
+./source/sql/postgresql/071/.svn/text-base/function-071.sql.svn-base:$$ LANGUAGE 'plpgsql';
+./source/sql/postgresql/071/.svn/text-base/function-071.sql.svn-base:$$ LANGUAGE 'plpgsql';
+./source/sql/postgresql/071/.svn/text-base/function-071.sql.svn-base:$$ LANGUAGE 'plpgsql';
+./source/sql/postgresql/071/.svn/text-base/function-071.sql.svn-base:$$ LANGUAGE 'plpgsql';
+./source/sql/postgresql/071/.svn/text-base/function-071.sql.svn-base:$$ LANGUAGE 'plpgsql';
+./source/sql/postgresql/071/.svn/text-base/function-071.sql.svn-base:$$ LANGUAGE 'plpgsql';
+./source/sql/postgresql/071/.svn/text-base/function-071.sql.svn-base:$$ LANGUAGE 'plpgsql';
+./source/sql/postgresql/071/.svn/text-base/function-071.sql.svn-base:$$ LANGUAGE 'plpgsql';
+./source/sql/postgresql/071/.svn/text-base/function-071.sql.svn-base:$$ LANGUAGE 'plpgsql';
+./source/sql/postgresql/071/function-071.sql:$$ LANGUAGE 'plpgsql';
+./source/sql/postgresql/071/function-071.sql:$$ LANGUAGE 'plpgsql';
+./source/sql/postgresql/071/function-071.sql:$$ LANGUAGE 'plpgsql';
+./source/sql/postgresql/071/function-071.sql:$$ LANGUAGE 'plpgsql';
+./source/sql/postgresql/071/function-071.sql:$$ LANGUAGE 'plpgsql';
+./source/sql/postgresql/071/function-071.sql:$$ LANGUAGE 'plpgsql';
+./source/sql/postgresql/071/function-071.sql:$$ LANGUAGE 'plpgsql';
+./source/sql/postgresql/071/function-071.sql:$$ LANGUAGE 'plpgsql';
+./source/sql/postgresql/071/function-071.sql:$$ LANGUAGE 'plpgsql';
+./source/sql/postgresql/072/.svn/text-base/function-072.sql.svn-base:$$ LANGUAGE 'plpgsql';
+./source/sql/postgresql/072/.svn/text-base/function-072.sql.svn-base:$$ LANGUAGE 'plpgsql';
+./source/sql/postgresql/072/.svn/text-base/function-072.sql.svn-base:$$ LANGUAGE 'plpgsql';
+./source/sql/postgresql/072/.svn/text-base/function-072.sql.svn-base:$$ LANGUAGE 'plpgsql';
+./source/sql/postgresql/072/.svn/text-base/function-072.sql.svn-base:$$ LANGUAGE 'plpgsql';
+./source/sql/postgresql/072/.svn/text-base/function-072.sql.svn-base:$$ LANGUAGE 'plpgsql';
+./source/sql/postgresql/072/.svn/text-base/function-072.sql.svn-base:$$ LANGUAGE 'plpgsql';
+./source/sql/postgresql/072/.svn/text-base/function-072.sql.svn-base:$$ LANGUAGE 'plpgsql';
+./source/sql/postgresql/072/.svn/text-base/function-072.sql.svn-base:$$ LANGUAGE 'plpgsql';
+./source/sql/postgresql/072/function-072.sql:$$ LANGUAGE 'plpgsql';
+./source/sql/postgresql/072/function-072.sql:$$ LANGUAGE 'plpgsql';
+./source/sql/postgresql/072/function-072.sql:$$ LANGUAGE 'plpgsql';
+./source/sql/postgresql/072/function-072.sql:$$ LANGUAGE 'plpgsql';
+./source/sql/postgresql/072/function-072.sql:$$ LANGUAGE 'plpgsql';
+./source/sql/postgresql/072/function-072.sql:$$ LANGUAGE 'plpgsql';
+./source/sql/postgresql/072/function-072.sql:$$ LANGUAGE 'plpgsql';
+./source/sql/postgresql/072/function-072.sql:$$ LANGUAGE 'plpgsql';
+./source/sql/postgresql/072/function-072.sql:$$ LANGUAGE 'plpgsql';
+./source/sql/postgresql/073/.svn/text-base/function-073.sql.svn-base:$$ LANGUAGE 'plpgsql';
+./source/sql/postgresql/073/.svn/text-base/function-073.sql.svn-base:$$ LANGUAGE 'plpgsql';
+./source/sql/postgresql/073/.svn/text-base/function-073.sql.svn-base:$$ LANGUAGE 'plpgsql';
+./source/sql/postgresql/073/.svn/text-base/function-073.sql.svn-base:$$ LANGUAGE 'plpgsql';
+./source/sql/postgresql/073/.svn/text-base/function-073.sql.svn-base:$$ LANGUAGE 'plpgsql';
+./source/sql/postgresql/073/.svn/text-base/function-073.sql.svn-base:$$ LANGUAGE 'plpgsql';
+./source/sql/postgresql/073/.svn/text-base/function-073.sql.svn-base:$$ LANGUAGE 'plpgsql';
+./source/sql/postgresql/073/.svn/text-base/function-073.sql.svn-base:$$ LANGUAGE 'plpgsql';
+./source/sql/postgresql/073/.svn/text-base/function-073.sql.svn-base:$$ LANGUAGE 'plpgsql';
+./source/sql/postgresql/073/function-073.sql:$$ LANGUAGE 'plpgsql';
+./source/sql/postgresql/073/function-073.sql:$$ LANGUAGE 'plpgsql';
+./source/sql/postgresql/073/function-073.sql:$$ LANGUAGE 'plpgsql';
+./source/sql/postgresql/073/function-073.sql:$$ LANGUAGE 'plpgsql';
+./source/sql/postgresql/073/function-073.sql:$$ LANGUAGE 'plpgsql';
+./source/sql/postgresql/073/function-073.sql:$$ LANGUAGE 'plpgsql';
+./source/sql/postgresql/073/function-073.sql:$$ LANGUAGE 'plpgsql';
+./source/sql/postgresql/073/function-073.sql:$$ LANGUAGE 'plpgsql';
+./source/sql/postgresql/073/function-073.sql:$$ LANGUAGE 'plpgsql';
+./source/sql/postgresql/074/.svn/text-base/function-074.sql.svn-base:$$ LANGUAGE 'plpgsql';
+./source/sql/postgresql/074/.svn/text-base/function-074.sql.svn-base:$$ LANGUAGE 'plpgsql';
+./source/sql/postgresql/074/.svn/text-base/function-074.sql.svn-base:$$ LANGUAGE 'plpgsql';
+./source/sql/postgresql/074/.svn/text-base/function-074.sql.svn-base:$$ LANGUAGE 'plpgsql';
+./source/sql/postgresql/074/.svn/text-base/function-074.sql.svn-base:$$ LANGUAGE 'plpgsql';
+./source/sql/postgresql/074/.svn/text-base/function-074.sql.svn-base:$$ LANGUAGE 'plpgsql';
+./source/sql/postgresql/074/.svn/text-base/function-074.sql.svn-base:$$ LANGUAGE 'plpgsql';
+./source/sql/postgresql/074/.svn/text-base/function-074.sql.svn-base:$$ LANGUAGE 'plpgsql';
+./source/sql/postgresql/074/.svn/text-base/function-074.sql.svn-base:$$ LANGUAGE 'plpgsql';
+./source/sql/postgresql/074/function-074.sql:$$ LANGUAGE 'plpgsql';
+./source/sql/postgresql/074/function-074.sql:$$ LANGUAGE 'plpgsql';
+./source/sql/postgresql/074/function-074.sql:$$ LANGUAGE 'plpgsql';
+./source/sql/postgresql/074/function-074.sql:$$ LANGUAGE 'plpgsql';
+./source/sql/postgresql/074/function-074.sql:$$ LANGUAGE 'plpgsql';
+./source/sql/postgresql/074/function-074.sql:$$ LANGUAGE 'plpgsql';
+./source/sql/postgresql/074/function-074.sql:$$ LANGUAGE 'plpgsql';
+./source/sql/postgresql/074/function-074.sql:$$ LANGUAGE 'plpgsql';
+./source/sql/postgresql/074/function-074.sql:$$ LANGUAGE 'plpgsql';
+./source/sql/postgresql/075/.svn/text-base/function-075.sql.svn-base:$$ LANGUAGE 'plpgsql';
+./source/sql/postgresql/075/.svn/text-base/function-075.sql.svn-base:$$ LANGUAGE 'plpgsql';
+./source/sql/postgresql/075/.svn/text-base/function-075.sql.svn-base:$$ LANGUAGE 'plpgsql';
+./source/sql/postgresql/075/.svn/text-base/function-075.sql.svn-base:$$ LANGUAGE 'plpgsql';
+./source/sql/postgresql/075/.svn/text-base/function-075.sql.svn-base:$$ LANGUAGE 'plpgsql';
+./source/sql/postgresql/075/.svn/text-base/function-075.sql.svn-base:$$ LANGUAGE 'plpgsql';
+./source/sql/postgresql/075/.svn/text-base/function-075.sql.svn-base:$$ LANGUAGE 'plpgsql';
+./source/sql/postgresql/075/.svn/text-base/function-075.sql.svn-base:$$ LANGUAGE 'plpgsql';
+./source/sql/postgresql/075/.svn/text-base/function-075.sql.svn-base:$$ LANGUAGE 'plpgsql';
+./source/sql/postgresql/075/function-075.sql:$$ LANGUAGE 'plpgsql';
+./source/sql/postgresql/075/function-075.sql:$$ LANGUAGE 'plpgsql';
+./source/sql/postgresql/075/function-075.sql:$$ LANGUAGE 'plpgsql';
+./source/sql/postgresql/075/function-075.sql:$$ LANGUAGE 'plpgsql';
+./source/sql/postgresql/075/function-075.sql:$$ LANGUAGE 'plpgsql';
+./source/sql/postgresql/075/function-075.sql:$$ LANGUAGE 'plpgsql';
+./source/sql/postgresql/075/function-075.sql:$$ LANGUAGE 'plpgsql';
+./source/sql/postgresql/075/function-075.sql:$$ LANGUAGE 'plpgsql';
+./source/sql/postgresql/075/function-075.sql:$$ LANGUAGE 'plpgsql';
+./source/sql/postgresql/076/.svn/text-base/function-076.sql.svn-base:$$ LANGUAGE 'plpgsql';
+./source/sql/postgresql/076/.svn/text-base/function-076.sql.svn-base:$$ LANGUAGE 'plpgsql';
+./source/sql/postgresql/076/.svn/text-base/function-076.sql.svn-base:$$ LANGUAGE 'plpgsql';
+./source/sql/postgresql/076/.svn/text-base/function-076.sql.svn-base:$$ LANGUAGE 'plpgsql';
+./source/sql/postgresql/076/.svn/text-base/function-076.sql.svn-base:$$ LANGUAGE 'plpgsql';
+./source/sql/postgresql/076/.svn/text-base/function-076.sql.svn-base:$$ LANGUAGE 'plpgsql';
+./source/sql/postgresql/076/.svn/text-base/function-076.sql.svn-base:$$ LANGUAGE 'plpgsql';
+./source/sql/postgresql/076/.svn/text-base/function-076.sql.svn-base:$$ LANGUAGE 'plpgsql';
+./source/sql/postgresql/076/.svn/text-base/function-076.sql.svn-base:$$ LANGUAGE 'plpgsql';
+./source/sql/postgresql/076/.svn/text-base/function-076.sql.svn-base:$$ LANGUAGE 'plpgsql';
+./source/sql/postgresql/076/.svn/text-base/function-076.sql.svn-base:$$ LANGUAGE 'plpgsql';
+./source/sql/postgresql/076/.svn/text-base/function-076.sql.svn-base:$$ LANGUAGE 'plpgsql';
+./source/sql/postgresql/076/.svn/text-base/function-076.sql.svn-base:$$ LANGUAGE 'plpgsql';
+./source/sql/postgresql/076/.svn/text-base/function-076.sql.svn-base:$$ LANGUAGE 'plpgsql';
+./source/sql/postgresql/076/function-076.sql:$$ LANGUAGE 'plpgsql';
+./source/sql/postgresql/076/function-076.sql:$$ LANGUAGE 'plpgsql';
+./source/sql/postgresql/076/function-076.sql:$$ LANGUAGE 'plpgsql';
+./source/sql/postgresql/076/function-076.sql:$$ LANGUAGE 'plpgsql';
+./source/sql/postgresql/076/function-076.sql:$$ LANGUAGE 'plpgsql';
+./source/sql/postgresql/076/function-076.sql:$$ LANGUAGE 'plpgsql';
+./source/sql/postgresql/076/function-076.sql:$$ LANGUAGE 'plpgsql';
+./source/sql/postgresql/076/function-076.sql:$$ LANGUAGE 'plpgsql';
+./source/sql/postgresql/076/function-076.sql:$$ LANGUAGE 'plpgsql';
+./source/sql/postgresql/076/function-076.sql:$$ LANGUAGE 'plpgsql';
+./source/sql/postgresql/076/function-076.sql:$$ LANGUAGE 'plpgsql';
+./source/sql/postgresql/076/function-076.sql:$$ LANGUAGE 'plpgsql';
+./source/sql/postgresql/076/function-076.sql:$$ LANGUAGE 'plpgsql';
+./source/sql/postgresql/076/function-076.sql:$$ LANGUAGE 'plpgsql';
+./source/sql/postgresql/077/.svn/text-base/function-077.sql.svn-base:$$ LANGUAGE 'plpgsql';
+./source/sql/postgresql/077/.svn/text-base/function-077.sql.svn-base:$$ LANGUAGE 'plpgsql';
+./source/sql/postgresql/077/.svn/text-base/function-077.sql.svn-base:$$ LANGUAGE 'plpgsql';
+./source/sql/postgresql/077/.svn/text-base/function-077.sql.svn-base:$$ LANGUAGE 'plpgsql';
+./source/sql/postgresql/077/.svn/text-base/function-077.sql.svn-base:$$ LANGUAGE 'plpgsql';
+./source/sql/postgresql/077/.svn/text-base/function-077.sql.svn-base:$$ LANGUAGE 'plpgsql';
+./source/sql/postgresql/077/.svn/text-base/function-077.sql.svn-base:$$ LANGUAGE 'plpgsql';
+./source/sql/postgresql/077/.svn/text-base/function-077.sql.svn-base:$$ LANGUAGE 'plpgsql';
+./source/sql/postgresql/077/.svn/text-base/function-077.sql.svn-base:$$ LANGUAGE 'plpgsql';
+./source/sql/postgresql/077/.svn/text-base/function-077.sql.svn-base:$$ LANGUAGE 'plpgsql';
+./source/sql/postgresql/077/.svn/text-base/function-077.sql.svn-base:$$ LANGUAGE 'plpgsql';
+./source/sql/postgresql/077/.svn/text-base/function-077.sql.svn-base:$$ LANGUAGE 'plpgsql';
+./source/sql/postgresql/077/.svn/text-base/function-077.sql.svn-base:$$ LANGUAGE 'plpgsql';
+./source/sql/postgresql/077/.svn/text-base/function-077.sql.svn-base:$$ LANGUAGE 'plpgsql';
+./source/sql/postgresql/077/function-077.sql:$$ LANGUAGE 'plpgsql';
+./source/sql/postgresql/077/function-077.sql:$$ LANGUAGE 'plpgsql';
+./source/sql/postgresql/077/function-077.sql:$$ LANGUAGE 'plpgsql';
+./source/sql/postgresql/077/function-077.sql:$$ LANGUAGE 'plpgsql';
+./source/sql/postgresql/077/function-077.sql:$$ LANGUAGE 'plpgsql';
+./source/sql/postgresql/077/function-077.sql:$$ LANGUAGE 'plpgsql';
+./source/sql/postgresql/077/function-077.sql:$$ LANGUAGE 'plpgsql';
+./source/sql/postgresql/077/function-077.sql:$$ LANGUAGE 'plpgsql';
+./source/sql/postgresql/077/function-077.sql:$$ LANGUAGE 'plpgsql';
+./source/sql/postgresql/077/function-077.sql:$$ LANGUAGE 'plpgsql';
+./source/sql/postgresql/077/function-077.sql:$$ LANGUAGE 'plpgsql';
+./source/sql/postgresql/077/function-077.sql:$$ LANGUAGE 'plpgsql';
+./source/sql/postgresql/077/function-077.sql:$$ LANGUAGE 'plpgsql';
+./source/sql/postgresql/077/function-077.sql:$$ LANGUAGE 'plpgsql';
+./source/sql/postgresql/078/.svn/text-base/function-078.sql.svn-base:$$ LANGUAGE 'plpgsql';
+./source/sql/postgresql/078/.svn/text-base/function-078.sql.svn-base:$$ LANGUAGE 'plpgsql';
+./source/sql/postgresql/078/.svn/text-base/function-078.sql.svn-base:$$ LANGUAGE 'plpgsql';
+./source/sql/postgresql/078/.svn/text-base/function-078.sql.svn-base:$$ LANGUAGE 'plpgsql';
+./source/sql/postgresql/078/.svn/text-base/function-078.sql.svn-base:$$ LANGUAGE 'plpgsql';
+./source/sql/postgresql/078/.svn/text-base/function-078.sql.svn-base:$$ LANGUAGE 'plpgsql';
+./source/sql/postgresql/078/.svn/text-base/function-078.sql.svn-base:$$ LANGUAGE 'plpgsql';
+./source/sql/postgresql/078/.svn/text-base/function-078.sql.svn-base:$$ LANGUAGE 'plpgsql';
+./source/sql/postgresql/078/.svn/text-base/function-078.sql.svn-base:$$ LANGUAGE 'plpgsql';
+./source/sql/postgresql/078/.svn/text-base/function-078.sql.svn-base:$$ LANGUAGE 'plpgsql';
+./source/sql/postgresql/078/.svn/text-base/function-078.sql.svn-base:$$ LANGUAGE 'plpgsql';
+./source/sql/postgresql/078/.svn/text-base/function-078.sql.svn-base:$$ LANGUAGE 'plpgsql';
+./source/sql/postgresql/078/.svn/text-base/function-078.sql.svn-base:$$ LANGUAGE 'plpgsql';
+./source/sql/postgresql/078/.svn/text-base/function-078.sql.svn-base:$$ LANGUAGE 'plpgsql';
+./source/sql/postgresql/078/function-078.sql:$$ LANGUAGE 'plpgsql';
+./source/sql/postgresql/078/function-078.sql:$$ LANGUAGE 'plpgsql';
+./source/sql/postgresql/078/function-078.sql:$$ LANGUAGE 'plpgsql';
+./source/sql/postgresql/078/function-078.sql:$$ LANGUAGE 'plpgsql';
+./source/sql/postgresql/078/function-078.sql:$$ LANGUAGE 'plpgsql';
+./source/sql/postgresql/078/function-078.sql:$$ LANGUAGE 'plpgsql';
+./source/sql/postgresql/078/function-078.sql:$$ LANGUAGE 'plpgsql';
+./source/sql/postgresql/078/function-078.sql:$$ LANGUAGE 'plpgsql';
+./source/sql/postgresql/078/function-078.sql:$$ LANGUAGE 'plpgsql';
+./source/sql/postgresql/078/function-078.sql:$$ LANGUAGE 'plpgsql';
+./source/sql/postgresql/078/function-078.sql:$$ LANGUAGE 'plpgsql';
+./source/sql/postgresql/078/function-078.sql:$$ LANGUAGE 'plpgsql';
+./source/sql/postgresql/078/function-078.sql:$$ LANGUAGE 'plpgsql';
+./source/sql/postgresql/078/function-078.sql:$$ LANGUAGE 'plpgsql';
+./source/sql/postgresql/079/.svn/text-base/function-079.sql.svn-base:$$ LANGUAGE 'plpgsql';
+./source/sql/postgresql/079/.svn/text-base/function-079.sql.svn-base:$$ LANGUAGE 'plpgsql';
+./source/sql/postgresql/079/.svn/text-base/function-079.sql.svn-base:$$ LANGUAGE 'plpgsql';
+./source/sql/postgresql/079/.svn/text-base/function-079.sql.svn-base:$$ LANGUAGE 'plpgsql';
+./source/sql/postgresql/079/.svn/text-base/function-079.sql.svn-base:$$ LANGUAGE 'plpgsql';
+./source/sql/postgresql/079/.svn/text-base/function-079.sql.svn-base:$$ LANGUAGE 'plpgsql';
+./source/sql/postgresql/079/.svn/text-base/function-079.sql.svn-base:$$ LANGUAGE 'plpgsql';
+./source/sql/postgresql/079/.svn/text-base/function-079.sql.svn-base:$$ LANGUAGE 'plpgsql';
+./source/sql/postgresql/079/.svn/text-base/function-079.sql.svn-base:$$ LANGUAGE 'plpgsql';
+./source/sql/postgresql/079/.svn/text-base/function-079.sql.svn-base:$$ LANGUAGE 'plpgsql';
+./source/sql/postgresql/079/.svn/text-base/function-079.sql.svn-base:$$ LANGUAGE 'plpgsql';
+./source/sql/postgresql/079/.svn/text-base/function-079.sql.svn-base:$$ LANGUAGE 'plpgsql';
+./source/sql/postgresql/079/.svn/text-base/function-079.sql.svn-base:$$ LANGUAGE 'plpgsql';
+./source/sql/postgresql/079/.svn/text-base/function-079.sql.svn-base:$$ LANGUAGE 'plpgsql';
+./source/sql/postgresql/079/function-079.sql:$$ LANGUAGE 'plpgsql';
+./source/sql/postgresql/079/function-079.sql:$$ LANGUAGE 'plpgsql';
+./source/sql/postgresql/079/function-079.sql:$$ LANGUAGE 'plpgsql';
+./source/sql/postgresql/079/function-079.sql:$$ LANGUAGE 'plpgsql';
+./source/sql/postgresql/079/function-079.sql:$$ LANGUAGE 'plpgsql';
+./source/sql/postgresql/079/function-079.sql:$$ LANGUAGE 'plpgsql';
+./source/sql/postgresql/079/function-079.sql:$$ LANGUAGE 'plpgsql';
+./source/sql/postgresql/079/function-079.sql:$$ LANGUAGE 'plpgsql';
+./source/sql/postgresql/079/function-079.sql:$$ LANGUAGE 'plpgsql';
+./source/sql/postgresql/079/function-079.sql:$$ LANGUAGE 'plpgsql';
+./source/sql/postgresql/079/function-079.sql:$$ LANGUAGE 'plpgsql';
+./source/sql/postgresql/079/function-079.sql:$$ LANGUAGE 'plpgsql';
+./source/sql/postgresql/079/function-079.sql:$$ LANGUAGE 'plpgsql';
+./source/sql/postgresql/079/function-079.sql:$$ LANGUAGE 'plpgsql';
+./source/sql/postgresql/migration/.svn/text-base/migration-012-013.sql.svn-base:$$ LANGUAGE 'plpgsql';
+./source/sql/postgresql/migration/.svn/text-base/migration-013-014.sql.svn-base:$$ LANGUAGE 'plpgsql';
+./source/sql/postgresql/migration/.svn/text-base/migration-015-016.sql.svn-base:$$ LANGUAGE 'plpgsql';
+./source/sql/postgresql/migration/.svn/text-base/migration-015-016.sql.svn-base:$$ LANGUAGE 'plpgsql';
+./source/sql/postgresql/migration/.svn/text-base/migration-015-016.sql.svn-base:$$ LANGUAGE 'plpgsql';
+./source/sql/postgresql/migration/.svn/text-base/migration-015-016.sql.svn-base:$$ LANGUAGE 'plpgsql';
+./source/sql/postgresql/migration/.svn/text-base/migration-015-016.sql.svn-base:$$ LANGUAGE 'plpgsql';
+./source/sql/postgresql/migration/.svn/text-base/migration-015-016.sql.svn-base:$$ LANGUAGE 'plpgsql';
+./source/sql/postgresql/migration/.svn/text-base/migration-015-016.sql.svn-base:$$ LANGUAGE 'plpgsql';
+./source/sql/postgresql/migration/.svn/text-base/migration-015-016.sql.svn-base:$$ LANGUAGE 'plpgsql';
+./source/sql/postgresql/migration/.svn/text-base/migration-015-016.sql.svn-base:$$ LANGUAGE 'plpgsql';
+./source/sql/postgresql/migration/.svn/text-base/migration-016-017.sql.svn-base:$$ LANGUAGE 'plpgsql';
+./source/sql/postgresql/migration/.svn/text-base/migration-018-019.sql.svn-base:$$ language 'plpgsql';
+./source/sql/postgresql/migration/.svn/text-base/migration-022-023.sql.svn-base:$$ LANGUAGE 'plpgsql';
+./source/sql/postgresql/migration/.svn/text-base/migration-023-024.sql.svn-base:$$ LANGUAGE 'plpgsql';
+./source/sql/postgresql/migration/.svn/text-base/migration-024-025.sql.svn-base:$$ LANGUAGE 'plpgsql';
+./source/sql/postgresql/migration/.svn/text-base/migration-025-026.sql.svn-base:$$ language 'plpgsql';
+./source/sql/postgresql/migration/.svn/text-base/migration-025-026.sql.svn-base:$$ language 'plpgsql';
+./source/sql/postgresql/migration/.svn/text-base/migration-026-027.sql.svn-base:    LANGUAGE plpgsql;
+./source/sql/postgresql/migration/.svn/text-base/migration-026-027.sql.svn-base:    LANGUAGE plpgsql;
+./source/sql/postgresql/migration/.svn/text-base/migration-026-027.sql.svn-base:$$ language 'plpgsql';
+./source/sql/postgresql/migration/.svn/text-base/migration-026-027.sql.svn-base:$$ language 'plpgsql';
+./source/sql/postgresql/migration/.svn/text-base/migration-027-028.sql.svn-base:$$ LANGUAGE 'plpgsql';
+./source/sql/postgresql/migration/.svn/text-base/migration-028-029.sql.svn-base:$$ LANGUAGE 'plpgsql';
+./source/sql/postgresql/migration/.svn/text-base/migration-028-029.sql.svn-base:$$ LANGUAGE 'plpgsql';
+./source/sql/postgresql/migration/.svn/text-base/migration-028-029.sql.svn-base:$$ LANGUAGE 'plpgsql';
+./source/sql/postgresql/migration/.svn/text-base/migration-029-030.sql.svn-base:$$ LANGUAGE 'plpgsql';
+./source/sql/postgresql/migration/.svn/text-base/migration-030-031.sql.svn-base:$$ LANGUAGE 'plpgsql';
+./source/sql/postgresql/migration/.svn/text-base/migration-031-032.sql.svn-base:$$ LANGUAGE 'plpgsql';
+./source/sql/postgresql/migration/.svn/text-base/migration-033-034.sql.svn-base:$$ LANGUAGE 'plpgsql';
+./source/sql/postgresql/migration/.svn/text-base/migration-033-034.sql.svn-base:$$ language 'plpgsql';
+./source/sql/postgresql/migration/.svn/text-base/migration-033-034.sql.svn-base:$$ language 'plpgsql';
+./source/sql/postgresql/migration/.svn/text-base/migration-033-034.sql.svn-base:$$ language 'plpgsql';
+./source/sql/postgresql/migration/.svn/text-base/migration-033-034.sql.svn-base:$$ language 'plpgsql';
+./source/sql/postgresql/migration/.svn/text-base/migration-033-034.sql.svn-base:$$ language 'plpgsql';
+./source/sql/postgresql/migration/.svn/text-base/migration-033-034.sql.svn-base:$$ language 'plpgsql';
+./source/sql/postgresql/migration/.svn/text-base/migration-033-034.sql.svn-base:$$ language 'plpgsql';
+./source/sql/postgresql/migration/.svn/text-base/migration-033-034.sql.svn-base:$$ language 'plpgsql';
+./source/sql/postgresql/migration/.svn/text-base/migration-033-034.sql.svn-base:$$ language 'plpgsql';
+./source/sql/postgresql/migration/.svn/text-base/migration-033-034.sql.svn-base:$$ language 'plpgsql';
+./source/sql/postgresql/migration/.svn/text-base/migration-040-041.sql.svn-base:$$ LANGUAGE 'plpgsql';
+./source/sql/postgresql/migration/.svn/text-base/migration-040-041.sql.svn-base:$$ LANGUAGE 'plpgsql';
+./source/sql/postgresql/migration/.svn/text-base/migration-052-053.sql.svn-base:$$ LANGUAGE 'plpgsql';
+./source/sql/postgresql/migration/.svn/text-base/migration-052-053.sql.svn-base:$$ LANGUAGE 'plpgsql';
+./source/sql/postgresql/migration/.svn/text-base/migration-053-054.sql.svn-base:$$ LANGUAGE 'plpgsql';
+./source/sql/postgresql/migration/.svn/text-base/migration-055-056.sql.svn-base:$$ LANGUAGE plpgsql;
+./source/sql/postgresql/migration/.svn/text-base/migration-055-056.sql.svn-base:$$ LANGUAGE 'plpgsql';
+./source/sql/postgresql/migration/.svn/text-base/migration-058-059.sql.svn-base:$$ LANGUAGE 'plpgsql';
+./source/sql/postgresql/migration/.svn/text-base/migration-061-062.sql.svn-base:    LANGUAGE plpgsql
+./source/sql/postgresql/migration/.svn/text-base/migration-061-062.sql.svn-base:    LANGUAGE plpgsql
+./source/sql/postgresql/migration/.svn/text-base/migration-065-066.sql.svn-base:$$ LANGUAGE 'plpgsql';
+./source/sql/postgresql/migration/.svn/text-base/migration-065-066.sql.svn-base:$$ LANGUAGE 'plpgsql';
+./source/sql/postgresql/migration/.svn/text-base/migration-065-066.sql.svn-base:$$ LANGUAGE 'plpgsql';
+./source/sql/postgresql/migration/.svn/text-base/migration-075-076.sql.svn-base:$$ LANGUAGE 'plpgsql';
+./source/sql/postgresql/migration/.svn/text-base/migration-075-076.sql.svn-base:$$ LANGUAGE 'plpgsql';
+./source/sql/postgresql/migration/.svn/text-base/migration-075-076.sql.svn-base:$$ LANGUAGE 'plpgsql';
+./source/sql/postgresql/migration/.svn/text-base/migration-075-076.sql.svn-base:$$ LANGUAGE 'plpgsql';
+./source/sql/postgresql/migration/.svn/text-base/migration-075-076.sql.svn-base:$$ LANGUAGE 'plpgsql';
+./source/sql/postgresql/migration/.svn/text-base/migration-077-078.sql.svn-base:$$ LANGUAGE 'plpgsql';
+./source/sql/postgresql/migration/.svn/text-base/migration-077-078.sql.svn-base:$$ LANGUAGE 'plpgsql';
+./source/sql/postgresql/migration/.svn/text-base/migration-077-078.sql.svn-base:$$ LANGUAGE 'plpgsql';
+./source/sql/postgresql/migration/.svn/text-base/migration-077-078.sql.svn-base:$$ LANGUAGE 'plpgsql';
+./source/sql/postgresql/migration/.svn/text-base/migration-077-078.sql.svn-base:$$ LANGUAGE 'plpgsql';
+./source/sql/postgresql/migration/.svn/text-base/migration-077-078.sql.svn-base:$$ LANGUAGE 'plpgsql';
+./source/sql/postgresql/migration/.svn/text-base/migration-077-078.sql.svn-base:$$ LANGUAGE 'plpgsql';
+./source/sql/postgresql/migration/migration-012-013.sql:$$ LANGUAGE 'plpgsql';
+./source/sql/postgresql/migration/migration-013-014.sql:$$ LANGUAGE 'plpgsql';
+./source/sql/postgresql/migration/migration-015-016.sql:$$ LANGUAGE 'plpgsql';
+./source/sql/postgresql/migration/migration-015-016.sql:$$ LANGUAGE 'plpgsql';
+./source/sql/postgresql/migration/migration-015-016.sql:$$ LANGUAGE 'plpgsql';
+./source/sql/postgresql/migration/migration-015-016.sql:$$ LANGUAGE 'plpgsql';
+./source/sql/postgresql/migration/migration-015-016.sql:$$ LANGUAGE 'plpgsql';
+./source/sql/postgresql/migration/migration-015-016.sql:$$ LANGUAGE 'plpgsql';
+./source/sql/postgresql/migration/migration-015-016.sql:$$ LANGUAGE 'plpgsql';
+./source/sql/postgresql/migration/migration-015-016.sql:$$ LANGUAGE 'plpgsql';
+./source/sql/postgresql/migration/migration-015-016.sql:$$ LANGUAGE 'plpgsql';
+./source/sql/postgresql/migration/migration-016-017.sql:$$ LANGUAGE 'plpgsql';
+./source/sql/postgresql/migration/migration-018-019.sql:$$ language 'plpgsql';
+./source/sql/postgresql/migration/migration-022-023.sql:$$ LANGUAGE 'plpgsql';
+./source/sql/postgresql/migration/migration-023-024.sql:$$ LANGUAGE 'plpgsql';
+./source/sql/postgresql/migration/migration-024-025.sql:$$ LANGUAGE 'plpgsql';
+./source/sql/postgresql/migration/migration-025-026.sql:$$ language 'plpgsql';
+./source/sql/postgresql/migration/migration-025-026.sql:$$ language 'plpgsql';
+./source/sql/postgresql/migration/migration-026-027.sql:    LANGUAGE plpgsql;
+./source/sql/postgresql/migration/migration-026-027.sql:    LANGUAGE plpgsql;
+./source/sql/postgresql/migration/migration-026-027.sql:$$ language 'plpgsql';
+./source/sql/postgresql/migration/migration-026-027.sql:$$ language 'plpgsql';
+./source/sql/postgresql/migration/migration-027-028.sql:$$ LANGUAGE 'plpgsql';
+./source/sql/postgresql/migration/migration-028-029.sql:$$ LANGUAGE 'plpgsql';
+./source/sql/postgresql/migration/migration-028-029.sql:$$ LANGUAGE 'plpgsql';
+./source/sql/postgresql/migration/migration-028-029.sql:$$ LANGUAGE 'plpgsql';
+./source/sql/postgresql/migration/migration-029-030.sql:$$ LANGUAGE 'plpgsql';
+./source/sql/postgresql/migration/migration-030-031.sql:$$ LANGUAGE 'plpgsql';
+./source/sql/postgresql/migration/migration-031-032.sql:$$ LANGUAGE 'plpgsql';
+./source/sql/postgresql/migration/migration-033-034.sql:$$ LANGUAGE 'plpgsql';
+./source/sql/postgresql/migration/migration-033-034.sql:$$ language 'plpgsql';
+./source/sql/postgresql/migration/migration-033-034.sql:$$ language 'plpgsql';
+./source/sql/postgresql/migration/migration-033-034.sql:$$ language 'plpgsql';
+./source/sql/postgresql/migration/migration-033-034.sql:$$ language 'plpgsql';
+./source/sql/postgresql/migration/migration-033-034.sql:$$ language 'plpgsql';
+./source/sql/postgresql/migration/migration-033-034.sql:$$ language 'plpgsql';
+./source/sql/postgresql/migration/migration-033-034.sql:$$ language 'plpgsql';
+./source/sql/postgresql/migration/migration-033-034.sql:$$ language 'plpgsql';
+./source/sql/postgresql/migration/migration-033-034.sql:$$ language 'plpgsql';
+./source/sql/postgresql/migration/migration-033-034.sql:$$ language 'plpgsql';
+./source/sql/postgresql/migration/migration-040-041.sql:$$ LANGUAGE 'plpgsql';
+./source/sql/postgresql/migration/migration-040-041.sql:$$ LANGUAGE 'plpgsql';
+./source/sql/postgresql/migration/migration-052-053.sql:$$ LANGUAGE 'plpgsql';
+./source/sql/postgresql/migration/migration-052-053.sql:$$ LANGUAGE 'plpgsql';
+./source/sql/postgresql/migration/migration-053-054.sql:$$ LANGUAGE 'plpgsql';
+./source/sql/postgresql/migration/migration-055-056.sql:$$ LANGUAGE plpgsql;
+./source/sql/postgresql/migration/migration-055-056.sql:$$ LANGUAGE 'plpgsql';
+./source/sql/postgresql/migration/migration-058-059.sql:$$ LANGUAGE 'plpgsql';
+./source/sql/postgresql/migration/migration-061-062.sql:    LANGUAGE plpgsql
+./source/sql/postgresql/migration/migration-061-062.sql:    LANGUAGE plpgsql
+./source/sql/postgresql/migration/migration-065-066.sql:$$ LANGUAGE 'plpgsql';
+./source/sql/postgresql/migration/migration-065-066.sql:$$ LANGUAGE 'plpgsql';
+./source/sql/postgresql/migration/migration-065-066.sql:$$ LANGUAGE 'plpgsql';
+./source/sql/postgresql/migration/migration-075-076.sql:$$ LANGUAGE 'plpgsql';
+./source/sql/postgresql/migration/migration-075-076.sql:$$ LANGUAGE 'plpgsql';
+./source/sql/postgresql/migration/migration-075-076.sql:$$ LANGUAGE 'plpgsql';
+./source/sql/postgresql/migration/migration-075-076.sql:$$ LANGUAGE 'plpgsql';
+./source/sql/postgresql/migration/migration-075-076.sql:$$ LANGUAGE 'plpgsql';
+./source/sql/postgresql/migration/migration-077-078.sql:$$ LANGUAGE 'plpgsql';
+./source/sql/postgresql/migration/migration-077-078.sql:$$ LANGUAGE 'plpgsql';
+./source/sql/postgresql/migration/migration-077-078.sql:$$ LANGUAGE 'plpgsql';
+./source/sql/postgresql/migration/migration-077-078.sql:$$ LANGUAGE 'plpgsql';
+./source/sql/postgresql/migration/migration-077-078.sql:$$ LANGUAGE 'plpgsql';
+./source/sql/postgresql/migration/migration-077-078.sql:$$ LANGUAGE 'plpgsql';
+./source/sql/postgresql/migration/migration-077-078.sql:$$ LANGUAGE 'plpgsql';
+./source/sql/postgresql/migration/migration-078-079.sql:$$ LANGUAGE 'plpgsql';
+./source/sql/postgresql/migration/migration-078-079.sql:$$ LANGUAGE 'plpgsql';
+./source/sql/postgresql/migration/migration-078-079.sql:$$ LANGUAGE 'plpgsql';
+./source/sql/postgresql/migration/migration-078-079.sql:$$ LANGUAGE 'plpgsql';
+./source/sql/postgresql/migration/migration-078-079.sql:$$ LANGUAGE 'plpgsql';
+./sourceTest/java/ch/systemsx/cisd/openbis/generic/server/business/importer/.svn/text-base/DatabaseInstanceImporterTest.java.svn-base:                    + "CREATE PROCEDURAL LANGUAGE plpgsql;\n"
+./sourceTest/java/ch/systemsx/cisd/openbis/generic/server/business/importer/.svn/text-base/DatabaseInstanceImporterTest.java.svn-base:                    + "CREATE PROCEDURAL LANGUAGE plpgsql;\n"
+./sourceTest/java/ch/systemsx/cisd/openbis/generic/server/business/importer/.svn/text-base/DatabaseInstanceImporterTest.java.svn-base:                    + "CREATE PROCEDURAL LANGUAGE plpgsql;\n"
+./sourceTest/java/ch/systemsx/cisd/openbis/generic/server/business/importer/.svn/text-base/DatabaseInstanceImporterTest.java.svn-base:                    + "CREATE PROCEDURAL LANGUAGE plpgsql;\n"
+./sourceTest/java/ch/systemsx/cisd/openbis/generic/server/business/importer/.svn/text-base/DatabaseInstanceImporterTest.java.svn-base:                    + "CREATE PROCEDURAL LANGUAGE plpgsql;\n"
+./sourceTest/java/ch/systemsx/cisd/openbis/generic/server/business/importer/DatabaseInstanceImporterTest.java:                    + "CREATE PROCEDURAL LANGUAGE plpgsql;\n"
+./sourceTest/java/ch/systemsx/cisd/openbis/generic/server/business/importer/DatabaseInstanceImporterTest.java:                    + "CREATE PROCEDURAL LANGUAGE plpgsql;\n"
+./sourceTest/java/ch/systemsx/cisd/openbis/generic/server/business/importer/DatabaseInstanceImporterTest.java:                    + "CREATE PROCEDURAL LANGUAGE plpgsql;\n"
+./sourceTest/java/ch/systemsx/cisd/openbis/generic/server/business/importer/DatabaseInstanceImporterTest.java:                    + "CREATE PROCEDURAL LANGUAGE plpgsql;\n"
+./sourceTest/java/ch/systemsx/cisd/openbis/generic/server/business/importer/DatabaseInstanceImporterTest.java:                    + "CREATE PROCEDURAL LANGUAGE plpgsql;\n"
+./sourceTest/sql/postgresql/018/.svn/text-base/006=database_version_logs.tsv.svn-base:007	source/sql/postgresql/007/schema-007.sql	SUCCESS	2008-01-05 14:51:36.56	-- D:\\\\DDL\\\\postgresql\\\\schema-007.sql\\012--\\012-- Generated for ANSI SQL92 on Thu Aug 23  19:02:15 2007 by Server Generator 10.1.2.6.18\\012-- Post generation PostgreSQL specific Changes:\\012-- \\012--  1. change domain FILE from BIT(32000) to BYTEA\\012--  2. change domain TECH_ID from NUMERIC(20) to BIGINT\\012--  3. Put single quotes around the default value NOW in the create domain statement for the domain TIME_STAMP\\012--     i.e. change CREATE DOMAIN TIME_STAMP AS TIMESTAMP DEFAULT now; to CREATE DOMAIN TIME_STAMP AS TIMESTAMP DEFAULT 'now';\\012--  4. Temporarily not created, due to data quality issues with the master plate layout data\\012--\\012-- ALTER TABLE MOLECULES ADD CONSTRAINT MOLE_BK_UK UNIQUE(SEQUENCE);\\012\\012\\012\\012CREATE DOMAIN DESCRIPTION_80 AS VARCHAR(80);\\012CREATE DOMAIN USER_ID AS VARCHAR(20);\\012CREATE DOMAIN DOUBLE_PRECISION_VALUE AS DOUBLE PRECISION;\\012CREATE DOMAIN FILE_NAME AS VARCHAR(100);\\012CREATE DOMAIN TECH_ID AS BIGINT;\\012CREATE DOMAIN OBJECT_NAME AS VARCHAR(50);\\012CREATE DOMAIN TIME_STAMP AS TIMESTAMP DEFAULT CURRENT_TIMESTAMP;\\012CREATE DOMAIN REAL_VALUE AS REAL;\\012CREATE DOMAIN FILE AS BYTEA;\\012CREATE DOMAIN CODE AS VARCHAR(20);\\012CREATE DOMAIN DESCRIPTION_250 AS VARCHAR(250);\\012CREATE TABLE EXPERIMENT_PROPERTIES  (ID TECH_ID NOT NULL,EXPE_ID TECH_ID NOT NULL,FILE_NAME FILE_NAME NOT NULL,REGISTRATION_TIMESTAMP TIME_STAMP NOT NULL DEFAULT CURRENT_TIMESTAMP,VALUE FILE NOT NULL,VERSION INTEGER NOT NULL,PERS_ID_REGISTERER TECH_ID NOT NULL) ;\\012CREATE TABLE EXPERIMENT_TYPES  (ID TECH_ID NOT NULL,CODE CODE NOT NULL,DESCRIPTION DESCRIPTION_80) ;\\012CREATE TABLE DATA_VALUES  (ID TECH_ID NOT NULL,DATA_ID TECH_ID NOT NULL,SACO_ID TECH_ID NOT NULL,VALUE DOUBLE_PRECISION_VALUE NOT NULL) ;\\012CREATE TABLE PERSONS  (ID TECH_ID NOT NULL,FIRST_NAME VARCHAR(30),LAST_NAME VARCHAR(30),USER_ID USER_ID,EMAIL OBJECT_NAME) ;\\012CREATE TABLE FILE_FORMAT_TYPES  (ID TECH_ID NOT NULL,CODE CODE NOT NULL,DESCRIPTION DESCRIPTION_80) ;\\012CREATE TABLE SAMPLE_INPUTS  (ID TECH_ID NOT NULL,SAMP_ID TECH_ID NOT NULL,PROC_ID TECH_ID NOT NULL) ;\\012CREATE TABLE OBSERVABLE_TYPES  (ID TECH_ID NOT NULL,CODE CODE NOT NULL,DESCRIPTION DESCRIPTION_80) ;\\012CREATE TABLE LOCATOR_TYPES  (ID TECH_ID NOT NULL,CODE CODE NOT NULL,DESCRIPTION DESCRIPTION_80) ;\\012CREATE TABLE SAMPLE_COMPONENTS  (ID TECH_ID NOT NULL,CODE CODE NOT NULL,SAMP_ID TECH_ID NOT NULL) ;\\012CREATE TABLE SAMPLE_TYPES  (ID TECH_ID NOT NULL,CODE CODE NOT NULL,DESCRIPTION DESCRIPTION_80) ;\\012CREATE TABLE ORGANIZATIONS  (ID TECH_ID NOT NULL,CODE CODE NOT NULL) ;\\012CREATE TABLE PROCEDURES  (ID TECH_ID NOT NULL,REGISTRATION_TIMESTAMP TIME_STAMP NOT NULL DEFAULT CURRENT_TIMESTAMP,EXPE_ID TECH_ID NOT NULL,PCTY_ID TECH_ID NOT NULL,PERS_ID TECH_ID) ;\\012CREATE TABLE PROCEDURE_TYPES  (ID TECH_ID NOT NULL,CODE CODE NOT NULL,DESCRIPTION DESCRIPTION_80 NOT NULL) ;\\012CREATE TABLE PROJECTS  (ID TECH_ID NOT NULL,CODE CODE NOT NULL,ORGA_ID TECH_ID NOT NULL) ;\\012CREATE TABLE SAMPLE_COMPONENT_MATERIALS  (ID TECH_ID NOT NULL,SACO_ID TECH_ID NOT NULL,MABA_ID TECH_ID NOT NULL) ;\\012CREATE TABLE EXTERNAL_DATA  (DATA_ID TECH_ID NOT NULL,LOCATION VARCHAR(200) NOT NULL,LOTY_ID TECH_ID NOT NULL,FFTY_ID TECH_ID NOT NULL) ;\\012CREATE TABLE DATA  (ID TECH_ID NOT NULL,REGISTRATION_TIMESTAMP TIME_STAMP NOT NULL DEFAULT CURRENT_TIMESTAMP,OBTY_ID TECH_ID NOT NULL,PROC_ID_ACQUIRED_BY TECH_ID NOT NULL,SAMP_ID_ACQUIRED_FROM TECH_ID,SAMP_ID_DERIVED_FROM TECH_ID) ;\\012CREATE TABLE SAMPLES  (ID TECH_ID NOT NULL,CODE CODE NOT NULL,CONT_ID TECH_ID,PROC_ID TECH_ID,SAMP_ID_TOP TECH_ID,SAMP_ID_GENERATED_FROM TECH_ID,SATY_ID TECH_ID NOT NULL,REGISTRATION_TIMESTAMP TIME_STAMP NOT NULL DEFAULT CURRENT_TIMESTAMP,PERS_ID_REGISTERER TECH_ID NOT NULL) ;\\012CREATE TABLE MATERIAL_TYPES  (ID TECH_ID NOT NULL,CODE CODE NOT NULL,DESCRIPTION DESCRIPTION_80) ;\\012CREATE TABLE MATERIAL_BATCHES  (ID TECH_ID NOT NULL,CODE CODE NOT NULL,AMOUNT REAL_VALUE,MATE_ID TECH_ID NOT NULL,CONT_ID TECH_ID,PROC_ID TECH_ID,REGISTRATION_TIMESTAMP TIME_STAMP NOT NULL DEFAULT CURRENT_TIMESTAMP,PERS_ID_REGISTERER TECH_ID NOT NULL) ;\\012CREATE TABLE MATERIALS  (ID TECH_ID NOT NULL,CODE CODE NOT NULL,DESCRIPTION DESCRIPTION_250,MATY_ID TECH_ID NOT NULL,REGISTRATION_TIMESTAMP TIME_STAMP NOT NULL DEFAULT CURRENT_TIMESTAMP,PERS_ID_REGISTERER TECH_ID NOT NULL) ;\\012CREATE TABLE MOLECULES  (MATE_ID TECH_ID NOT NULL,SEQUENCE VARCHAR(100),ACCESSION_NUMBER OBJECT_NAME,OFF_SET VARCHAR(20),MOLE_ID_INHIBITOR_OF TECH_ID,GENE_SYMBOL CODE) ;\\012CREATE TABLE EXPERIMENTS  (ID TECH_ID NOT NULL,CODE CODE NOT NULL,EXTY_ID TECH_ID NOT NULL,MATE_ID_STUDY_OBJECT TECH_ID,PERS_ID_REGISTERER TECH_ID,REGISTRATION_TIMESTAMP TIME_STAMP NOT NULL DEFAULT CURRENT_TIMESTAMP,DESCRIPTION DESCRIPTION_250,PROJ_ID TECH_ID NOT NULL) ;\\012\\012ALTER TABLE EXPERIMENT_PROPERTIES ADD CONSTRAINT EXPR_PK PRIMARY KEY(ID);\\012ALTER TABLE EXPERIMENT_TYPES ADD CONSTRAINT EXTY_PK PRIMARY KEY(ID);\\012ALTER TABLE DATA_VALUES ADD CONSTRAINT DAVA_PK PRIMARY KEY(ID);\\012ALTER TABLE PERSONS ADD CONSTRAINT PERS_PK PRIMARY KEY(ID);\\012ALTER TABLE FILE_FORMAT_TYPES ADD CONSTRAINT FFTY_PK PRIMARY KEY(ID);\\012ALTER TABLE SAMPLE_INPUTS ADD CONSTRAINT SAIN_PK PRIMARY KEY(ID);\\012ALTER TABLE OBSERVABLE_TYPES ADD CONSTRAINT OBTY_PK PRIMARY KEY(ID);\\012ALTER TABLE LOCATOR_TYPES ADD CONSTRAINT LOTY_PK PRIMARY KEY(ID);\\012ALTER TABLE SAMPLE_COMPONENTS ADD CONSTRAINT SACO_PK PRIMARY KEY(ID);\\012ALTER TABLE SAMPLE_TYPES ADD CONSTRAINT SATY_PK PRIMARY KEY(ID);\\012ALTER TABLE ORGANIZATIONS ADD CONSTRAINT ORGA_PK PRIMARY KEY(ID);\\012ALTER TABLE PROCEDURES ADD CONSTRAINT PROC_PK PRIMARY KEY(ID);\\012ALTER TABLE PROCEDURE_TYPES ADD CONSTRAINT PCTY_PK PRIMARY KEY(ID);\\012ALTER TABLE PROJECTS ADD CONSTRAINT PROJ_PK PRIMARY KEY(ID);\\012ALTER TABLE SAMPLE_COMPONENT_MATERIALS ADD CONSTRAINT SCMA_PK PRIMARY KEY(ID);\\012ALTER TABLE EXTERNAL_DATA ADD CONSTRAINT EXDA_PK PRIMARY KEY(DATA_ID);\\012ALTER TABLE DATA ADD CONSTRAINT DATA_PK PRIMARY KEY(ID);\\012ALTER TABLE SAMPLES ADD CONSTRAINT SAMP_PK PRIMARY KEY(ID);\\012ALTER TABLE MATERIAL_TYPES ADD CONSTRAINT MATY_PK PRIMARY KEY(ID);\\012ALTER TABLE MATERIAL_BATCHES ADD CONSTRAINT MABA_PK PRIMARY KEY(ID);\\012ALTER TABLE MATERIALS ADD CONSTRAINT MATE_PK PRIMARY KEY(ID);\\012ALTER TABLE MOLECULES ADD CONSTRAINT MOLE_PK PRIMARY KEY(MATE_ID);\\012ALTER TABLE EXPERIMENTS ADD CONSTRAINT EXPE_PK PRIMARY KEY(ID);\\012ALTER TABLE EXPERIMENT_PROPERTIES ADD CONSTRAINT EXPR_BK_UK UNIQUE(EXPE_ID,FILE_NAME,VERSION);\\012ALTER TABLE EXPERIMENT_TYPES ADD CONSTRAINT EXTY_BK_UK UNIQUE(CODE);\\012ALTER TABLE DATA_VALUES ADD CONSTRAINT DAVA_BK_UK UNIQUE(DATA_ID,SACO_ID);\\012ALTER TABLE PERSONS ADD CONSTRAINT PERS_BK_UK UNIQUE(USER_ID);\\012ALTER TABLE FILE_FORMAT_TYPES ADD CONSTRAINT FFTY_BK_UK UNIQUE(CODE);\\012ALTER TABLE SAMPLE_INPUTS ADD CONSTRAINT SAIN_BK_UK UNIQUE(SAMP_ID,PROC_ID);\\012ALTER TABLE OBSERVABLE_TYPES ADD CONSTRAINT OBTY_BK_UK UNIQUE(CODE);\\012ALTER TABLE LOCATOR_TYPES ADD CONSTRAINT LOTY_BK_UK UNIQUE(CODE);\\012ALTER TABLE SAMPLE_COMPONENTS ADD CONSTRAINT SACO_BK_UK UNIQUE(CODE,SAMP_ID);\\012ALTER TABLE SAMPLE_TYPES ADD CONSTRAINT SATY_BK_UK UNIQUE(CODE);\\012ALTER TABLE ORGANIZATIONS ADD CONSTRAINT ORGA_BK_UK UNIQUE(CODE);\\012ALTER TABLE PROCEDURE_TYPES ADD CONSTRAINT PCTY_BK_UK UNIQUE(CODE);\\012ALTER TABLE PROJECTS ADD CONSTRAINT PROJ_BK_UK UNIQUE(CODE,ORGA_ID);\\012ALTER TABLE SAMPLE_COMPONENT_MATERIALS ADD CONSTRAINT SCMA_BK_UK UNIQUE(MABA_ID,SACO_ID);\\012ALTER TABLE EXTERNAL_DATA ADD CONSTRAINT EXDA_BK_UK UNIQUE(LOCATION);\\012ALTER TABLE SAMPLES ADD CONSTRAINT SAMP_BK_UK UNIQUE(CODE);\\012ALTER TABLE MATERIAL_TYPES ADD CONSTRAINT MATY_UK UNIQUE(CODE);\\012ALTER TABLE MATERIAL_TYPES ADD CONSTRAINT MATY_BK_UK UNIQUE(CODE);\\012ALTER TABLE MATERIALS ADD CONSTRAINT MATE_BK_UK UNIQUE(CODE);\\012--\\012--  Temporarily not created, due to data quality issues with the master plate layout data\\012--\\012-- ALTER TABLE MOLECULES ADD CONSTRAINT MOLE_BK_UK UNIQUE(SEQUENCE);\\012ALTER TABLE EXPERIMENTS ADD CONSTRAINT EXPE_BK_UK UNIQUE(CODE,PROJ_ID);\\012\\012ALTER TABLE DATA ADD CONSTRAINT DATA_SAMP_ARC_CK CHECK ((samp_id_acquired_from IS NOT NULL \\012and samp_id_derived_from IS NULL) \\012or (samp_id_acquired_from IS NULL \\012and samp_id_derived_from IS NOT NULL)) ;\\012ALTER TABLE EXPERIMENT_PROPERTIES ADD CONSTRAINT EXPR_PERS_FK FOREIGN KEY (PERS_ID_REGISTERER)REFERENCES PERSONS(ID);\\012ALTER TABLE EXPERIMENT_PROPERTIES ADD CONSTRAINT EXPR_EXPE_FK FOREIGN KEY (EXPE_ID)REFERENCES EXPERIMENTS(ID);\\012ALTER TABLE DATA_VALUES ADD CONSTRAINT DAVA_DATA_FK FOREIGN KEY (DATA_ID)REFERENCES DATA(ID);\\012ALTER TABLE DATA_VALUES ADD CONSTRAINT DAVA_SACO_FK FOREIGN KEY (SACO_ID)REFERENCES SAMPLE_COMPONENTS(ID);\\012ALTER TABLE SAMPLE_INPUTS ADD CONSTRAINT SAIN_PROC_FK FOREIGN KEY (PROC_ID)REFERENCES PROCEDURES(ID);\\012ALTER TABLE SAMPLE_INPUTS ADD CONSTRAINT SAIN_SAMP_FK FOREIGN KEY (SAMP_ID)REFERENCES SAMPLES(ID);\\012ALTER TABLE SAMPLE_COMPONENTS ADD CONSTRAINT SACO_SAMP_FK FOREIGN KEY (SAMP_ID)REFERENCES SAMPLES(ID);\\012ALTER TABLE PROCEDURES ADD CONSTRAINT PROC_PCTY_FK FOREIGN KEY (PCTY_ID)REFERENCES PROCEDURE_TYPES(ID);\\012ALTER TABLE PROCEDURES ADD CONSTRAINT PROC_PERS_FK FOREIGN KEY (PERS_ID)REFERENCES PERSONS(ID);\\012ALTER TABLE PROCEDURES ADD CONSTRAINT PROC_EXPE_FK FOREIGN KEY (EXPE_ID)REFERENCES EXPERIMENTS(ID);\\012ALTER TABLE PROJECTS ADD CONSTRAINT PROJ_ORGA_FK FOREIGN KEY (ORGA_ID)REFERENCES ORGANIZATIONS(ID);\\012ALTER TABLE SAMPLE_COMPONENT_MATERIALS ADD CONSTRAINT SCMA_MABA_FK FOREIGN KEY (MABA_ID)REFERENCES MATERIAL_BATCHES(ID);\\012ALTER TABLE SAMPLE_COMPONENT_MATERIALS ADD CONSTRAINT SCMA_SACO_FK FOREIGN KEY (SACO_ID)REFERENCES SAMPLE_COMPONENTS(ID);\\012ALTER TABLE EXTERNAL_DATA ADD CONSTRAINT EXDA_DATA_FK FOREIGN KEY (DATA_ID)REFERENCES DATA(ID);\\012ALTER TABLE EXTERNAL_DATA ADD CONSTRAINT EXDA_LOTY_FK FOREIGN KEY (LOTY_ID)REFERENCES LOCATOR_TYPES(ID);\\012ALTER TABLE EXTERNAL_DATA ADD CONSTRAINT EXDA_FFTY_FK FOREIGN KEY (FFTY_ID)REFERENCES FILE_FORMAT_TYPES(ID);\\012ALTER TABLE DATA ADD CONSTRAINT DATA_SAMP_DERIVED_FROM_FK FOREIGN KEY (SAMP_ID_DERIVED_FROM)REFERENCES SAMPLES(ID);\\012ALTER TABLE DATA ADD CONSTRAINT DATA_SAMP_FK FOREIGN KEY (SAMP_ID_ACQUIRED_FROM)REFERENCES SAMPLES(ID);\\012ALTER TABLE DATA ADD CONSTRAINT DATA_PROC_FK FOREIGN KEY (PROC_ID_ACQUIRED_BY)REFERENCES PROCEDURES(ID);\\012ALTER TABLE DATA ADD CONSTRAINT DATA_OBTY_FK FOREIGN KEY (OBTY_ID)REFERENCES OBSERVABLE_TYPES(ID);\\012ALTER TABLE SAMPLES ADD CONSTRAINT SAMP_PERS_FK FOREIGN KEY (PERS_ID_REGISTERER)REFERENCES PERSONS(ID);\\012ALTER TABLE SAMPLES ADD CONSTRAINT SAMP_PROC_FK FOREIGN KEY (PROC_ID)REFERENCES PROCEDURES(ID);\\012ALTER TABLE SAMPLES ADD CONSTRAINT SAMP_SAMP_FK_GENERATED_FROM FOREIGN KEY (SAMP_ID_GENERATED_FROM)REFERENCES SAMPLES(ID);\\012ALTER TABLE SAMPLES ADD CONSTRAINT SAMP_SAMP_FK_TOP FOREIGN KEY (SAMP_ID_TOP)REFERENCES SAMPLES(ID);\\012ALTER TABLE SAMPLES ADD CONSTRAINT SAMP_SATY_FK FOREIGN KEY (SATY_ID)REFERENCES SAMPLE_TYPES(ID);\\012ALTER TABLE MATERIAL_BATCHES ADD CONSTRAINT MABA_PERS_FK FOREIGN KEY (PERS_ID_REGISTERER)REFERENCES PERSONS(ID);\\012ALTER TABLE MATERIAL_BATCHES ADD CONSTRAINT MABA_MATE_FK FOREIGN KEY (MATE_ID)REFERENCES MATERIALS(ID);\\012ALTER TABLE MATERIAL_BATCHES ADD CONSTRAINT MABA_PROC_FK FOREIGN KEY (PROC_ID)REFERENCES PROCEDURES(ID);\\012ALTER TABLE MATERIALS ADD CONSTRAINT MATE_MATY_FK FOREIGN KEY (MATY_ID)REFERENCES MATERIAL_TYPES(ID);\\012ALTER TABLE MATERIALS ADD CONSTRAINT MATE_PERS_FK FOREIGN KEY (PERS_ID_REGISTERER)REFERENCES PERSONS(ID);\\012ALTER TABLE MOLECULES ADD CONSTRAINT MOLE_MATE_FK FOREIGN KEY (MATE_ID)REFERENCES MATERIALS(ID);\\012ALTER TABLE MOLECULES ADD CONSTRAINT MOLE_MOLE_FK FOREIGN KEY (MOLE_ID_INHIBITOR_OF)REFERENCES MOLECULES(MATE_ID);\\012ALTER TABLE EXPERIMENTS ADD CONSTRAINT EXPE_MATE_FK FOREIGN KEY (MATE_ID_STUDY_OBJECT)REFERENCES MATERIALS(ID);\\012ALTER TABLE EXPERIMENTS ADD CONSTRAINT EXPE_EXTY_FK FOREIGN KEY (EXTY_ID)REFERENCES EXPERIMENT_TYPES(ID);\\012ALTER TABLE EXPERIMENTS ADD CONSTRAINT EXPE_PERS_FK FOREIGN KEY (PERS_ID_REGISTERER)REFERENCES PERSONS(ID);\\012ALTER TABLE EXPERIMENTS ADD CONSTRAINT EXPE_PROJ_FK FOREIGN KEY (PROJ_ID)REFERENCES PROJECTS(ID);\\012\\012\\012\\012--  Creating Sequences\\012\\012CREATE SEQUENCE EXPERIMENT_PROPERTY_ID_SEQ;\\012\\012CREATE SEQUENCE PROCEDURE_TYPE_ID_SEQ;\\012\\012CREATE SEQUENCE SAMPLE_INPUT_ID_SEQ;\\012\\012CREATE SEQUENCE SAMPLE_TYPE_ID_SEQ;\\012\\012CREATE SEQUENCE LOCATOR_TYPE_ID_SEQ;\\012\\012CREATE SEQUENCE SAMPLE_ID_SEQ;\\012\\012CREATE SEQUENCE EXPERIMENT_ID_SEQ;\\012\\012CREATE SEQUENCE MATERIAL_BATCH_ID_SEQ;\\012\\012CREATE SEQUENCE OBSERVABLE_TYPE_ID_SEQ;\\012\\012CREATE SEQUENCE SAMPLE_COMPONENT_ID_SEQ;\\012\\012CREATE SEQUENCE MATERIAL_ID_SEQ;\\012\\012CREATE SEQUENCE DATA_ID_SEQ;\\012\\012--  Creating Sequence for the SAMPLE_COMPONENT_MATERIALS table (standard naming convention was too long)\\012CREATE SEQUENCE SCMA_ID_SEQ;\\012\\012CREATE SEQUENCE PROCEDURE_ID_SEQ;\\012\\012CREATE SEQUENCE FILE_FORMAT_TYPE_ID_SEQ;\\012\\012CREATE SEQUENCE MATERIAL_TYPE_ID_SEQ;\\012\\012CREATE SEQUENCE EXPERIMENT_TYPE_ID_SEQ;\\012\\012CREATE SEQUENCE PERSON_ID_SEQ;\\012\\012CREATE SEQUENCE ORGANIZATION_ID_SEQ;\\012\\012CREATE SEQUENCE PROJECT_ID_SEQ;\\012\\012CREATE SEQUENCE DATA_VALUE_ID_SEQ;\\012\\012\\012\\012/*\\012   Trigger Section\\012   ===============*/\\012\\012CREATE OR REPLACE FUNCTION br001_crtl_plate_chk() RETURNS trigger AS $br001_crtl_plate_chk$\\012DECLARE\\012   cnt           INTEGER;\\012   v_cell_plate  CODE;\\012BEGIN\\012\\012   select code into v_cell_plate from sample_types where id  = NEW.saty_id;\\012\\012   -- Check if the sample is of type "Cell Plate"\\012   if v_cell_plate = 'CELL PLATE' then\\012\\012      -- Check that a Control Plate exists before registering the Cell Plate\\012      select count(*) into cnt from samples s, sample_types st where s.saty_id = st.id and st.code = 'CONTROL LAYOUT';\\011 \\012      IF cnt = 0 THEN\\012\\011\\011 -- Doens't make sense, so comment it out\\012         -- RAISE EXCEPTION 'A Control Plate must exist before you can register Cell Plate: %', NEW.code;\\012      END IF;\\012\\012   end if;\\012\\012   RETURN NEW;\\012\\012END;\\012$br001_crtl_plate_chk$ LANGUAGE plpgsql;\\012\\012\\012CREATE TRIGGER br001_crtl_plate_chk BEFORE INSERT ON samples\\012    FOR EACH ROW EXECUTE PROCEDURE br001_crtl_plate_chk();\\012	\N
+./sourceTest/sql/postgresql/018/.svn/text-base/006=database_version_logs.tsv.svn-base:013	source/sql/postgresql/migration/migration-012-013.sql	SUCCESS	2008-05-09 10:11:20.487	----------------------------------------------------------------------------------------------\\012--  File: migration-012-013.sql\\012--\\012-- \\012--  This script enables the migration of the database schema from 012 to 013.\\012-- \\012--  Update History\\012--\\012--\\012--\\011Who\\011\\011\\011\\011\\011\\011\\011When\\011\\011\\011\\011What\\012--\\011---\\011\\011\\011\\011\\011\\011\\011----\\011\\011\\011\\011----\\012--\\011Bernd Rinn\\011\\0112008-01-04\\011Initial Version - add support for invalidations and material type BACTERIUM \\012--\\011Bernd Rinn\\011\\0112008-01-05\\011Add material type COMPOUND and material type property type entries for the new material types \\012--  \\012----------------------------------------------------------------------------------------------\\012\\012------------------------------------------------------------------------------------\\012--  Purpose:  Create function RENAME_SEQUENCE() that is required for renaming the sequences belonging to tables\\012------------------------------------------------------------------------------------\\012\\012CREATE FUNCTION RENAME_SEQUENCE(OLD_NAME VARCHAR, NEW_NAME VARCHAR) RETURNS INTEGER AS $$\\012DECLARE\\012  CURR_SEQ_VAL   INTEGER;\\012BEGIN\\012  SELECT INTO CURR_SEQ_VAL NEXTVAL(OLD_NAME);\\012  EXECUTE 'CREATE SEQUENCE ' || NEW_NAME || ' START WITH ' || CURR_SEQ_VAL;\\012  EXECUTE 'DROP SEQUENCE ' || OLD_NAME;\\012  RETURN CURR_SEQ_VAL;\\012END;\\012$$ LANGUAGE 'plpgsql';\\012\\012\\012------------------------------------------------------------------------------------\\012--  Purpose:  Add table INVALIDATIONS to store invalidations\\012------------------------------------------------------------------------------------\\012\\012CREATE TABLE INVALIDATIONS (ID TECH_ID NOT NULL,PERS_ID_REGISTERER TECH_ID NOT NULL,REGISTRATION_TIMESTAMP TIME_STAMP NOT NULL DEFAULT CURRENT_TIMESTAMP,REASON DESCRIPTION_250);\\012ALTER TABLE INVALIDATIONS ADD CONSTRAINT INVA_PK PRIMARY KEY(ID);\\012ALTER TABLE INVALIDATIONS ADD CONSTRAINT INVA_PERS_FK FOREIGN KEY (PERS_ID_REGISTERER) REFERENCES PERSONS(ID);\\012CREATE SEQUENCE INVALIDATION_ID_SEQ;\\012CREATE INDEX INVA_PERS_FK_I ON INVALIDATIONS (PERS_ID_REGISTERER);\\012\\012------------------------------------------------------------------------------------\\012--  Purpose:  Add column INVA_ID to table SAMPLES in order to allow invalidation of samples  \\012------------------------------------------------------------------------------------\\012\\012ALTER TABLE SAMPLES ADD INVA_ID TECH_ID;\\012ALTER TABLE SAMPLES ADD CONSTRAINT SAMP_INVA_FK FOREIGN KEY (INVA_ID) REFERENCES INVALIDATIONS(ID);\\012CREATE INDEX SAMP_INVA_FK_I ON SAMPLES (INVA_ID);\\012\\012\\012------------------------------------------------------------------------------------\\012--  Purpose:  Rename table EXPERIMENT_PROPERTIES TO EXPERIMENT_ATTACHMENTS  \\012------------------------------------------------------------------------------------\\012\\012ALTER TABLE EXPERIMENT_PROPERTIES DROP CONSTRAINT EXPR_PK;\\012ALTER TABLE EXPERIMENT_PROPERTIES DROP CONSTRAINT EXPR_BK_UK;\\012ALTER TABLE EXPERIMENT_PROPERTIES DROP CONSTRAINT EXPR_EXPE_FK;\\012ALTER TABLE EXPERIMENT_PROPERTIES DROP CONSTRAINT EXPR_PERS_FK;\\012\\012ALTER TABLE EXPERIMENT_PROPERTIES RENAME TO EXPERIMENT_ATTACHMENTS;\\012ALTER INDEX EXPR_EXPE_FK_I RENAME TO EXAT_EXPE_FK_I;\\012ALTER INDEX EXPR_PERS_FK_I RENAME TO EXAT_PERS_FK_I;\\012SELECT RENAME_SEQUENCE('EXPERIMENT_PROPERTY_ID_SEQ', 'EXPERIMENT_ATTACHMENT_ID_SEQ');\\012\\012ALTER TABLE EXPERIMENT_ATTACHMENTS ADD CONSTRAINT EXAT_PK PRIMARY KEY(ID);\\012ALTER TABLE EXPERIMENT_ATTACHMENTS ADD CONSTRAINT EXAT_BK_UK UNIQUE(EXPE_ID,FILE_NAME,VERSION);\\012ALTER TABLE EXPERIMENT_ATTACHMENTS ADD CONSTRAINT EXAT_EXPE_FK FOREIGN KEY (EXPE_ID) REFERENCES EXPERIMENTS(ID);\\012ALTER TABLE EXPERIMENT_ATTACHMENTS ADD CONSTRAINT EXAT_PERS_FK FOREIGN KEY (PERS_ID_REGISTERER) REFERENCES PERSONS(ID);\\012\\012\\012------------------------------------------------------------------------------------\\012--  Purpose:  Add the material type BACTERIUM\\012------------------------------------------------------------------------------------\\012\\012insert into material_types\\012(id\\012,code\\012,description)\\012values \\012(nextval('MATERIAL_TYPE_ID_SEQ')\\012,'BACTERIUM'\\012,'Bacterium'\\012);\\012\\012------------------------------------------------------------------------------------\\012--  Purpose:  Add the material type COMPOUND\\012------------------------------------------------------------------------------------\\012\\012insert into material_types\\012(id\\012,code\\012,description)\\012values \\012(nextval('MATERIAL_TYPE_ID_SEQ')\\012,'COMPOUND'\\012,'Compound'\\012);\\012\\012------------------------------------------------------------------------------------\\012--  Purpose:  Insert an initial data set into the table MATERIAL_TYPE_PROPERTY_TYPES\\012------------------------------------------------------------------------------------\\012\\012   -----------------------\\012   --  Material Type BACTERIUM\\012   -----------------------\\012\\012insert into material_type_property_types\\012(   id\\012   ,maty_id\\012   ,prty_id\\012   ,is_mandatory\\012   ,pers_id_registerer\\012   )\\012values \\012   (nextval('MTPT_ID_SEQ')\\012   ,(select id from material_types where code = 'BACTERIUM')\\012   ,(select id from property_types where code = 'DESCRIPTION')\\012   ,true\\012   ,(select id from persons where user_id ='system')\\012);\\012\\012   -----------------------\\012   --  Material Type COMPOUND\\012   -----------------------\\012\\012insert into material_type_property_types\\012(   id\\012   ,maty_id\\012   ,prty_id\\012   ,is_mandatory\\012   ,pers_id_registerer\\012   )\\012values \\012   (nextval('MTPT_ID_SEQ')\\012   ,(select id from material_types where code = 'COMPOUND')\\012   ,(select id from property_types where code = 'DESCRIPTION')\\012   ,true\\012   ,(select id from persons where user_id ='system')\\012);\\012\\012\\012------------------------------------------------------------------------------------\\012--  Purpose:  Change according to naming convention for CODEs\\012------------------------------------------------------------------------------------\\012\\012update procedure_types set code='DATA_ACQUISITION' where code='DATA ACQUISITION';\\012update procedure_types set code='IMAGE_ANALYSIS' where code='IMAGE ANALYSIS';\\012update locator_types set code='RELATIVE_LOCATION' where code='RELATIVE LOCATION';\\012update sample_types set code='MASTER_PLATE' where code='MASTER PLATE';\\012update sample_types set code='DILUTION_PLATE' where code='DILUTION PLATE';\\012update sample_types set code='CELL_PLATE' where code='CELL PLATE';\\012update sample_types set code='REINFECT_PLATE' where code='REINFECT PLATE';\\012update sample_types set description='Re-infection Plate' where code='REINFECT_PLATE';\\012update sample_types set code='CONTROL_LAYOUT' where code='CONTROL LAYOUT';\\012	\N
+./sourceTest/sql/postgresql/018/.svn/text-base/006=database_version_logs.tsv.svn-base:014	source/sql/postgresql/migration/migration-013-014.sql	SUCCESS	2008-05-09 10:11:22.523	----------------------------------------------------------------------------------------------\\012--  File: migration-013-014.sql\\012--\\012-- \\012--  This script enables the migration of the database schema from 013 to 014.\\012-- \\012--  Update History\\012--\\012--\\012--\\011Who\\011\\011\\011When\\011\\011What\\012--\\011---\\011\\011\\011----\\011\\011----\\012--\\011Charles Ramin-Wright\\0112008-01-29\\011Initial Version \\012--  \\012----------------------------------------------------------------------------------------------\\012\\012--=================================\\012-- New Tables and related objects\\012--=================================\\012\\012------------------------------------------------------------------------------------\\012--  Purpose:  Add tables CONTROLLED_VOCABULARIES and CONTROLLED_VOCABULARY_TERMS\\012------------------------------------------------------------------------------------\\012\\012CREATE TABLE CONTROLLED_VOCABULARIES (ID TECH_ID NOT NULL,CODE CODE NOT NULL,DESCRIPTION DESCRIPTION_80,REGISTRATION_TIMESTAMP TIME_STAMP NOT NULL DEFAULT CURRENT_TIMESTAMP,PERS_ID TECH_ID NOT NULL);\\012CREATE TABLE CONTROLLED_VOCABULARY_TERMS (ID TECH_ID NOT NULL,CODE OBJECT_NAME NOT NULL,REGISTRATION_TIMESTAMP TIME_STAMP NOT NULL DEFAULT CURRENT_TIMESTAMP,COVO_ID TECH_ID NOT NULL,PERS_ID TECH_ID NOT NULL);\\012\\012\\012-- Creating primary key constraints\\012\\012ALTER TABLE CONTROLLED_VOCABULARIES ADD CONSTRAINT COVO_PK PRIMARY KEY(ID);\\012ALTER TABLE CONTROLLED_VOCABULARY_TERMS ADD CONSTRAINT CVTE_PK PRIMARY KEY(ID);\\012\\012-- Creating unique constraints\\012\\012ALTER TABLE CONTROLLED_VOCABULARIES ADD CONSTRAINT COVO_BK_UK UNIQUE(CODE);\\012ALTER TABLE CONTROLLED_VOCABULARY_TERMS ADD CONSTRAINT CVTE_BK_UK UNIQUE(CODE,COVO_ID);\\012\\012-- Creating foreign key constraints\\012\\012ALTER TABLE CONTROLLED_VOCABULARIES ADD CONSTRAINT COVO_PERS_FK FOREIGN KEY (PERS_ID) REFERENCES PERSONS(ID);\\012ALTER TABLE CONTROLLED_VOCABULARY_TERMS ADD CONSTRAINT CVTE_COVO_FK FOREIGN KEY (COVO_ID) REFERENCES CONTROLLED_VOCABULARIES(ID);\\012ALTER TABLE CONTROLLED_VOCABULARY_TERMS ADD CONSTRAINT CVTE_PERS_FK FOREIGN KEY (PERS_ID) REFERENCES PERSONS(ID);\\012\\012-- Creating sequences\\012\\012CREATE SEQUENCE CONTROLLED_VOCABULARY_ID_SEQ;\\012CREATE SEQUENCE CVTE_ID_SEQ;\\012\\012\\012-- Creating indexes\\012\\012CREATE INDEX COVO_PERS_FK_I ON CONTROLLED_VOCABULARIES (PERS_ID);\\012CREATE INDEX CVTE_COVO_FK_I ON CONTROLLED_VOCABULARY_TERMS (COVO_ID);\\012CREATE INDEX CVTE_PERS_FK_I ON CONTROLLED_VOCABULARY_TERMS (PERS_ID);\\012\\012\\012--====================================\\012-- Modifications of existing objects\\012--====================================\\012\\012---------------------------------------------------------------------------------------------------\\012--  Purpose:  Add column INVA_ID to table EXPERIMENTS in order to allow invalidation of experiments\\012---------------------------------------------------------------------------------------------------\\012\\012ALTER TABLE EXPERIMENTS ADD INVA_ID TECH_ID;\\012ALTER TABLE EXPERIMENTS ADD CONSTRAINT EXPE_INVA_FK FOREIGN KEY (INVA_ID) REFERENCES INVALIDATIONS(ID);\\012CREATE INDEX EXPE_INVA_FK_I ON EXPERIMENTS (INVA_ID);\\012\\012------------------------------------------------------------------------------------\\012--  Purpose:  Add column SAMP_ID_CONTROL_LAYOUT to table SAMPLES in order to allow \\012--            the association of a sample of type CONTROL_LAYOUT to samples\\012------------------------------------------------------------------------------------\\012\\012ALTER TABLE SAMPLES ADD SAMP_ID_CONTROL_LAYOUT TECH_ID;\\012ALTER TABLE SAMPLES ADD CONSTRAINT SAMP_SAMP_FK_CONTROL_LAYOUT FOREIGN KEY (SAMP_ID_CONTROL_LAYOUT) REFERENCES SAMPLES(ID);\\012CREATE INDEX SAMP_SAMP_FK_I_CONTROL_LAYOUT ON SAMPLES (SAMP_ID_CONTROL_LAYOUT);\\012\\012\\012--------------------------------------------------------------\\012--  Purpose:  Add column CVTE_ID to table MATERIAL_PROPERTIES \\012--------------------------------------------------------------\\012ALTER TABLE MATERIAL_PROPERTIES ADD CVTE_ID TECH_ID;\\012ALTER TABLE MATERIAL_PROPERTIES ADD CONSTRAINT MAPR_CVTE_FK FOREIGN KEY (CVTE_ID) REFERENCES CONTROLLED_VOCABULARY_TERMS(ID);\\012CREATE INDEX MAPR_CVTE_FK_I ON MATERIAL_PROPERTIES (CVTE_ID);\\012\\012--------------------------------------------------------------\\012--  Purpose:  Change column VALUE from mandatory to optional\\012--------------------------------------------------------------\\012ALTER TABLE MATERIAL_PROPERTIES ALTER VALUE DROP NOT NULL;\\012\\012-- Creating check constraints\\012\\012ALTER TABLE MATERIAL_PROPERTIES ADD CONSTRAINT VALUE_OR_CVTE_ID CHECK ((value IS NOT NULL and cvte_id IS NULL) or (value IS NULL and cvte_id IS NOT NULL));\\012\\012\\012--------------------------------------------------------------\\012--  Purpose:  Add column COVO_ID to table PROPERTY_TYPES  \\012--------------------------------------------------------------\\012ALTER TABLE PROPERTY_TYPES ADD COVO_ID TECH_ID;\\012ALTER TABLE PROPERTY_TYPES ADD CONSTRAINT PRTY_COVO_FK FOREIGN KEY (COVO_ID) REFERENCES CONTROLLED_VOCABULARIES(ID);\\012CREATE INDEX PRTY_COVO_FK_I ON PROPERTY_TYPES (COVO_ID);\\012\\012\\012------------------------------------------------------------------------------------\\012--  Purpose:  Create trigger CONTROLLED_VOCABULARY_CHECK \\012------------------------------------------------------------------------------------\\012\\012CREATE OR REPLACE FUNCTION CONTROLLED_VOCABULARY_CHECK() RETURNS trigger AS $$\\012DECLARE\\012   cnt     INTEGER;\\012   v_code  CODE;\\012BEGIN\\012\\012   select code into v_code from data_types where id  = NEW.daty_id;\\012\\012   -- Check if the data is of type "CONTROLLEDVOCABULARY"\\012   if v_code = 'CONTROLLEDVOCABULARY' then\\012      if NEW.covo_id IS NULL then\\012         RAISE EXCEPTION 'Insert/Update of Property Type (Code: %) failed, as its Data Type is CONTROLLEDVOCABULARY, but it is not linked to a Controlled Vocabulary.', NEW.code;\\012      end if;\\012   end if;\\012\\012   RETURN NEW;\\012\\012END;\\012$$ LANGUAGE 'plpgsql';\\012\\012\\012CREATE TRIGGER CONTROLLED_VOCABULARY_CHECK BEFORE INSERT OR UPDATE ON PROPERTY_TYPES\\012    FOR EACH ROW EXECUTE PROCEDURE CONTROLLED_VOCABULARY_CHECK();\\012\\012\\012--====================================\\012-- Deletion of existing objects\\012--====================================\\012\\012drop trigger br001_crtl_plate_chk on samples;\\012drop function br001_crtl_plate_chk();\\012\\012\\012--====================================\\012-- Add Master Data\\012--====================================\\012\\012-----------------------------------------------------------------------------------\\012--  Purpose:  Insert into the table DATA_TYPES\\012--\\012--            Create the data type CONTROLLEDVOCABULARY.\\012-----------------------------------------------------------------------------------\\012insert into data_types\\012(id\\012,code\\012,description)\\012values \\012(nextval('DATA_TYPE_ID_SEQ')\\012,'CONTROLLEDVOCABULARY'\\012,'Controlled Vocabulary'\\012);\\012\\012--==========================================\\012--\\012--   Data Migration\\012--\\012--==========================================\\012\\012-----------------------------------------------------------------------------------\\012--  Purpose:  Migrate the CONTROL_LAYOUTs from the SAMPLE_INPUTS table \\012--            to the foreign key SAMP_SAMP_FK_CONTROL_LAYOUT in the SAMPLES table\\012--\\012--            This results in having all CONTROL_LAYOUTs being directly linked \\012--            to CELL_PLATEs.            \\012-----------------------------------------------------------------------------------\\012\\012UPDATE samples cell_plate\\012   SET samp_id_control_layout = \\012          (select control_layout.samp_id\\012           from   sample_inputs control_layout inner join samples s \\012           on     control_layout.samp_id = s.id\\012           where  s.saty_id = (select id from sample_types where code = 'CONTROL_LAYOUT')\\012           and    proc_id = (\\012              select  proc_id\\012              from sample_inputs cp\\012              where cp.samp_id = cell_plate.id))\\012   WHERE saty_id = (select id from sample_types where code = 'CELL_PLATE')\\012   and   id = (select distinct (samp_id)\\012                  from   sample_inputs sain inner join samples s2 \\012                  on  sain.samp_id = cell_plate.id)\\012;\\012\\012-----------------------------------------------------------------------------------\\012--   Delete the CONTROL LAYOUTs from the SAMPLE_INPUTS table\\012-----------------------------------------------------------------------------------\\012\\012delete from sample_inputs\\012where  id in (select si.id \\012              from   sample_inputs si inner join samples s \\012              on     si.samp_id = s.id\\012              where  s.saty_id = (select id from sample_types where code = 'CONTROL_LAYOUT')\\012              )\\012;\\012\\012	\N
+./sourceTest/sql/postgresql/018/.svn/text-base/006=database_version_logs.tsv.svn-base:016	source/sql/postgresql/migration/migration-015-016.sql	SUCCESS	2008-05-09 10:12:52.062	----------------------------------------------------------------------------------------------\\012--  File: migration-015-016.sql\\012--\\012-- \\012--  This script enables the migration of the database schema from 015 to 016.\\012-- \\012--  Update History\\012--\\012--\\012--\\011Who\\011\\011\\011When\\011\\011What\\012--\\011---\\011\\011\\011----\\011\\011----\\012--\\011Bernd Rinn\\0112008-03-22\\011Initial Version \\012--  \\012----------------------------------------------------------------------------------------------\\012\\012\\012--=================================\\012-- New Domains\\012--=================================\\012\\012-----------------------------------------------------------------------------------\\012--  Purpose:  Change all CODE columns to LONG_CODE, then re-create DOMAIN CODE identical to LONG_CODE\\012--  and change LONG_CODE columns back to the (new) CODE \\012-----------------------------------------------------------------------------------\\012\\012-- First step: create new domain LONG_CODE\\012CREATE DOMAIN LONG_CODE AS VARCHAR(40);\\012\\012-- Second step: change all CODE to LONG_CODE\\012ALTER TABLE CONTROLLED_VOCABULARIES ALTER COLUMN CODE TYPE LONG_CODE;\\012ALTER TABLE DATA_TYPES ALTER COLUMN CODE TYPE LONG_CODE;\\012ALTER TABLE EXPERIMENTS ALTER COLUMN CODE TYPE LONG_CODE;\\012ALTER TABLE EXPERIMENT_TYPES ALTER COLUMN CODE TYPE LONG_CODE;\\012ALTER TABLE FILE_FORMAT_TYPES ALTER COLUMN CODE TYPE LONG_CODE;\\012ALTER TABLE LOCATOR_TYPES ALTER COLUMN CODE TYPE LONG_CODE;\\012ALTER TABLE MATERIALS ALTER COLUMN CODE TYPE LONG_CODE;\\012ALTER TABLE MATERIAL_BATCHES ALTER COLUMN CODE TYPE LONG_CODE;\\012ALTER TABLE MATERIAL_TYPES ALTER COLUMN CODE TYPE LONG_CODE;\\012ALTER TABLE OBSERVABLE_TYPES ALTER COLUMN CODE TYPE LONG_CODE;\\012ALTER TABLE ORGANIZATIONS ALTER COLUMN CODE TYPE LONG_CODE;\\012ALTER TABLE PROCEDURE_TYPES ALTER COLUMN CODE TYPE LONG_CODE;\\012ALTER TABLE PROJECTS ALTER COLUMN CODE TYPE LONG_CODE;\\012ALTER TABLE PROPERTY_TYPES ALTER COLUMN CODE TYPE LONG_CODE;\\012ALTER TABLE SAMPLES ALTER COLUMN CODE TYPE LONG_CODE;\\012ALTER TABLE SAMPLE_COMPONENTS ALTER COLUMN CODE TYPE LONG_CODE;\\012ALTER TABLE SAMPLE_TYPES ALTER COLUMN CODE TYPE LONG_CODE;\\012\\012-- Third step: re-create CODE as VARCHAR(40)\\012DROP DOMAIN CODE;\\012CREATE DOMAIN CODE AS VARCHAR(40);\\012\\012-- Forth step: change all LONG_CODE columns back to CODE\\012ALTER TABLE CONTROLLED_VOCABULARIES ALTER COLUMN CODE TYPE CODE;\\012ALTER TABLE DATA_TYPES ALTER COLUMN CODE TYPE CODE;\\012ALTER TABLE EXPERIMENTS ALTER COLUMN CODE TYPE CODE;\\012ALTER TABLE EXPERIMENT_TYPES ALTER COLUMN CODE TYPE CODE;\\012ALTER TABLE FILE_FORMAT_TYPES ALTER COLUMN CODE TYPE CODE;\\012ALTER TABLE LOCATOR_TYPES ALTER COLUMN CODE TYPE CODE;\\012ALTER TABLE MATERIALS ALTER COLUMN CODE TYPE CODE;\\012ALTER TABLE MATERIAL_BATCHES ALTER COLUMN CODE TYPE CODE;\\012ALTER TABLE MATERIAL_TYPES ALTER COLUMN CODE TYPE CODE;\\012ALTER TABLE OBSERVABLE_TYPES ALTER COLUMN CODE TYPE CODE;\\012ALTER TABLE ORGANIZATIONS ALTER COLUMN CODE TYPE CODE;\\012ALTER TABLE PROCEDURE_TYPES ALTER COLUMN CODE TYPE CODE;\\012ALTER TABLE PROJECTS ALTER COLUMN CODE TYPE CODE;\\012ALTER TABLE PROPERTY_TYPES ALTER COLUMN CODE TYPE CODE;\\012ALTER TABLE SAMPLES ALTER COLUMN CODE TYPE CODE;\\012ALTER TABLE SAMPLE_COMPONENTS ALTER COLUMN CODE TYPE CODE;\\012ALTER TABLE SAMPLE_TYPES ALTER COLUMN CODE TYPE CODE;\\012\\012-- Fifth step: drop domain LONG_CODE\\012DROP DOMAIN LONG_CODE;\\012\\012-----------------------------------------------------------------------------------\\012--  Purpose:  Create new domain TIME_STAMP_DFL and change current users of TIME_STAMP to TIME_STAMP_DFL\\012--  This adds time zone information and allows for a clean separation between registration time stamps\\012--  which should have a default of CURRENT_TIMESTAMP and other time stamps which should not. \\012-----------------------------------------------------------------------------------\\012\\012-- First step: create new domain TIME_STAMP_DFL\\012CREATE DOMAIN TIME_STAMP_DFL AS TIMESTAMP WITH TIME ZONE NOT NULL DEFAULT CURRENT_TIMESTAMP;\\012\\012-- Second step: change all TIME_STAMP columns to TIME_STAMP_DFL\\012ALTER TABLE CONTROLLED_VOCABULARIES ALTER COLUMN REGISTRATION_TIMESTAMP TYPE TIME_STAMP_DFL;\\012ALTER TABLE CONTROLLED_VOCABULARIES ALTER COLUMN REGISTRATION_TIMESTAMP DROP NOT NULL;\\012ALTER TABLE CONTROLLED_VOCABULARIES ALTER COLUMN REGISTRATION_TIMESTAMP DROP DEFAULT;\\012ALTER TABLE CONTROLLED_VOCABULARY_TERMS ALTER COLUMN REGISTRATION_TIMESTAMP TYPE TIME_STAMP_DFL;\\012ALTER TABLE CONTROLLED_VOCABULARY_TERMS ALTER COLUMN REGISTRATION_TIMESTAMP DROP NOT NULL;\\012ALTER TABLE CONTROLLED_VOCABULARY_TERMS ALTER COLUMN REGISTRATION_TIMESTAMP DROP DEFAULT;\\012ALTER TABLE DATA ALTER COLUMN REGISTRATION_TIMESTAMP TYPE TIME_STAMP_DFL;\\012ALTER TABLE DATA ALTER COLUMN REGISTRATION_TIMESTAMP DROP NOT NULL;\\012ALTER TABLE DATA ALTER COLUMN REGISTRATION_TIMESTAMP DROP DEFAULT;\\012ALTER TABLE EXPERIMENTS ALTER COLUMN REGISTRATION_TIMESTAMP TYPE TIME_STAMP_DFL;\\012ALTER TABLE EXPERIMENTS ALTER COLUMN REGISTRATION_TIMESTAMP DROP NOT NULL;\\012ALTER TABLE EXPERIMENTS ALTER COLUMN REGISTRATION_TIMESTAMP DROP DEFAULT;\\012ALTER TABLE EXPERIMENT_ATTACHMENTS ALTER COLUMN REGISTRATION_TIMESTAMP TYPE TIME_STAMP_DFL;\\012ALTER TABLE EXPERIMENT_ATTACHMENTS ALTER COLUMN REGISTRATION_TIMESTAMP DROP NOT NULL;\\012ALTER TABLE EXPERIMENT_ATTACHMENTS ALTER COLUMN REGISTRATION_TIMESTAMP DROP DEFAULT;\\012ALTER TABLE EXPERIMENT_PROPERTIES ALTER COLUMN REGISTRATION_TIMESTAMP TYPE TIME_STAMP_DFL;\\012ALTER TABLE EXPERIMENT_PROPERTIES ALTER COLUMN REGISTRATION_TIMESTAMP DROP NOT NULL;\\012ALTER TABLE EXPERIMENT_PROPERTIES ALTER COLUMN REGISTRATION_TIMESTAMP DROP DEFAULT;\\012ALTER TABLE EXPERIMENT_TYPE_PROPERTY_TYPES ALTER COLUMN REGISTRATION_TIMESTAMP TYPE TIME_STAMP_DFL;\\012ALTER TABLE EXPERIMENT_TYPE_PROPERTY_TYPES ALTER COLUMN REGISTRATION_TIMESTAMP DROP NOT NULL;\\012ALTER TABLE EXPERIMENT_TYPE_PROPERTY_TYPES ALTER COLUMN REGISTRATION_TIMESTAMP DROP DEFAULT;\\012ALTER TABLE INVALIDATIONS ALTER COLUMN REGISTRATION_TIMESTAMP TYPE TIME_STAMP_DFL;\\012ALTER TABLE INVALIDATIONS ALTER COLUMN REGISTRATION_TIMESTAMP DROP NOT NULL;\\012ALTER TABLE INVALIDATIONS ALTER COLUMN REGISTRATION_TIMESTAMP DROP DEFAULT;\\012ALTER TABLE MATERIALS ALTER COLUMN REGISTRATION_TIMESTAMP TYPE TIME_STAMP_DFL;\\012ALTER TABLE MATERIALS ALTER COLUMN REGISTRATION_TIMESTAMP DROP NOT NULL;\\012ALTER TABLE MATERIALS ALTER COLUMN REGISTRATION_TIMESTAMP DROP DEFAULT;\\012ALTER TABLE MATERIAL_BATCHES ALTER COLUMN REGISTRATION_TIMESTAMP TYPE TIME_STAMP_DFL;\\012ALTER TABLE MATERIAL_BATCHES ALTER COLUMN REGISTRATION_TIMESTAMP DROP NOT NULL;\\012ALTER TABLE MATERIAL_BATCHES ALTER COLUMN REGISTRATION_TIMESTAMP DROP DEFAULT;\\012ALTER TABLE MATERIAL_PROPERTIES ALTER COLUMN REGISTRATION_TIMESTAMP TYPE TIME_STAMP_DFL;\\012ALTER TABLE MATERIAL_PROPERTIES ALTER COLUMN REGISTRATION_TIMESTAMP DROP NOT NULL;\\012ALTER TABLE MATERIAL_PROPERTIES ALTER COLUMN REGISTRATION_TIMESTAMP DROP DEFAULT;\\012ALTER TABLE MATERIAL_TYPE_PROPERTY_TYPES ALTER COLUMN REGISTRATION_TIMESTAMP TYPE TIME_STAMP_DFL;\\012ALTER TABLE MATERIAL_TYPE_PROPERTY_TYPES ALTER COLUMN REGISTRATION_TIMESTAMP DROP NOT NULL;\\012ALTER TABLE MATERIAL_TYPE_PROPERTY_TYPES ALTER COLUMN REGISTRATION_TIMESTAMP DROP DEFAULT;\\012ALTER TABLE PROCEDURES ALTER COLUMN REGISTRATION_TIMESTAMP TYPE TIME_STAMP_DFL;\\012ALTER TABLE PROCEDURES ALTER COLUMN REGISTRATION_TIMESTAMP DROP NOT NULL;\\012ALTER TABLE PROCEDURES ALTER COLUMN REGISTRATION_TIMESTAMP DROP DEFAULT;\\012ALTER TABLE PROPERTY_TYPES ALTER COLUMN REGISTRATION_TIMESTAMP TYPE TIME_STAMP_DFL;\\012ALTER TABLE PROPERTY_TYPES ALTER COLUMN REGISTRATION_TIMESTAMP DROP NOT NULL;\\012ALTER TABLE PROPERTY_TYPES ALTER COLUMN REGISTRATION_TIMESTAMP DROP DEFAULT;\\012ALTER TABLE SAMPLES ALTER COLUMN REGISTRATION_TIMESTAMP TYPE TIME_STAMP_DFL;\\012ALTER TABLE SAMPLES ALTER COLUMN REGISTRATION_TIMESTAMP DROP NOT NULL;\\012ALTER TABLE SAMPLES ALTER COLUMN REGISTRATION_TIMESTAMP DROP DEFAULT;\\012ALTER TABLE SAMPLE_PROPERTIES ALTER COLUMN REGISTRATION_TIMESTAMP TYPE TIME_STAMP_DFL;\\012ALTER TABLE SAMPLE_PROPERTIES ALTER COLUMN REGISTRATION_TIMESTAMP DROP NOT NULL;\\012ALTER TABLE SAMPLE_PROPERTIES ALTER COLUMN REGISTRATION_TIMESTAMP DROP DEFAULT;\\012ALTER TABLE SAMPLE_TYPE_PROPERTY_TYPES ALTER COLUMN REGISTRATION_TIMESTAMP TYPE TIME_STAMP_DFL;\\012ALTER TABLE SAMPLE_TYPE_PROPERTY_TYPES ALTER COLUMN REGISTRATION_TIMESTAMP DROP NOT NULL;\\012ALTER TABLE SAMPLE_TYPE_PROPERTY_TYPES ALTER COLUMN REGISTRATION_TIMESTAMP DROP DEFAULT;\\012\\012-- Third step: drop old domain TIME_STAMP\\012DROP DOMAIN TIME_STAMP;\\012\\012-- Forth step: create new domain time_stamp\\012CREATE DOMAIN TIME_STAMP AS TIMESTAMP WITH TIME ZONE;\\012\\012--=================================\\012-- New Tables and related objects\\012--=================================\\012\\012------------------------------------------------------------------------------------\\012-- table DATA_SET_RELATIONSHIPS (new)\\012------------------------------------------------------------------------------------\\012\\012-- Creating tables\\012\\012CREATE TABLE DATA_SET_RELATIONSHIPS (ID TECH_ID NOT NULL,DATA_ID_PARENT TECH_ID NOT NULL,DATA_ID_CHILD TECH_ID NOT NULL,REGISTRATION_TIMESTAMP TIME_STAMP_DFL);\\012\\012-- Creating primary key constraints\\012\\012ALTER TABLE DATA_SET_RELATIONSHIPS ADD CONSTRAINT DSRE_PK PRIMARY KEY(ID);\\012\\012-- Creating unique constraints\\012\\012ALTER TABLE DATA_SET_RELATIONSHIPS ADD CONSTRAINT DSRE_BK_UK UNIQUE(DATA_ID_CHILD,DATA_ID_PARENT);\\012\\012-- Creating foreign key constraints\\012\\012ALTER TABLE DATA_SET_RELATIONSHIPS ADD CONSTRAINT DSRE_DATA_FK_CHILD FOREIGN KEY (DATA_ID_CHILD) REFERENCES DATA(ID);\\012ALTER TABLE DATA_SET_RELATIONSHIPS ADD CONSTRAINT DSRE_DATA_FK_PARENT FOREIGN KEY (DATA_ID_PARENT) REFERENCES DATA(ID);\\012\\012-- Creating sequences\\012\\012CREATE SEQUENCE DATA_SET_RELATIONSHIP_ID_SEQ;\\012\\012-- Creating indexes\\012\\012CREATE INDEX DSRE_DATA_FK_I_CHILD ON DATA_SET_RELATIONSHIPS (DATA_ID_CHILD);\\012CREATE INDEX DSRE_DATA_FK_I_PARENT ON DATA_SET_RELATIONSHIPS (DATA_ID_PARENT);\\012\\012--====================================\\012-- Drop Tables and related objects\\012--====================================\\012\\012------------------------------------------------------------------------------------\\012-- table DATA_VALUES (deleted)\\012------------------------------------------------------------------------------------\\012\\012-- Delete constraints\\012\\012ALTER TABLE DATA_VALUES DROP CONSTRAINT DAVA_PK;\\012ALTER TABLE DATA_VALUES DROP CONSTRAINT DAVA_BK_UK;\\012ALTER TABLE DATA_VALUES DROP CONSTRAINT DAVA_DATA_FK;\\012ALTER TABLE DATA_VALUES DROP CONSTRAINT DAVA_SACO_FK;\\012\\012-- Delete indices\\012\\012DROP INDEX DAVA_DATA_FK_I;\\012DROP INDEX DAVA_SACO_FK_I;\\012\\012-- Delete sequences\\012\\012DROP SEQUENCE DATA_VALUE_ID_SEQ;\\012\\012-- Delete tables\\012\\012DROP TABLE DATA_VALUES;\\012\\012--====================================\\012-- Modifications of existing objects\\012--====================================\\012\\012------------------------------------------------------------------------------------\\012-- table ORGANIZATIONS (changed)\\012-- * rename to GROUPS\\012--\\012-- table DATA (changed)\\012-- * rename column PROC_ID_ACQUIRED_BY into: PROC_ID_PRODUCED_BY\\012-- * add columns:\\012-- ** IS_PLACEHOLDER BOOLEAN_CHAR\\012-- ** CODE CODE\\012-- ** DATA_PRODUCER_CODE CODE\\012-- ** PRODUCTION_TIMESTAMP TIME_STAMP\\012--\\012-- table EXTERNAL_DATA (changed)\\012-- * add column:\\012-- ** CVTE_ID_STOR_FMT TECH_ID NOT NULL\\012--\\012-- table PROPERTY_TYPES (changed)\\012-- * add column IS_MANAGED_INTERNALLY BOOLEAN_CHAR NOT NULL DEFAULT 'F'\\012-- * add unique constraint PRTY_BK_UK_LBL for column LABEL\\012--\\012-- tables EXPERIMENT_TYPE_PROPERTY_TYPES, MATERIAL_TYPE_PROPERTY_TYPES, SAMPLE_TYPE_PROPERTY_TYPES\\012-- * make the assignments of property types DESCRIPTION, NUCLEOTIDE_SEQUENCE, OFFSET and GENE_SYMBOL \\012--   to material types internally managed \\012--\\012-- table PROCEDURE_TYPES (changed)\\012-- * add column IS_DATA_ACQUISITION BOOLEAN_CHAR NOT NULL DEFAULT 'F'.\\012--\\012-- all tables\\012-- * convert all codes to upper case\\012------------------------------------------------------------------------------------\\012\\012---------------------------------------------------------------------------------------------------\\012--  Purpose:  Rename table ORGANIZATIONS to GROUPS.\\012---------------------------------------------------------------------------------------------------\\012\\012ALTER TABLE PROJECTS DROP CONSTRAINT PROJ_ORGA_FK;\\012ALTER TABLE ORGANIZATIONS DROP CONSTRAINT ORGA_BK_UK;\\012ALTER TABLE ORGANIZATIONS DROP CONSTRAINT ORGA_PK;\\012ALTER TABLE ORGANIZATIONS RENAME TO GROUPS;\\012ALTER INDEX PROJ_ORGA_FK_I RENAME TO PROJ_GROU_FK_I;\\012select RENAME_SEQUENCE('ORGANIZATION_ID_SEQ', 'GROUP_ID_SEQ');\\012ALTER TABLE PROJECTS RENAME COLUMN ORGA_ID TO GROU_ID;\\012ALTER TABLE GROUPS ADD CONSTRAINT GROU_PK PRIMARY KEY(ID);\\012ALTER TABLE GROUPS ADD CONSTRAINT GROU_BK_UK UNIQUE(CODE);\\012ALTER TABLE PROJECTS ADD CONSTRAINT PROJ_GROU_FK FOREIGN KEY (GROU_ID) REFERENCES GROUPS(ID);\\012\\012\\012---------------------------------------------------------------------------------------------------\\012--  Purpose:  Add columnd IS_PLACEHOLDER of table DATA.\\012---------------------------------------------------------------------------------------------------\\012\\012ALTER TABLE DATA ADD COLUMN IS_PLACEHOLDER BOOLEAN_CHAR NOT NULL;\\012\\012\\012---------------------------------------------------------------------------------------------------\\012--  Purpose:  Add and populate column CODE of table DATA.\\012---------------------------------------------------------------------------------------------------\\012\\012ALTER TABLE DATA ADD COLUMN CODE CODE;\\012\\012CREATE OR REPLACE FUNCTION populate_data_codes() RETURNS integer AS $$\\012DECLARE\\012    rec RECORD;\\012BEGIN\\012    FOR rec IN SELECT * FROM data LOOP\\012        rec.code := to_char(rec.registration_timestamp, 'YYYYMMDDHH24MISSMS') || '-' || to_char(rec.id, 'FM99999999999999999999');\\012        update data set code=rec.code where id=rec.id;\\012    END LOOP;\\012    RETURN 1;\\012END;\\012$$ LANGUAGE 'plpgsql';\\012\\012SELECT populate_data_codes();\\012DROP FUNCTION populate_data_codes();\\012\\012ALTER TABLE DATA ALTER COLUMN CODE SET NOT NULL;\\012ALTER TABLE DATA ADD CONSTRAINT DATA_BK_UK UNIQUE(CODE);\\012\\012---------------------------------------------------------------------------------------------------\\012--  Purpose:  Add and populate columns CVTE_ID_STOR_FMT.\\012---------------------------------------------------------------------------------------------------\\012\\012ALTER TABLE EXTERNAL_DATA ADD COLUMN CVTE_ID_STOR_FMT TECH_ID;\\012ALTER TABLE EXTERNAL_DATA ADD CONSTRAINT EXDA_STOR_FMT_FK FOREIGN KEY (CVTE_ID_STOR_FMT) REFERENCES CONTROLLED_VOCABULARY_TERMS(ID);\\012\\012------------------------------------------------------------------------------------\\012--  Purpose:  Create trigger EXTERNAL_DATA_STORAGE_FORMAT_CHECK \\012------------------------------------------------------------------------------------\\012\\012CREATE OR REPLACE FUNCTION EXTERNAL_DATA_STORAGE_FORMAT_CHECK() RETURNS trigger AS $$\\012DECLARE\\012   v_covo_code  CODE;\\012BEGIN\\012\\012   select code into v_covo_code from controlled_vocabularies\\012      where id = (select covo_id from controlled_vocabulary_terms where id = NEW.cvte_id_stor_fmt);\\012\\012   -- Check if the data storage format is a term of the controlled vocabulary "STORAGE_FORMAT"\\012   if v_covo_code != '.STORAGE_FORMAT' then\\012      RAISE EXCEPTION 'Insert/Update of Data (Code: %) failed, as its Storage Format is %, but is required to be STORAGE_FORMAT.', NEW.code, v_covo_code;\\012   end if;\\012\\012   RETURN NEW;\\012\\012END;\\012$$ LANGUAGE 'plpgsql';\\012\\012CREATE TRIGGER EXTERNAL_DATA_STORAGE_FORMAT_CHECK BEFORE INSERT OR UPDATE ON EXTERNAL_DATA\\012    FOR EACH ROW EXECUTE PROCEDURE EXTERNAL_DATA_STORAGE_FORMAT_CHECK();\\012\\012-----------------------------------------------------------------------------------\\012--  Purpose:  Create Controlled Vocabulary .STORAGE_FORMAT\\012-----------------------------------------------------------------------------------\\012insert into controlled_vocabularies \\012       ( id\\012       , code\\012       , description\\012       , pers_id_registerer\\012       , is_managed_internally )\\012values  (nextval('CONTROLLED_VOCABULARY_ID_SEQ')\\012       , '.STORAGE_FORMAT'\\012       , 'The on-disk storage format of a data set'\\012       , (select id from persons where user_id ='system')\\012       , true);\\012\\012\\012-----------------------------------------------------------------------------------\\012--  Purpose:  Create Controlled Vocabulary Terms for STORAGE_FORMAT\\012-----------------------------------------------------------------------------------\\012insert into controlled_vocabulary_terms \\012       ( id\\012       , code\\012       , covo_id \\012       , pers_id_registerer )\\012values  (nextval('CVTE_ID_SEQ')\\012       , 'PROPRIETARY'\\012       , (select id from controlled_vocabularies where code = '.STORAGE_FORMAT')\\012       , (select id from persons where user_id ='system'));\\012\\012insert into controlled_vocabulary_terms \\012       ( id\\012       , code\\012       , covo_id \\012       , pers_id_registerer )\\012values  (nextval('CVTE_ID_SEQ')\\012       , 'BDS_DIRECTORY'\\012       , (select id from controlled_vocabularies where code = '.STORAGE_FORMAT')\\012       , (select id from persons where user_id ='system'));\\012\\012\\012--------------------------------------------------------------------------\\012--  Purpose:  Insert an entry for OBSERVABLE_TYPE UNKNOWN\\012--------------------------------------------------------------------------\\012\\012insert into observable_types\\012(id\\012,code\\012,description)\\012values \\012(nextval('OBSERVABLE_TYPE_ID_SEQ')\\012,'UNKNOWN'\\012,'Unknown'\\012);\\012\\012----------------------------------------------------------------------\\012--  Purpose:  Insert an entry for PROCEDURE_TYPE UNKNOWN\\012-----------------------------------------------------------------------\\012\\012insert into procedure_types\\012(id\\012,code\\012,description)\\012values \\012(nextval('PROCEDURE_TYPE_ID_SEQ')\\012,'UNKNOWN'\\012,'Unknown'\\012);\\012\\012\\012---------------------------------------------------------------------------------------------------\\012--  Purpose:  Populate external_data.cvte_id_stor_fmt with a default value.\\012---------------------------------------------------------------------------------------------------\\012\\012CREATE OR REPLACE FUNCTION polulate_external_data_cvte_id_stor_fmt() RETURNS integer AS $$\\012DECLARE\\012    rec RECORD;\\012    dfl_stor_fmt_code VARCHAR := 'PROPRIETARY';\\012    dfl_stor_fmt_id TECH_ID;\\012BEGIN\\012    select cvte.id into dfl_stor_fmt_id from controlled_vocabulary_terms cvte, controlled_vocabularies cv \\012        where cvte.code = dfl_stor_fmt_code and cvte.covo_id = cv.id and cv.code = '.STORAGE_FORMAT'; \\012    update external_data set cvte_id_stor_fmt = dfl_stor_fmt_id;\\012    RETURN 1;\\012END;\\012$$ LANGUAGE 'plpgsql';\\012\\012SELECT polulate_external_data_cvte_id_stor_fmt();\\012DROP FUNCTION polulate_external_data_cvte_id_stor_fmt();\\012\\012-- Now that the field is populated, create the not null constraint for it.\\012\\012ALTER TABLE EXTERNAL_DATA ALTER COLUMN CVTE_ID_STOR_FMT SET NOT NULL;\\012\\012---------------------------------------------------------------------------------------------------\\012--  Purpose:  Add and populate columns DATA_PRODUCER_CODE and PRODUCTION_TIMESTAMP to table DATA.\\012---------------------------------------------------------------------------------------------------\\012\\012ALTER TABLE DATA ADD COLUMN DATA_PRODUCER_CODE CODE;\\012ALTER TABLE DATA ADD COLUMN PRODUCTION_TIMESTAMP TIME_STAMP;\\012\\012CREATE OR REPLACE FUNCTION populate_data_producer_code_and_production_timestamp() RETURNS integer AS $$\\012DECLARE\\012    rec RECORD;\\012    loty_rel_code VARCHAR := 'RELATIVE_LOCATION';\\012    loty_rel_id TECH_ID;\\012    meas_ts TIMESTAMP;\\012    ds_code CODE;\\012    meas_ts_str TEXT;\\012BEGIN\\012    select id into loty_rel_id from locator_types where code = loty_rel_code; \\012    FOR rec IN SELECT d.id, ed.location FROM data d, external_data ed where d.id = ed.data_id and ed.loty_id = loty_rel_id LOOP\\012        meas_ts_str = substring(rec.location from '^.*/([0-9]{14})_[^_]+_(.*)$');\\012        ds_code := substring(rec.location from '^.*/[0-9]{14}_([^_]+)_(.*)$');\\012        IF meas_ts_str is not null and ds_code is not null THEN\\012            meas_ts := to_timestamp(meas_ts_str, 'YYYYMMDDHH24MISS');\\012            update data set production_timestamp=meas_ts, data_producer_code=ds_code where id=rec.id;\\012        END IF;\\012    END LOOP;\\012    RETURN 1;\\012END;\\012$$ LANGUAGE 'plpgsql';\\012\\012SELECT populate_data_producer_code_and_production_timestamp();\\012DROP FUNCTION populate_data_producer_code_and_production_timestamp();\\012\\012-- Rename columns\\012\\012ALTER TABLE DATA RENAME COLUMN PROC_ID_ACQUIRED_BY to PROC_ID_PRODUCED_BY;\\012\\012---------------------------------------------------------------------------------------------------\\012--  Purpose:  Populate table DATA_SET_RELATIONSHIPS, by using heuristics.\\012---------------------------------------------------------------------------------------------------\\012\\012CREATE OR REPLACE FUNCTION abs_interval(ts1 time_stamp_dfl, ts2 time_stamp_dfl) returns interval AS $$\\012BEGIN\\012    IF ts1 < ts2 THEN\\012        RETURN ts2 - ts1;\\012    ELSE\\012        RETURN ts1 - ts2;\\012    END IF;\\012END;\\012$$ LANGUAGE 'plpgsql';\\012\\012CREATE OR REPLACE FUNCTION populate_data_set_relationships() RETURNS INTEGER AS $$\\012DECLARE\\012    source_id TECH_ID;\\012    rec_derived RECORD;\\012    rec_acquired RECORD;\\012    rel_location TEXT;\\012    data_set_code TEXT;\\012    data_set_code_trial TEXT;\\012    loty_rel_code TEXT := 'RELATIVE_LOCATION';\\012    loty_rel_id TECH_ID;\\012    count INTEGER := 0;\\012BEGIN\\012    select id into loty_rel_id from locator_types where code = loty_rel_code;\\012    FOR rec_derived IN select id, samp_id_derived_from, registration_timestamp from data where samp_id_derived_from is not null LOOP\\012        source_id := NULL;\\012        select location into rel_location from external_data where data_id = rec_derived.id and loty_id = loty_rel_id;\\012        IF rel_location is not null then\\012            data_set_code := substring(rel_location from '^.*/([0-9]{14}_[^_]+)_.*$');\\012            IF data_set_code is not null THEN\\012                FOR rec_acquired IN select id, samp_id_acquired_from from data where samp_id_acquired_from = rec_derived.samp_id_derived_from LOOP\\012                    select location into rel_location from external_data where data_id = rec_acquired.id and loty_id = loty_rel_id;\\012                    IF rel_location is not null THEN\\012                        data_set_code_trial := substring(rel_location from '^.*/([0-9]{14}_[^_]+)_.*$');\\012                        IF data_set_code_trial = data_set_code THEN\\012                            source_id = rec_acquired.id;\\012                            EXIT;\\012                        END IF;\\012                    END IF;\\012                END LOOP;\\012            END IF;\\012        END IF;\\012        -- If the location didn't tell us about data set relationships, try the backup strategy.\\012        IF source_id is null THEN\\012            -- Use the measured data set as source that is closest in registration timestamp.\\012            select id into source_id from data where samp_id_acquired_from = rec_derived.samp_id_derived_from \\012                and abs_interval(registration_timestamp, rec_derived.registration_timestamp) \\012                    = (select min(abs_interval(registration_timestamp, rec_derived.registration_timestamp)) \\012                        from data where samp_id_acquired_from = rec_derived.samp_id_derived_from);\\012        END IF;\\012        IF source_id is not null THEN\\012            insert into data_set_relationships (id, data_id_parent, data_id_child)\\012                values (nextval('DATA_SET_RELATIONSHIP_ID_SEQ'), source_id, rec_derived.id);\\012            count := count + 1;\\012        END IF;\\012    END LOOP;\\012    RETURN count;\\012END;\\012$$ LANGUAGE 'plpgsql';\\012\\012SELECT populate_data_set_relationships();\\012DROP FUNCTION populate_data_set_relationships();\\012DROP FUNCTION abs_interval(time_stamp_dfl, time_stamp_dfl);\\012\\012---------------------------------------------------------------------------------------------------\\012--  Purpose:  Add column IS_MANAGED_INTERNALLY to table PROPERTY_TYPES. Internally managed \\012--  properties can not be assigned by users of openBIS, but only by the system. \\012---------------------------------------------------------------------------------------------------\\012\\012ALTER TABLE PROPERTY_TYPES ADD COLUMN IS_MANAGED_INTERNALLY BOOLEAN_CHAR NOT NULL DEFAULT 'F';\\012\\012-- Update already existing property type PLATE_GEOMETRY\\012update property_types set is_managed_internally = true, code = '.' || code where code = 'PLATE_GEOMETRY';\\012\\012-- Update already existing controlled vocabulary PLATE_GEOMETRY \\012update controlled_vocabularies set code = '.' || code where code = 'PLATE_GEOMETRY';\\012\\012---------------------------------------------------------------------------------------------------\\012--  Purpose:  Add unique constraint on column LABEL. \\012---------------------------------------------------------------------------------------------------\\012\\012CREATE OR REPLACE FUNCTION make_prty_labels_unique() RETURNS INTEGER AS $$\\012DECLARE\\012    prev_key TEXT := NULL;\\012    this_key TEXT;\\012    dup_count INTEGER;\\012    cnt INTEGER := 0;\\012    already_exists INTEGER;\\012    new_label TEXT;\\012    this_id TECH_ID;\\012BEGIN\\012    FOR this_id, this_key IN select id, label from property_types order by label,id LOOP\\012        IF this_key = prev_key THEN\\012            dup_count := dup_count + 1;\\012            cnt := cnt + 1;\\012        ELSE\\012            dup_count := 0;\\012        END IF;\\012        IF dup_count > 0 THEN\\012            -- Check whether the new key already exists.\\012            LOOP\\012                new_label := this_key || '(' || dup_count::text || ')';\\012                select count(*) into already_exists from property_types where label = new_label;\\012                IF already_exists = 0 THEN\\012                    EXIT;\\012                END IF;\\012                dup_count := dup_count + 1;\\012            END LOOP;\\012            update property_types set label = new_label where id = this_id;\\012        END IF;\\012        prev_key := this_key;\\012    END LOOP;\\012    RETURN cnt;\\012END;\\012$$ LANGUAGE 'plpgsql';\\012\\012SELECT make_prty_labels_unique();\\012DROP FUNCTION make_prty_labels_unique();\\012\\012ALTER TABLE PROPERTY_TYPES ADD CONSTRAINT PRTY_BK_UK_LBL UNIQUE(LABEL);\\012\\012-----------------------------------------------------------------------------------\\012--  Purpose:  Add Controlled Vocabulary Terms to PLATE_GEOMETRY\\012-----------------------------------------------------------------------------------\\012\\012insert into controlled_vocabulary_terms \\012       ( id\\012       , code\\012       , covo_id \\012       , pers_id_registerer)\\012values  (nextval('CVTE_ID_SEQ')\\012       , '96_WELLS_8X12'\\012       , (select id from controlled_vocabularies where code = '.PLATE_GEOMETRY')\\012       , (select id from persons where user_id = 'system'));\\012\\012insert into controlled_vocabulary_terms \\012       ( id\\012       , code\\012       , covo_id \\012       , pers_id_registerer)\\012values  (nextval('CVTE_ID_SEQ')\\012       , '1536_WELLS_32X48'\\012       , (select id from controlled_vocabularies where code = '.PLATE_GEOMETRY')\\012       , (select id from persons where user_id = 'system'));\\012\\012\\012-----------------------------------------------------------------------------------\\012--  Purpose:  Rename Observable Types: IMAGE -> HCS_IMAGE, IMAGE_ANALYSIS_DATA -> HCS_IMAGE_ANALYSIS_DATA\\012--  and descriptions accordingly\\012-----------------------------------------------------------------------------------\\012\\012update observable_types set code = 'HCS_IMAGE', description = 'Data derived from analysis of HCS images' where code = 'IMAGE';\\012update observable_types set code = 'HCS_IMAGE_ANALYSIS_DATA', description = 'Data derived from analysis of HCS images' where code = 'IMAGE_ANALYSIS_DATA';\\012\\012\\012-----------------------------------------------------------------------------------\\012--  Purpose: Make the assignments of property types DESCRIPTION, NUCLEOTIDE_SEQUENCE, OFFSET \\012--  and GENE_SYMBOL to material types internally managed. \\012-----------------------------------------------------------------------------------\\012\\012update material_type_property_types set is_managed_internally = true\\012    where prty_id in (select id from property_types where code = 'DESCRIPTION' \\012        or code = 'NUCLEOTIDE_SEQUENCE' or code = 'OFFSET' or code = 'GENE_SYMBOL');\\012\\012-----------------------------------------------------------------------------------\\012--  Purpose: Add column IS_DATA_ACQUISITION BOOLEAN_CHAR NOT NULL DEFAULT 'F' to table PROCEDURE_TYPES.\\012-----------------------------------------------------------------------------------\\012\\012ALTER TABLE PROCEDURE_TYPES ADD COLUMN IS_DATA_ACQUISITION BOOLEAN_CHAR NOT NULL DEFAULT 'F';\\012\\012-- Set the new attribute for procedure type DATA_ACQUISITION\\012update procedure_types set is_data_acquisition = true where code = 'DATA_ACQUISITION';\\012\\012-----------------------------------------------------------------------------------\\012--  Purpose: Convert all codes to upper case. \\012-----------------------------------------------------------------------------------\\012\\012CREATE OR REPLACE FUNCTION column_to_uppercase_fix_duplicates(tbl TEXT, clm TEXT) RETURNS INTEGER AS $$\\012DECLARE\\012    prev_key TEXT := NULL;\\012    this_key TEXT;\\012    dup_count INTEGER;\\012    count INTEGER := 0;\\012    already_exists INTEGER;\\012    new_clm TEXT;\\012BEGIN\\012    FOR this_key IN EXECUTE 'select ' || clm || ' from ' || tbl \\012        || ' order by upper(' || clm || '),id' LOOP\\012        IF upper(this_key) = upper(prev_key) THEN\\012            dup_count := dup_count + 1;\\012            count := count + 1;\\012        ELSE\\012            dup_count := 0;\\012        END IF;\\012        IF dup_count > 0 THEN\\012            -- Check whether the new key already exists.\\012            LOOP\\012                new_clm := this_key || '(' || dup_count::text || ')';\\012                EXECUTE 'select count(*) from ' || tbl \\012                    || ' where upper(' || clm || ') = ' || quote_literal(upper(new_clm)) \\012                    into already_exists;\\012                IF already_exists = 0 THEN\\012                    EXIT;\\012                END IF;\\012                dup_count := dup_count + 1;\\012            END LOOP;\\012            EXECUTE 'update ' || tbl || ' set ' || clm || ' = ' || quote_literal(new_clm) || \\012                ' where ' || clm || ' = ' || quote_literal(this_key);\\012        END IF;\\012        prev_key := this_key;\\012    END LOOP;\\012    EXECUTE 'update ' || tbl || ' set ' || clm || ' = upper(' || clm || ')';\\012    RETURN count;\\012END;\\012$$ LANGUAGE 'plpgsql';\\012\\012\\012CREATE OR REPLACE FUNCTION column_to_uppercase_fix_duplicates(tbl TEXT, clm TEXT, clm2 TEXT) RETURNS INTEGER AS $$\\012DECLARE\\012    prev_key TEXT := NULL;\\012    prev_key2 TECH_ID;\\012    this_key TEXT;\\012    this_key2 TECH_ID;\\012    dup_count INTEGER;\\012    count INTEGER := 0;\\012    already_exists INTEGER;\\012    new_clm TEXT;\\012BEGIN\\012    FOR this_key, this_key2 IN EXECUTE 'select ' || clm || ',' || clm2 || ' from ' || tbl \\012        || ' order by ' || clm2 || ',upper(' ||  clm || '),id' LOOP\\012        IF upper(this_key) = upper(prev_key) and this_key2 = prev_key2 THEN\\012            dup_count := dup_count + 1;\\012            count := count + 1;\\012        ELSE\\012            dup_count := 0;\\012        END IF;\\012        IF dup_count > 0 THEN\\012            -- Check whether the new key already exists.\\012            LOOP\\012                new_clm := this_key || '(' || dup_count::text || ')';\\012                EXECUTE 'select count(*) from ' || tbl \\012                    || ' where upper(' || clm || ') = ' || quote_literal(upper(new_clm)) \\012                    || ' and ' || clm2 || ' = ' || quote_literal(this_key2) \\012                    into already_exists;\\012                IF already_exists = 0 THEN\\012                    EXIT;\\012                END IF;\\012                dup_count := dup_count + 1;\\012            END LOOP;\\012            EXECUTE 'update ' || tbl || ' set ' || clm || ' = ' || quote_literal(new_clm) || \\012                ' where ' || clm || ' = ' || quote_literal(this_key) || ' and ' \\012                || clm2 || ' = ' || quote_literal(this_key2);\\012        END IF;\\012        prev_key := this_key;\\012        prev_key2 := this_key2;\\012    END LOOP;\\012    EXECUTE 'update ' || tbl || ' set ' || clm || ' = upper(' || clm || ')';\\012    RETURN count;\\012END;\\012$$ LANGUAGE 'plpgsql';\\012\\012\\012SELECT column_to_uppercase_fix_duplicates('samples', 'code');\\012SELECT column_to_uppercase_fix_duplicates('property_types', 'code');\\012SELECT column_to_uppercase_fix_duplicates('controlled_vocabularies', 'code');\\012\\012SELECT column_to_uppercase_fix_duplicates('projects', 'code', 'grou_id');\\012SELECT column_to_uppercase_fix_duplicates('experiments', 'code', 'proj_id');\\012SELECT column_to_uppercase_fix_duplicates('controlled_vocabulary_terms', 'code', 'covo_id');\\012SELECT column_to_uppercase_fix_duplicates('materials', 'code', 'maty_id');\\012SELECT column_to_uppercase_fix_duplicates('material_batches', 'code', 'mate_id');\\012SELECT column_to_uppercase_fix_duplicates('sample_components', 'code', 'samp_id');\\012\\012-- These will only need changes if someone entered them through the 'back door' directly on the server.\\012\\012SELECT column_to_uppercase_fix_duplicates('groups', 'code');\\012SELECT column_to_uppercase_fix_duplicates('sample_types', 'code');\\012SELECT column_to_uppercase_fix_duplicates('material_types', 'code');\\012SELECT column_to_uppercase_fix_duplicates('experiment_types', 'code');\\012SELECT column_to_uppercase_fix_duplicates('procedure_types', 'code');\\012SELECT column_to_uppercase_fix_duplicates('observable_types', 'code');\\012SELECT column_to_uppercase_fix_duplicates('locator_types', 'code');\\012SELECT column_to_uppercase_fix_duplicates('file_format_types', 'code');\\012SELECT column_to_uppercase_fix_duplicates('data_types', 'code');\\012\\012DROP FUNCTION column_to_uppercase_fix_duplicates(TEXT, TEXT);\\012DROP FUNCTION column_to_uppercase_fix_duplicates(TEXT, TEXT, TEXT);\\012\\012-----------------------------------------------------------------------------------\\012--  Purpose:  Delete sample_components with no associated material_batches.\\012--  This deletes superfluous controls of master plates\\012-----------------------------------------------------------------------------------\\012\\012delete from sample_components\\012where  id in (select sc.id \\012              from   sample_components as sc left join sample_component_materials as scm \\012              on     scm.saco_id = sc.id \\012              where  scm.saco_id is null\\012              )\\012;\\012	\N
+./sourceTest/sql/postgresql/018/.svn/text-base/006=database_version_logs.tsv.svn-base:017	source/sql/postgresql/migration/migration-016-017.sql	SUCCESS	2008-05-09 10:12:57.473	----------------------------------------------------------------------------------------------\\012--  File: migration-016-017.sql\\012--\\012-- \\012--  This script enables the migration of the database schema from 016 to 017.\\012-- \\012--  Update History\\012--\\012--\\012--\\011Who\\011\\011\\011              When\\011\\011    What\\012--\\011---\\011\\011\\011              ----      \\011----\\012--\\011Charles Ramin-Wright\\0112008-04-11\\011Initial Version \\012--  \\012----------------------------------------------------------------------------------------------\\012\\012\\012--=================================\\012-- Create Objects\\012--=================================\\012\\012-- Domains\\012\\012-- 'F' is false, 'T' is true and 'U' is unknown\\012CREATE DOMAIN BOOLEAN_CHAR_OR_UNKNOWN AS CHAR(1) CHECK (VALUE in ('F', 'T', 'U'));\\012\\012-- Tables and related objects\\012\\012-- Sequences\\012\\012-- Indices\\012\\012--====================================\\012-- Delete Objects\\012--====================================\\012\\012-- Domains\\012\\012-- Tables\\012\\012-- Sequences\\012\\012-- Indices\\012\\012--====================================\\012-- Alter Objects\\012--====================================\\012\\012-- Add column IS_INTERNAL_NAMESPACE to table CONTROLLED_VOCABULARIES \\012\\012ALTER TABLE CONTROLLED_VOCABULARIES ADD IS_INTERNAL_NAMESPACE BOOLEAN_CHAR NOT NULL DEFAULT 'F';\\012\\012-- Add column IS_INTERNAL_NAMESPACE to table PROPERTY_TYPES \\012\\012ALTER TABLE PROPERTY_TYPES ADD IS_INTERNAL_NAMESPACE BOOLEAN_CHAR NOT NULL DEFAULT 'F';\\012\\012-- Add column IS_INTERNAL_NAMESPACE as key component to the unique key constraint COVO_BK_UK\\012\\012ALTER TABLE CONTROLLED_VOCABULARIES DROP CONSTRAINT COVO_BK_UK;\\012ALTER TABLE CONTROLLED_VOCABULARIES ADD CONSTRAINT COVO_BK_UK UNIQUE(CODE,IS_INTERNAL_NAMESPACE);\\012\\012-- Add column IS_INTERNAL_NAMESPACE as key component to the unique key constraint PRTY_BK_UK\\012\\012ALTER TABLE PROPERTY_TYPES DROP CONSTRAINT PRTY_BK_UK;\\012ALTER TABLE PROPERTY_TYPES ADD CONSTRAINT PRTY_BK_UK UNIQUE(CODE,IS_INTERNAL_NAMESPACE);\\012\\012-- Delete unique key constraint PRTY_BK_UK_LBL (which was for column LABEL) from table PROPERTY_TYPES\\012\\012ALTER TABLE PROPERTY_TYPES DROP CONSTRAINT PRTY_BK_UK_LBL;\\012\\012\\012-- Change unique constraint EXDA_BK_UK to contain EXTERNAL_DATA.LOTY_ID \\012\\012ALTER TABLE EXTERNAL_DATA DROP CONSTRAINT EXDA_BK_UK;\\012ALTER TABLE EXTERNAL_DATA ADD CONSTRAINT EXDA_BK_UK UNIQUE(LOCATION,LOTY_ID);\\012\\012\\012-- Increase length of EXTERNAL_DATA.LOCATION from 200 to 1024\\012\\012ALTER TABLE EXTERNAL_DATA ALTER COLUMN LOCATION TYPE VARCHAR(1024);\\012\\012\\012-- Add column IS_COMPLETE to table EXTERNAL_DATA\\012\\012ALTER TABLE EXTERNAL_DATA ADD COLUMN IS_COMPLETE BOOLEAN_CHAR_OR_UNKNOWN NOT NULL DEFAULT 'U';\\012\\012\\012--=================================\\012-- Replace EXTERNAL_DATA_STORAGE_FORMAT_CHECK() function\\012--=================================\\012\\012CREATE OR REPLACE FUNCTION EXTERNAL_DATA_STORAGE_FORMAT_CHECK() RETURNS trigger AS $$\\012DECLARE\\012   v_covo_code  CODE;\\012   data_code CODE;\\012BEGIN\\012\\012   select code into v_covo_code from controlled_vocabularies\\012      where is_internal_namespace = true and \\012         id = (select covo_id from controlled_vocabulary_terms where id = NEW.cvte_id_stor_fmt);\\012\\012-- Check if the data storage format is a term of the controlled vocabulary "STORAGE_FORMAT"\\012   if v_covo_code != 'STORAGE_FORMAT' then\\012      select code into data_code from data where id = NEW.data_id; \\012      RAISE EXCEPTION 'Insert/Update of Data (Code: %) failed, as its Storage Format is %, but is required to be STORAGE_FORMAT.', data_code, v_covo_code;\\012   end if;\\012\\012   RETURN NEW;\\012\\012END;\\012$$ LANGUAGE 'plpgsql';\\012\\012\\012--=================================\\012-- Data Migration\\012--=================================\\012\\012\\012---------------------------------------------------------------------------------------\\012--   Translate the internally managed CODES which are represented by the Dot-Prefix to:\\012--\\012--   CODE without a Dot-Prefix plus the new column IS_INTERNAL_NAMESPACE = true.\\012---------------------------------------------------------------------------------------\\012\\012UPDATE property_types\\012SET    code = substr(code,2,length(code))\\012     , is_internal_namespace = true \\012WHERE  substr(code,1,1) = '.';\\012\\012UPDATE controlled_vocabularies\\012SET    code = substr(code,2,length(code))\\012     , is_internal_namespace = true \\012WHERE  substr(code,1,1) = '.';\\012\\012------------------------------------------------------------------------------------\\012--  Purpose: Move experiment descriptions from column to property DESCRIPTION\\012------------------------------------------------------------------------------------\\012\\012   -----------------------\\012   --  Material Type SIRNHACS\\012   -----------------------\\012\\012insert into experiment_type_property_types\\012(   id\\012   ,exty_id\\012   ,prty_id\\012   ,is_mandatory\\012   ,is_managed_internally\\012   ,pers_id_registerer\\012   )\\012values \\012(   nextval('ETPT_ID_SEQ')\\012   ,(select id from experiment_types where code = 'SIRNAHCS')\\012   ,(select id from property_types where code = 'DESCRIPTION')\\012   ,true\\012   ,true\\012   ,(select id from persons where user_id ='system')\\012);\\012\\012-- Add experiment_properties for descriptions of all experiments of type SIRNAHCS \\012\\012insert into experiment_properties\\012(   id\\012   ,expe_id\\012   ,value\\012   ,etpt_id\\012   ,pers_id_registerer\\012)\\012select\\012    nextval('EXPERIMENT_PROPERTY_ID_SEQ')\\012   ,id\\012   ,case when description is not null then description else 'No description given' end\\012   ,currval('ETPT_ID_SEQ')\\012   ,(select id from persons where user_id ='system')  \\012from experiments where exty_id = (select id from experiment_types where code = 'SIRNAHCS');\\012\\012-- Finally: drop column\\012\\012ALTER TABLE EXPERIMENTS DROP COLUMN DESCRIPTION;\\012	\N
+./sourceTest/sql/postgresql/018/.svn/text-base/schema-018.sql.svn-base:    LANGUAGE plpgsql;
+./sourceTest/sql/postgresql/018/.svn/text-base/schema-018.sql.svn-base:    LANGUAGE plpgsql;
+./sourceTest/sql/postgresql/018/.svn/text-base/schema-018.sql.svn-base:    LANGUAGE plpgsql;
+./sourceTest/sql/postgresql/018/006=database_version_logs.tsv:007	source/sql/postgresql/007/schema-007.sql	SUCCESS	2008-01-05 14:51:36.56	-- D:\\\\DDL\\\\postgresql\\\\schema-007.sql\\012--\\012-- Generated for ANSI SQL92 on Thu Aug 23  19:02:15 2007 by Server Generator 10.1.2.6.18\\012-- Post generation PostgreSQL specific Changes:\\012-- \\012--  1. change domain FILE from BIT(32000) to BYTEA\\012--  2. change domain TECH_ID from NUMERIC(20) to BIGINT\\012--  3. Put single quotes around the default value NOW in the create domain statement for the domain TIME_STAMP\\012--     i.e. change CREATE DOMAIN TIME_STAMP AS TIMESTAMP DEFAULT now; to CREATE DOMAIN TIME_STAMP AS TIMESTAMP DEFAULT 'now';\\012--  4. Temporarily not created, due to data quality issues with the master plate layout data\\012--\\012-- ALTER TABLE MOLECULES ADD CONSTRAINT MOLE_BK_UK UNIQUE(SEQUENCE);\\012\\012\\012\\012CREATE DOMAIN DESCRIPTION_80 AS VARCHAR(80);\\012CREATE DOMAIN USER_ID AS VARCHAR(20);\\012CREATE DOMAIN DOUBLE_PRECISION_VALUE AS DOUBLE PRECISION;\\012CREATE DOMAIN FILE_NAME AS VARCHAR(100);\\012CREATE DOMAIN TECH_ID AS BIGINT;\\012CREATE DOMAIN OBJECT_NAME AS VARCHAR(50);\\012CREATE DOMAIN TIME_STAMP AS TIMESTAMP DEFAULT CURRENT_TIMESTAMP;\\012CREATE DOMAIN REAL_VALUE AS REAL;\\012CREATE DOMAIN FILE AS BYTEA;\\012CREATE DOMAIN CODE AS VARCHAR(20);\\012CREATE DOMAIN DESCRIPTION_250 AS VARCHAR(250);\\012CREATE TABLE EXPERIMENT_PROPERTIES  (ID TECH_ID NOT NULL,EXPE_ID TECH_ID NOT NULL,FILE_NAME FILE_NAME NOT NULL,REGISTRATION_TIMESTAMP TIME_STAMP NOT NULL DEFAULT CURRENT_TIMESTAMP,VALUE FILE NOT NULL,VERSION INTEGER NOT NULL,PERS_ID_REGISTERER TECH_ID NOT NULL) ;\\012CREATE TABLE EXPERIMENT_TYPES  (ID TECH_ID NOT NULL,CODE CODE NOT NULL,DESCRIPTION DESCRIPTION_80) ;\\012CREATE TABLE DATA_VALUES  (ID TECH_ID NOT NULL,DATA_ID TECH_ID NOT NULL,SACO_ID TECH_ID NOT NULL,VALUE DOUBLE_PRECISION_VALUE NOT NULL) ;\\012CREATE TABLE PERSONS  (ID TECH_ID NOT NULL,FIRST_NAME VARCHAR(30),LAST_NAME VARCHAR(30),USER_ID USER_ID,EMAIL OBJECT_NAME) ;\\012CREATE TABLE FILE_FORMAT_TYPES  (ID TECH_ID NOT NULL,CODE CODE NOT NULL,DESCRIPTION DESCRIPTION_80) ;\\012CREATE TABLE SAMPLE_INPUTS  (ID TECH_ID NOT NULL,SAMP_ID TECH_ID NOT NULL,PROC_ID TECH_ID NOT NULL) ;\\012CREATE TABLE OBSERVABLE_TYPES  (ID TECH_ID NOT NULL,CODE CODE NOT NULL,DESCRIPTION DESCRIPTION_80) ;\\012CREATE TABLE LOCATOR_TYPES  (ID TECH_ID NOT NULL,CODE CODE NOT NULL,DESCRIPTION DESCRIPTION_80) ;\\012CREATE TABLE SAMPLE_COMPONENTS  (ID TECH_ID NOT NULL,CODE CODE NOT NULL,SAMP_ID TECH_ID NOT NULL) ;\\012CREATE TABLE SAMPLE_TYPES  (ID TECH_ID NOT NULL,CODE CODE NOT NULL,DESCRIPTION DESCRIPTION_80) ;\\012CREATE TABLE ORGANIZATIONS  (ID TECH_ID NOT NULL,CODE CODE NOT NULL) ;\\012CREATE TABLE PROCEDURES  (ID TECH_ID NOT NULL,REGISTRATION_TIMESTAMP TIME_STAMP NOT NULL DEFAULT CURRENT_TIMESTAMP,EXPE_ID TECH_ID NOT NULL,PCTY_ID TECH_ID NOT NULL,PERS_ID TECH_ID) ;\\012CREATE TABLE PROCEDURE_TYPES  (ID TECH_ID NOT NULL,CODE CODE NOT NULL,DESCRIPTION DESCRIPTION_80 NOT NULL) ;\\012CREATE TABLE PROJECTS  (ID TECH_ID NOT NULL,CODE CODE NOT NULL,ORGA_ID TECH_ID NOT NULL) ;\\012CREATE TABLE SAMPLE_COMPONENT_MATERIALS  (ID TECH_ID NOT NULL,SACO_ID TECH_ID NOT NULL,MABA_ID TECH_ID NOT NULL) ;\\012CREATE TABLE EXTERNAL_DATA  (DATA_ID TECH_ID NOT NULL,LOCATION VARCHAR(200) NOT NULL,LOTY_ID TECH_ID NOT NULL,FFTY_ID TECH_ID NOT NULL) ;\\012CREATE TABLE DATA  (ID TECH_ID NOT NULL,REGISTRATION_TIMESTAMP TIME_STAMP NOT NULL DEFAULT CURRENT_TIMESTAMP,OBTY_ID TECH_ID NOT NULL,PROC_ID_ACQUIRED_BY TECH_ID NOT NULL,SAMP_ID_ACQUIRED_FROM TECH_ID,SAMP_ID_DERIVED_FROM TECH_ID) ;\\012CREATE TABLE SAMPLES  (ID TECH_ID NOT NULL,CODE CODE NOT NULL,CONT_ID TECH_ID,PROC_ID TECH_ID,SAMP_ID_TOP TECH_ID,SAMP_ID_GENERATED_FROM TECH_ID,SATY_ID TECH_ID NOT NULL,REGISTRATION_TIMESTAMP TIME_STAMP NOT NULL DEFAULT CURRENT_TIMESTAMP,PERS_ID_REGISTERER TECH_ID NOT NULL) ;\\012CREATE TABLE MATERIAL_TYPES  (ID TECH_ID NOT NULL,CODE CODE NOT NULL,DESCRIPTION DESCRIPTION_80) ;\\012CREATE TABLE MATERIAL_BATCHES  (ID TECH_ID NOT NULL,CODE CODE NOT NULL,AMOUNT REAL_VALUE,MATE_ID TECH_ID NOT NULL,CONT_ID TECH_ID,PROC_ID TECH_ID,REGISTRATION_TIMESTAMP TIME_STAMP NOT NULL DEFAULT CURRENT_TIMESTAMP,PERS_ID_REGISTERER TECH_ID NOT NULL) ;\\012CREATE TABLE MATERIALS  (ID TECH_ID NOT NULL,CODE CODE NOT NULL,DESCRIPTION DESCRIPTION_250,MATY_ID TECH_ID NOT NULL,REGISTRATION_TIMESTAMP TIME_STAMP NOT NULL DEFAULT CURRENT_TIMESTAMP,PERS_ID_REGISTERER TECH_ID NOT NULL) ;\\012CREATE TABLE MOLECULES  (MATE_ID TECH_ID NOT NULL,SEQUENCE VARCHAR(100),ACCESSION_NUMBER OBJECT_NAME,OFF_SET VARCHAR(20),MOLE_ID_INHIBITOR_OF TECH_ID,GENE_SYMBOL CODE) ;\\012CREATE TABLE EXPERIMENTS  (ID TECH_ID NOT NULL,CODE CODE NOT NULL,EXTY_ID TECH_ID NOT NULL,MATE_ID_STUDY_OBJECT TECH_ID,PERS_ID_REGISTERER TECH_ID,REGISTRATION_TIMESTAMP TIME_STAMP NOT NULL DEFAULT CURRENT_TIMESTAMP,DESCRIPTION DESCRIPTION_250,PROJ_ID TECH_ID NOT NULL) ;\\012\\012ALTER TABLE EXPERIMENT_PROPERTIES ADD CONSTRAINT EXPR_PK PRIMARY KEY(ID);\\012ALTER TABLE EXPERIMENT_TYPES ADD CONSTRAINT EXTY_PK PRIMARY KEY(ID);\\012ALTER TABLE DATA_VALUES ADD CONSTRAINT DAVA_PK PRIMARY KEY(ID);\\012ALTER TABLE PERSONS ADD CONSTRAINT PERS_PK PRIMARY KEY(ID);\\012ALTER TABLE FILE_FORMAT_TYPES ADD CONSTRAINT FFTY_PK PRIMARY KEY(ID);\\012ALTER TABLE SAMPLE_INPUTS ADD CONSTRAINT SAIN_PK PRIMARY KEY(ID);\\012ALTER TABLE OBSERVABLE_TYPES ADD CONSTRAINT OBTY_PK PRIMARY KEY(ID);\\012ALTER TABLE LOCATOR_TYPES ADD CONSTRAINT LOTY_PK PRIMARY KEY(ID);\\012ALTER TABLE SAMPLE_COMPONENTS ADD CONSTRAINT SACO_PK PRIMARY KEY(ID);\\012ALTER TABLE SAMPLE_TYPES ADD CONSTRAINT SATY_PK PRIMARY KEY(ID);\\012ALTER TABLE ORGANIZATIONS ADD CONSTRAINT ORGA_PK PRIMARY KEY(ID);\\012ALTER TABLE PROCEDURES ADD CONSTRAINT PROC_PK PRIMARY KEY(ID);\\012ALTER TABLE PROCEDURE_TYPES ADD CONSTRAINT PCTY_PK PRIMARY KEY(ID);\\012ALTER TABLE PROJECTS ADD CONSTRAINT PROJ_PK PRIMARY KEY(ID);\\012ALTER TABLE SAMPLE_COMPONENT_MATERIALS ADD CONSTRAINT SCMA_PK PRIMARY KEY(ID);\\012ALTER TABLE EXTERNAL_DATA ADD CONSTRAINT EXDA_PK PRIMARY KEY(DATA_ID);\\012ALTER TABLE DATA ADD CONSTRAINT DATA_PK PRIMARY KEY(ID);\\012ALTER TABLE SAMPLES ADD CONSTRAINT SAMP_PK PRIMARY KEY(ID);\\012ALTER TABLE MATERIAL_TYPES ADD CONSTRAINT MATY_PK PRIMARY KEY(ID);\\012ALTER TABLE MATERIAL_BATCHES ADD CONSTRAINT MABA_PK PRIMARY KEY(ID);\\012ALTER TABLE MATERIALS ADD CONSTRAINT MATE_PK PRIMARY KEY(ID);\\012ALTER TABLE MOLECULES ADD CONSTRAINT MOLE_PK PRIMARY KEY(MATE_ID);\\012ALTER TABLE EXPERIMENTS ADD CONSTRAINT EXPE_PK PRIMARY KEY(ID);\\012ALTER TABLE EXPERIMENT_PROPERTIES ADD CONSTRAINT EXPR_BK_UK UNIQUE(EXPE_ID,FILE_NAME,VERSION);\\012ALTER TABLE EXPERIMENT_TYPES ADD CONSTRAINT EXTY_BK_UK UNIQUE(CODE);\\012ALTER TABLE DATA_VALUES ADD CONSTRAINT DAVA_BK_UK UNIQUE(DATA_ID,SACO_ID);\\012ALTER TABLE PERSONS ADD CONSTRAINT PERS_BK_UK UNIQUE(USER_ID);\\012ALTER TABLE FILE_FORMAT_TYPES ADD CONSTRAINT FFTY_BK_UK UNIQUE(CODE);\\012ALTER TABLE SAMPLE_INPUTS ADD CONSTRAINT SAIN_BK_UK UNIQUE(SAMP_ID,PROC_ID);\\012ALTER TABLE OBSERVABLE_TYPES ADD CONSTRAINT OBTY_BK_UK UNIQUE(CODE);\\012ALTER TABLE LOCATOR_TYPES ADD CONSTRAINT LOTY_BK_UK UNIQUE(CODE);\\012ALTER TABLE SAMPLE_COMPONENTS ADD CONSTRAINT SACO_BK_UK UNIQUE(CODE,SAMP_ID);\\012ALTER TABLE SAMPLE_TYPES ADD CONSTRAINT SATY_BK_UK UNIQUE(CODE);\\012ALTER TABLE ORGANIZATIONS ADD CONSTRAINT ORGA_BK_UK UNIQUE(CODE);\\012ALTER TABLE PROCEDURE_TYPES ADD CONSTRAINT PCTY_BK_UK UNIQUE(CODE);\\012ALTER TABLE PROJECTS ADD CONSTRAINT PROJ_BK_UK UNIQUE(CODE,ORGA_ID);\\012ALTER TABLE SAMPLE_COMPONENT_MATERIALS ADD CONSTRAINT SCMA_BK_UK UNIQUE(MABA_ID,SACO_ID);\\012ALTER TABLE EXTERNAL_DATA ADD CONSTRAINT EXDA_BK_UK UNIQUE(LOCATION);\\012ALTER TABLE SAMPLES ADD CONSTRAINT SAMP_BK_UK UNIQUE(CODE);\\012ALTER TABLE MATERIAL_TYPES ADD CONSTRAINT MATY_UK UNIQUE(CODE);\\012ALTER TABLE MATERIAL_TYPES ADD CONSTRAINT MATY_BK_UK UNIQUE(CODE);\\012ALTER TABLE MATERIALS ADD CONSTRAINT MATE_BK_UK UNIQUE(CODE);\\012--\\012--  Temporarily not created, due to data quality issues with the master plate layout data\\012--\\012-- ALTER TABLE MOLECULES ADD CONSTRAINT MOLE_BK_UK UNIQUE(SEQUENCE);\\012ALTER TABLE EXPERIMENTS ADD CONSTRAINT EXPE_BK_UK UNIQUE(CODE,PROJ_ID);\\012\\012ALTER TABLE DATA ADD CONSTRAINT DATA_SAMP_ARC_CK CHECK ((samp_id_acquired_from IS NOT NULL \\012and samp_id_derived_from IS NULL) \\012or (samp_id_acquired_from IS NULL \\012and samp_id_derived_from IS NOT NULL)) ;\\012ALTER TABLE EXPERIMENT_PROPERTIES ADD CONSTRAINT EXPR_PERS_FK FOREIGN KEY (PERS_ID_REGISTERER)REFERENCES PERSONS(ID);\\012ALTER TABLE EXPERIMENT_PROPERTIES ADD CONSTRAINT EXPR_EXPE_FK FOREIGN KEY (EXPE_ID)REFERENCES EXPERIMENTS(ID);\\012ALTER TABLE DATA_VALUES ADD CONSTRAINT DAVA_DATA_FK FOREIGN KEY (DATA_ID)REFERENCES DATA(ID);\\012ALTER TABLE DATA_VALUES ADD CONSTRAINT DAVA_SACO_FK FOREIGN KEY (SACO_ID)REFERENCES SAMPLE_COMPONENTS(ID);\\012ALTER TABLE SAMPLE_INPUTS ADD CONSTRAINT SAIN_PROC_FK FOREIGN KEY (PROC_ID)REFERENCES PROCEDURES(ID);\\012ALTER TABLE SAMPLE_INPUTS ADD CONSTRAINT SAIN_SAMP_FK FOREIGN KEY (SAMP_ID)REFERENCES SAMPLES(ID);\\012ALTER TABLE SAMPLE_COMPONENTS ADD CONSTRAINT SACO_SAMP_FK FOREIGN KEY (SAMP_ID)REFERENCES SAMPLES(ID);\\012ALTER TABLE PROCEDURES ADD CONSTRAINT PROC_PCTY_FK FOREIGN KEY (PCTY_ID)REFERENCES PROCEDURE_TYPES(ID);\\012ALTER TABLE PROCEDURES ADD CONSTRAINT PROC_PERS_FK FOREIGN KEY (PERS_ID)REFERENCES PERSONS(ID);\\012ALTER TABLE PROCEDURES ADD CONSTRAINT PROC_EXPE_FK FOREIGN KEY (EXPE_ID)REFERENCES EXPERIMENTS(ID);\\012ALTER TABLE PROJECTS ADD CONSTRAINT PROJ_ORGA_FK FOREIGN KEY (ORGA_ID)REFERENCES ORGANIZATIONS(ID);\\012ALTER TABLE SAMPLE_COMPONENT_MATERIALS ADD CONSTRAINT SCMA_MABA_FK FOREIGN KEY (MABA_ID)REFERENCES MATERIAL_BATCHES(ID);\\012ALTER TABLE SAMPLE_COMPONENT_MATERIALS ADD CONSTRAINT SCMA_SACO_FK FOREIGN KEY (SACO_ID)REFERENCES SAMPLE_COMPONENTS(ID);\\012ALTER TABLE EXTERNAL_DATA ADD CONSTRAINT EXDA_DATA_FK FOREIGN KEY (DATA_ID)REFERENCES DATA(ID);\\012ALTER TABLE EXTERNAL_DATA ADD CONSTRAINT EXDA_LOTY_FK FOREIGN KEY (LOTY_ID)REFERENCES LOCATOR_TYPES(ID);\\012ALTER TABLE EXTERNAL_DATA ADD CONSTRAINT EXDA_FFTY_FK FOREIGN KEY (FFTY_ID)REFERENCES FILE_FORMAT_TYPES(ID);\\012ALTER TABLE DATA ADD CONSTRAINT DATA_SAMP_DERIVED_FROM_FK FOREIGN KEY (SAMP_ID_DERIVED_FROM)REFERENCES SAMPLES(ID);\\012ALTER TABLE DATA ADD CONSTRAINT DATA_SAMP_FK FOREIGN KEY (SAMP_ID_ACQUIRED_FROM)REFERENCES SAMPLES(ID);\\012ALTER TABLE DATA ADD CONSTRAINT DATA_PROC_FK FOREIGN KEY (PROC_ID_ACQUIRED_BY)REFERENCES PROCEDURES(ID);\\012ALTER TABLE DATA ADD CONSTRAINT DATA_OBTY_FK FOREIGN KEY (OBTY_ID)REFERENCES OBSERVABLE_TYPES(ID);\\012ALTER TABLE SAMPLES ADD CONSTRAINT SAMP_PERS_FK FOREIGN KEY (PERS_ID_REGISTERER)REFERENCES PERSONS(ID);\\012ALTER TABLE SAMPLES ADD CONSTRAINT SAMP_PROC_FK FOREIGN KEY (PROC_ID)REFERENCES PROCEDURES(ID);\\012ALTER TABLE SAMPLES ADD CONSTRAINT SAMP_SAMP_FK_GENERATED_FROM FOREIGN KEY (SAMP_ID_GENERATED_FROM)REFERENCES SAMPLES(ID);\\012ALTER TABLE SAMPLES ADD CONSTRAINT SAMP_SAMP_FK_TOP FOREIGN KEY (SAMP_ID_TOP)REFERENCES SAMPLES(ID);\\012ALTER TABLE SAMPLES ADD CONSTRAINT SAMP_SATY_FK FOREIGN KEY (SATY_ID)REFERENCES SAMPLE_TYPES(ID);\\012ALTER TABLE MATERIAL_BATCHES ADD CONSTRAINT MABA_PERS_FK FOREIGN KEY (PERS_ID_REGISTERER)REFERENCES PERSONS(ID);\\012ALTER TABLE MATERIAL_BATCHES ADD CONSTRAINT MABA_MATE_FK FOREIGN KEY (MATE_ID)REFERENCES MATERIALS(ID);\\012ALTER TABLE MATERIAL_BATCHES ADD CONSTRAINT MABA_PROC_FK FOREIGN KEY (PROC_ID)REFERENCES PROCEDURES(ID);\\012ALTER TABLE MATERIALS ADD CONSTRAINT MATE_MATY_FK FOREIGN KEY (MATY_ID)REFERENCES MATERIAL_TYPES(ID);\\012ALTER TABLE MATERIALS ADD CONSTRAINT MATE_PERS_FK FOREIGN KEY (PERS_ID_REGISTERER)REFERENCES PERSONS(ID);\\012ALTER TABLE MOLECULES ADD CONSTRAINT MOLE_MATE_FK FOREIGN KEY (MATE_ID)REFERENCES MATERIALS(ID);\\012ALTER TABLE MOLECULES ADD CONSTRAINT MOLE_MOLE_FK FOREIGN KEY (MOLE_ID_INHIBITOR_OF)REFERENCES MOLECULES(MATE_ID);\\012ALTER TABLE EXPERIMENTS ADD CONSTRAINT EXPE_MATE_FK FOREIGN KEY (MATE_ID_STUDY_OBJECT)REFERENCES MATERIALS(ID);\\012ALTER TABLE EXPERIMENTS ADD CONSTRAINT EXPE_EXTY_FK FOREIGN KEY (EXTY_ID)REFERENCES EXPERIMENT_TYPES(ID);\\012ALTER TABLE EXPERIMENTS ADD CONSTRAINT EXPE_PERS_FK FOREIGN KEY (PERS_ID_REGISTERER)REFERENCES PERSONS(ID);\\012ALTER TABLE EXPERIMENTS ADD CONSTRAINT EXPE_PROJ_FK FOREIGN KEY (PROJ_ID)REFERENCES PROJECTS(ID);\\012\\012\\012\\012--  Creating Sequences\\012\\012CREATE SEQUENCE EXPERIMENT_PROPERTY_ID_SEQ;\\012\\012CREATE SEQUENCE PROCEDURE_TYPE_ID_SEQ;\\012\\012CREATE SEQUENCE SAMPLE_INPUT_ID_SEQ;\\012\\012CREATE SEQUENCE SAMPLE_TYPE_ID_SEQ;\\012\\012CREATE SEQUENCE LOCATOR_TYPE_ID_SEQ;\\012\\012CREATE SEQUENCE SAMPLE_ID_SEQ;\\012\\012CREATE SEQUENCE EXPERIMENT_ID_SEQ;\\012\\012CREATE SEQUENCE MATERIAL_BATCH_ID_SEQ;\\012\\012CREATE SEQUENCE OBSERVABLE_TYPE_ID_SEQ;\\012\\012CREATE SEQUENCE SAMPLE_COMPONENT_ID_SEQ;\\012\\012CREATE SEQUENCE MATERIAL_ID_SEQ;\\012\\012CREATE SEQUENCE DATA_ID_SEQ;\\012\\012--  Creating Sequence for the SAMPLE_COMPONENT_MATERIALS table (standard naming convention was too long)\\012CREATE SEQUENCE SCMA_ID_SEQ;\\012\\012CREATE SEQUENCE PROCEDURE_ID_SEQ;\\012\\012CREATE SEQUENCE FILE_FORMAT_TYPE_ID_SEQ;\\012\\012CREATE SEQUENCE MATERIAL_TYPE_ID_SEQ;\\012\\012CREATE SEQUENCE EXPERIMENT_TYPE_ID_SEQ;\\012\\012CREATE SEQUENCE PERSON_ID_SEQ;\\012\\012CREATE SEQUENCE ORGANIZATION_ID_SEQ;\\012\\012CREATE SEQUENCE PROJECT_ID_SEQ;\\012\\012CREATE SEQUENCE DATA_VALUE_ID_SEQ;\\012\\012\\012\\012/*\\012   Trigger Section\\012   ===============*/\\012\\012CREATE OR REPLACE FUNCTION br001_crtl_plate_chk() RETURNS trigger AS $br001_crtl_plate_chk$\\012DECLARE\\012   cnt           INTEGER;\\012   v_cell_plate  CODE;\\012BEGIN\\012\\012   select code into v_cell_plate from sample_types where id  = NEW.saty_id;\\012\\012   -- Check if the sample is of type "Cell Plate"\\012   if v_cell_plate = 'CELL PLATE' then\\012\\012      -- Check that a Control Plate exists before registering the Cell Plate\\012      select count(*) into cnt from samples s, sample_types st where s.saty_id = st.id and st.code = 'CONTROL LAYOUT';\\011 \\012      IF cnt = 0 THEN\\012\\011\\011 -- Doens't make sense, so comment it out\\012         -- RAISE EXCEPTION 'A Control Plate must exist before you can register Cell Plate: %', NEW.code;\\012      END IF;\\012\\012   end if;\\012\\012   RETURN NEW;\\012\\012END;\\012$br001_crtl_plate_chk$ LANGUAGE plpgsql;\\012\\012\\012CREATE TRIGGER br001_crtl_plate_chk BEFORE INSERT ON samples\\012    FOR EACH ROW EXECUTE PROCEDURE br001_crtl_plate_chk();\\012	\N
+./sourceTest/sql/postgresql/018/006=database_version_logs.tsv:013	source/sql/postgresql/migration/migration-012-013.sql	SUCCESS	2008-05-09 10:11:20.487	----------------------------------------------------------------------------------------------\\012--  File: migration-012-013.sql\\012--\\012-- \\012--  This script enables the migration of the database schema from 012 to 013.\\012-- \\012--  Update History\\012--\\012--\\012--\\011Who\\011\\011\\011\\011\\011\\011\\011When\\011\\011\\011\\011What\\012--\\011---\\011\\011\\011\\011\\011\\011\\011----\\011\\011\\011\\011----\\012--\\011Bernd Rinn\\011\\0112008-01-04\\011Initial Version - add support for invalidations and material type BACTERIUM \\012--\\011Bernd Rinn\\011\\0112008-01-05\\011Add material type COMPOUND and material type property type entries for the new material types \\012--  \\012----------------------------------------------------------------------------------------------\\012\\012------------------------------------------------------------------------------------\\012--  Purpose:  Create function RENAME_SEQUENCE() that is required for renaming the sequences belonging to tables\\012------------------------------------------------------------------------------------\\012\\012CREATE FUNCTION RENAME_SEQUENCE(OLD_NAME VARCHAR, NEW_NAME VARCHAR) RETURNS INTEGER AS $$\\012DECLARE\\012  CURR_SEQ_VAL   INTEGER;\\012BEGIN\\012  SELECT INTO CURR_SEQ_VAL NEXTVAL(OLD_NAME);\\012  EXECUTE 'CREATE SEQUENCE ' || NEW_NAME || ' START WITH ' || CURR_SEQ_VAL;\\012  EXECUTE 'DROP SEQUENCE ' || OLD_NAME;\\012  RETURN CURR_SEQ_VAL;\\012END;\\012$$ LANGUAGE 'plpgsql';\\012\\012\\012------------------------------------------------------------------------------------\\012--  Purpose:  Add table INVALIDATIONS to store invalidations\\012------------------------------------------------------------------------------------\\012\\012CREATE TABLE INVALIDATIONS (ID TECH_ID NOT NULL,PERS_ID_REGISTERER TECH_ID NOT NULL,REGISTRATION_TIMESTAMP TIME_STAMP NOT NULL DEFAULT CURRENT_TIMESTAMP,REASON DESCRIPTION_250);\\012ALTER TABLE INVALIDATIONS ADD CONSTRAINT INVA_PK PRIMARY KEY(ID);\\012ALTER TABLE INVALIDATIONS ADD CONSTRAINT INVA_PERS_FK FOREIGN KEY (PERS_ID_REGISTERER) REFERENCES PERSONS(ID);\\012CREATE SEQUENCE INVALIDATION_ID_SEQ;\\012CREATE INDEX INVA_PERS_FK_I ON INVALIDATIONS (PERS_ID_REGISTERER);\\012\\012------------------------------------------------------------------------------------\\012--  Purpose:  Add column INVA_ID to table SAMPLES in order to allow invalidation of samples  \\012------------------------------------------------------------------------------------\\012\\012ALTER TABLE SAMPLES ADD INVA_ID TECH_ID;\\012ALTER TABLE SAMPLES ADD CONSTRAINT SAMP_INVA_FK FOREIGN KEY (INVA_ID) REFERENCES INVALIDATIONS(ID);\\012CREATE INDEX SAMP_INVA_FK_I ON SAMPLES (INVA_ID);\\012\\012\\012------------------------------------------------------------------------------------\\012--  Purpose:  Rename table EXPERIMENT_PROPERTIES TO EXPERIMENT_ATTACHMENTS  \\012------------------------------------------------------------------------------------\\012\\012ALTER TABLE EXPERIMENT_PROPERTIES DROP CONSTRAINT EXPR_PK;\\012ALTER TABLE EXPERIMENT_PROPERTIES DROP CONSTRAINT EXPR_BK_UK;\\012ALTER TABLE EXPERIMENT_PROPERTIES DROP CONSTRAINT EXPR_EXPE_FK;\\012ALTER TABLE EXPERIMENT_PROPERTIES DROP CONSTRAINT EXPR_PERS_FK;\\012\\012ALTER TABLE EXPERIMENT_PROPERTIES RENAME TO EXPERIMENT_ATTACHMENTS;\\012ALTER INDEX EXPR_EXPE_FK_I RENAME TO EXAT_EXPE_FK_I;\\012ALTER INDEX EXPR_PERS_FK_I RENAME TO EXAT_PERS_FK_I;\\012SELECT RENAME_SEQUENCE('EXPERIMENT_PROPERTY_ID_SEQ', 'EXPERIMENT_ATTACHMENT_ID_SEQ');\\012\\012ALTER TABLE EXPERIMENT_ATTACHMENTS ADD CONSTRAINT EXAT_PK PRIMARY KEY(ID);\\012ALTER TABLE EXPERIMENT_ATTACHMENTS ADD CONSTRAINT EXAT_BK_UK UNIQUE(EXPE_ID,FILE_NAME,VERSION);\\012ALTER TABLE EXPERIMENT_ATTACHMENTS ADD CONSTRAINT EXAT_EXPE_FK FOREIGN KEY (EXPE_ID) REFERENCES EXPERIMENTS(ID);\\012ALTER TABLE EXPERIMENT_ATTACHMENTS ADD CONSTRAINT EXAT_PERS_FK FOREIGN KEY (PERS_ID_REGISTERER) REFERENCES PERSONS(ID);\\012\\012\\012------------------------------------------------------------------------------------\\012--  Purpose:  Add the material type BACTERIUM\\012------------------------------------------------------------------------------------\\012\\012insert into material_types\\012(id\\012,code\\012,description)\\012values \\012(nextval('MATERIAL_TYPE_ID_SEQ')\\012,'BACTERIUM'\\012,'Bacterium'\\012);\\012\\012------------------------------------------------------------------------------------\\012--  Purpose:  Add the material type COMPOUND\\012------------------------------------------------------------------------------------\\012\\012insert into material_types\\012(id\\012,code\\012,description)\\012values \\012(nextval('MATERIAL_TYPE_ID_SEQ')\\012,'COMPOUND'\\012,'Compound'\\012);\\012\\012------------------------------------------------------------------------------------\\012--  Purpose:  Insert an initial data set into the table MATERIAL_TYPE_PROPERTY_TYPES\\012------------------------------------------------------------------------------------\\012\\012   -----------------------\\012   --  Material Type BACTERIUM\\012   -----------------------\\012\\012insert into material_type_property_types\\012(   id\\012   ,maty_id\\012   ,prty_id\\012   ,is_mandatory\\012   ,pers_id_registerer\\012   )\\012values \\012   (nextval('MTPT_ID_SEQ')\\012   ,(select id from material_types where code = 'BACTERIUM')\\012   ,(select id from property_types where code = 'DESCRIPTION')\\012   ,true\\012   ,(select id from persons where user_id ='system')\\012);\\012\\012   -----------------------\\012   --  Material Type COMPOUND\\012   -----------------------\\012\\012insert into material_type_property_types\\012(   id\\012   ,maty_id\\012   ,prty_id\\012   ,is_mandatory\\012   ,pers_id_registerer\\012   )\\012values \\012   (nextval('MTPT_ID_SEQ')\\012   ,(select id from material_types where code = 'COMPOUND')\\012   ,(select id from property_types where code = 'DESCRIPTION')\\012   ,true\\012   ,(select id from persons where user_id ='system')\\012);\\012\\012\\012------------------------------------------------------------------------------------\\012--  Purpose:  Change according to naming convention for CODEs\\012------------------------------------------------------------------------------------\\012\\012update procedure_types set code='DATA_ACQUISITION' where code='DATA ACQUISITION';\\012update procedure_types set code='IMAGE_ANALYSIS' where code='IMAGE ANALYSIS';\\012update locator_types set code='RELATIVE_LOCATION' where code='RELATIVE LOCATION';\\012update sample_types set code='MASTER_PLATE' where code='MASTER PLATE';\\012update sample_types set code='DILUTION_PLATE' where code='DILUTION PLATE';\\012update sample_types set code='CELL_PLATE' where code='CELL PLATE';\\012update sample_types set code='REINFECT_PLATE' where code='REINFECT PLATE';\\012update sample_types set description='Re-infection Plate' where code='REINFECT_PLATE';\\012update sample_types set code='CONTROL_LAYOUT' where code='CONTROL LAYOUT';\\012	\N
+./sourceTest/sql/postgresql/018/006=database_version_logs.tsv:014	source/sql/postgresql/migration/migration-013-014.sql	SUCCESS	2008-05-09 10:11:22.523	----------------------------------------------------------------------------------------------\\012--  File: migration-013-014.sql\\012--\\012-- \\012--  This script enables the migration of the database schema from 013 to 014.\\012-- \\012--  Update History\\012--\\012--\\012--\\011Who\\011\\011\\011When\\011\\011What\\012--\\011---\\011\\011\\011----\\011\\011----\\012--\\011Charles Ramin-Wright\\0112008-01-29\\011Initial Version \\012--  \\012----------------------------------------------------------------------------------------------\\012\\012--=================================\\012-- New Tables and related objects\\012--=================================\\012\\012------------------------------------------------------------------------------------\\012--  Purpose:  Add tables CONTROLLED_VOCABULARIES and CONTROLLED_VOCABULARY_TERMS\\012------------------------------------------------------------------------------------\\012\\012CREATE TABLE CONTROLLED_VOCABULARIES (ID TECH_ID NOT NULL,CODE CODE NOT NULL,DESCRIPTION DESCRIPTION_80,REGISTRATION_TIMESTAMP TIME_STAMP NOT NULL DEFAULT CURRENT_TIMESTAMP,PERS_ID TECH_ID NOT NULL);\\012CREATE TABLE CONTROLLED_VOCABULARY_TERMS (ID TECH_ID NOT NULL,CODE OBJECT_NAME NOT NULL,REGISTRATION_TIMESTAMP TIME_STAMP NOT NULL DEFAULT CURRENT_TIMESTAMP,COVO_ID TECH_ID NOT NULL,PERS_ID TECH_ID NOT NULL);\\012\\012\\012-- Creating primary key constraints\\012\\012ALTER TABLE CONTROLLED_VOCABULARIES ADD CONSTRAINT COVO_PK PRIMARY KEY(ID);\\012ALTER TABLE CONTROLLED_VOCABULARY_TERMS ADD CONSTRAINT CVTE_PK PRIMARY KEY(ID);\\012\\012-- Creating unique constraints\\012\\012ALTER TABLE CONTROLLED_VOCABULARIES ADD CONSTRAINT COVO_BK_UK UNIQUE(CODE);\\012ALTER TABLE CONTROLLED_VOCABULARY_TERMS ADD CONSTRAINT CVTE_BK_UK UNIQUE(CODE,COVO_ID);\\012\\012-- Creating foreign key constraints\\012\\012ALTER TABLE CONTROLLED_VOCABULARIES ADD CONSTRAINT COVO_PERS_FK FOREIGN KEY (PERS_ID) REFERENCES PERSONS(ID);\\012ALTER TABLE CONTROLLED_VOCABULARY_TERMS ADD CONSTRAINT CVTE_COVO_FK FOREIGN KEY (COVO_ID) REFERENCES CONTROLLED_VOCABULARIES(ID);\\012ALTER TABLE CONTROLLED_VOCABULARY_TERMS ADD CONSTRAINT CVTE_PERS_FK FOREIGN KEY (PERS_ID) REFERENCES PERSONS(ID);\\012\\012-- Creating sequences\\012\\012CREATE SEQUENCE CONTROLLED_VOCABULARY_ID_SEQ;\\012CREATE SEQUENCE CVTE_ID_SEQ;\\012\\012\\012-- Creating indexes\\012\\012CREATE INDEX COVO_PERS_FK_I ON CONTROLLED_VOCABULARIES (PERS_ID);\\012CREATE INDEX CVTE_COVO_FK_I ON CONTROLLED_VOCABULARY_TERMS (COVO_ID);\\012CREATE INDEX CVTE_PERS_FK_I ON CONTROLLED_VOCABULARY_TERMS (PERS_ID);\\012\\012\\012--====================================\\012-- Modifications of existing objects\\012--====================================\\012\\012---------------------------------------------------------------------------------------------------\\012--  Purpose:  Add column INVA_ID to table EXPERIMENTS in order to allow invalidation of experiments\\012---------------------------------------------------------------------------------------------------\\012\\012ALTER TABLE EXPERIMENTS ADD INVA_ID TECH_ID;\\012ALTER TABLE EXPERIMENTS ADD CONSTRAINT EXPE_INVA_FK FOREIGN KEY (INVA_ID) REFERENCES INVALIDATIONS(ID);\\012CREATE INDEX EXPE_INVA_FK_I ON EXPERIMENTS (INVA_ID);\\012\\012------------------------------------------------------------------------------------\\012--  Purpose:  Add column SAMP_ID_CONTROL_LAYOUT to table SAMPLES in order to allow \\012--            the association of a sample of type CONTROL_LAYOUT to samples\\012------------------------------------------------------------------------------------\\012\\012ALTER TABLE SAMPLES ADD SAMP_ID_CONTROL_LAYOUT TECH_ID;\\012ALTER TABLE SAMPLES ADD CONSTRAINT SAMP_SAMP_FK_CONTROL_LAYOUT FOREIGN KEY (SAMP_ID_CONTROL_LAYOUT) REFERENCES SAMPLES(ID);\\012CREATE INDEX SAMP_SAMP_FK_I_CONTROL_LAYOUT ON SAMPLES (SAMP_ID_CONTROL_LAYOUT);\\012\\012\\012--------------------------------------------------------------\\012--  Purpose:  Add column CVTE_ID to table MATERIAL_PROPERTIES \\012--------------------------------------------------------------\\012ALTER TABLE MATERIAL_PROPERTIES ADD CVTE_ID TECH_ID;\\012ALTER TABLE MATERIAL_PROPERTIES ADD CONSTRAINT MAPR_CVTE_FK FOREIGN KEY (CVTE_ID) REFERENCES CONTROLLED_VOCABULARY_TERMS(ID);\\012CREATE INDEX MAPR_CVTE_FK_I ON MATERIAL_PROPERTIES (CVTE_ID);\\012\\012--------------------------------------------------------------\\012--  Purpose:  Change column VALUE from mandatory to optional\\012--------------------------------------------------------------\\012ALTER TABLE MATERIAL_PROPERTIES ALTER VALUE DROP NOT NULL;\\012\\012-- Creating check constraints\\012\\012ALTER TABLE MATERIAL_PROPERTIES ADD CONSTRAINT VALUE_OR_CVTE_ID CHECK ((value IS NOT NULL and cvte_id IS NULL) or (value IS NULL and cvte_id IS NOT NULL));\\012\\012\\012--------------------------------------------------------------\\012--  Purpose:  Add column COVO_ID to table PROPERTY_TYPES  \\012--------------------------------------------------------------\\012ALTER TABLE PROPERTY_TYPES ADD COVO_ID TECH_ID;\\012ALTER TABLE PROPERTY_TYPES ADD CONSTRAINT PRTY_COVO_FK FOREIGN KEY (COVO_ID) REFERENCES CONTROLLED_VOCABULARIES(ID);\\012CREATE INDEX PRTY_COVO_FK_I ON PROPERTY_TYPES (COVO_ID);\\012\\012\\012------------------------------------------------------------------------------------\\012--  Purpose:  Create trigger CONTROLLED_VOCABULARY_CHECK \\012------------------------------------------------------------------------------------\\012\\012CREATE OR REPLACE FUNCTION CONTROLLED_VOCABULARY_CHECK() RETURNS trigger AS $$\\012DECLARE\\012   cnt     INTEGER;\\012   v_code  CODE;\\012BEGIN\\012\\012   select code into v_code from data_types where id  = NEW.daty_id;\\012\\012   -- Check if the data is of type "CONTROLLEDVOCABULARY"\\012   if v_code = 'CONTROLLEDVOCABULARY' then\\012      if NEW.covo_id IS NULL then\\012         RAISE EXCEPTION 'Insert/Update of Property Type (Code: %) failed, as its Data Type is CONTROLLEDVOCABULARY, but it is not linked to a Controlled Vocabulary.', NEW.code;\\012      end if;\\012   end if;\\012\\012   RETURN NEW;\\012\\012END;\\012$$ LANGUAGE 'plpgsql';\\012\\012\\012CREATE TRIGGER CONTROLLED_VOCABULARY_CHECK BEFORE INSERT OR UPDATE ON PROPERTY_TYPES\\012    FOR EACH ROW EXECUTE PROCEDURE CONTROLLED_VOCABULARY_CHECK();\\012\\012\\012--====================================\\012-- Deletion of existing objects\\012--====================================\\012\\012drop trigger br001_crtl_plate_chk on samples;\\012drop function br001_crtl_plate_chk();\\012\\012\\012--====================================\\012-- Add Master Data\\012--====================================\\012\\012-----------------------------------------------------------------------------------\\012--  Purpose:  Insert into the table DATA_TYPES\\012--\\012--            Create the data type CONTROLLEDVOCABULARY.\\012-----------------------------------------------------------------------------------\\012insert into data_types\\012(id\\012,code\\012,description)\\012values \\012(nextval('DATA_TYPE_ID_SEQ')\\012,'CONTROLLEDVOCABULARY'\\012,'Controlled Vocabulary'\\012);\\012\\012--==========================================\\012--\\012--   Data Migration\\012--\\012--==========================================\\012\\012-----------------------------------------------------------------------------------\\012--  Purpose:  Migrate the CONTROL_LAYOUTs from the SAMPLE_INPUTS table \\012--            to the foreign key SAMP_SAMP_FK_CONTROL_LAYOUT in the SAMPLES table\\012--\\012--            This results in having all CONTROL_LAYOUTs being directly linked \\012--            to CELL_PLATEs.            \\012-----------------------------------------------------------------------------------\\012\\012UPDATE samples cell_plate\\012   SET samp_id_control_layout = \\012          (select control_layout.samp_id\\012           from   sample_inputs control_layout inner join samples s \\012           on     control_layout.samp_id = s.id\\012           where  s.saty_id = (select id from sample_types where code = 'CONTROL_LAYOUT')\\012           and    proc_id = (\\012              select  proc_id\\012              from sample_inputs cp\\012              where cp.samp_id = cell_plate.id))\\012   WHERE saty_id = (select id from sample_types where code = 'CELL_PLATE')\\012   and   id = (select distinct (samp_id)\\012                  from   sample_inputs sain inner join samples s2 \\012                  on  sain.samp_id = cell_plate.id)\\012;\\012\\012-----------------------------------------------------------------------------------\\012--   Delete the CONTROL LAYOUTs from the SAMPLE_INPUTS table\\012-----------------------------------------------------------------------------------\\012\\012delete from sample_inputs\\012where  id in (select si.id \\012              from   sample_inputs si inner join samples s \\012              on     si.samp_id = s.id\\012              where  s.saty_id = (select id from sample_types where code = 'CONTROL_LAYOUT')\\012              )\\012;\\012\\012	\N
+./sourceTest/sql/postgresql/018/006=database_version_logs.tsv:016	source/sql/postgresql/migration/migration-015-016.sql	SUCCESS	2008-05-09 10:12:52.062	----------------------------------------------------------------------------------------------\\012--  File: migration-015-016.sql\\012--\\012-- \\012--  This script enables the migration of the database schema from 015 to 016.\\012-- \\012--  Update History\\012--\\012--\\012--\\011Who\\011\\011\\011When\\011\\011What\\012--\\011---\\011\\011\\011----\\011\\011----\\012--\\011Bernd Rinn\\0112008-03-22\\011Initial Version \\012--  \\012----------------------------------------------------------------------------------------------\\012\\012\\012--=================================\\012-- New Domains\\012--=================================\\012\\012-----------------------------------------------------------------------------------\\012--  Purpose:  Change all CODE columns to LONG_CODE, then re-create DOMAIN CODE identical to LONG_CODE\\012--  and change LONG_CODE columns back to the (new) CODE \\012-----------------------------------------------------------------------------------\\012\\012-- First step: create new domain LONG_CODE\\012CREATE DOMAIN LONG_CODE AS VARCHAR(40);\\012\\012-- Second step: change all CODE to LONG_CODE\\012ALTER TABLE CONTROLLED_VOCABULARIES ALTER COLUMN CODE TYPE LONG_CODE;\\012ALTER TABLE DATA_TYPES ALTER COLUMN CODE TYPE LONG_CODE;\\012ALTER TABLE EXPERIMENTS ALTER COLUMN CODE TYPE LONG_CODE;\\012ALTER TABLE EXPERIMENT_TYPES ALTER COLUMN CODE TYPE LONG_CODE;\\012ALTER TABLE FILE_FORMAT_TYPES ALTER COLUMN CODE TYPE LONG_CODE;\\012ALTER TABLE LOCATOR_TYPES ALTER COLUMN CODE TYPE LONG_CODE;\\012ALTER TABLE MATERIALS ALTER COLUMN CODE TYPE LONG_CODE;\\012ALTER TABLE MATERIAL_BATCHES ALTER COLUMN CODE TYPE LONG_CODE;\\012ALTER TABLE MATERIAL_TYPES ALTER COLUMN CODE TYPE LONG_CODE;\\012ALTER TABLE OBSERVABLE_TYPES ALTER COLUMN CODE TYPE LONG_CODE;\\012ALTER TABLE ORGANIZATIONS ALTER COLUMN CODE TYPE LONG_CODE;\\012ALTER TABLE PROCEDURE_TYPES ALTER COLUMN CODE TYPE LONG_CODE;\\012ALTER TABLE PROJECTS ALTER COLUMN CODE TYPE LONG_CODE;\\012ALTER TABLE PROPERTY_TYPES ALTER COLUMN CODE TYPE LONG_CODE;\\012ALTER TABLE SAMPLES ALTER COLUMN CODE TYPE LONG_CODE;\\012ALTER TABLE SAMPLE_COMPONENTS ALTER COLUMN CODE TYPE LONG_CODE;\\012ALTER TABLE SAMPLE_TYPES ALTER COLUMN CODE TYPE LONG_CODE;\\012\\012-- Third step: re-create CODE as VARCHAR(40)\\012DROP DOMAIN CODE;\\012CREATE DOMAIN CODE AS VARCHAR(40);\\012\\012-- Forth step: change all LONG_CODE columns back to CODE\\012ALTER TABLE CONTROLLED_VOCABULARIES ALTER COLUMN CODE TYPE CODE;\\012ALTER TABLE DATA_TYPES ALTER COLUMN CODE TYPE CODE;\\012ALTER TABLE EXPERIMENTS ALTER COLUMN CODE TYPE CODE;\\012ALTER TABLE EXPERIMENT_TYPES ALTER COLUMN CODE TYPE CODE;\\012ALTER TABLE FILE_FORMAT_TYPES ALTER COLUMN CODE TYPE CODE;\\012ALTER TABLE LOCATOR_TYPES ALTER COLUMN CODE TYPE CODE;\\012ALTER TABLE MATERIALS ALTER COLUMN CODE TYPE CODE;\\012ALTER TABLE MATERIAL_BATCHES ALTER COLUMN CODE TYPE CODE;\\012ALTER TABLE MATERIAL_TYPES ALTER COLUMN CODE TYPE CODE;\\012ALTER TABLE OBSERVABLE_TYPES ALTER COLUMN CODE TYPE CODE;\\012ALTER TABLE ORGANIZATIONS ALTER COLUMN CODE TYPE CODE;\\012ALTER TABLE PROCEDURE_TYPES ALTER COLUMN CODE TYPE CODE;\\012ALTER TABLE PROJECTS ALTER COLUMN CODE TYPE CODE;\\012ALTER TABLE PROPERTY_TYPES ALTER COLUMN CODE TYPE CODE;\\012ALTER TABLE SAMPLES ALTER COLUMN CODE TYPE CODE;\\012ALTER TABLE SAMPLE_COMPONENTS ALTER COLUMN CODE TYPE CODE;\\012ALTER TABLE SAMPLE_TYPES ALTER COLUMN CODE TYPE CODE;\\012\\012-- Fifth step: drop domain LONG_CODE\\012DROP DOMAIN LONG_CODE;\\012\\012-----------------------------------------------------------------------------------\\012--  Purpose:  Create new domain TIME_STAMP_DFL and change current users of TIME_STAMP to TIME_STAMP_DFL\\012--  This adds time zone information and allows for a clean separation between registration time stamps\\012--  which should have a default of CURRENT_TIMESTAMP and other time stamps which should not. \\012-----------------------------------------------------------------------------------\\012\\012-- First step: create new domain TIME_STAMP_DFL\\012CREATE DOMAIN TIME_STAMP_DFL AS TIMESTAMP WITH TIME ZONE NOT NULL DEFAULT CURRENT_TIMESTAMP;\\012\\012-- Second step: change all TIME_STAMP columns to TIME_STAMP_DFL\\012ALTER TABLE CONTROLLED_VOCABULARIES ALTER COLUMN REGISTRATION_TIMESTAMP TYPE TIME_STAMP_DFL;\\012ALTER TABLE CONTROLLED_VOCABULARIES ALTER COLUMN REGISTRATION_TIMESTAMP DROP NOT NULL;\\012ALTER TABLE CONTROLLED_VOCABULARIES ALTER COLUMN REGISTRATION_TIMESTAMP DROP DEFAULT;\\012ALTER TABLE CONTROLLED_VOCABULARY_TERMS ALTER COLUMN REGISTRATION_TIMESTAMP TYPE TIME_STAMP_DFL;\\012ALTER TABLE CONTROLLED_VOCABULARY_TERMS ALTER COLUMN REGISTRATION_TIMESTAMP DROP NOT NULL;\\012ALTER TABLE CONTROLLED_VOCABULARY_TERMS ALTER COLUMN REGISTRATION_TIMESTAMP DROP DEFAULT;\\012ALTER TABLE DATA ALTER COLUMN REGISTRATION_TIMESTAMP TYPE TIME_STAMP_DFL;\\012ALTER TABLE DATA ALTER COLUMN REGISTRATION_TIMESTAMP DROP NOT NULL;\\012ALTER TABLE DATA ALTER COLUMN REGISTRATION_TIMESTAMP DROP DEFAULT;\\012ALTER TABLE EXPERIMENTS ALTER COLUMN REGISTRATION_TIMESTAMP TYPE TIME_STAMP_DFL;\\012ALTER TABLE EXPERIMENTS ALTER COLUMN REGISTRATION_TIMESTAMP DROP NOT NULL;\\012ALTER TABLE EXPERIMENTS ALTER COLUMN REGISTRATION_TIMESTAMP DROP DEFAULT;\\012ALTER TABLE EXPERIMENT_ATTACHMENTS ALTER COLUMN REGISTRATION_TIMESTAMP TYPE TIME_STAMP_DFL;\\012ALTER TABLE EXPERIMENT_ATTACHMENTS ALTER COLUMN REGISTRATION_TIMESTAMP DROP NOT NULL;\\012ALTER TABLE EXPERIMENT_ATTACHMENTS ALTER COLUMN REGISTRATION_TIMESTAMP DROP DEFAULT;\\012ALTER TABLE EXPERIMENT_PROPERTIES ALTER COLUMN REGISTRATION_TIMESTAMP TYPE TIME_STAMP_DFL;\\012ALTER TABLE EXPERIMENT_PROPERTIES ALTER COLUMN REGISTRATION_TIMESTAMP DROP NOT NULL;\\012ALTER TABLE EXPERIMENT_PROPERTIES ALTER COLUMN REGISTRATION_TIMESTAMP DROP DEFAULT;\\012ALTER TABLE EXPERIMENT_TYPE_PROPERTY_TYPES ALTER COLUMN REGISTRATION_TIMESTAMP TYPE TIME_STAMP_DFL;\\012ALTER TABLE EXPERIMENT_TYPE_PROPERTY_TYPES ALTER COLUMN REGISTRATION_TIMESTAMP DROP NOT NULL;\\012ALTER TABLE EXPERIMENT_TYPE_PROPERTY_TYPES ALTER COLUMN REGISTRATION_TIMESTAMP DROP DEFAULT;\\012ALTER TABLE INVALIDATIONS ALTER COLUMN REGISTRATION_TIMESTAMP TYPE TIME_STAMP_DFL;\\012ALTER TABLE INVALIDATIONS ALTER COLUMN REGISTRATION_TIMESTAMP DROP NOT NULL;\\012ALTER TABLE INVALIDATIONS ALTER COLUMN REGISTRATION_TIMESTAMP DROP DEFAULT;\\012ALTER TABLE MATERIALS ALTER COLUMN REGISTRATION_TIMESTAMP TYPE TIME_STAMP_DFL;\\012ALTER TABLE MATERIALS ALTER COLUMN REGISTRATION_TIMESTAMP DROP NOT NULL;\\012ALTER TABLE MATERIALS ALTER COLUMN REGISTRATION_TIMESTAMP DROP DEFAULT;\\012ALTER TABLE MATERIAL_BATCHES ALTER COLUMN REGISTRATION_TIMESTAMP TYPE TIME_STAMP_DFL;\\012ALTER TABLE MATERIAL_BATCHES ALTER COLUMN REGISTRATION_TIMESTAMP DROP NOT NULL;\\012ALTER TABLE MATERIAL_BATCHES ALTER COLUMN REGISTRATION_TIMESTAMP DROP DEFAULT;\\012ALTER TABLE MATERIAL_PROPERTIES ALTER COLUMN REGISTRATION_TIMESTAMP TYPE TIME_STAMP_DFL;\\012ALTER TABLE MATERIAL_PROPERTIES ALTER COLUMN REGISTRATION_TIMESTAMP DROP NOT NULL;\\012ALTER TABLE MATERIAL_PROPERTIES ALTER COLUMN REGISTRATION_TIMESTAMP DROP DEFAULT;\\012ALTER TABLE MATERIAL_TYPE_PROPERTY_TYPES ALTER COLUMN REGISTRATION_TIMESTAMP TYPE TIME_STAMP_DFL;\\012ALTER TABLE MATERIAL_TYPE_PROPERTY_TYPES ALTER COLUMN REGISTRATION_TIMESTAMP DROP NOT NULL;\\012ALTER TABLE MATERIAL_TYPE_PROPERTY_TYPES ALTER COLUMN REGISTRATION_TIMESTAMP DROP DEFAULT;\\012ALTER TABLE PROCEDURES ALTER COLUMN REGISTRATION_TIMESTAMP TYPE TIME_STAMP_DFL;\\012ALTER TABLE PROCEDURES ALTER COLUMN REGISTRATION_TIMESTAMP DROP NOT NULL;\\012ALTER TABLE PROCEDURES ALTER COLUMN REGISTRATION_TIMESTAMP DROP DEFAULT;\\012ALTER TABLE PROPERTY_TYPES ALTER COLUMN REGISTRATION_TIMESTAMP TYPE TIME_STAMP_DFL;\\012ALTER TABLE PROPERTY_TYPES ALTER COLUMN REGISTRATION_TIMESTAMP DROP NOT NULL;\\012ALTER TABLE PROPERTY_TYPES ALTER COLUMN REGISTRATION_TIMESTAMP DROP DEFAULT;\\012ALTER TABLE SAMPLES ALTER COLUMN REGISTRATION_TIMESTAMP TYPE TIME_STAMP_DFL;\\012ALTER TABLE SAMPLES ALTER COLUMN REGISTRATION_TIMESTAMP DROP NOT NULL;\\012ALTER TABLE SAMPLES ALTER COLUMN REGISTRATION_TIMESTAMP DROP DEFAULT;\\012ALTER TABLE SAMPLE_PROPERTIES ALTER COLUMN REGISTRATION_TIMESTAMP TYPE TIME_STAMP_DFL;\\012ALTER TABLE SAMPLE_PROPERTIES ALTER COLUMN REGISTRATION_TIMESTAMP DROP NOT NULL;\\012ALTER TABLE SAMPLE_PROPERTIES ALTER COLUMN REGISTRATION_TIMESTAMP DROP DEFAULT;\\012ALTER TABLE SAMPLE_TYPE_PROPERTY_TYPES ALTER COLUMN REGISTRATION_TIMESTAMP TYPE TIME_STAMP_DFL;\\012ALTER TABLE SAMPLE_TYPE_PROPERTY_TYPES ALTER COLUMN REGISTRATION_TIMESTAMP DROP NOT NULL;\\012ALTER TABLE SAMPLE_TYPE_PROPERTY_TYPES ALTER COLUMN REGISTRATION_TIMESTAMP DROP DEFAULT;\\012\\012-- Third step: drop old domain TIME_STAMP\\012DROP DOMAIN TIME_STAMP;\\012\\012-- Forth step: create new domain time_stamp\\012CREATE DOMAIN TIME_STAMP AS TIMESTAMP WITH TIME ZONE;\\012\\012--=================================\\012-- New Tables and related objects\\012--=================================\\012\\012------------------------------------------------------------------------------------\\012-- table DATA_SET_RELATIONSHIPS (new)\\012------------------------------------------------------------------------------------\\012\\012-- Creating tables\\012\\012CREATE TABLE DATA_SET_RELATIONSHIPS (ID TECH_ID NOT NULL,DATA_ID_PARENT TECH_ID NOT NULL,DATA_ID_CHILD TECH_ID NOT NULL,REGISTRATION_TIMESTAMP TIME_STAMP_DFL);\\012\\012-- Creating primary key constraints\\012\\012ALTER TABLE DATA_SET_RELATIONSHIPS ADD CONSTRAINT DSRE_PK PRIMARY KEY(ID);\\012\\012-- Creating unique constraints\\012\\012ALTER TABLE DATA_SET_RELATIONSHIPS ADD CONSTRAINT DSRE_BK_UK UNIQUE(DATA_ID_CHILD,DATA_ID_PARENT);\\012\\012-- Creating foreign key constraints\\012\\012ALTER TABLE DATA_SET_RELATIONSHIPS ADD CONSTRAINT DSRE_DATA_FK_CHILD FOREIGN KEY (DATA_ID_CHILD) REFERENCES DATA(ID);\\012ALTER TABLE DATA_SET_RELATIONSHIPS ADD CONSTRAINT DSRE_DATA_FK_PARENT FOREIGN KEY (DATA_ID_PARENT) REFERENCES DATA(ID);\\012\\012-- Creating sequences\\012\\012CREATE SEQUENCE DATA_SET_RELATIONSHIP_ID_SEQ;\\012\\012-- Creating indexes\\012\\012CREATE INDEX DSRE_DATA_FK_I_CHILD ON DATA_SET_RELATIONSHIPS (DATA_ID_CHILD);\\012CREATE INDEX DSRE_DATA_FK_I_PARENT ON DATA_SET_RELATIONSHIPS (DATA_ID_PARENT);\\012\\012--====================================\\012-- Drop Tables and related objects\\012--====================================\\012\\012------------------------------------------------------------------------------------\\012-- table DATA_VALUES (deleted)\\012------------------------------------------------------------------------------------\\012\\012-- Delete constraints\\012\\012ALTER TABLE DATA_VALUES DROP CONSTRAINT DAVA_PK;\\012ALTER TABLE DATA_VALUES DROP CONSTRAINT DAVA_BK_UK;\\012ALTER TABLE DATA_VALUES DROP CONSTRAINT DAVA_DATA_FK;\\012ALTER TABLE DATA_VALUES DROP CONSTRAINT DAVA_SACO_FK;\\012\\012-- Delete indices\\012\\012DROP INDEX DAVA_DATA_FK_I;\\012DROP INDEX DAVA_SACO_FK_I;\\012\\012-- Delete sequences\\012\\012DROP SEQUENCE DATA_VALUE_ID_SEQ;\\012\\012-- Delete tables\\012\\012DROP TABLE DATA_VALUES;\\012\\012--====================================\\012-- Modifications of existing objects\\012--====================================\\012\\012------------------------------------------------------------------------------------\\012-- table ORGANIZATIONS (changed)\\012-- * rename to GROUPS\\012--\\012-- table DATA (changed)\\012-- * rename column PROC_ID_ACQUIRED_BY into: PROC_ID_PRODUCED_BY\\012-- * add columns:\\012-- ** IS_PLACEHOLDER BOOLEAN_CHAR\\012-- ** CODE CODE\\012-- ** DATA_PRODUCER_CODE CODE\\012-- ** PRODUCTION_TIMESTAMP TIME_STAMP\\012--\\012-- table EXTERNAL_DATA (changed)\\012-- * add column:\\012-- ** CVTE_ID_STOR_FMT TECH_ID NOT NULL\\012--\\012-- table PROPERTY_TYPES (changed)\\012-- * add column IS_MANAGED_INTERNALLY BOOLEAN_CHAR NOT NULL DEFAULT 'F'\\012-- * add unique constraint PRTY_BK_UK_LBL for column LABEL\\012--\\012-- tables EXPERIMENT_TYPE_PROPERTY_TYPES, MATERIAL_TYPE_PROPERTY_TYPES, SAMPLE_TYPE_PROPERTY_TYPES\\012-- * make the assignments of property types DESCRIPTION, NUCLEOTIDE_SEQUENCE, OFFSET and GENE_SYMBOL \\012--   to material types internally managed \\012--\\012-- table PROCEDURE_TYPES (changed)\\012-- * add column IS_DATA_ACQUISITION BOOLEAN_CHAR NOT NULL DEFAULT 'F'.\\012--\\012-- all tables\\012-- * convert all codes to upper case\\012------------------------------------------------------------------------------------\\012\\012---------------------------------------------------------------------------------------------------\\012--  Purpose:  Rename table ORGANIZATIONS to GROUPS.\\012---------------------------------------------------------------------------------------------------\\012\\012ALTER TABLE PROJECTS DROP CONSTRAINT PROJ_ORGA_FK;\\012ALTER TABLE ORGANIZATIONS DROP CONSTRAINT ORGA_BK_UK;\\012ALTER TABLE ORGANIZATIONS DROP CONSTRAINT ORGA_PK;\\012ALTER TABLE ORGANIZATIONS RENAME TO GROUPS;\\012ALTER INDEX PROJ_ORGA_FK_I RENAME TO PROJ_GROU_FK_I;\\012select RENAME_SEQUENCE('ORGANIZATION_ID_SEQ', 'GROUP_ID_SEQ');\\012ALTER TABLE PROJECTS RENAME COLUMN ORGA_ID TO GROU_ID;\\012ALTER TABLE GROUPS ADD CONSTRAINT GROU_PK PRIMARY KEY(ID);\\012ALTER TABLE GROUPS ADD CONSTRAINT GROU_BK_UK UNIQUE(CODE);\\012ALTER TABLE PROJECTS ADD CONSTRAINT PROJ_GROU_FK FOREIGN KEY (GROU_ID) REFERENCES GROUPS(ID);\\012\\012\\012---------------------------------------------------------------------------------------------------\\012--  Purpose:  Add columnd IS_PLACEHOLDER of table DATA.\\012---------------------------------------------------------------------------------------------------\\012\\012ALTER TABLE DATA ADD COLUMN IS_PLACEHOLDER BOOLEAN_CHAR NOT NULL;\\012\\012\\012---------------------------------------------------------------------------------------------------\\012--  Purpose:  Add and populate column CODE of table DATA.\\012---------------------------------------------------------------------------------------------------\\012\\012ALTER TABLE DATA ADD COLUMN CODE CODE;\\012\\012CREATE OR REPLACE FUNCTION populate_data_codes() RETURNS integer AS $$\\012DECLARE\\012    rec RECORD;\\012BEGIN\\012    FOR rec IN SELECT * FROM data LOOP\\012        rec.code := to_char(rec.registration_timestamp, 'YYYYMMDDHH24MISSMS') || '-' || to_char(rec.id, 'FM99999999999999999999');\\012        update data set code=rec.code where id=rec.id;\\012    END LOOP;\\012    RETURN 1;\\012END;\\012$$ LANGUAGE 'plpgsql';\\012\\012SELECT populate_data_codes();\\012DROP FUNCTION populate_data_codes();\\012\\012ALTER TABLE DATA ALTER COLUMN CODE SET NOT NULL;\\012ALTER TABLE DATA ADD CONSTRAINT DATA_BK_UK UNIQUE(CODE);\\012\\012---------------------------------------------------------------------------------------------------\\012--  Purpose:  Add and populate columns CVTE_ID_STOR_FMT.\\012---------------------------------------------------------------------------------------------------\\012\\012ALTER TABLE EXTERNAL_DATA ADD COLUMN CVTE_ID_STOR_FMT TECH_ID;\\012ALTER TABLE EXTERNAL_DATA ADD CONSTRAINT EXDA_STOR_FMT_FK FOREIGN KEY (CVTE_ID_STOR_FMT) REFERENCES CONTROLLED_VOCABULARY_TERMS(ID);\\012\\012------------------------------------------------------------------------------------\\012--  Purpose:  Create trigger EXTERNAL_DATA_STORAGE_FORMAT_CHECK \\012------------------------------------------------------------------------------------\\012\\012CREATE OR REPLACE FUNCTION EXTERNAL_DATA_STORAGE_FORMAT_CHECK() RETURNS trigger AS $$\\012DECLARE\\012   v_covo_code  CODE;\\012BEGIN\\012\\012   select code into v_covo_code from controlled_vocabularies\\012      where id = (select covo_id from controlled_vocabulary_terms where id = NEW.cvte_id_stor_fmt);\\012\\012   -- Check if the data storage format is a term of the controlled vocabulary "STORAGE_FORMAT"\\012   if v_covo_code != '.STORAGE_FORMAT' then\\012      RAISE EXCEPTION 'Insert/Update of Data (Code: %) failed, as its Storage Format is %, but is required to be STORAGE_FORMAT.', NEW.code, v_covo_code;\\012   end if;\\012\\012   RETURN NEW;\\012\\012END;\\012$$ LANGUAGE 'plpgsql';\\012\\012CREATE TRIGGER EXTERNAL_DATA_STORAGE_FORMAT_CHECK BEFORE INSERT OR UPDATE ON EXTERNAL_DATA\\012    FOR EACH ROW EXECUTE PROCEDURE EXTERNAL_DATA_STORAGE_FORMAT_CHECK();\\012\\012-----------------------------------------------------------------------------------\\012--  Purpose:  Create Controlled Vocabulary .STORAGE_FORMAT\\012-----------------------------------------------------------------------------------\\012insert into controlled_vocabularies \\012       ( id\\012       , code\\012       , description\\012       , pers_id_registerer\\012       , is_managed_internally )\\012values  (nextval('CONTROLLED_VOCABULARY_ID_SEQ')\\012       , '.STORAGE_FORMAT'\\012       , 'The on-disk storage format of a data set'\\012       , (select id from persons where user_id ='system')\\012       , true);\\012\\012\\012-----------------------------------------------------------------------------------\\012--  Purpose:  Create Controlled Vocabulary Terms for STORAGE_FORMAT\\012-----------------------------------------------------------------------------------\\012insert into controlled_vocabulary_terms \\012       ( id\\012       , code\\012       , covo_id \\012       , pers_id_registerer )\\012values  (nextval('CVTE_ID_SEQ')\\012       , 'PROPRIETARY'\\012       , (select id from controlled_vocabularies where code = '.STORAGE_FORMAT')\\012       , (select id from persons where user_id ='system'));\\012\\012insert into controlled_vocabulary_terms \\012       ( id\\012       , code\\012       , covo_id \\012       , pers_id_registerer )\\012values  (nextval('CVTE_ID_SEQ')\\012       , 'BDS_DIRECTORY'\\012       , (select id from controlled_vocabularies where code = '.STORAGE_FORMAT')\\012       , (select id from persons where user_id ='system'));\\012\\012\\012--------------------------------------------------------------------------\\012--  Purpose:  Insert an entry for OBSERVABLE_TYPE UNKNOWN\\012--------------------------------------------------------------------------\\012\\012insert into observable_types\\012(id\\012,code\\012,description)\\012values \\012(nextval('OBSERVABLE_TYPE_ID_SEQ')\\012,'UNKNOWN'\\012,'Unknown'\\012);\\012\\012----------------------------------------------------------------------\\012--  Purpose:  Insert an entry for PROCEDURE_TYPE UNKNOWN\\012-----------------------------------------------------------------------\\012\\012insert into procedure_types\\012(id\\012,code\\012,description)\\012values \\012(nextval('PROCEDURE_TYPE_ID_SEQ')\\012,'UNKNOWN'\\012,'Unknown'\\012);\\012\\012\\012---------------------------------------------------------------------------------------------------\\012--  Purpose:  Populate external_data.cvte_id_stor_fmt with a default value.\\012---------------------------------------------------------------------------------------------------\\012\\012CREATE OR REPLACE FUNCTION polulate_external_data_cvte_id_stor_fmt() RETURNS integer AS $$\\012DECLARE\\012    rec RECORD;\\012    dfl_stor_fmt_code VARCHAR := 'PROPRIETARY';\\012    dfl_stor_fmt_id TECH_ID;\\012BEGIN\\012    select cvte.id into dfl_stor_fmt_id from controlled_vocabulary_terms cvte, controlled_vocabularies cv \\012        where cvte.code = dfl_stor_fmt_code and cvte.covo_id = cv.id and cv.code = '.STORAGE_FORMAT'; \\012    update external_data set cvte_id_stor_fmt = dfl_stor_fmt_id;\\012    RETURN 1;\\012END;\\012$$ LANGUAGE 'plpgsql';\\012\\012SELECT polulate_external_data_cvte_id_stor_fmt();\\012DROP FUNCTION polulate_external_data_cvte_id_stor_fmt();\\012\\012-- Now that the field is populated, create the not null constraint for it.\\012\\012ALTER TABLE EXTERNAL_DATA ALTER COLUMN CVTE_ID_STOR_FMT SET NOT NULL;\\012\\012---------------------------------------------------------------------------------------------------\\012--  Purpose:  Add and populate columns DATA_PRODUCER_CODE and PRODUCTION_TIMESTAMP to table DATA.\\012---------------------------------------------------------------------------------------------------\\012\\012ALTER TABLE DATA ADD COLUMN DATA_PRODUCER_CODE CODE;\\012ALTER TABLE DATA ADD COLUMN PRODUCTION_TIMESTAMP TIME_STAMP;\\012\\012CREATE OR REPLACE FUNCTION populate_data_producer_code_and_production_timestamp() RETURNS integer AS $$\\012DECLARE\\012    rec RECORD;\\012    loty_rel_code VARCHAR := 'RELATIVE_LOCATION';\\012    loty_rel_id TECH_ID;\\012    meas_ts TIMESTAMP;\\012    ds_code CODE;\\012    meas_ts_str TEXT;\\012BEGIN\\012    select id into loty_rel_id from locator_types where code = loty_rel_code; \\012    FOR rec IN SELECT d.id, ed.location FROM data d, external_data ed where d.id = ed.data_id and ed.loty_id = loty_rel_id LOOP\\012        meas_ts_str = substring(rec.location from '^.*/([0-9]{14})_[^_]+_(.*)$');\\012        ds_code := substring(rec.location from '^.*/[0-9]{14}_([^_]+)_(.*)$');\\012        IF meas_ts_str is not null and ds_code is not null THEN\\012            meas_ts := to_timestamp(meas_ts_str, 'YYYYMMDDHH24MISS');\\012            update data set production_timestamp=meas_ts, data_producer_code=ds_code where id=rec.id;\\012        END IF;\\012    END LOOP;\\012    RETURN 1;\\012END;\\012$$ LANGUAGE 'plpgsql';\\012\\012SELECT populate_data_producer_code_and_production_timestamp();\\012DROP FUNCTION populate_data_producer_code_and_production_timestamp();\\012\\012-- Rename columns\\012\\012ALTER TABLE DATA RENAME COLUMN PROC_ID_ACQUIRED_BY to PROC_ID_PRODUCED_BY;\\012\\012---------------------------------------------------------------------------------------------------\\012--  Purpose:  Populate table DATA_SET_RELATIONSHIPS, by using heuristics.\\012---------------------------------------------------------------------------------------------------\\012\\012CREATE OR REPLACE FUNCTION abs_interval(ts1 time_stamp_dfl, ts2 time_stamp_dfl) returns interval AS $$\\012BEGIN\\012    IF ts1 < ts2 THEN\\012        RETURN ts2 - ts1;\\012    ELSE\\012        RETURN ts1 - ts2;\\012    END IF;\\012END;\\012$$ LANGUAGE 'plpgsql';\\012\\012CREATE OR REPLACE FUNCTION populate_data_set_relationships() RETURNS INTEGER AS $$\\012DECLARE\\012    source_id TECH_ID;\\012    rec_derived RECORD;\\012    rec_acquired RECORD;\\012    rel_location TEXT;\\012    data_set_code TEXT;\\012    data_set_code_trial TEXT;\\012    loty_rel_code TEXT := 'RELATIVE_LOCATION';\\012    loty_rel_id TECH_ID;\\012    count INTEGER := 0;\\012BEGIN\\012    select id into loty_rel_id from locator_types where code = loty_rel_code;\\012    FOR rec_derived IN select id, samp_id_derived_from, registration_timestamp from data where samp_id_derived_from is not null LOOP\\012        source_id := NULL;\\012        select location into rel_location from external_data where data_id = rec_derived.id and loty_id = loty_rel_id;\\012        IF rel_location is not null then\\012            data_set_code := substring(rel_location from '^.*/([0-9]{14}_[^_]+)_.*$');\\012            IF data_set_code is not null THEN\\012                FOR rec_acquired IN select id, samp_id_acquired_from from data where samp_id_acquired_from = rec_derived.samp_id_derived_from LOOP\\012                    select location into rel_location from external_data where data_id = rec_acquired.id and loty_id = loty_rel_id;\\012                    IF rel_location is not null THEN\\012                        data_set_code_trial := substring(rel_location from '^.*/([0-9]{14}_[^_]+)_.*$');\\012                        IF data_set_code_trial = data_set_code THEN\\012                            source_id = rec_acquired.id;\\012                            EXIT;\\012                        END IF;\\012                    END IF;\\012                END LOOP;\\012            END IF;\\012        END IF;\\012        -- If the location didn't tell us about data set relationships, try the backup strategy.\\012        IF source_id is null THEN\\012            -- Use the measured data set as source that is closest in registration timestamp.\\012            select id into source_id from data where samp_id_acquired_from = rec_derived.samp_id_derived_from \\012                and abs_interval(registration_timestamp, rec_derived.registration_timestamp) \\012                    = (select min(abs_interval(registration_timestamp, rec_derived.registration_timestamp)) \\012                        from data where samp_id_acquired_from = rec_derived.samp_id_derived_from);\\012        END IF;\\012        IF source_id is not null THEN\\012            insert into data_set_relationships (id, data_id_parent, data_id_child)\\012                values (nextval('DATA_SET_RELATIONSHIP_ID_SEQ'), source_id, rec_derived.id);\\012            count := count + 1;\\012        END IF;\\012    END LOOP;\\012    RETURN count;\\012END;\\012$$ LANGUAGE 'plpgsql';\\012\\012SELECT populate_data_set_relationships();\\012DROP FUNCTION populate_data_set_relationships();\\012DROP FUNCTION abs_interval(time_stamp_dfl, time_stamp_dfl);\\012\\012---------------------------------------------------------------------------------------------------\\012--  Purpose:  Add column IS_MANAGED_INTERNALLY to table PROPERTY_TYPES. Internally managed \\012--  properties can not be assigned by users of openBIS, but only by the system. \\012---------------------------------------------------------------------------------------------------\\012\\012ALTER TABLE PROPERTY_TYPES ADD COLUMN IS_MANAGED_INTERNALLY BOOLEAN_CHAR NOT NULL DEFAULT 'F';\\012\\012-- Update already existing property type PLATE_GEOMETRY\\012update property_types set is_managed_internally = true, code = '.' || code where code = 'PLATE_GEOMETRY';\\012\\012-- Update already existing controlled vocabulary PLATE_GEOMETRY \\012update controlled_vocabularies set code = '.' || code where code = 'PLATE_GEOMETRY';\\012\\012---------------------------------------------------------------------------------------------------\\012--  Purpose:  Add unique constraint on column LABEL. \\012---------------------------------------------------------------------------------------------------\\012\\012CREATE OR REPLACE FUNCTION make_prty_labels_unique() RETURNS INTEGER AS $$\\012DECLARE\\012    prev_key TEXT := NULL;\\012    this_key TEXT;\\012    dup_count INTEGER;\\012    cnt INTEGER := 0;\\012    already_exists INTEGER;\\012    new_label TEXT;\\012    this_id TECH_ID;\\012BEGIN\\012    FOR this_id, this_key IN select id, label from property_types order by label,id LOOP\\012        IF this_key = prev_key THEN\\012            dup_count := dup_count + 1;\\012            cnt := cnt + 1;\\012        ELSE\\012            dup_count := 0;\\012        END IF;\\012        IF dup_count > 0 THEN\\012            -- Check whether the new key already exists.\\012            LOOP\\012                new_label := this_key || '(' || dup_count::text || ')';\\012                select count(*) into already_exists from property_types where label = new_label;\\012                IF already_exists = 0 THEN\\012                    EXIT;\\012                END IF;\\012                dup_count := dup_count + 1;\\012            END LOOP;\\012            update property_types set label = new_label where id = this_id;\\012        END IF;\\012        prev_key := this_key;\\012    END LOOP;\\012    RETURN cnt;\\012END;\\012$$ LANGUAGE 'plpgsql';\\012\\012SELECT make_prty_labels_unique();\\012DROP FUNCTION make_prty_labels_unique();\\012\\012ALTER TABLE PROPERTY_TYPES ADD CONSTRAINT PRTY_BK_UK_LBL UNIQUE(LABEL);\\012\\012-----------------------------------------------------------------------------------\\012--  Purpose:  Add Controlled Vocabulary Terms to PLATE_GEOMETRY\\012-----------------------------------------------------------------------------------\\012\\012insert into controlled_vocabulary_terms \\012       ( id\\012       , code\\012       , covo_id \\012       , pers_id_registerer)\\012values  (nextval('CVTE_ID_SEQ')\\012       , '96_WELLS_8X12'\\012       , (select id from controlled_vocabularies where code = '.PLATE_GEOMETRY')\\012       , (select id from persons where user_id = 'system'));\\012\\012insert into controlled_vocabulary_terms \\012       ( id\\012       , code\\012       , covo_id \\012       , pers_id_registerer)\\012values  (nextval('CVTE_ID_SEQ')\\012       , '1536_WELLS_32X48'\\012       , (select id from controlled_vocabularies where code = '.PLATE_GEOMETRY')\\012       , (select id from persons where user_id = 'system'));\\012\\012\\012-----------------------------------------------------------------------------------\\012--  Purpose:  Rename Observable Types: IMAGE -> HCS_IMAGE, IMAGE_ANALYSIS_DATA -> HCS_IMAGE_ANALYSIS_DATA\\012--  and descriptions accordingly\\012-----------------------------------------------------------------------------------\\012\\012update observable_types set code = 'HCS_IMAGE', description = 'Data derived from analysis of HCS images' where code = 'IMAGE';\\012update observable_types set code = 'HCS_IMAGE_ANALYSIS_DATA', description = 'Data derived from analysis of HCS images' where code = 'IMAGE_ANALYSIS_DATA';\\012\\012\\012-----------------------------------------------------------------------------------\\012--  Purpose: Make the assignments of property types DESCRIPTION, NUCLEOTIDE_SEQUENCE, OFFSET \\012--  and GENE_SYMBOL to material types internally managed. \\012-----------------------------------------------------------------------------------\\012\\012update material_type_property_types set is_managed_internally = true\\012    where prty_id in (select id from property_types where code = 'DESCRIPTION' \\012        or code = 'NUCLEOTIDE_SEQUENCE' or code = 'OFFSET' or code = 'GENE_SYMBOL');\\012\\012-----------------------------------------------------------------------------------\\012--  Purpose: Add column IS_DATA_ACQUISITION BOOLEAN_CHAR NOT NULL DEFAULT 'F' to table PROCEDURE_TYPES.\\012-----------------------------------------------------------------------------------\\012\\012ALTER TABLE PROCEDURE_TYPES ADD COLUMN IS_DATA_ACQUISITION BOOLEAN_CHAR NOT NULL DEFAULT 'F';\\012\\012-- Set the new attribute for procedure type DATA_ACQUISITION\\012update procedure_types set is_data_acquisition = true where code = 'DATA_ACQUISITION';\\012\\012-----------------------------------------------------------------------------------\\012--  Purpose: Convert all codes to upper case. \\012-----------------------------------------------------------------------------------\\012\\012CREATE OR REPLACE FUNCTION column_to_uppercase_fix_duplicates(tbl TEXT, clm TEXT) RETURNS INTEGER AS $$\\012DECLARE\\012    prev_key TEXT := NULL;\\012    this_key TEXT;\\012    dup_count INTEGER;\\012    count INTEGER := 0;\\012    already_exists INTEGER;\\012    new_clm TEXT;\\012BEGIN\\012    FOR this_key IN EXECUTE 'select ' || clm || ' from ' || tbl \\012        || ' order by upper(' || clm || '),id' LOOP\\012        IF upper(this_key) = upper(prev_key) THEN\\012            dup_count := dup_count + 1;\\012            count := count + 1;\\012        ELSE\\012            dup_count := 0;\\012        END IF;\\012        IF dup_count > 0 THEN\\012            -- Check whether the new key already exists.\\012            LOOP\\012                new_clm := this_key || '(' || dup_count::text || ')';\\012                EXECUTE 'select count(*) from ' || tbl \\012                    || ' where upper(' || clm || ') = ' || quote_literal(upper(new_clm)) \\012                    into already_exists;\\012                IF already_exists = 0 THEN\\012                    EXIT;\\012                END IF;\\012                dup_count := dup_count + 1;\\012            END LOOP;\\012            EXECUTE 'update ' || tbl || ' set ' || clm || ' = ' || quote_literal(new_clm) || \\012                ' where ' || clm || ' = ' || quote_literal(this_key);\\012        END IF;\\012        prev_key := this_key;\\012    END LOOP;\\012    EXECUTE 'update ' || tbl || ' set ' || clm || ' = upper(' || clm || ')';\\012    RETURN count;\\012END;\\012$$ LANGUAGE 'plpgsql';\\012\\012\\012CREATE OR REPLACE FUNCTION column_to_uppercase_fix_duplicates(tbl TEXT, clm TEXT, clm2 TEXT) RETURNS INTEGER AS $$\\012DECLARE\\012    prev_key TEXT := NULL;\\012    prev_key2 TECH_ID;\\012    this_key TEXT;\\012    this_key2 TECH_ID;\\012    dup_count INTEGER;\\012    count INTEGER := 0;\\012    already_exists INTEGER;\\012    new_clm TEXT;\\012BEGIN\\012    FOR this_key, this_key2 IN EXECUTE 'select ' || clm || ',' || clm2 || ' from ' || tbl \\012        || ' order by ' || clm2 || ',upper(' ||  clm || '),id' LOOP\\012        IF upper(this_key) = upper(prev_key) and this_key2 = prev_key2 THEN\\012            dup_count := dup_count + 1;\\012            count := count + 1;\\012        ELSE\\012            dup_count := 0;\\012        END IF;\\012        IF dup_count > 0 THEN\\012            -- Check whether the new key already exists.\\012            LOOP\\012                new_clm := this_key || '(' || dup_count::text || ')';\\012                EXECUTE 'select count(*) from ' || tbl \\012                    || ' where upper(' || clm || ') = ' || quote_literal(upper(new_clm)) \\012                    || ' and ' || clm2 || ' = ' || quote_literal(this_key2) \\012                    into already_exists;\\012                IF already_exists = 0 THEN\\012                    EXIT;\\012                END IF;\\012                dup_count := dup_count + 1;\\012            END LOOP;\\012            EXECUTE 'update ' || tbl || ' set ' || clm || ' = ' || quote_literal(new_clm) || \\012                ' where ' || clm || ' = ' || quote_literal(this_key) || ' and ' \\012                || clm2 || ' = ' || quote_literal(this_key2);\\012        END IF;\\012        prev_key := this_key;\\012        prev_key2 := this_key2;\\012    END LOOP;\\012    EXECUTE 'update ' || tbl || ' set ' || clm || ' = upper(' || clm || ')';\\012    RETURN count;\\012END;\\012$$ LANGUAGE 'plpgsql';\\012\\012\\012SELECT column_to_uppercase_fix_duplicates('samples', 'code');\\012SELECT column_to_uppercase_fix_duplicates('property_types', 'code');\\012SELECT column_to_uppercase_fix_duplicates('controlled_vocabularies', 'code');\\012\\012SELECT column_to_uppercase_fix_duplicates('projects', 'code', 'grou_id');\\012SELECT column_to_uppercase_fix_duplicates('experiments', 'code', 'proj_id');\\012SELECT column_to_uppercase_fix_duplicates('controlled_vocabulary_terms', 'code', 'covo_id');\\012SELECT column_to_uppercase_fix_duplicates('materials', 'code', 'maty_id');\\012SELECT column_to_uppercase_fix_duplicates('material_batches', 'code', 'mate_id');\\012SELECT column_to_uppercase_fix_duplicates('sample_components', 'code', 'samp_id');\\012\\012-- These will only need changes if someone entered them through the 'back door' directly on the server.\\012\\012SELECT column_to_uppercase_fix_duplicates('groups', 'code');\\012SELECT column_to_uppercase_fix_duplicates('sample_types', 'code');\\012SELECT column_to_uppercase_fix_duplicates('material_types', 'code');\\012SELECT column_to_uppercase_fix_duplicates('experiment_types', 'code');\\012SELECT column_to_uppercase_fix_duplicates('procedure_types', 'code');\\012SELECT column_to_uppercase_fix_duplicates('observable_types', 'code');\\012SELECT column_to_uppercase_fix_duplicates('locator_types', 'code');\\012SELECT column_to_uppercase_fix_duplicates('file_format_types', 'code');\\012SELECT column_to_uppercase_fix_duplicates('data_types', 'code');\\012\\012DROP FUNCTION column_to_uppercase_fix_duplicates(TEXT, TEXT);\\012DROP FUNCTION column_to_uppercase_fix_duplicates(TEXT, TEXT, TEXT);\\012\\012-----------------------------------------------------------------------------------\\012--  Purpose:  Delete sample_components with no associated material_batches.\\012--  This deletes superfluous controls of master plates\\012-----------------------------------------------------------------------------------\\012\\012delete from sample_components\\012where  id in (select sc.id \\012              from   sample_components as sc left join sample_component_materials as scm \\012              on     scm.saco_id = sc.id \\012              where  scm.saco_id is null\\012              )\\012;\\012	\N
+./sourceTest/sql/postgresql/018/006=database_version_logs.tsv:017	source/sql/postgresql/migration/migration-016-017.sql	SUCCESS	2008-05-09 10:12:57.473	----------------------------------------------------------------------------------------------\\012--  File: migration-016-017.sql\\012--\\012-- \\012--  This script enables the migration of the database schema from 016 to 017.\\012-- \\012--  Update History\\012--\\012--\\012--\\011Who\\011\\011\\011              When\\011\\011    What\\012--\\011---\\011\\011\\011              ----      \\011----\\012--\\011Charles Ramin-Wright\\0112008-04-11\\011Initial Version \\012--  \\012----------------------------------------------------------------------------------------------\\012\\012\\012--=================================\\012-- Create Objects\\012--=================================\\012\\012-- Domains\\012\\012-- 'F' is false, 'T' is true and 'U' is unknown\\012CREATE DOMAIN BOOLEAN_CHAR_OR_UNKNOWN AS CHAR(1) CHECK (VALUE in ('F', 'T', 'U'));\\012\\012-- Tables and related objects\\012\\012-- Sequences\\012\\012-- Indices\\012\\012--====================================\\012-- Delete Objects\\012--====================================\\012\\012-- Domains\\012\\012-- Tables\\012\\012-- Sequences\\012\\012-- Indices\\012\\012--====================================\\012-- Alter Objects\\012--====================================\\012\\012-- Add column IS_INTERNAL_NAMESPACE to table CONTROLLED_VOCABULARIES \\012\\012ALTER TABLE CONTROLLED_VOCABULARIES ADD IS_INTERNAL_NAMESPACE BOOLEAN_CHAR NOT NULL DEFAULT 'F';\\012\\012-- Add column IS_INTERNAL_NAMESPACE to table PROPERTY_TYPES \\012\\012ALTER TABLE PROPERTY_TYPES ADD IS_INTERNAL_NAMESPACE BOOLEAN_CHAR NOT NULL DEFAULT 'F';\\012\\012-- Add column IS_INTERNAL_NAMESPACE as key component to the unique key constraint COVO_BK_UK\\012\\012ALTER TABLE CONTROLLED_VOCABULARIES DROP CONSTRAINT COVO_BK_UK;\\012ALTER TABLE CONTROLLED_VOCABULARIES ADD CONSTRAINT COVO_BK_UK UNIQUE(CODE,IS_INTERNAL_NAMESPACE);\\012\\012-- Add column IS_INTERNAL_NAMESPACE as key component to the unique key constraint PRTY_BK_UK\\012\\012ALTER TABLE PROPERTY_TYPES DROP CONSTRAINT PRTY_BK_UK;\\012ALTER TABLE PROPERTY_TYPES ADD CONSTRAINT PRTY_BK_UK UNIQUE(CODE,IS_INTERNAL_NAMESPACE);\\012\\012-- Delete unique key constraint PRTY_BK_UK_LBL (which was for column LABEL) from table PROPERTY_TYPES\\012\\012ALTER TABLE PROPERTY_TYPES DROP CONSTRAINT PRTY_BK_UK_LBL;\\012\\012\\012-- Change unique constraint EXDA_BK_UK to contain EXTERNAL_DATA.LOTY_ID \\012\\012ALTER TABLE EXTERNAL_DATA DROP CONSTRAINT EXDA_BK_UK;\\012ALTER TABLE EXTERNAL_DATA ADD CONSTRAINT EXDA_BK_UK UNIQUE(LOCATION,LOTY_ID);\\012\\012\\012-- Increase length of EXTERNAL_DATA.LOCATION from 200 to 1024\\012\\012ALTER TABLE EXTERNAL_DATA ALTER COLUMN LOCATION TYPE VARCHAR(1024);\\012\\012\\012-- Add column IS_COMPLETE to table EXTERNAL_DATA\\012\\012ALTER TABLE EXTERNAL_DATA ADD COLUMN IS_COMPLETE BOOLEAN_CHAR_OR_UNKNOWN NOT NULL DEFAULT 'U';\\012\\012\\012--=================================\\012-- Replace EXTERNAL_DATA_STORAGE_FORMAT_CHECK() function\\012--=================================\\012\\012CREATE OR REPLACE FUNCTION EXTERNAL_DATA_STORAGE_FORMAT_CHECK() RETURNS trigger AS $$\\012DECLARE\\012   v_covo_code  CODE;\\012   data_code CODE;\\012BEGIN\\012\\012   select code into v_covo_code from controlled_vocabularies\\012      where is_internal_namespace = true and \\012         id = (select covo_id from controlled_vocabulary_terms where id = NEW.cvte_id_stor_fmt);\\012\\012-- Check if the data storage format is a term of the controlled vocabulary "STORAGE_FORMAT"\\012   if v_covo_code != 'STORAGE_FORMAT' then\\012      select code into data_code from data where id = NEW.data_id; \\012      RAISE EXCEPTION 'Insert/Update of Data (Code: %) failed, as its Storage Format is %, but is required to be STORAGE_FORMAT.', data_code, v_covo_code;\\012   end if;\\012\\012   RETURN NEW;\\012\\012END;\\012$$ LANGUAGE 'plpgsql';\\012\\012\\012--=================================\\012-- Data Migration\\012--=================================\\012\\012\\012---------------------------------------------------------------------------------------\\012--   Translate the internally managed CODES which are represented by the Dot-Prefix to:\\012--\\012--   CODE without a Dot-Prefix plus the new column IS_INTERNAL_NAMESPACE = true.\\012---------------------------------------------------------------------------------------\\012\\012UPDATE property_types\\012SET    code = substr(code,2,length(code))\\012     , is_internal_namespace = true \\012WHERE  substr(code,1,1) = '.';\\012\\012UPDATE controlled_vocabularies\\012SET    code = substr(code,2,length(code))\\012     , is_internal_namespace = true \\012WHERE  substr(code,1,1) = '.';\\012\\012------------------------------------------------------------------------------------\\012--  Purpose: Move experiment descriptions from column to property DESCRIPTION\\012------------------------------------------------------------------------------------\\012\\012   -----------------------\\012   --  Material Type SIRNHACS\\012   -----------------------\\012\\012insert into experiment_type_property_types\\012(   id\\012   ,exty_id\\012   ,prty_id\\012   ,is_mandatory\\012   ,is_managed_internally\\012   ,pers_id_registerer\\012   )\\012values \\012(   nextval('ETPT_ID_SEQ')\\012   ,(select id from experiment_types where code = 'SIRNAHCS')\\012   ,(select id from property_types where code = 'DESCRIPTION')\\012   ,true\\012   ,true\\012   ,(select id from persons where user_id ='system')\\012);\\012\\012-- Add experiment_properties for descriptions of all experiments of type SIRNAHCS \\012\\012insert into experiment_properties\\012(   id\\012   ,expe_id\\012   ,value\\012   ,etpt_id\\012   ,pers_id_registerer\\012)\\012select\\012    nextval('EXPERIMENT_PROPERTY_ID_SEQ')\\012   ,id\\012   ,case when description is not null then description else 'No description given' end\\012   ,currval('ETPT_ID_SEQ')\\012   ,(select id from persons where user_id ='system')  \\012from experiments where exty_id = (select id from experiment_types where code = 'SIRNAHCS');\\012\\012-- Finally: drop column\\012\\012ALTER TABLE EXPERIMENTS DROP COLUMN DESCRIPTION;\\012	\N
+./sourceTest/sql/postgresql/018/schema-018.sql:    LANGUAGE plpgsql;
+./sourceTest/sql/postgresql/018/schema-018.sql:    LANGUAGE plpgsql;
+./sourceTest/sql/postgresql/018/schema-018.sql:    LANGUAGE plpgsql;
+./sourceTest/sql/postgresql/019/.svn/text-base/schema-019.sql.svn-base:    LANGUAGE plpgsql;
+./sourceTest/sql/postgresql/019/.svn/text-base/schema-019.sql.svn-base:    LANGUAGE plpgsql;
+./sourceTest/sql/postgresql/019/.svn/text-base/schema-019.sql.svn-base:    LANGUAGE plpgsql;
+./sourceTest/sql/postgresql/019/schema-019.sql:    LANGUAGE plpgsql;
+./sourceTest/sql/postgresql/019/schema-019.sql:    LANGUAGE plpgsql;
+./sourceTest/sql/postgresql/019/schema-019.sql:    LANGUAGE plpgsql;
+./sourceTest/sql/postgresql/020/.svn/text-base/schema-020.sql.svn-base:    LANGUAGE plpgsql;
+./sourceTest/sql/postgresql/020/.svn/text-base/schema-020.sql.svn-base:    LANGUAGE plpgsql;
+./sourceTest/sql/postgresql/020/.svn/text-base/schema-020.sql.svn-base:    LANGUAGE plpgsql;
+./sourceTest/sql/postgresql/020/schema-020.sql:    LANGUAGE plpgsql;
+./sourceTest/sql/postgresql/020/schema-020.sql:    LANGUAGE plpgsql;
+./sourceTest/sql/postgresql/020/schema-020.sql:    LANGUAGE plpgsql;
+./sourceTest/sql/postgresql/021/.svn/text-base/schema-021.sql.svn-base:    LANGUAGE plpgsql;
+./sourceTest/sql/postgresql/021/.svn/text-base/schema-021.sql.svn-base:    LANGUAGE plpgsql;
+./sourceTest/sql/postgresql/021/.svn/text-base/schema-021.sql.svn-base:    LANGUAGE plpgsql;
+./sourceTest/sql/postgresql/021/schema-021.sql:    LANGUAGE plpgsql;
+./sourceTest/sql/postgresql/021/schema-021.sql:    LANGUAGE plpgsql;
+./sourceTest/sql/postgresql/021/schema-021.sql:    LANGUAGE plpgsql;
+./sourceTest/sql/postgresql/022/.svn/text-base/schema-022.sql.svn-base:    LANGUAGE plpgsql;
+./sourceTest/sql/postgresql/022/.svn/text-base/schema-022.sql.svn-base:    LANGUAGE plpgsql;
+./sourceTest/sql/postgresql/022/.svn/text-base/schema-022.sql.svn-base:    LANGUAGE plpgsql;
+./sourceTest/sql/postgresql/022/schema-022.sql:    LANGUAGE plpgsql;
+./sourceTest/sql/postgresql/022/schema-022.sql:    LANGUAGE plpgsql;
+./sourceTest/sql/postgresql/022/schema-022.sql:    LANGUAGE plpgsql;
+./sourceTest/sql/postgresql/023/.svn/text-base/schema-023.sql.svn-base:    LANGUAGE plpgsql;
+./sourceTest/sql/postgresql/023/.svn/text-base/schema-023.sql.svn-base:    LANGUAGE plpgsql;
+./sourceTest/sql/postgresql/023/.svn/text-base/schema-023.sql.svn-base:    LANGUAGE plpgsql;
+./sourceTest/sql/postgresql/023/schema-023.sql:    LANGUAGE plpgsql;
+./sourceTest/sql/postgresql/023/schema-023.sql:    LANGUAGE plpgsql;
+./sourceTest/sql/postgresql/023/schema-023.sql:    LANGUAGE plpgsql;
+./sourceTest/sql/postgresql/024/.svn/text-base/schema-024.sql.svn-base:    LANGUAGE plpgsql;
+./sourceTest/sql/postgresql/024/.svn/text-base/schema-024.sql.svn-base:    LANGUAGE plpgsql;
+./sourceTest/sql/postgresql/024/.svn/text-base/schema-024.sql.svn-base:    LANGUAGE plpgsql;
+./sourceTest/sql/postgresql/024/.svn/text-base/schema-024.sql.svn-base:    LANGUAGE plpgsql;
+./sourceTest/sql/postgresql/024/schema-024.sql:    LANGUAGE plpgsql;
+./sourceTest/sql/postgresql/024/schema-024.sql:    LANGUAGE plpgsql;
+./sourceTest/sql/postgresql/024/schema-024.sql:    LANGUAGE plpgsql;
+./sourceTest/sql/postgresql/024/schema-024.sql:    LANGUAGE plpgsql;
+./sourceTest/sql/postgresql/025/.svn/text-base/schema-025.sql.svn-base:    LANGUAGE plpgsql;
+./sourceTest/sql/postgresql/025/.svn/text-base/schema-025.sql.svn-base:    LANGUAGE plpgsql;
+./sourceTest/sql/postgresql/025/.svn/text-base/schema-025.sql.svn-base:    LANGUAGE plpgsql;
+./sourceTest/sql/postgresql/025/.svn/text-base/schema-025.sql.svn-base:    LANGUAGE plpgsql;
+./sourceTest/sql/postgresql/025/.svn/text-base/schema-025.sql.svn-base:    LANGUAGE plpgsql;
+./sourceTest/sql/postgresql/025/schema-025.sql:    LANGUAGE plpgsql;
+./sourceTest/sql/postgresql/025/schema-025.sql:    LANGUAGE plpgsql;
+./sourceTest/sql/postgresql/025/schema-025.sql:    LANGUAGE plpgsql;
+./sourceTest/sql/postgresql/025/schema-025.sql:    LANGUAGE plpgsql;
+./sourceTest/sql/postgresql/025/schema-025.sql:    LANGUAGE plpgsql;
+./sourceTest/sql/postgresql/026/.svn/text-base/009=database_version_logs.tsv.svn-base:007	source/sql/postgresql/007/schema-007.sql	SUCCESS	2008-01-05 14:51:36.56	-- D:\\\\DDL\\\\postgresql\\\\schema-007.sql\\012--\\012-- Generated for ANSI SQL92 on Thu Aug 23  19:02:15 2007 by Server Generator 10.1.2.6.18\\012-- Post generation PostgreSQL specific Changes:\\012-- \\012--  1. change domain FILE from BIT(32000) to BYTEA\\012--  2. change domain TECH_ID from NUMERIC(20) to BIGINT\\012--  3. Put single quotes around the default value NOW in the create domain statement for the domain TIME_STAMP\\012--     i.e. change CREATE DOMAIN TIME_STAMP AS TIMESTAMP DEFAULT now; to CREATE DOMAIN TIME_STAMP AS TIMESTAMP DEFAULT 'now';\\012--  4. Temporarily not created, due to data quality issues with the master plate layout data\\012--\\012-- ALTER TABLE MOLECULES ADD CONSTRAINT MOLE_BK_UK UNIQUE(SEQUENCE);\\012\\012\\012\\012CREATE DOMAIN DESCRIPTION_80 AS VARCHAR(80);\\012CREATE DOMAIN USER_ID AS VARCHAR(20);\\012CREATE DOMAIN DOUBLE_PRECISION_VALUE AS DOUBLE PRECISION;\\012CREATE DOMAIN FILE_NAME AS VARCHAR(100);\\012CREATE DOMAIN TECH_ID AS BIGINT;\\012CREATE DOMAIN OBJECT_NAME AS VARCHAR(50);\\012CREATE DOMAIN TIME_STAMP AS TIMESTAMP DEFAULT CURRENT_TIMESTAMP;\\012CREATE DOMAIN REAL_VALUE AS REAL;\\012CREATE DOMAIN FILE AS BYTEA;\\012CREATE DOMAIN CODE AS VARCHAR(20);\\012CREATE DOMAIN DESCRIPTION_250 AS VARCHAR(250);\\012CREATE TABLE EXPERIMENT_PROPERTIES  (ID TECH_ID NOT NULL,EXPE_ID TECH_ID NOT NULL,FILE_NAME FILE_NAME NOT NULL,REGISTRATION_TIMESTAMP TIME_STAMP NOT NULL DEFAULT CURRENT_TIMESTAMP,VALUE FILE NOT NULL,VERSION INTEGER NOT NULL,PERS_ID_REGISTERER TECH_ID NOT NULL) ;\\012CREATE TABLE EXPERIMENT_TYPES  (ID TECH_ID NOT NULL,CODE CODE NOT NULL,DESCRIPTION DESCRIPTION_80) ;\\012CREATE TABLE DATA_VALUES  (ID TECH_ID NOT NULL,DATA_ID TECH_ID NOT NULL,SACO_ID TECH_ID NOT NULL,VALUE DOUBLE_PRECISION_VALUE NOT NULL) ;\\012CREATE TABLE PERSONS  (ID TECH_ID NOT NULL,FIRST_NAME VARCHAR(30),LAST_NAME VARCHAR(30),USER_ID USER_ID,EMAIL OBJECT_NAME) ;\\012CREATE TABLE FILE_FORMAT_TYPES  (ID TECH_ID NOT NULL,CODE CODE NOT NULL,DESCRIPTION DESCRIPTION_80) ;\\012CREATE TABLE SAMPLE_INPUTS  (ID TECH_ID NOT NULL,SAMP_ID TECH_ID NOT NULL,PROC_ID TECH_ID NOT NULL) ;\\012CREATE TABLE OBSERVABLE_TYPES  (ID TECH_ID NOT NULL,CODE CODE NOT NULL,DESCRIPTION DESCRIPTION_80) ;\\012CREATE TABLE LOCATOR_TYPES  (ID TECH_ID NOT NULL,CODE CODE NOT NULL,DESCRIPTION DESCRIPTION_80) ;\\012CREATE TABLE SAMPLE_COMPONENTS  (ID TECH_ID NOT NULL,CODE CODE NOT NULL,SAMP_ID TECH_ID NOT NULL) ;\\012CREATE TABLE SAMPLE_TYPES  (ID TECH_ID NOT NULL,CODE CODE NOT NULL,DESCRIPTION DESCRIPTION_80) ;\\012CREATE TABLE ORGANIZATIONS  (ID TECH_ID NOT NULL,CODE CODE NOT NULL) ;\\012CREATE TABLE PROCEDURES  (ID TECH_ID NOT NULL,REGISTRATION_TIMESTAMP TIME_STAMP NOT NULL DEFAULT CURRENT_TIMESTAMP,EXPE_ID TECH_ID NOT NULL,PCTY_ID TECH_ID NOT NULL,PERS_ID TECH_ID) ;\\012CREATE TABLE PROCEDURE_TYPES  (ID TECH_ID NOT NULL,CODE CODE NOT NULL,DESCRIPTION DESCRIPTION_80 NOT NULL) ;\\012CREATE TABLE PROJECTS  (ID TECH_ID NOT NULL,CODE CODE NOT NULL,ORGA_ID TECH_ID NOT NULL) ;\\012CREATE TABLE SAMPLE_COMPONENT_MATERIALS  (ID TECH_ID NOT NULL,SACO_ID TECH_ID NOT NULL,MABA_ID TECH_ID NOT NULL) ;\\012CREATE TABLE EXTERNAL_DATA  (DATA_ID TECH_ID NOT NULL,LOCATION VARCHAR(200) NOT NULL,LOTY_ID TECH_ID NOT NULL,FFTY_ID TECH_ID NOT NULL) ;\\012CREATE TABLE DATA  (ID TECH_ID NOT NULL,REGISTRATION_TIMESTAMP TIME_STAMP NOT NULL DEFAULT CURRENT_TIMESTAMP,OBTY_ID TECH_ID NOT NULL,PROC_ID_ACQUIRED_BY TECH_ID NOT NULL,SAMP_ID_ACQUIRED_FROM TECH_ID,SAMP_ID_DERIVED_FROM TECH_ID) ;\\012CREATE TABLE SAMPLES  (ID TECH_ID NOT NULL,CODE CODE NOT NULL,CONT_ID TECH_ID,PROC_ID TECH_ID,SAMP_ID_TOP TECH_ID,SAMP_ID_GENERATED_FROM TECH_ID,SATY_ID TECH_ID NOT NULL,REGISTRATION_TIMESTAMP TIME_STAMP NOT NULL DEFAULT CURRENT_TIMESTAMP,PERS_ID_REGISTERER TECH_ID NOT NULL) ;\\012CREATE TABLE MATERIAL_TYPES  (ID TECH_ID NOT NULL,CODE CODE NOT NULL,DESCRIPTION DESCRIPTION_80) ;\\012CREATE TABLE MATERIAL_BATCHES  (ID TECH_ID NOT NULL,CODE CODE NOT NULL,AMOUNT REAL_VALUE,MATE_ID TECH_ID NOT NULL,CONT_ID TECH_ID,PROC_ID TECH_ID,REGISTRATION_TIMESTAMP TIME_STAMP NOT NULL DEFAULT CURRENT_TIMESTAMP,PERS_ID_REGISTERER TECH_ID NOT NULL) ;\\012CREATE TABLE MATERIALS  (ID TECH_ID NOT NULL,CODE CODE NOT NULL,DESCRIPTION DESCRIPTION_250,MATY_ID TECH_ID NOT NULL,REGISTRATION_TIMESTAMP TIME_STAMP NOT NULL DEFAULT CURRENT_TIMESTAMP,PERS_ID_REGISTERER TECH_ID NOT NULL) ;\\012CREATE TABLE MOLECULES  (MATE_ID TECH_ID NOT NULL,SEQUENCE VARCHAR(100),ACCESSION_NUMBER OBJECT_NAME,OFF_SET VARCHAR(20),MOLE_ID_INHIBITOR_OF TECH_ID,GENE_SYMBOL CODE) ;\\012CREATE TABLE EXPERIMENTS  (ID TECH_ID NOT NULL,CODE CODE NOT NULL,EXTY_ID TECH_ID NOT NULL,MATE_ID_STUDY_OBJECT TECH_ID,PERS_ID_REGISTERER TECH_ID,REGISTRATION_TIMESTAMP TIME_STAMP NOT NULL DEFAULT CURRENT_TIMESTAMP,DESCRIPTION DESCRIPTION_250,PROJ_ID TECH_ID NOT NULL) ;\\012\\012ALTER TABLE EXPERIMENT_PROPERTIES ADD CONSTRAINT EXPR_PK PRIMARY KEY(ID);\\012ALTER TABLE EXPERIMENT_TYPES ADD CONSTRAINT EXTY_PK PRIMARY KEY(ID);\\012ALTER TABLE DATA_VALUES ADD CONSTRAINT DAVA_PK PRIMARY KEY(ID);\\012ALTER TABLE PERSONS ADD CONSTRAINT PERS_PK PRIMARY KEY(ID);\\012ALTER TABLE FILE_FORMAT_TYPES ADD CONSTRAINT FFTY_PK PRIMARY KEY(ID);\\012ALTER TABLE SAMPLE_INPUTS ADD CONSTRAINT SAIN_PK PRIMARY KEY(ID);\\012ALTER TABLE OBSERVABLE_TYPES ADD CONSTRAINT OBTY_PK PRIMARY KEY(ID);\\012ALTER TABLE LOCATOR_TYPES ADD CONSTRAINT LOTY_PK PRIMARY KEY(ID);\\012ALTER TABLE SAMPLE_COMPONENTS ADD CONSTRAINT SACO_PK PRIMARY KEY(ID);\\012ALTER TABLE SAMPLE_TYPES ADD CONSTRAINT SATY_PK PRIMARY KEY(ID);\\012ALTER TABLE ORGANIZATIONS ADD CONSTRAINT ORGA_PK PRIMARY KEY(ID);\\012ALTER TABLE PROCEDURES ADD CONSTRAINT PROC_PK PRIMARY KEY(ID);\\012ALTER TABLE PROCEDURE_TYPES ADD CONSTRAINT PCTY_PK PRIMARY KEY(ID);\\012ALTER TABLE PROJECTS ADD CONSTRAINT PROJ_PK PRIMARY KEY(ID);\\012ALTER TABLE SAMPLE_COMPONENT_MATERIALS ADD CONSTRAINT SCMA_PK PRIMARY KEY(ID);\\012ALTER TABLE EXTERNAL_DATA ADD CONSTRAINT EXDA_PK PRIMARY KEY(DATA_ID);\\012ALTER TABLE DATA ADD CONSTRAINT DATA_PK PRIMARY KEY(ID);\\012ALTER TABLE SAMPLES ADD CONSTRAINT SAMP_PK PRIMARY KEY(ID);\\012ALTER TABLE MATERIAL_TYPES ADD CONSTRAINT MATY_PK PRIMARY KEY(ID);\\012ALTER TABLE MATERIAL_BATCHES ADD CONSTRAINT MABA_PK PRIMARY KEY(ID);\\012ALTER TABLE MATERIALS ADD CONSTRAINT MATE_PK PRIMARY KEY(ID);\\012ALTER TABLE MOLECULES ADD CONSTRAINT MOLE_PK PRIMARY KEY(MATE_ID);\\012ALTER TABLE EXPERIMENTS ADD CONSTRAINT EXPE_PK PRIMARY KEY(ID);\\012ALTER TABLE EXPERIMENT_PROPERTIES ADD CONSTRAINT EXPR_BK_UK UNIQUE(EXPE_ID,FILE_NAME,VERSION);\\012ALTER TABLE EXPERIMENT_TYPES ADD CONSTRAINT EXTY_BK_UK UNIQUE(CODE);\\012ALTER TABLE DATA_VALUES ADD CONSTRAINT DAVA_BK_UK UNIQUE(DATA_ID,SACO_ID);\\012ALTER TABLE PERSONS ADD CONSTRAINT PERS_BK_UK UNIQUE(USER_ID);\\012ALTER TABLE FILE_FORMAT_TYPES ADD CONSTRAINT FFTY_BK_UK UNIQUE(CODE);\\012ALTER TABLE SAMPLE_INPUTS ADD CONSTRAINT SAIN_BK_UK UNIQUE(SAMP_ID,PROC_ID);\\012ALTER TABLE OBSERVABLE_TYPES ADD CONSTRAINT OBTY_BK_UK UNIQUE(CODE);\\012ALTER TABLE LOCATOR_TYPES ADD CONSTRAINT LOTY_BK_UK UNIQUE(CODE);\\012ALTER TABLE SAMPLE_COMPONENTS ADD CONSTRAINT SACO_BK_UK UNIQUE(CODE,SAMP_ID);\\012ALTER TABLE SAMPLE_TYPES ADD CONSTRAINT SATY_BK_UK UNIQUE(CODE);\\012ALTER TABLE ORGANIZATIONS ADD CONSTRAINT ORGA_BK_UK UNIQUE(CODE);\\012ALTER TABLE PROCEDURE_TYPES ADD CONSTRAINT PCTY_BK_UK UNIQUE(CODE);\\012ALTER TABLE PROJECTS ADD CONSTRAINT PROJ_BK_UK UNIQUE(CODE,ORGA_ID);\\012ALTER TABLE SAMPLE_COMPONENT_MATERIALS ADD CONSTRAINT SCMA_BK_UK UNIQUE(MABA_ID,SACO_ID);\\012ALTER TABLE EXTERNAL_DATA ADD CONSTRAINT EXDA_BK_UK UNIQUE(LOCATION);\\012ALTER TABLE SAMPLES ADD CONSTRAINT SAMP_BK_UK UNIQUE(CODE);\\012ALTER TABLE MATERIAL_TYPES ADD CONSTRAINT MATY_UK UNIQUE(CODE);\\012ALTER TABLE MATERIAL_TYPES ADD CONSTRAINT MATY_BK_UK UNIQUE(CODE);\\012ALTER TABLE MATERIALS ADD CONSTRAINT MATE_BK_UK UNIQUE(CODE);\\012--\\012--  Temporarily not created, due to data quality issues with the master plate layout data\\012--\\012-- ALTER TABLE MOLECULES ADD CONSTRAINT MOLE_BK_UK UNIQUE(SEQUENCE);\\012ALTER TABLE EXPERIMENTS ADD CONSTRAINT EXPE_BK_UK UNIQUE(CODE,PROJ_ID);\\012\\012ALTER TABLE DATA ADD CONSTRAINT DATA_SAMP_ARC_CK CHECK ((samp_id_acquired_from IS NOT NULL \\012and samp_id_derived_from IS NULL) \\012or (samp_id_acquired_from IS NULL \\012and samp_id_derived_from IS NOT NULL)) ;\\012ALTER TABLE EXPERIMENT_PROPERTIES ADD CONSTRAINT EXPR_PERS_FK FOREIGN KEY (PERS_ID_REGISTERER)REFERENCES PERSONS(ID);\\012ALTER TABLE EXPERIMENT_PROPERTIES ADD CONSTRAINT EXPR_EXPE_FK FOREIGN KEY (EXPE_ID)REFERENCES EXPERIMENTS(ID);\\012ALTER TABLE DATA_VALUES ADD CONSTRAINT DAVA_DATA_FK FOREIGN KEY (DATA_ID)REFERENCES DATA(ID);\\012ALTER TABLE DATA_VALUES ADD CONSTRAINT DAVA_SACO_FK FOREIGN KEY (SACO_ID)REFERENCES SAMPLE_COMPONENTS(ID);\\012ALTER TABLE SAMPLE_INPUTS ADD CONSTRAINT SAIN_PROC_FK FOREIGN KEY (PROC_ID)REFERENCES PROCEDURES(ID);\\012ALTER TABLE SAMPLE_INPUTS ADD CONSTRAINT SAIN_SAMP_FK FOREIGN KEY (SAMP_ID)REFERENCES SAMPLES(ID);\\012ALTER TABLE SAMPLE_COMPONENTS ADD CONSTRAINT SACO_SAMP_FK FOREIGN KEY (SAMP_ID)REFERENCES SAMPLES(ID);\\012ALTER TABLE PROCEDURES ADD CONSTRAINT PROC_PCTY_FK FOREIGN KEY (PCTY_ID)REFERENCES PROCEDURE_TYPES(ID);\\012ALTER TABLE PROCEDURES ADD CONSTRAINT PROC_PERS_FK FOREIGN KEY (PERS_ID)REFERENCES PERSONS(ID);\\012ALTER TABLE PROCEDURES ADD CONSTRAINT PROC_EXPE_FK FOREIGN KEY (EXPE_ID)REFERENCES EXPERIMENTS(ID);\\012ALTER TABLE PROJECTS ADD CONSTRAINT PROJ_ORGA_FK FOREIGN KEY (ORGA_ID)REFERENCES ORGANIZATIONS(ID);\\012ALTER TABLE SAMPLE_COMPONENT_MATERIALS ADD CONSTRAINT SCMA_MABA_FK FOREIGN KEY (MABA_ID)REFERENCES MATERIAL_BATCHES(ID);\\012ALTER TABLE SAMPLE_COMPONENT_MATERIALS ADD CONSTRAINT SCMA_SACO_FK FOREIGN KEY (SACO_ID)REFERENCES SAMPLE_COMPONENTS(ID);\\012ALTER TABLE EXTERNAL_DATA ADD CONSTRAINT EXDA_DATA_FK FOREIGN KEY (DATA_ID)REFERENCES DATA(ID);\\012ALTER TABLE EXTERNAL_DATA ADD CONSTRAINT EXDA_LOTY_FK FOREIGN KEY (LOTY_ID)REFERENCES LOCATOR_TYPES(ID);\\012ALTER TABLE EXTERNAL_DATA ADD CONSTRAINT EXDA_FFTY_FK FOREIGN KEY (FFTY_ID)REFERENCES FILE_FORMAT_TYPES(ID);\\012ALTER TABLE DATA ADD CONSTRAINT DATA_SAMP_DERIVED_FROM_FK FOREIGN KEY (SAMP_ID_DERIVED_FROM)REFERENCES SAMPLES(ID);\\012ALTER TABLE DATA ADD CONSTRAINT DATA_SAMP_FK FOREIGN KEY (SAMP_ID_ACQUIRED_FROM)REFERENCES SAMPLES(ID);\\012ALTER TABLE DATA ADD CONSTRAINT DATA_PROC_FK FOREIGN KEY (PROC_ID_ACQUIRED_BY)REFERENCES PROCEDURES(ID);\\012ALTER TABLE DATA ADD CONSTRAINT DATA_OBTY_FK FOREIGN KEY (OBTY_ID)REFERENCES OBSERVABLE_TYPES(ID);\\012ALTER TABLE SAMPLES ADD CONSTRAINT SAMP_PERS_FK FOREIGN KEY (PERS_ID_REGISTERER)REFERENCES PERSONS(ID);\\012ALTER TABLE SAMPLES ADD CONSTRAINT SAMP_PROC_FK FOREIGN KEY (PROC_ID)REFERENCES PROCEDURES(ID);\\012ALTER TABLE SAMPLES ADD CONSTRAINT SAMP_SAMP_FK_GENERATED_FROM FOREIGN KEY (SAMP_ID_GENERATED_FROM)REFERENCES SAMPLES(ID);\\012ALTER TABLE SAMPLES ADD CONSTRAINT SAMP_SAMP_FK_TOP FOREIGN KEY (SAMP_ID_TOP)REFERENCES SAMPLES(ID);\\012ALTER TABLE SAMPLES ADD CONSTRAINT SAMP_SATY_FK FOREIGN KEY (SATY_ID)REFERENCES SAMPLE_TYPES(ID);\\012ALTER TABLE MATERIAL_BATCHES ADD CONSTRAINT MABA_PERS_FK FOREIGN KEY (PERS_ID_REGISTERER)REFERENCES PERSONS(ID);\\012ALTER TABLE MATERIAL_BATCHES ADD CONSTRAINT MABA_MATE_FK FOREIGN KEY (MATE_ID)REFERENCES MATERIALS(ID);\\012ALTER TABLE MATERIAL_BATCHES ADD CONSTRAINT MABA_PROC_FK FOREIGN KEY (PROC_ID)REFERENCES PROCEDURES(ID);\\012ALTER TABLE MATERIALS ADD CONSTRAINT MATE_MATY_FK FOREIGN KEY (MATY_ID)REFERENCES MATERIAL_TYPES(ID);\\012ALTER TABLE MATERIALS ADD CONSTRAINT MATE_PERS_FK FOREIGN KEY (PERS_ID_REGISTERER)REFERENCES PERSONS(ID);\\012ALTER TABLE MOLECULES ADD CONSTRAINT MOLE_MATE_FK FOREIGN KEY (MATE_ID)REFERENCES MATERIALS(ID);\\012ALTER TABLE MOLECULES ADD CONSTRAINT MOLE_MOLE_FK FOREIGN KEY (MOLE_ID_INHIBITOR_OF)REFERENCES MOLECULES(MATE_ID);\\012ALTER TABLE EXPERIMENTS ADD CONSTRAINT EXPE_MATE_FK FOREIGN KEY (MATE_ID_STUDY_OBJECT)REFERENCES MATERIALS(ID);\\012ALTER TABLE EXPERIMENTS ADD CONSTRAINT EXPE_EXTY_FK FOREIGN KEY (EXTY_ID)REFERENCES EXPERIMENT_TYPES(ID);\\012ALTER TABLE EXPERIMENTS ADD CONSTRAINT EXPE_PERS_FK FOREIGN KEY (PERS_ID_REGISTERER)REFERENCES PERSONS(ID);\\012ALTER TABLE EXPERIMENTS ADD CONSTRAINT EXPE_PROJ_FK FOREIGN KEY (PROJ_ID)REFERENCES PROJECTS(ID);\\012\\012\\012\\012--  Creating Sequences\\012\\012CREATE SEQUENCE EXPERIMENT_PROPERTY_ID_SEQ;\\012\\012CREATE SEQUENCE PROCEDURE_TYPE_ID_SEQ;\\012\\012CREATE SEQUENCE SAMPLE_INPUT_ID_SEQ;\\012\\012CREATE SEQUENCE SAMPLE_TYPE_ID_SEQ;\\012\\012CREATE SEQUENCE LOCATOR_TYPE_ID_SEQ;\\012\\012CREATE SEQUENCE SAMPLE_ID_SEQ;\\012\\012CREATE SEQUENCE EXPERIMENT_ID_SEQ;\\012\\012CREATE SEQUENCE MATERIAL_BATCH_ID_SEQ;\\012\\012CREATE SEQUENCE OBSERVABLE_TYPE_ID_SEQ;\\012\\012CREATE SEQUENCE SAMPLE_COMPONENT_ID_SEQ;\\012\\012CREATE SEQUENCE MATERIAL_ID_SEQ;\\012\\012CREATE SEQUENCE DATA_ID_SEQ;\\012\\012--  Creating Sequence for the SAMPLE_COMPONENT_MATERIALS table (standard naming convention was too long)\\012CREATE SEQUENCE SCMA_ID_SEQ;\\012\\012CREATE SEQUENCE PROCEDURE_ID_SEQ;\\012\\012CREATE SEQUENCE FILE_FORMAT_TYPE_ID_SEQ;\\012\\012CREATE SEQUENCE MATERIAL_TYPE_ID_SEQ;\\012\\012CREATE SEQUENCE EXPERIMENT_TYPE_ID_SEQ;\\012\\012CREATE SEQUENCE PERSON_ID_SEQ;\\012\\012CREATE SEQUENCE ORGANIZATION_ID_SEQ;\\012\\012CREATE SEQUENCE PROJECT_ID_SEQ;\\012\\012CREATE SEQUENCE DATA_VALUE_ID_SEQ;\\012\\012\\012\\012/*\\012   Trigger Section\\012   ===============*/\\012\\012CREATE OR REPLACE FUNCTION br001_crtl_plate_chk() RETURNS trigger AS $br001_crtl_plate_chk$\\012DECLARE\\012   cnt           INTEGER;\\012   v_cell_plate  CODE;\\012BEGIN\\012\\012   select code into v_cell_plate from sample_types where id  = NEW.saty_id;\\012\\012   -- Check if the sample is of type "Cell Plate"\\012   if v_cell_plate = 'CELL PLATE' then\\012\\012      -- Check that a Control Plate exists before registering the Cell Plate\\012      select count(*) into cnt from samples s, sample_types st where s.saty_id = st.id and st.code = 'CONTROL LAYOUT';\\011 \\012      IF cnt = 0 THEN\\012\\011\\011 -- Doens't make sense, so comment it out\\012         -- RAISE EXCEPTION 'A Control Plate must exist before you can register Cell Plate: %', NEW.code;\\012      END IF;\\012\\012   end if;\\012\\012   RETURN NEW;\\012\\012END;\\012$br001_crtl_plate_chk$ LANGUAGE plpgsql;\\012\\012\\012CREATE TRIGGER br001_crtl_plate_chk BEFORE INSERT ON samples\\012    FOR EACH ROW EXECUTE PROCEDURE br001_crtl_plate_chk();\\012	\N
+./sourceTest/sql/postgresql/026/.svn/text-base/009=database_version_logs.tsv.svn-base:013	source/sql/postgresql/migration/migration-012-013.sql	SUCCESS	2008-05-09 10:11:20.487	----------------------------------------------------------------------------------------------\\012--  File: migration-012-013.sql\\012--\\012-- \\012--  This script enables the migration of the database schema from 012 to 013.\\012-- \\012--  Update History\\012--\\012--\\012--\\011Who\\011\\011\\011\\011\\011\\011\\011When\\011\\011\\011\\011What\\012--\\011---\\011\\011\\011\\011\\011\\011\\011----\\011\\011\\011\\011----\\012--\\011Bernd Rinn\\011\\0112008-01-04\\011Initial Version - add support for invalidations and material type BACTERIUM \\012--\\011Bernd Rinn\\011\\0112008-01-05\\011Add material type COMPOUND and material type property type entries for the new material types \\012--  \\012----------------------------------------------------------------------------------------------\\012\\012------------------------------------------------------------------------------------\\012--  Purpose:  Create function RENAME_SEQUENCE() that is required for renaming the sequences belonging to tables\\012------------------------------------------------------------------------------------\\012\\012CREATE FUNCTION RENAME_SEQUENCE(OLD_NAME VARCHAR, NEW_NAME VARCHAR) RETURNS INTEGER AS $$\\012DECLARE\\012  CURR_SEQ_VAL   INTEGER;\\012BEGIN\\012  SELECT INTO CURR_SEQ_VAL NEXTVAL(OLD_NAME);\\012  EXECUTE 'CREATE SEQUENCE ' || NEW_NAME || ' START WITH ' || CURR_SEQ_VAL;\\012  EXECUTE 'DROP SEQUENCE ' || OLD_NAME;\\012  RETURN CURR_SEQ_VAL;\\012END;\\012$$ LANGUAGE 'plpgsql';\\012\\012\\012------------------------------------------------------------------------------------\\012--  Purpose:  Add table INVALIDATIONS to store invalidations\\012------------------------------------------------------------------------------------\\012\\012CREATE TABLE INVALIDATIONS (ID TECH_ID NOT NULL,PERS_ID_REGISTERER TECH_ID NOT NULL,REGISTRATION_TIMESTAMP TIME_STAMP NOT NULL DEFAULT CURRENT_TIMESTAMP,REASON DESCRIPTION_250);\\012ALTER TABLE INVALIDATIONS ADD CONSTRAINT INVA_PK PRIMARY KEY(ID);\\012ALTER TABLE INVALIDATIONS ADD CONSTRAINT INVA_PERS_FK FOREIGN KEY (PERS_ID_REGISTERER) REFERENCES PERSONS(ID);\\012CREATE SEQUENCE INVALIDATION_ID_SEQ;\\012CREATE INDEX INVA_PERS_FK_I ON INVALIDATIONS (PERS_ID_REGISTERER);\\012\\012------------------------------------------------------------------------------------\\012--  Purpose:  Add column INVA_ID to table SAMPLES in order to allow invalidation of samples  \\012------------------------------------------------------------------------------------\\012\\012ALTER TABLE SAMPLES ADD INVA_ID TECH_ID;\\012ALTER TABLE SAMPLES ADD CONSTRAINT SAMP_INVA_FK FOREIGN KEY (INVA_ID) REFERENCES INVALIDATIONS(ID);\\012CREATE INDEX SAMP_INVA_FK_I ON SAMPLES (INVA_ID);\\012\\012\\012------------------------------------------------------------------------------------\\012--  Purpose:  Rename table EXPERIMENT_PROPERTIES TO EXPERIMENT_ATTACHMENTS  \\012------------------------------------------------------------------------------------\\012\\012ALTER TABLE EXPERIMENT_PROPERTIES DROP CONSTRAINT EXPR_PK;\\012ALTER TABLE EXPERIMENT_PROPERTIES DROP CONSTRAINT EXPR_BK_UK;\\012ALTER TABLE EXPERIMENT_PROPERTIES DROP CONSTRAINT EXPR_EXPE_FK;\\012ALTER TABLE EXPERIMENT_PROPERTIES DROP CONSTRAINT EXPR_PERS_FK;\\012\\012ALTER TABLE EXPERIMENT_PROPERTIES RENAME TO EXPERIMENT_ATTACHMENTS;\\012ALTER INDEX EXPR_EXPE_FK_I RENAME TO EXAT_EXPE_FK_I;\\012ALTER INDEX EXPR_PERS_FK_I RENAME TO EXAT_PERS_FK_I;\\012SELECT RENAME_SEQUENCE('EXPERIMENT_PROPERTY_ID_SEQ', 'EXPERIMENT_ATTACHMENT_ID_SEQ');\\012\\012ALTER TABLE EXPERIMENT_ATTACHMENTS ADD CONSTRAINT EXAT_PK PRIMARY KEY(ID);\\012ALTER TABLE EXPERIMENT_ATTACHMENTS ADD CONSTRAINT EXAT_BK_UK UNIQUE(EXPE_ID,FILE_NAME,VERSION);\\012ALTER TABLE EXPERIMENT_ATTACHMENTS ADD CONSTRAINT EXAT_EXPE_FK FOREIGN KEY (EXPE_ID) REFERENCES EXPERIMENTS(ID);\\012ALTER TABLE EXPERIMENT_ATTACHMENTS ADD CONSTRAINT EXAT_PERS_FK FOREIGN KEY (PERS_ID_REGISTERER) REFERENCES PERSONS(ID);\\012\\012\\012------------------------------------------------------------------------------------\\012--  Purpose:  Add the material type BACTERIUM\\012------------------------------------------------------------------------------------\\012\\012insert into material_types\\012(id\\012,code\\012,description)\\012values \\012(nextval('MATERIAL_TYPE_ID_SEQ')\\012,'BACTERIUM'\\012,'Bacterium'\\012);\\012\\012------------------------------------------------------------------------------------\\012--  Purpose:  Add the material type COMPOUND\\012------------------------------------------------------------------------------------\\012\\012insert into material_types\\012(id\\012,code\\012,description)\\012values \\012(nextval('MATERIAL_TYPE_ID_SEQ')\\012,'COMPOUND'\\012,'Compound'\\012);\\012\\012------------------------------------------------------------------------------------\\012--  Purpose:  Insert an initial data set into the table MATERIAL_TYPE_PROPERTY_TYPES\\012------------------------------------------------------------------------------------\\012\\012   -----------------------\\012   --  Material Type BACTERIUM\\012   -----------------------\\012\\012insert into material_type_property_types\\012(   id\\012   ,maty_id\\012   ,prty_id\\012   ,is_mandatory\\012   ,pers_id_registerer\\012   )\\012values \\012   (nextval('MTPT_ID_SEQ')\\012   ,(select id from material_types where code = 'BACTERIUM')\\012   ,(select id from property_types where code = 'DESCRIPTION')\\012   ,true\\012   ,(select id from persons where user_id ='system')\\012);\\012\\012   -----------------------\\012   --  Material Type COMPOUND\\012   -----------------------\\012\\012insert into material_type_property_types\\012(   id\\012   ,maty_id\\012   ,prty_id\\012   ,is_mandatory\\012   ,pers_id_registerer\\012   )\\012values \\012   (nextval('MTPT_ID_SEQ')\\012   ,(select id from material_types where code = 'COMPOUND')\\012   ,(select id from property_types where code = 'DESCRIPTION')\\012   ,true\\012   ,(select id from persons where user_id ='system')\\012);\\012\\012\\012------------------------------------------------------------------------------------\\012--  Purpose:  Change according to naming convention for CODEs\\012------------------------------------------------------------------------------------\\012\\012update procedure_types set code='DATA_ACQUISITION' where code='DATA ACQUISITION';\\012update procedure_types set code='IMAGE_ANALYSIS' where code='IMAGE ANALYSIS';\\012update locator_types set code='RELATIVE_LOCATION' where code='RELATIVE LOCATION';\\012update sample_types set code='MASTER_PLATE' where code='MASTER PLATE';\\012update sample_types set code='DILUTION_PLATE' where code='DILUTION PLATE';\\012update sample_types set code='CELL_PLATE' where code='CELL PLATE';\\012update sample_types set code='REINFECT_PLATE' where code='REINFECT PLATE';\\012update sample_types set description='Re-infection Plate' where code='REINFECT_PLATE';\\012update sample_types set code='CONTROL_LAYOUT' where code='CONTROL LAYOUT';\\012	\N
+./sourceTest/sql/postgresql/026/.svn/text-base/009=database_version_logs.tsv.svn-base:014	source/sql/postgresql/migration/migration-013-014.sql	SUCCESS	2008-05-09 10:11:22.523	----------------------------------------------------------------------------------------------\\012--  File: migration-013-014.sql\\012--\\012-- \\012--  This script enables the migration of the database schema from 013 to 014.\\012-- \\012--  Update History\\012--\\012--\\012--\\011Who\\011\\011\\011When\\011\\011What\\012--\\011---\\011\\011\\011----\\011\\011----\\012--\\011Charles Ramin-Wright\\0112008-01-29\\011Initial Version \\012--  \\012----------------------------------------------------------------------------------------------\\012\\012--=================================\\012-- New Tables and related objects\\012--=================================\\012\\012------------------------------------------------------------------------------------\\012--  Purpose:  Add tables CONTROLLED_VOCABULARIES and CONTROLLED_VOCABULARY_TERMS\\012------------------------------------------------------------------------------------\\012\\012CREATE TABLE CONTROLLED_VOCABULARIES (ID TECH_ID NOT NULL,CODE CODE NOT NULL,DESCRIPTION DESCRIPTION_80,REGISTRATION_TIMESTAMP TIME_STAMP NOT NULL DEFAULT CURRENT_TIMESTAMP,PERS_ID TECH_ID NOT NULL);\\012CREATE TABLE CONTROLLED_VOCABULARY_TERMS (ID TECH_ID NOT NULL,CODE OBJECT_NAME NOT NULL,REGISTRATION_TIMESTAMP TIME_STAMP NOT NULL DEFAULT CURRENT_TIMESTAMP,COVO_ID TECH_ID NOT NULL,PERS_ID TECH_ID NOT NULL);\\012\\012\\012-- Creating primary key constraints\\012\\012ALTER TABLE CONTROLLED_VOCABULARIES ADD CONSTRAINT COVO_PK PRIMARY KEY(ID);\\012ALTER TABLE CONTROLLED_VOCABULARY_TERMS ADD CONSTRAINT CVTE_PK PRIMARY KEY(ID);\\012\\012-- Creating unique constraints\\012\\012ALTER TABLE CONTROLLED_VOCABULARIES ADD CONSTRAINT COVO_BK_UK UNIQUE(CODE);\\012ALTER TABLE CONTROLLED_VOCABULARY_TERMS ADD CONSTRAINT CVTE_BK_UK UNIQUE(CODE,COVO_ID);\\012\\012-- Creating foreign key constraints\\012\\012ALTER TABLE CONTROLLED_VOCABULARIES ADD CONSTRAINT COVO_PERS_FK FOREIGN KEY (PERS_ID) REFERENCES PERSONS(ID);\\012ALTER TABLE CONTROLLED_VOCABULARY_TERMS ADD CONSTRAINT CVTE_COVO_FK FOREIGN KEY (COVO_ID) REFERENCES CONTROLLED_VOCABULARIES(ID);\\012ALTER TABLE CONTROLLED_VOCABULARY_TERMS ADD CONSTRAINT CVTE_PERS_FK FOREIGN KEY (PERS_ID) REFERENCES PERSONS(ID);\\012\\012-- Creating sequences\\012\\012CREATE SEQUENCE CONTROLLED_VOCABULARY_ID_SEQ;\\012CREATE SEQUENCE CVTE_ID_SEQ;\\012\\012\\012-- Creating indexes\\012\\012CREATE INDEX COVO_PERS_FK_I ON CONTROLLED_VOCABULARIES (PERS_ID);\\012CREATE INDEX CVTE_COVO_FK_I ON CONTROLLED_VOCABULARY_TERMS (COVO_ID);\\012CREATE INDEX CVTE_PERS_FK_I ON CONTROLLED_VOCABULARY_TERMS (PERS_ID);\\012\\012\\012--====================================\\012-- Modifications of existing objects\\012--====================================\\012\\012---------------------------------------------------------------------------------------------------\\012--  Purpose:  Add column INVA_ID to table EXPERIMENTS in order to allow invalidation of experiments\\012---------------------------------------------------------------------------------------------------\\012\\012ALTER TABLE EXPERIMENTS ADD INVA_ID TECH_ID;\\012ALTER TABLE EXPERIMENTS ADD CONSTRAINT EXPE_INVA_FK FOREIGN KEY (INVA_ID) REFERENCES INVALIDATIONS(ID);\\012CREATE INDEX EXPE_INVA_FK_I ON EXPERIMENTS (INVA_ID);\\012\\012------------------------------------------------------------------------------------\\012--  Purpose:  Add column SAMP_ID_CONTROL_LAYOUT to table SAMPLES in order to allow \\012--            the association of a sample of type CONTROL_LAYOUT to samples\\012------------------------------------------------------------------------------------\\012\\012ALTER TABLE SAMPLES ADD SAMP_ID_CONTROL_LAYOUT TECH_ID;\\012ALTER TABLE SAMPLES ADD CONSTRAINT SAMP_SAMP_FK_CONTROL_LAYOUT FOREIGN KEY (SAMP_ID_CONTROL_LAYOUT) REFERENCES SAMPLES(ID);\\012CREATE INDEX SAMP_SAMP_FK_I_CONTROL_LAYOUT ON SAMPLES (SAMP_ID_CONTROL_LAYOUT);\\012\\012\\012--------------------------------------------------------------\\012--  Purpose:  Add column CVTE_ID to table MATERIAL_PROPERTIES \\012--------------------------------------------------------------\\012ALTER TABLE MATERIAL_PROPERTIES ADD CVTE_ID TECH_ID;\\012ALTER TABLE MATERIAL_PROPERTIES ADD CONSTRAINT MAPR_CVTE_FK FOREIGN KEY (CVTE_ID) REFERENCES CONTROLLED_VOCABULARY_TERMS(ID);\\012CREATE INDEX MAPR_CVTE_FK_I ON MATERIAL_PROPERTIES (CVTE_ID);\\012\\012--------------------------------------------------------------\\012--  Purpose:  Change column VALUE from mandatory to optional\\012--------------------------------------------------------------\\012ALTER TABLE MATERIAL_PROPERTIES ALTER VALUE DROP NOT NULL;\\012\\012-- Creating check constraints\\012\\012ALTER TABLE MATERIAL_PROPERTIES ADD CONSTRAINT VALUE_OR_CVTE_ID CHECK ((value IS NOT NULL and cvte_id IS NULL) or (value IS NULL and cvte_id IS NOT NULL));\\012\\012\\012--------------------------------------------------------------\\012--  Purpose:  Add column COVO_ID to table PROPERTY_TYPES  \\012--------------------------------------------------------------\\012ALTER TABLE PROPERTY_TYPES ADD COVO_ID TECH_ID;\\012ALTER TABLE PROPERTY_TYPES ADD CONSTRAINT PRTY_COVO_FK FOREIGN KEY (COVO_ID) REFERENCES CONTROLLED_VOCABULARIES(ID);\\012CREATE INDEX PRTY_COVO_FK_I ON PROPERTY_TYPES (COVO_ID);\\012\\012\\012------------------------------------------------------------------------------------\\012--  Purpose:  Create trigger CONTROLLED_VOCABULARY_CHECK \\012------------------------------------------------------------------------------------\\012\\012CREATE OR REPLACE FUNCTION CONTROLLED_VOCABULARY_CHECK() RETURNS trigger AS $$\\012DECLARE\\012   cnt     INTEGER;\\012   v_code  CODE;\\012BEGIN\\012\\012   select code into v_code from data_types where id  = NEW.daty_id;\\012\\012   -- Check if the data is of type "CONTROLLEDVOCABULARY"\\012   if v_code = 'CONTROLLEDVOCABULARY' then\\012      if NEW.covo_id IS NULL then\\012         RAISE EXCEPTION 'Insert/Update of Property Type (Code: %) failed, as its Data Type is CONTROLLEDVOCABULARY, but it is not linked to a Controlled Vocabulary.', NEW.code;\\012      end if;\\012   end if;\\012\\012   RETURN NEW;\\012\\012END;\\012$$ LANGUAGE 'plpgsql';\\012\\012\\012CREATE TRIGGER CONTROLLED_VOCABULARY_CHECK BEFORE INSERT OR UPDATE ON PROPERTY_TYPES\\012    FOR EACH ROW EXECUTE PROCEDURE CONTROLLED_VOCABULARY_CHECK();\\012\\012\\012--====================================\\012-- Deletion of existing objects\\012--====================================\\012\\012drop trigger br001_crtl_plate_chk on samples;\\012drop function br001_crtl_plate_chk();\\012\\012\\012--====================================\\012-- Add Master Data\\012--====================================\\012\\012-----------------------------------------------------------------------------------\\012--  Purpose:  Insert into the table DATA_TYPES\\012--\\012--            Create the data type CONTROLLEDVOCABULARY.\\012-----------------------------------------------------------------------------------\\012insert into data_types\\012(id\\012,code\\012,description)\\012values \\012(nextval('DATA_TYPE_ID_SEQ')\\012,'CONTROLLEDVOCABULARY'\\012,'Controlled Vocabulary'\\012);\\012\\012--==========================================\\012--\\012--   Data Migration\\012--\\012--==========================================\\012\\012-----------------------------------------------------------------------------------\\012--  Purpose:  Migrate the CONTROL_LAYOUTs from the SAMPLE_INPUTS table \\012--            to the foreign key SAMP_SAMP_FK_CONTROL_LAYOUT in the SAMPLES table\\012--\\012--            This results in having all CONTROL_LAYOUTs being directly linked \\012--            to CELL_PLATEs.            \\012-----------------------------------------------------------------------------------\\012\\012UPDATE samples cell_plate\\012   SET samp_id_control_layout = \\012          (select control_layout.samp_id\\012           from   sample_inputs control_layout inner join samples s \\012           on     control_layout.samp_id = s.id\\012           where  s.saty_id = (select id from sample_types where code = 'CONTROL_LAYOUT')\\012           and    proc_id = (\\012              select  proc_id\\012              from sample_inputs cp\\012              where cp.samp_id = cell_plate.id))\\012   WHERE saty_id = (select id from sample_types where code = 'CELL_PLATE')\\012   and   id = (select distinct (samp_id)\\012                  from   sample_inputs sain inner join samples s2 \\012                  on  sain.samp_id = cell_plate.id)\\012;\\012\\012-----------------------------------------------------------------------------------\\012--   Delete the CONTROL LAYOUTs from the SAMPLE_INPUTS table\\012-----------------------------------------------------------------------------------\\012\\012delete from sample_inputs\\012where  id in (select si.id \\012              from   sample_inputs si inner join samples s \\012              on     si.samp_id = s.id\\012              where  s.saty_id = (select id from sample_types where code = 'CONTROL_LAYOUT')\\012              )\\012;\\012\\012	\N
+./sourceTest/sql/postgresql/026/.svn/text-base/009=database_version_logs.tsv.svn-base:016	source/sql/postgresql/migration/migration-015-016.sql	SUCCESS	2008-05-09 10:12:52.062	----------------------------------------------------------------------------------------------\\012--  File: migration-015-016.sql\\012--\\012-- \\012--  This script enables the migration of the database schema from 015 to 016.\\012-- \\012--  Update History\\012--\\012--\\012--\\011Who\\011\\011\\011When\\011\\011What\\012--\\011---\\011\\011\\011----\\011\\011----\\012--\\011Bernd Rinn\\0112008-03-22\\011Initial Version \\012--  \\012----------------------------------------------------------------------------------------------\\012\\012\\012--=================================\\012-- New Domains\\012--=================================\\012\\012-----------------------------------------------------------------------------------\\012--  Purpose:  Change all CODE columns to LONG_CODE, then re-create DOMAIN CODE identical to LONG_CODE\\012--  and change LONG_CODE columns back to the (new) CODE \\012-----------------------------------------------------------------------------------\\012\\012-- First step: create new domain LONG_CODE\\012CREATE DOMAIN LONG_CODE AS VARCHAR(40);\\012\\012-- Second step: change all CODE to LONG_CODE\\012ALTER TABLE CONTROLLED_VOCABULARIES ALTER COLUMN CODE TYPE LONG_CODE;\\012ALTER TABLE DATA_TYPES ALTER COLUMN CODE TYPE LONG_CODE;\\012ALTER TABLE EXPERIMENTS ALTER COLUMN CODE TYPE LONG_CODE;\\012ALTER TABLE EXPERIMENT_TYPES ALTER COLUMN CODE TYPE LONG_CODE;\\012ALTER TABLE FILE_FORMAT_TYPES ALTER COLUMN CODE TYPE LONG_CODE;\\012ALTER TABLE LOCATOR_TYPES ALTER COLUMN CODE TYPE LONG_CODE;\\012ALTER TABLE MATERIALS ALTER COLUMN CODE TYPE LONG_CODE;\\012ALTER TABLE MATERIAL_BATCHES ALTER COLUMN CODE TYPE LONG_CODE;\\012ALTER TABLE MATERIAL_TYPES ALTER COLUMN CODE TYPE LONG_CODE;\\012ALTER TABLE OBSERVABLE_TYPES ALTER COLUMN CODE TYPE LONG_CODE;\\012ALTER TABLE ORGANIZATIONS ALTER COLUMN CODE TYPE LONG_CODE;\\012ALTER TABLE PROCEDURE_TYPES ALTER COLUMN CODE TYPE LONG_CODE;\\012ALTER TABLE PROJECTS ALTER COLUMN CODE TYPE LONG_CODE;\\012ALTER TABLE PROPERTY_TYPES ALTER COLUMN CODE TYPE LONG_CODE;\\012ALTER TABLE SAMPLES ALTER COLUMN CODE TYPE LONG_CODE;\\012ALTER TABLE SAMPLE_COMPONENTS ALTER COLUMN CODE TYPE LONG_CODE;\\012ALTER TABLE SAMPLE_TYPES ALTER COLUMN CODE TYPE LONG_CODE;\\012\\012-- Third step: re-create CODE as VARCHAR(40)\\012DROP DOMAIN CODE;\\012CREATE DOMAIN CODE AS VARCHAR(40);\\012\\012-- Forth step: change all LONG_CODE columns back to CODE\\012ALTER TABLE CONTROLLED_VOCABULARIES ALTER COLUMN CODE TYPE CODE;\\012ALTER TABLE DATA_TYPES ALTER COLUMN CODE TYPE CODE;\\012ALTER TABLE EXPERIMENTS ALTER COLUMN CODE TYPE CODE;\\012ALTER TABLE EXPERIMENT_TYPES ALTER COLUMN CODE TYPE CODE;\\012ALTER TABLE FILE_FORMAT_TYPES ALTER COLUMN CODE TYPE CODE;\\012ALTER TABLE LOCATOR_TYPES ALTER COLUMN CODE TYPE CODE;\\012ALTER TABLE MATERIALS ALTER COLUMN CODE TYPE CODE;\\012ALTER TABLE MATERIAL_BATCHES ALTER COLUMN CODE TYPE CODE;\\012ALTER TABLE MATERIAL_TYPES ALTER COLUMN CODE TYPE CODE;\\012ALTER TABLE OBSERVABLE_TYPES ALTER COLUMN CODE TYPE CODE;\\012ALTER TABLE ORGANIZATIONS ALTER COLUMN CODE TYPE CODE;\\012ALTER TABLE PROCEDURE_TYPES ALTER COLUMN CODE TYPE CODE;\\012ALTER TABLE PROJECTS ALTER COLUMN CODE TYPE CODE;\\012ALTER TABLE PROPERTY_TYPES ALTER COLUMN CODE TYPE CODE;\\012ALTER TABLE SAMPLES ALTER COLUMN CODE TYPE CODE;\\012ALTER TABLE SAMPLE_COMPONENTS ALTER COLUMN CODE TYPE CODE;\\012ALTER TABLE SAMPLE_TYPES ALTER COLUMN CODE TYPE CODE;\\012\\012-- Fifth step: drop domain LONG_CODE\\012DROP DOMAIN LONG_CODE;\\012\\012-----------------------------------------------------------------------------------\\012--  Purpose:  Create new domain TIME_STAMP_DFL and change current users of TIME_STAMP to TIME_STAMP_DFL\\012--  This adds time zone information and allows for a clean separation between registration time stamps\\012--  which should have a default of CURRENT_TIMESTAMP and other time stamps which should not. \\012-----------------------------------------------------------------------------------\\012\\012-- First step: create new domain TIME_STAMP_DFL\\012CREATE DOMAIN TIME_STAMP_DFL AS TIMESTAMP WITH TIME ZONE NOT NULL DEFAULT CURRENT_TIMESTAMP;\\012\\012-- Second step: change all TIME_STAMP columns to TIME_STAMP_DFL\\012ALTER TABLE CONTROLLED_VOCABULARIES ALTER COLUMN REGISTRATION_TIMESTAMP TYPE TIME_STAMP_DFL;\\012ALTER TABLE CONTROLLED_VOCABULARIES ALTER COLUMN REGISTRATION_TIMESTAMP DROP NOT NULL;\\012ALTER TABLE CONTROLLED_VOCABULARIES ALTER COLUMN REGISTRATION_TIMESTAMP DROP DEFAULT;\\012ALTER TABLE CONTROLLED_VOCABULARY_TERMS ALTER COLUMN REGISTRATION_TIMESTAMP TYPE TIME_STAMP_DFL;\\012ALTER TABLE CONTROLLED_VOCABULARY_TERMS ALTER COLUMN REGISTRATION_TIMESTAMP DROP NOT NULL;\\012ALTER TABLE CONTROLLED_VOCABULARY_TERMS ALTER COLUMN REGISTRATION_TIMESTAMP DROP DEFAULT;\\012ALTER TABLE DATA ALTER COLUMN REGISTRATION_TIMESTAMP TYPE TIME_STAMP_DFL;\\012ALTER TABLE DATA ALTER COLUMN REGISTRATION_TIMESTAMP DROP NOT NULL;\\012ALTER TABLE DATA ALTER COLUMN REGISTRATION_TIMESTAMP DROP DEFAULT;\\012ALTER TABLE EXPERIMENTS ALTER COLUMN REGISTRATION_TIMESTAMP TYPE TIME_STAMP_DFL;\\012ALTER TABLE EXPERIMENTS ALTER COLUMN REGISTRATION_TIMESTAMP DROP NOT NULL;\\012ALTER TABLE EXPERIMENTS ALTER COLUMN REGISTRATION_TIMESTAMP DROP DEFAULT;\\012ALTER TABLE EXPERIMENT_ATTACHMENTS ALTER COLUMN REGISTRATION_TIMESTAMP TYPE TIME_STAMP_DFL;\\012ALTER TABLE EXPERIMENT_ATTACHMENTS ALTER COLUMN REGISTRATION_TIMESTAMP DROP NOT NULL;\\012ALTER TABLE EXPERIMENT_ATTACHMENTS ALTER COLUMN REGISTRATION_TIMESTAMP DROP DEFAULT;\\012ALTER TABLE EXPERIMENT_PROPERTIES ALTER COLUMN REGISTRATION_TIMESTAMP TYPE TIME_STAMP_DFL;\\012ALTER TABLE EXPERIMENT_PROPERTIES ALTER COLUMN REGISTRATION_TIMESTAMP DROP NOT NULL;\\012ALTER TABLE EXPERIMENT_PROPERTIES ALTER COLUMN REGISTRATION_TIMESTAMP DROP DEFAULT;\\012ALTER TABLE EXPERIMENT_TYPE_PROPERTY_TYPES ALTER COLUMN REGISTRATION_TIMESTAMP TYPE TIME_STAMP_DFL;\\012ALTER TABLE EXPERIMENT_TYPE_PROPERTY_TYPES ALTER COLUMN REGISTRATION_TIMESTAMP DROP NOT NULL;\\012ALTER TABLE EXPERIMENT_TYPE_PROPERTY_TYPES ALTER COLUMN REGISTRATION_TIMESTAMP DROP DEFAULT;\\012ALTER TABLE INVALIDATIONS ALTER COLUMN REGISTRATION_TIMESTAMP TYPE TIME_STAMP_DFL;\\012ALTER TABLE INVALIDATIONS ALTER COLUMN REGISTRATION_TIMESTAMP DROP NOT NULL;\\012ALTER TABLE INVALIDATIONS ALTER COLUMN REGISTRATION_TIMESTAMP DROP DEFAULT;\\012ALTER TABLE MATERIALS ALTER COLUMN REGISTRATION_TIMESTAMP TYPE TIME_STAMP_DFL;\\012ALTER TABLE MATERIALS ALTER COLUMN REGISTRATION_TIMESTAMP DROP NOT NULL;\\012ALTER TABLE MATERIALS ALTER COLUMN REGISTRATION_TIMESTAMP DROP DEFAULT;\\012ALTER TABLE MATERIAL_BATCHES ALTER COLUMN REGISTRATION_TIMESTAMP TYPE TIME_STAMP_DFL;\\012ALTER TABLE MATERIAL_BATCHES ALTER COLUMN REGISTRATION_TIMESTAMP DROP NOT NULL;\\012ALTER TABLE MATERIAL_BATCHES ALTER COLUMN REGISTRATION_TIMESTAMP DROP DEFAULT;\\012ALTER TABLE MATERIAL_PROPERTIES ALTER COLUMN REGISTRATION_TIMESTAMP TYPE TIME_STAMP_DFL;\\012ALTER TABLE MATERIAL_PROPERTIES ALTER COLUMN REGISTRATION_TIMESTAMP DROP NOT NULL;\\012ALTER TABLE MATERIAL_PROPERTIES ALTER COLUMN REGISTRATION_TIMESTAMP DROP DEFAULT;\\012ALTER TABLE MATERIAL_TYPE_PROPERTY_TYPES ALTER COLUMN REGISTRATION_TIMESTAMP TYPE TIME_STAMP_DFL;\\012ALTER TABLE MATERIAL_TYPE_PROPERTY_TYPES ALTER COLUMN REGISTRATION_TIMESTAMP DROP NOT NULL;\\012ALTER TABLE MATERIAL_TYPE_PROPERTY_TYPES ALTER COLUMN REGISTRATION_TIMESTAMP DROP DEFAULT;\\012ALTER TABLE PROCEDURES ALTER COLUMN REGISTRATION_TIMESTAMP TYPE TIME_STAMP_DFL;\\012ALTER TABLE PROCEDURES ALTER COLUMN REGISTRATION_TIMESTAMP DROP NOT NULL;\\012ALTER TABLE PROCEDURES ALTER COLUMN REGISTRATION_TIMESTAMP DROP DEFAULT;\\012ALTER TABLE PROPERTY_TYPES ALTER COLUMN REGISTRATION_TIMESTAMP TYPE TIME_STAMP_DFL;\\012ALTER TABLE PROPERTY_TYPES ALTER COLUMN REGISTRATION_TIMESTAMP DROP NOT NULL;\\012ALTER TABLE PROPERTY_TYPES ALTER COLUMN REGISTRATION_TIMESTAMP DROP DEFAULT;\\012ALTER TABLE SAMPLES ALTER COLUMN REGISTRATION_TIMESTAMP TYPE TIME_STAMP_DFL;\\012ALTER TABLE SAMPLES ALTER COLUMN REGISTRATION_TIMESTAMP DROP NOT NULL;\\012ALTER TABLE SAMPLES ALTER COLUMN REGISTRATION_TIMESTAMP DROP DEFAULT;\\012ALTER TABLE SAMPLE_PROPERTIES ALTER COLUMN REGISTRATION_TIMESTAMP TYPE TIME_STAMP_DFL;\\012ALTER TABLE SAMPLE_PROPERTIES ALTER COLUMN REGISTRATION_TIMESTAMP DROP NOT NULL;\\012ALTER TABLE SAMPLE_PROPERTIES ALTER COLUMN REGISTRATION_TIMESTAMP DROP DEFAULT;\\012ALTER TABLE SAMPLE_TYPE_PROPERTY_TYPES ALTER COLUMN REGISTRATION_TIMESTAMP TYPE TIME_STAMP_DFL;\\012ALTER TABLE SAMPLE_TYPE_PROPERTY_TYPES ALTER COLUMN REGISTRATION_TIMESTAMP DROP NOT NULL;\\012ALTER TABLE SAMPLE_TYPE_PROPERTY_TYPES ALTER COLUMN REGISTRATION_TIMESTAMP DROP DEFAULT;\\012\\012-- Third step: drop old domain TIME_STAMP\\012DROP DOMAIN TIME_STAMP;\\012\\012-- Forth step: create new domain time_stamp\\012CREATE DOMAIN TIME_STAMP AS TIMESTAMP WITH TIME ZONE;\\012\\012--=================================\\012-- New Tables and related objects\\012--=================================\\012\\012------------------------------------------------------------------------------------\\012-- table DATA_SET_RELATIONSHIPS (new)\\012------------------------------------------------------------------------------------\\012\\012-- Creating tables\\012\\012CREATE TABLE DATA_SET_RELATIONSHIPS (ID TECH_ID NOT NULL,DATA_ID_PARENT TECH_ID NOT NULL,DATA_ID_CHILD TECH_ID NOT NULL,REGISTRATION_TIMESTAMP TIME_STAMP_DFL);\\012\\012-- Creating primary key constraints\\012\\012ALTER TABLE DATA_SET_RELATIONSHIPS ADD CONSTRAINT DSRE_PK PRIMARY KEY(ID);\\012\\012-- Creating unique constraints\\012\\012ALTER TABLE DATA_SET_RELATIONSHIPS ADD CONSTRAINT DSRE_BK_UK UNIQUE(DATA_ID_CHILD,DATA_ID_PARENT);\\012\\012-- Creating foreign key constraints\\012\\012ALTER TABLE DATA_SET_RELATIONSHIPS ADD CONSTRAINT DSRE_DATA_FK_CHILD FOREIGN KEY (DATA_ID_CHILD) REFERENCES DATA(ID);\\012ALTER TABLE DATA_SET_RELATIONSHIPS ADD CONSTRAINT DSRE_DATA_FK_PARENT FOREIGN KEY (DATA_ID_PARENT) REFERENCES DATA(ID);\\012\\012-- Creating sequences\\012\\012CREATE SEQUENCE DATA_SET_RELATIONSHIP_ID_SEQ;\\012\\012-- Creating indexes\\012\\012CREATE INDEX DSRE_DATA_FK_I_CHILD ON DATA_SET_RELATIONSHIPS (DATA_ID_CHILD);\\012CREATE INDEX DSRE_DATA_FK_I_PARENT ON DATA_SET_RELATIONSHIPS (DATA_ID_PARENT);\\012\\012--====================================\\012-- Drop Tables and related objects\\012--====================================\\012\\012------------------------------------------------------------------------------------\\012-- table DATA_VALUES (deleted)\\012------------------------------------------------------------------------------------\\012\\012-- Delete constraints\\012\\012ALTER TABLE DATA_VALUES DROP CONSTRAINT DAVA_PK;\\012ALTER TABLE DATA_VALUES DROP CONSTRAINT DAVA_BK_UK;\\012ALTER TABLE DATA_VALUES DROP CONSTRAINT DAVA_DATA_FK;\\012ALTER TABLE DATA_VALUES DROP CONSTRAINT DAVA_SACO_FK;\\012\\012-- Delete indices\\012\\012DROP INDEX DAVA_DATA_FK_I;\\012DROP INDEX DAVA_SACO_FK_I;\\012\\012-- Delete sequences\\012\\012DROP SEQUENCE DATA_VALUE_ID_SEQ;\\012\\012-- Delete tables\\012\\012DROP TABLE DATA_VALUES;\\012\\012--====================================\\012-- Modifications of existing objects\\012--====================================\\012\\012------------------------------------------------------------------------------------\\012-- table ORGANIZATIONS (changed)\\012-- * rename to GROUPS\\012--\\012-- table DATA (changed)\\012-- * rename column PROC_ID_ACQUIRED_BY into: PROC_ID_PRODUCED_BY\\012-- * add columns:\\012-- ** IS_PLACEHOLDER BOOLEAN_CHAR\\012-- ** CODE CODE\\012-- ** DATA_PRODUCER_CODE CODE\\012-- ** PRODUCTION_TIMESTAMP TIME_STAMP\\012--\\012-- table EXTERNAL_DATA (changed)\\012-- * add column:\\012-- ** CVTE_ID_STOR_FMT TECH_ID NOT NULL\\012--\\012-- table PROPERTY_TYPES (changed)\\012-- * add column IS_MANAGED_INTERNALLY BOOLEAN_CHAR NOT NULL DEFAULT 'F'\\012-- * add unique constraint PRTY_BK_UK_LBL for column LABEL\\012--\\012-- tables EXPERIMENT_TYPE_PROPERTY_TYPES, MATERIAL_TYPE_PROPERTY_TYPES, SAMPLE_TYPE_PROPERTY_TYPES\\012-- * make the assignments of property types DESCRIPTION, NUCLEOTIDE_SEQUENCE, OFFSET and GENE_SYMBOL \\012--   to material types internally managed \\012--\\012-- table PROCEDURE_TYPES (changed)\\012-- * add column IS_DATA_ACQUISITION BOOLEAN_CHAR NOT NULL DEFAULT 'F'.\\012--\\012-- all tables\\012-- * convert all codes to upper case\\012------------------------------------------------------------------------------------\\012\\012---------------------------------------------------------------------------------------------------\\012--  Purpose:  Rename table ORGANIZATIONS to GROUPS.\\012---------------------------------------------------------------------------------------------------\\012\\012ALTER TABLE PROJECTS DROP CONSTRAINT PROJ_ORGA_FK;\\012ALTER TABLE ORGANIZATIONS DROP CONSTRAINT ORGA_BK_UK;\\012ALTER TABLE ORGANIZATIONS DROP CONSTRAINT ORGA_PK;\\012ALTER TABLE ORGANIZATIONS RENAME TO GROUPS;\\012ALTER INDEX PROJ_ORGA_FK_I RENAME TO PROJ_GROU_FK_I;\\012select RENAME_SEQUENCE('ORGANIZATION_ID_SEQ', 'GROUP_ID_SEQ');\\012ALTER TABLE PROJECTS RENAME COLUMN ORGA_ID TO GROU_ID;\\012ALTER TABLE GROUPS ADD CONSTRAINT GROU_PK PRIMARY KEY(ID);\\012ALTER TABLE GROUPS ADD CONSTRAINT GROU_BK_UK UNIQUE(CODE);\\012ALTER TABLE PROJECTS ADD CONSTRAINT PROJ_GROU_FK FOREIGN KEY (GROU_ID) REFERENCES GROUPS(ID);\\012\\012\\012---------------------------------------------------------------------------------------------------\\012--  Purpose:  Add columnd IS_PLACEHOLDER of table DATA.\\012---------------------------------------------------------------------------------------------------\\012\\012ALTER TABLE DATA ADD COLUMN IS_PLACEHOLDER BOOLEAN_CHAR NOT NULL;\\012\\012\\012---------------------------------------------------------------------------------------------------\\012--  Purpose:  Add and populate column CODE of table DATA.\\012---------------------------------------------------------------------------------------------------\\012\\012ALTER TABLE DATA ADD COLUMN CODE CODE;\\012\\012CREATE OR REPLACE FUNCTION populate_data_codes() RETURNS integer AS $$\\012DECLARE\\012    rec RECORD;\\012BEGIN\\012    FOR rec IN SELECT * FROM data LOOP\\012        rec.code := to_char(rec.registration_timestamp, 'YYYYMMDDHH24MISSMS') || '-' || to_char(rec.id, 'FM99999999999999999999');\\012        update data set code=rec.code where id=rec.id;\\012    END LOOP;\\012    RETURN 1;\\012END;\\012$$ LANGUAGE 'plpgsql';\\012\\012SELECT populate_data_codes();\\012DROP FUNCTION populate_data_codes();\\012\\012ALTER TABLE DATA ALTER COLUMN CODE SET NOT NULL;\\012ALTER TABLE DATA ADD CONSTRAINT DATA_BK_UK UNIQUE(CODE);\\012\\012---------------------------------------------------------------------------------------------------\\012--  Purpose:  Add and populate columns CVTE_ID_STOR_FMT.\\012---------------------------------------------------------------------------------------------------\\012\\012ALTER TABLE EXTERNAL_DATA ADD COLUMN CVTE_ID_STOR_FMT TECH_ID;\\012ALTER TABLE EXTERNAL_DATA ADD CONSTRAINT EXDA_STOR_FMT_FK FOREIGN KEY (CVTE_ID_STOR_FMT) REFERENCES CONTROLLED_VOCABULARY_TERMS(ID);\\012\\012------------------------------------------------------------------------------------\\012--  Purpose:  Create trigger EXTERNAL_DATA_STORAGE_FORMAT_CHECK \\012------------------------------------------------------------------------------------\\012\\012CREATE OR REPLACE FUNCTION EXTERNAL_DATA_STORAGE_FORMAT_CHECK() RETURNS trigger AS $$\\012DECLARE\\012   v_covo_code  CODE;\\012BEGIN\\012\\012   select code into v_covo_code from controlled_vocabularies\\012      where id = (select covo_id from controlled_vocabulary_terms where id = NEW.cvte_id_stor_fmt);\\012\\012   -- Check if the data storage format is a term of the controlled vocabulary "STORAGE_FORMAT"\\012   if v_covo_code != '.STORAGE_FORMAT' then\\012      RAISE EXCEPTION 'Insert/Update of Data (Code: %) failed, as its Storage Format is %, but is required to be STORAGE_FORMAT.', NEW.code, v_covo_code;\\012   end if;\\012\\012   RETURN NEW;\\012\\012END;\\012$$ LANGUAGE 'plpgsql';\\012\\012CREATE TRIGGER EXTERNAL_DATA_STORAGE_FORMAT_CHECK BEFORE INSERT OR UPDATE ON EXTERNAL_DATA\\012    FOR EACH ROW EXECUTE PROCEDURE EXTERNAL_DATA_STORAGE_FORMAT_CHECK();\\012\\012-----------------------------------------------------------------------------------\\012--  Purpose:  Create Controlled Vocabulary .STORAGE_FORMAT\\012-----------------------------------------------------------------------------------\\012insert into controlled_vocabularies \\012       ( id\\012       , code\\012       , description\\012       , pers_id_registerer\\012       , is_managed_internally )\\012values  (nextval('CONTROLLED_VOCABULARY_ID_SEQ')\\012       , '.STORAGE_FORMAT'\\012       , 'The on-disk storage format of a data set'\\012       , (select id from persons where user_id ='system')\\012       , true);\\012\\012\\012-----------------------------------------------------------------------------------\\012--  Purpose:  Create Controlled Vocabulary Terms for STORAGE_FORMAT\\012-----------------------------------------------------------------------------------\\012insert into controlled_vocabulary_terms \\012       ( id\\012       , code\\012       , covo_id \\012       , pers_id_registerer )\\012values  (nextval('CVTE_ID_SEQ')\\012       , 'PROPRIETARY'\\012       , (select id from controlled_vocabularies where code = '.STORAGE_FORMAT')\\012       , (select id from persons where user_id ='system'));\\012\\012insert into controlled_vocabulary_terms \\012       ( id\\012       , code\\012       , covo_id \\012       , pers_id_registerer )\\012values  (nextval('CVTE_ID_SEQ')\\012       , 'BDS_DIRECTORY'\\012       , (select id from controlled_vocabularies where code = '.STORAGE_FORMAT')\\012       , (select id from persons where user_id ='system'));\\012\\012\\012--------------------------------------------------------------------------\\012--  Purpose:  Insert an entry for OBSERVABLE_TYPE UNKNOWN\\012--------------------------------------------------------------------------\\012\\012insert into observable_types\\012(id\\012,code\\012,description)\\012values \\012(nextval('OBSERVABLE_TYPE_ID_SEQ')\\012,'UNKNOWN'\\012,'Unknown'\\012);\\012\\012----------------------------------------------------------------------\\012--  Purpose:  Insert an entry for PROCEDURE_TYPE UNKNOWN\\012-----------------------------------------------------------------------\\012\\012insert into procedure_types\\012(id\\012,code\\012,description)\\012values \\012(nextval('PROCEDURE_TYPE_ID_SEQ')\\012,'UNKNOWN'\\012,'Unknown'\\012);\\012\\012\\012---------------------------------------------------------------------------------------------------\\012--  Purpose:  Populate external_data.cvte_id_stor_fmt with a default value.\\012---------------------------------------------------------------------------------------------------\\012\\012CREATE OR REPLACE FUNCTION polulate_external_data_cvte_id_stor_fmt() RETURNS integer AS $$\\012DECLARE\\012    rec RECORD;\\012    dfl_stor_fmt_code VARCHAR := 'PROPRIETARY';\\012    dfl_stor_fmt_id TECH_ID;\\012BEGIN\\012    select cvte.id into dfl_stor_fmt_id from controlled_vocabulary_terms cvte, controlled_vocabularies cv \\012        where cvte.code = dfl_stor_fmt_code and cvte.covo_id = cv.id and cv.code = '.STORAGE_FORMAT'; \\012    update external_data set cvte_id_stor_fmt = dfl_stor_fmt_id;\\012    RETURN 1;\\012END;\\012$$ LANGUAGE 'plpgsql';\\012\\012SELECT polulate_external_data_cvte_id_stor_fmt();\\012DROP FUNCTION polulate_external_data_cvte_id_stor_fmt();\\012\\012-- Now that the field is populated, create the not null constraint for it.\\012\\012ALTER TABLE EXTERNAL_DATA ALTER COLUMN CVTE_ID_STOR_FMT SET NOT NULL;\\012\\012---------------------------------------------------------------------------------------------------\\012--  Purpose:  Add and populate columns DATA_PRODUCER_CODE and PRODUCTION_TIMESTAMP to table DATA.\\012---------------------------------------------------------------------------------------------------\\012\\012ALTER TABLE DATA ADD COLUMN DATA_PRODUCER_CODE CODE;\\012ALTER TABLE DATA ADD COLUMN PRODUCTION_TIMESTAMP TIME_STAMP;\\012\\012CREATE OR REPLACE FUNCTION populate_data_producer_code_and_production_timestamp() RETURNS integer AS $$\\012DECLARE\\012    rec RECORD;\\012    loty_rel_code VARCHAR := 'RELATIVE_LOCATION';\\012    loty_rel_id TECH_ID;\\012    meas_ts TIMESTAMP;\\012    ds_code CODE;\\012    meas_ts_str TEXT;\\012BEGIN\\012    select id into loty_rel_id from locator_types where code = loty_rel_code; \\012    FOR rec IN SELECT d.id, ed.location FROM data d, external_data ed where d.id = ed.data_id and ed.loty_id = loty_rel_id LOOP\\012        meas_ts_str = substring(rec.location from '^.*/([0-9]{14})_[^_]+_(.*)$');\\012        ds_code := substring(rec.location from '^.*/[0-9]{14}_([^_]+)_(.*)$');\\012        IF meas_ts_str is not null and ds_code is not null THEN\\012            meas_ts := to_timestamp(meas_ts_str, 'YYYYMMDDHH24MISS');\\012            update data set production_timestamp=meas_ts, data_producer_code=ds_code where id=rec.id;\\012        END IF;\\012    END LOOP;\\012    RETURN 1;\\012END;\\012$$ LANGUAGE 'plpgsql';\\012\\012SELECT populate_data_producer_code_and_production_timestamp();\\012DROP FUNCTION populate_data_producer_code_and_production_timestamp();\\012\\012-- Rename columns\\012\\012ALTER TABLE DATA RENAME COLUMN PROC_ID_ACQUIRED_BY to PROC_ID_PRODUCED_BY;\\012\\012---------------------------------------------------------------------------------------------------\\012--  Purpose:  Populate table DATA_SET_RELATIONSHIPS, by using heuristics.\\012---------------------------------------------------------------------------------------------------\\012\\012CREATE OR REPLACE FUNCTION abs_interval(ts1 time_stamp_dfl, ts2 time_stamp_dfl) returns interval AS $$\\012BEGIN\\012    IF ts1 < ts2 THEN\\012        RETURN ts2 - ts1;\\012    ELSE\\012        RETURN ts1 - ts2;\\012    END IF;\\012END;\\012$$ LANGUAGE 'plpgsql';\\012\\012CREATE OR REPLACE FUNCTION populate_data_set_relationships() RETURNS INTEGER AS $$\\012DECLARE\\012    source_id TECH_ID;\\012    rec_derived RECORD;\\012    rec_acquired RECORD;\\012    rel_location TEXT;\\012    data_set_code TEXT;\\012    data_set_code_trial TEXT;\\012    loty_rel_code TEXT := 'RELATIVE_LOCATION';\\012    loty_rel_id TECH_ID;\\012    count INTEGER := 0;\\012BEGIN\\012    select id into loty_rel_id from locator_types where code = loty_rel_code;\\012    FOR rec_derived IN select id, samp_id_derived_from, registration_timestamp from data where samp_id_derived_from is not null LOOP\\012        source_id := NULL;\\012        select location into rel_location from external_data where data_id = rec_derived.id and loty_id = loty_rel_id;\\012        IF rel_location is not null then\\012            data_set_code := substring(rel_location from '^.*/([0-9]{14}_[^_]+)_.*$');\\012            IF data_set_code is not null THEN\\012                FOR rec_acquired IN select id, samp_id_acquired_from from data where samp_id_acquired_from = rec_derived.samp_id_derived_from LOOP\\012                    select location into rel_location from external_data where data_id = rec_acquired.id and loty_id = loty_rel_id;\\012                    IF rel_location is not null THEN\\012                        data_set_code_trial := substring(rel_location from '^.*/([0-9]{14}_[^_]+)_.*$');\\012                        IF data_set_code_trial = data_set_code THEN\\012                            source_id = rec_acquired.id;\\012                            EXIT;\\012                        END IF;\\012                    END IF;\\012                END LOOP;\\012            END IF;\\012        END IF;\\012        -- If the location didn't tell us about data set relationships, try the backup strategy.\\012        IF source_id is null THEN\\012            -- Use the measured data set as source that is closest in registration timestamp.\\012            select id into source_id from data where samp_id_acquired_from = rec_derived.samp_id_derived_from \\012                and abs_interval(registration_timestamp, rec_derived.registration_timestamp) \\012                    = (select min(abs_interval(registration_timestamp, rec_derived.registration_timestamp)) \\012                        from data where samp_id_acquired_from = rec_derived.samp_id_derived_from);\\012        END IF;\\012        IF source_id is not null THEN\\012            insert into data_set_relationships (id, data_id_parent, data_id_child)\\012                values (nextval('DATA_SET_RELATIONSHIP_ID_SEQ'), source_id, rec_derived.id);\\012            count := count + 1;\\012        END IF;\\012    END LOOP;\\012    RETURN count;\\012END;\\012$$ LANGUAGE 'plpgsql';\\012\\012SELECT populate_data_set_relationships();\\012DROP FUNCTION populate_data_set_relationships();\\012DROP FUNCTION abs_interval(time_stamp_dfl, time_stamp_dfl);\\012\\012---------------------------------------------------------------------------------------------------\\012--  Purpose:  Add column IS_MANAGED_INTERNALLY to table PROPERTY_TYPES. Internally managed \\012--  properties can not be assigned by users of openBIS, but only by the system. \\012---------------------------------------------------------------------------------------------------\\012\\012ALTER TABLE PROPERTY_TYPES ADD COLUMN IS_MANAGED_INTERNALLY BOOLEAN_CHAR NOT NULL DEFAULT 'F';\\012\\012-- Update already existing property type PLATE_GEOMETRY\\012update property_types set is_managed_internally = true, code = '.' || code where code = 'PLATE_GEOMETRY';\\012\\012-- Update already existing controlled vocabulary PLATE_GEOMETRY \\012update controlled_vocabularies set code = '.' || code where code = 'PLATE_GEOMETRY';\\012\\012---------------------------------------------------------------------------------------------------\\012--  Purpose:  Add unique constraint on column LABEL. \\012---------------------------------------------------------------------------------------------------\\012\\012CREATE OR REPLACE FUNCTION make_prty_labels_unique() RETURNS INTEGER AS $$\\012DECLARE\\012    prev_key TEXT := NULL;\\012    this_key TEXT;\\012    dup_count INTEGER;\\012    cnt INTEGER := 0;\\012    already_exists INTEGER;\\012    new_label TEXT;\\012    this_id TECH_ID;\\012BEGIN\\012    FOR this_id, this_key IN select id, label from property_types order by label,id LOOP\\012        IF this_key = prev_key THEN\\012            dup_count := dup_count + 1;\\012            cnt := cnt + 1;\\012        ELSE\\012            dup_count := 0;\\012        END IF;\\012        IF dup_count > 0 THEN\\012            -- Check whether the new key already exists.\\012            LOOP\\012                new_label := this_key || '(' || dup_count::text || ')';\\012                select count(*) into already_exists from property_types where label = new_label;\\012                IF already_exists = 0 THEN\\012                    EXIT;\\012                END IF;\\012                dup_count := dup_count + 1;\\012            END LOOP;\\012            update property_types set label = new_label where id = this_id;\\012        END IF;\\012        prev_key := this_key;\\012    END LOOP;\\012    RETURN cnt;\\012END;\\012$$ LANGUAGE 'plpgsql';\\012\\012SELECT make_prty_labels_unique();\\012DROP FUNCTION make_prty_labels_unique();\\012\\012ALTER TABLE PROPERTY_TYPES ADD CONSTRAINT PRTY_BK_UK_LBL UNIQUE(LABEL);\\012\\012-----------------------------------------------------------------------------------\\012--  Purpose:  Add Controlled Vocabulary Terms to PLATE_GEOMETRY\\012-----------------------------------------------------------------------------------\\012\\012insert into controlled_vocabulary_terms \\012       ( id\\012       , code\\012       , covo_id \\012       , pers_id_registerer)\\012values  (nextval('CVTE_ID_SEQ')\\012       , '96_WELLS_8X12'\\012       , (select id from controlled_vocabularies where code = '.PLATE_GEOMETRY')\\012       , (select id from persons where user_id = 'system'));\\012\\012insert into controlled_vocabulary_terms \\012       ( id\\012       , code\\012       , covo_id \\012       , pers_id_registerer)\\012values  (nextval('CVTE_ID_SEQ')\\012       , '1536_WELLS_32X48'\\012       , (select id from controlled_vocabularies where code = '.PLATE_GEOMETRY')\\012       , (select id from persons where user_id = 'system'));\\012\\012\\012-----------------------------------------------------------------------------------\\012--  Purpose:  Rename Observable Types: IMAGE -> HCS_IMAGE, IMAGE_ANALYSIS_DATA -> HCS_IMAGE_ANALYSIS_DATA\\012--  and descriptions accordingly\\012-----------------------------------------------------------------------------------\\012\\012update observable_types set code = 'HCS_IMAGE', description = 'Data derived from analysis of HCS images' where code = 'IMAGE';\\012update observable_types set code = 'HCS_IMAGE_ANALYSIS_DATA', description = 'Data derived from analysis of HCS images' where code = 'IMAGE_ANALYSIS_DATA';\\012\\012\\012-----------------------------------------------------------------------------------\\012--  Purpose: Make the assignments of property types DESCRIPTION, NUCLEOTIDE_SEQUENCE, OFFSET \\012--  and GENE_SYMBOL to material types internally managed. \\012-----------------------------------------------------------------------------------\\012\\012update material_type_property_types set is_managed_internally = true\\012    where prty_id in (select id from property_types where code = 'DESCRIPTION' \\012        or code = 'NUCLEOTIDE_SEQUENCE' or code = 'OFFSET' or code = 'GENE_SYMBOL');\\012\\012-----------------------------------------------------------------------------------\\012--  Purpose: Add column IS_DATA_ACQUISITION BOOLEAN_CHAR NOT NULL DEFAULT 'F' to table PROCEDURE_TYPES.\\012-----------------------------------------------------------------------------------\\012\\012ALTER TABLE PROCEDURE_TYPES ADD COLUMN IS_DATA_ACQUISITION BOOLEAN_CHAR NOT NULL DEFAULT 'F';\\012\\012-- Set the new attribute for procedure type DATA_ACQUISITION\\012update procedure_types set is_data_acquisition = true where code = 'DATA_ACQUISITION';\\012\\012-----------------------------------------------------------------------------------\\012--  Purpose: Convert all codes to upper case. \\012-----------------------------------------------------------------------------------\\012\\012CREATE OR REPLACE FUNCTION column_to_uppercase_fix_duplicates(tbl TEXT, clm TEXT) RETURNS INTEGER AS $$\\012DECLARE\\012    prev_key TEXT := NULL;\\012    this_key TEXT;\\012    dup_count INTEGER;\\012    count INTEGER := 0;\\012    already_exists INTEGER;\\012    new_clm TEXT;\\012BEGIN\\012    FOR this_key IN EXECUTE 'select ' || clm || ' from ' || tbl \\012        || ' order by upper(' || clm || '),id' LOOP\\012        IF upper(this_key) = upper(prev_key) THEN\\012            dup_count := dup_count + 1;\\012            count := count + 1;\\012        ELSE\\012            dup_count := 0;\\012        END IF;\\012        IF dup_count > 0 THEN\\012            -- Check whether the new key already exists.\\012            LOOP\\012                new_clm := this_key || '(' || dup_count::text || ')';\\012                EXECUTE 'select count(*) from ' || tbl \\012                    || ' where upper(' || clm || ') = ' || quote_literal(upper(new_clm)) \\012                    into already_exists;\\012                IF already_exists = 0 THEN\\012                    EXIT;\\012                END IF;\\012                dup_count := dup_count + 1;\\012            END LOOP;\\012            EXECUTE 'update ' || tbl || ' set ' || clm || ' = ' || quote_literal(new_clm) || \\012                ' where ' || clm || ' = ' || quote_literal(this_key);\\012        END IF;\\012        prev_key := this_key;\\012    END LOOP;\\012    EXECUTE 'update ' || tbl || ' set ' || clm || ' = upper(' || clm || ')';\\012    RETURN count;\\012END;\\012$$ LANGUAGE 'plpgsql';\\012\\012\\012CREATE OR REPLACE FUNCTION column_to_uppercase_fix_duplicates(tbl TEXT, clm TEXT, clm2 TEXT) RETURNS INTEGER AS $$\\012DECLARE\\012    prev_key TEXT := NULL;\\012    prev_key2 TECH_ID;\\012    this_key TEXT;\\012    this_key2 TECH_ID;\\012    dup_count INTEGER;\\012    count INTEGER := 0;\\012    already_exists INTEGER;\\012    new_clm TEXT;\\012BEGIN\\012    FOR this_key, this_key2 IN EXECUTE 'select ' || clm || ',' || clm2 || ' from ' || tbl \\012        || ' order by ' || clm2 || ',upper(' ||  clm || '),id' LOOP\\012        IF upper(this_key) = upper(prev_key) and this_key2 = prev_key2 THEN\\012            dup_count := dup_count + 1;\\012            count := count + 1;\\012        ELSE\\012            dup_count := 0;\\012        END IF;\\012        IF dup_count > 0 THEN\\012            -- Check whether the new key already exists.\\012            LOOP\\012                new_clm := this_key || '(' || dup_count::text || ')';\\012                EXECUTE 'select count(*) from ' || tbl \\012                    || ' where upper(' || clm || ') = ' || quote_literal(upper(new_clm)) \\012                    || ' and ' || clm2 || ' = ' || quote_literal(this_key2) \\012                    into already_exists;\\012                IF already_exists = 0 THEN\\012                    EXIT;\\012                END IF;\\012                dup_count := dup_count + 1;\\012            END LOOP;\\012            EXECUTE 'update ' || tbl || ' set ' || clm || ' = ' || quote_literal(new_clm) || \\012                ' where ' || clm || ' = ' || quote_literal(this_key) || ' and ' \\012                || clm2 || ' = ' || quote_literal(this_key2);\\012        END IF;\\012        prev_key := this_key;\\012        prev_key2 := this_key2;\\012    END LOOP;\\012    EXECUTE 'update ' || tbl || ' set ' || clm || ' = upper(' || clm || ')';\\012    RETURN count;\\012END;\\012$$ LANGUAGE 'plpgsql';\\012\\012\\012SELECT column_to_uppercase_fix_duplicates('samples', 'code');\\012SELECT column_to_uppercase_fix_duplicates('property_types', 'code');\\012SELECT column_to_uppercase_fix_duplicates('controlled_vocabularies', 'code');\\012\\012SELECT column_to_uppercase_fix_duplicates('projects', 'code', 'grou_id');\\012SELECT column_to_uppercase_fix_duplicates('experiments', 'code', 'proj_id');\\012SELECT column_to_uppercase_fix_duplicates('controlled_vocabulary_terms', 'code', 'covo_id');\\012SELECT column_to_uppercase_fix_duplicates('materials', 'code', 'maty_id');\\012SELECT column_to_uppercase_fix_duplicates('material_batches', 'code', 'mate_id');\\012SELECT column_to_uppercase_fix_duplicates('sample_components', 'code', 'samp_id');\\012\\012-- These will only need changes if someone entered them through the 'back door' directly on the server.\\012\\012SELECT column_to_uppercase_fix_duplicates('groups', 'code');\\012SELECT column_to_uppercase_fix_duplicates('sample_types', 'code');\\012SELECT column_to_uppercase_fix_duplicates('material_types', 'code');\\012SELECT column_to_uppercase_fix_duplicates('experiment_types', 'code');\\012SELECT column_to_uppercase_fix_duplicates('procedure_types', 'code');\\012SELECT column_to_uppercase_fix_duplicates('observable_types', 'code');\\012SELECT column_to_uppercase_fix_duplicates('locator_types', 'code');\\012SELECT column_to_uppercase_fix_duplicates('file_format_types', 'code');\\012SELECT column_to_uppercase_fix_duplicates('data_types', 'code');\\012\\012DROP FUNCTION column_to_uppercase_fix_duplicates(TEXT, TEXT);\\012DROP FUNCTION column_to_uppercase_fix_duplicates(TEXT, TEXT, TEXT);\\012\\012-----------------------------------------------------------------------------------\\012--  Purpose:  Delete sample_components with no associated material_batches.\\012--  This deletes superfluous controls of master plates\\012-----------------------------------------------------------------------------------\\012\\012delete from sample_components\\012where  id in (select sc.id \\012              from   sample_components as sc left join sample_component_materials as scm \\012              on     scm.saco_id = sc.id \\012              where  scm.saco_id is null\\012              )\\012;\\012	\N
+./sourceTest/sql/postgresql/026/.svn/text-base/009=database_version_logs.tsv.svn-base:017	source/sql/postgresql/migration/migration-016-017.sql	SUCCESS	2008-05-09 10:12:57.473	----------------------------------------------------------------------------------------------\\012--  File: migration-016-017.sql\\012--\\012-- \\012--  This script enables the migration of the database schema from 016 to 017.\\012-- \\012--  Update History\\012--\\012--\\012--\\011Who\\011\\011\\011              When\\011\\011    What\\012--\\011---\\011\\011\\011              ----      \\011----\\012--\\011Charles Ramin-Wright\\0112008-04-11\\011Initial Version \\012--  \\012----------------------------------------------------------------------------------------------\\012\\012\\012--=================================\\012-- Create Objects\\012--=================================\\012\\012-- Domains\\012\\012-- 'F' is false, 'T' is true and 'U' is unknown\\012CREATE DOMAIN BOOLEAN_CHAR_OR_UNKNOWN AS CHAR(1) CHECK (VALUE in ('F', 'T', 'U'));\\012\\012-- Tables and related objects\\012\\012-- Sequences\\012\\012-- Indices\\012\\012--====================================\\012-- Delete Objects\\012--====================================\\012\\012-- Domains\\012\\012-- Tables\\012\\012-- Sequences\\012\\012-- Indices\\012\\012--====================================\\012-- Alter Objects\\012--====================================\\012\\012-- Add column IS_INTERNAL_NAMESPACE to table CONTROLLED_VOCABULARIES \\012\\012ALTER TABLE CONTROLLED_VOCABULARIES ADD IS_INTERNAL_NAMESPACE BOOLEAN_CHAR NOT NULL DEFAULT 'F';\\012\\012-- Add column IS_INTERNAL_NAMESPACE to table PROPERTY_TYPES \\012\\012ALTER TABLE PROPERTY_TYPES ADD IS_INTERNAL_NAMESPACE BOOLEAN_CHAR NOT NULL DEFAULT 'F';\\012\\012-- Add column IS_INTERNAL_NAMESPACE as key component to the unique key constraint COVO_BK_UK\\012\\012ALTER TABLE CONTROLLED_VOCABULARIES DROP CONSTRAINT COVO_BK_UK;\\012ALTER TABLE CONTROLLED_VOCABULARIES ADD CONSTRAINT COVO_BK_UK UNIQUE(CODE,IS_INTERNAL_NAMESPACE);\\012\\012-- Add column IS_INTERNAL_NAMESPACE as key component to the unique key constraint PRTY_BK_UK\\012\\012ALTER TABLE PROPERTY_TYPES DROP CONSTRAINT PRTY_BK_UK;\\012ALTER TABLE PROPERTY_TYPES ADD CONSTRAINT PRTY_BK_UK UNIQUE(CODE,IS_INTERNAL_NAMESPACE);\\012\\012-- Delete unique key constraint PRTY_BK_UK_LBL (which was for column LABEL) from table PROPERTY_TYPES\\012\\012ALTER TABLE PROPERTY_TYPES DROP CONSTRAINT PRTY_BK_UK_LBL;\\012\\012\\012-- Change unique constraint EXDA_BK_UK to contain EXTERNAL_DATA.LOTY_ID \\012\\012ALTER TABLE EXTERNAL_DATA DROP CONSTRAINT EXDA_BK_UK;\\012ALTER TABLE EXTERNAL_DATA ADD CONSTRAINT EXDA_BK_UK UNIQUE(LOCATION,LOTY_ID);\\012\\012\\012-- Increase length of EXTERNAL_DATA.LOCATION from 200 to 1024\\012\\012ALTER TABLE EXTERNAL_DATA ALTER COLUMN LOCATION TYPE VARCHAR(1024);\\012\\012\\012-- Add column IS_COMPLETE to table EXTERNAL_DATA\\012\\012ALTER TABLE EXTERNAL_DATA ADD COLUMN IS_COMPLETE BOOLEAN_CHAR_OR_UNKNOWN NOT NULL DEFAULT 'U';\\012\\012\\012--=================================\\012-- Replace EXTERNAL_DATA_STORAGE_FORMAT_CHECK() function\\012--=================================\\012\\012CREATE OR REPLACE FUNCTION EXTERNAL_DATA_STORAGE_FORMAT_CHECK() RETURNS trigger AS $$\\012DECLARE\\012   v_covo_code  CODE;\\012   data_code CODE;\\012BEGIN\\012\\012   select code into v_covo_code from controlled_vocabularies\\012      where is_internal_namespace = true and \\012         id = (select covo_id from controlled_vocabulary_terms where id = NEW.cvte_id_stor_fmt);\\012\\012-- Check if the data storage format is a term of the controlled vocabulary "STORAGE_FORMAT"\\012   if v_covo_code != 'STORAGE_FORMAT' then\\012      select code into data_code from data where id = NEW.data_id; \\012      RAISE EXCEPTION 'Insert/Update of Data (Code: %) failed, as its Storage Format is %, but is required to be STORAGE_FORMAT.', data_code, v_covo_code;\\012   end if;\\012\\012   RETURN NEW;\\012\\012END;\\012$$ LANGUAGE 'plpgsql';\\012\\012\\012--=================================\\012-- Data Migration\\012--=================================\\012\\012\\012---------------------------------------------------------------------------------------\\012--   Translate the internally managed CODES which are represented by the Dot-Prefix to:\\012--\\012--   CODE without a Dot-Prefix plus the new column IS_INTERNAL_NAMESPACE = true.\\012---------------------------------------------------------------------------------------\\012\\012UPDATE property_types\\012SET    code = substr(code,2,length(code))\\012     , is_internal_namespace = true \\012WHERE  substr(code,1,1) = '.';\\012\\012UPDATE controlled_vocabularies\\012SET    code = substr(code,2,length(code))\\012     , is_internal_namespace = true \\012WHERE  substr(code,1,1) = '.';\\012\\012------------------------------------------------------------------------------------\\012--  Purpose: Move experiment descriptions from column to property DESCRIPTION\\012------------------------------------------------------------------------------------\\012\\012   -----------------------\\012   --  Material Type SIRNHACS\\012   -----------------------\\012\\012insert into experiment_type_property_types\\012(   id\\012   ,exty_id\\012   ,prty_id\\012   ,is_mandatory\\012   ,is_managed_internally\\012   ,pers_id_registerer\\012   )\\012values \\012(   nextval('ETPT_ID_SEQ')\\012   ,(select id from experiment_types where code = 'SIRNAHCS')\\012   ,(select id from property_types where code = 'DESCRIPTION')\\012   ,true\\012   ,true\\012   ,(select id from persons where user_id ='system')\\012);\\012\\012-- Add experiment_properties for descriptions of all experiments of type SIRNAHCS \\012\\012insert into experiment_properties\\012(   id\\012   ,expe_id\\012   ,value\\012   ,etpt_id\\012   ,pers_id_registerer\\012)\\012select\\012    nextval('EXPERIMENT_PROPERTY_ID_SEQ')\\012   ,id\\012   ,case when description is not null then description else 'No description given' end\\012   ,currval('ETPT_ID_SEQ')\\012   ,(select id from persons where user_id ='system')  \\012from experiments where exty_id = (select id from experiment_types where code = 'SIRNAHCS');\\012\\012-- Finally: drop column\\012\\012ALTER TABLE EXPERIMENTS DROP COLUMN DESCRIPTION;\\012	\N
+./sourceTest/sql/postgresql/026/.svn/text-base/009=database_version_logs.tsv.svn-base:023	../openbis/source/sql/postgresql/migration/migration-022-023.sql	SUCCESS	2008-09-15 14:46:19.697	-- JAVA ch.systemsx.cisd.lims.server.dataaccess.migration.MigrationStepFrom022To023\\012\\012-- Add column GLOBAL_CODE to the DATABASE_INSTANCES table.\\012-- Set it's value from the code, it will be updated later from java.\\012\\012ALTER TABLE DATABASE_INSTANCES ADD COLUMN GLOBAL_CODE CODE;\\012update DATABASE_INSTANCES set GLOBAL_CODE = CODE;\\012ALTER TABLE DATABASE_INSTANCES ADD CONSTRAINT DBIN_GLOBAL_CODE_UK UNIQUE(GLOBAL_CODE);\\012ALTER TABLE DATABASE_INSTANCES alter column GLOBAL_CODE set NOT NULL;\\012\\012-- Add column the new FK column SAMP_ID_PART_OF of the SAMPLES table\\012\\012ALTER TABLE SAMPLES ADD COLUMN SAMP_ID_PART_OF TECH_ID;\\012\\012-- Drop constraint SAMP_BK_DBIN_UK of SAMPLES table\\012\\012ALTER TABLE SAMPLES DROP CONSTRAINT SAMP_BK_DBIN_UK;\\012\\012-- Drop constraint SAMP_BK_GROU_UK of SAMPLES table\\012\\012ALTER TABLE SAMPLES DROP CONSTRAINT SAMP_BK_GROU_UK;\\012\\012-- Add FK PART_OF to the SAMPLES table\\012\\012ALTER TABLE SAMPLES ADD CONSTRAINT SAMP_SAMP_FK_PART_OF FOREIGN KEY (SAMP_ID_PART_OF) REFERENCES SAMPLES(ID);\\012\\012-- Add Index for the FK Part Of of the SAMPLES table\\012CREATE INDEX SAMP_SAMP_FK_I_PART_OF ON SAMPLES (SAMP_ID_PART_OF);\\012\\012-- Create the SAMPLE_MATERIAL_BATCHES table\\012\\012CREATE TABLE SAMPLE_MATERIAL_BATCHES (ID TECH_ID NOT NULL,SAMP_ID TECH_ID NOT NULL,MABA_ID TECH_ID NOT NULL);\\012\\012-- Create the sequence for the SAMPLE_MATERIAL_BATCHES table\\012\\012CREATE SEQUENCE SAMPLE_MATERIAL_BATCH_ID_SEQ;\\012\\012\\012--  Create WELL as a new SAMPLE_TYPE\\012\\012insert into sample_types\\012(id\\012,code\\012,description\\012,dbin_id)\\012values \\012(nextval('SAMPLE_TYPE_ID_SEQ')\\012,'WELL'\\012,'Plate Well'\\012,(select id from database_instances where is_original_source = true)\\012);\\012\\012\\012-- Transfer data from the SAMPLE_COMPONENTS table to the SAMPLES table\\012\\012INSERT INTO samples(\\012              id\\012            , code\\012            , samp_id_top\\012            , samp_id_generated_from\\012            , saty_id\\012            , pers_id_registerer\\012            , inva_id\\012            , samp_id_control_layout\\012            , dbin_id\\012            , grou_id\\012            , samp_id_part_of)\\012SELECT        nextval('sample_id_seq')\\012            , saco.code\\012            , null\\012            , null\\012            , (select id from sample_types where code = 'WELL')\\012            , (select id from persons where user_id ='system')\\012            , samp.inva_id\\012            , null\\012            , samp.dbin_id\\012            , samp.grou_id\\012            , saco.samp_id\\012FROM samples samp INNER JOIN sample_components saco\\012     ON   samp.id = saco.samp_id;\\012\\012\\012-- Fill the SAMPLE_MATERIAL_BATCHES table via SAMPLE_C0MPONENT_MATERIALS, SAMPLE_C0MPONENTS, SAMPLES and MATERIAL_BATCHES tables\\012\\012INSERT INTO sample_material_batches(\\012              id\\012            , samp_id\\012            , maba_id)\\012SELECT        nextval('sample_material_batch_id_seq')\\012            , well.id\\012            , scma.maba_id\\012FROM sample_component_materials scma \\012   INNER JOIN material_batches maba\\012     ON scma.maba_id = maba.id\\012        INNER JOIN sample_components saco\\012           ON scma.saco_id = saco.id\\012              INNER JOIN samples well\\012                 ON saco.code = well.code and saco.samp_id = well.samp_id_part_of\\012;\\012\\012\\012-- Drop the retired Database Objects\\012\\012DROP TABLE SAMPLE_COMPONENT_MATERIALS;\\012DROP TABLE SAMPLE_COMPONENTS;\\012\\012DROP SEQUENCE SCMA_ID_SEQ;\\012DROP SEQUENCE SAMPLE_COMPONENT_ID_SEQ;\\012\\012------------------------------------------------------------------------------------\\012--  Purpose:  Create trigger SAMPLE_CODE_UNIQUENESS_CHECK \\012------------------------------------------------------------------------------------\\012\\012CREATE OR REPLACE FUNCTION SAMPLE_CODE_UNIQUENESS_CHECK() RETURNS trigger AS $$\\012DECLARE\\012   counter  INTEGER;\\012BEGIN\\012\\011IF (NEW.samp_id_part_of is NULL) THEN\\012\\011\\011IF (NEW.dbin_id is not NULL) THEN\\012\\011\\011\\011SELECT count(*) into counter FROM samples \\012\\011\\011\\011\\011where id != NEW.id and code = NEW.code and dbin_id = NEW.dbin_id;\\012\\011\\011\\011IF (counter > 0) THEN\\012\\011\\011\\011\\011RAISE EXCEPTION 'Insert/Update of Sample (Code: %) failed because database instance sample with the same code already exists.', NEW.code;\\012\\011\\011\\011END IF;\\012\\011\\011ELSIF (NEW.grou_id is not NULL) THEN\\012\\011\\011\\011SELECT count(*) into counter FROM samples \\012\\011\\011\\011\\011where id != NEW.id and code = NEW.code and grou_id = NEW.grou_id;\\012\\011\\011\\011IF (counter > 0) THEN\\012\\011\\011\\011\\011RAISE EXCEPTION 'Insert/Update of Sample (Code: %) failed because group sample with the same code already exists.', NEW.code;\\012\\011\\011\\011END IF;\\012\\011\\011END IF;\\012        ELSE\\012\\011\\011IF (NEW.dbin_id is not NULL) THEN\\012\\011\\011\\011SELECT count(*) into counter FROM samples \\012\\011\\011\\011\\011where id != NEW.id and code = NEW.code and samp_id_part_of = NEW.samp_id_part_of and dbin_id = NEW.dbin_id;\\012\\011\\011\\011IF (counter > 0) THEN\\012\\011\\011\\011\\011RAISE EXCEPTION 'Insert/Update of Sample (Code: %) failed because database instance sample with the same code and being the part of the same parent already exists.', NEW.code;\\012\\011\\011\\011END IF;\\012\\011\\011ELSIF (NEW.grou_id is not NULL) THEN\\012\\011\\011\\011SELECT count(*) into counter FROM samples \\012\\011\\011\\011\\011where id != NEW.id and code = NEW.code and samp_id_part_of = NEW.samp_id_part_of and grou_id = NEW.grou_id;\\012\\011\\011\\011IF (counter > 0) THEN\\012\\011\\011\\011\\011RAISE EXCEPTION 'Insert/Update of Sample (Code: %) failed because group sample with the same code and being the part of the same parent already exists.', NEW.code;\\012\\011\\011\\011END IF;\\012\\011\\011END IF;\\012        END IF;   \\012   RETURN NEW;\\012END;\\012$$ LANGUAGE 'plpgsql';\\012\\012CREATE TRIGGER SAMPLE_CODE_UNIQUENESS_CHECK BEFORE INSERT OR UPDATE ON SAMPLES\\012    FOR EACH ROW EXECUTE PROCEDURE SAMPLE_CODE_UNIQUENESS_CHECK();\\012	\N
+./sourceTest/sql/postgresql/026/.svn/text-base/009=database_version_logs.tsv.svn-base:024	../openbis/source/sql/postgresql/migration/migration-023-024.sql	SUCCESS	2008-09-15 14:46:19.886	-- JAVA ch.systemsx.cisd.lims.server.dataaccess.migration.MigrationStepFrom023To024\\012\\012-- Drop constraint DBIN_GLOBAL_CODE_UK of DATABASE_INSTANCES table\\012\\012ALTER TABLE DATABASE_INSTANCES DROP CONSTRAINT DBIN_GLOBAL_CODE_UK;\\012\\012-- Name changes\\012\\012ALTER TABLE DATABASE_INSTANCES RENAME COLUMN GLOBAL_CODE TO UUID;\\012\\012-- Add constraint DBIN_UUID_UK to the DATABASE_INSTANCES table\\012\\012ALTER TABLE DATABASE_INSTANCES ADD CONSTRAINT DBIN_UUID_UK UNIQUE(UUID);\\012\\012-- Drop column in EXPERIMENTS\\012\\012ALTER TABLE EXPERIMENTS DROP COLUMN DESCRIPTION;\\012\\012-- Add index to SAMPLES table\\012\\012CREATE INDEX SAMP_CODE_I ON SAMPLES (CODE);\\012\\012-- Bug fix in trigger function SAMPLE_CODE_UNIQUENESS_CHECK()\\012\\012CREATE OR REPLACE FUNCTION SAMPLE_CODE_UNIQUENESS_CHECK() RETURNS trigger AS $$\\012DECLARE\\012   counter  INTEGER;\\012BEGIN\\012    IF (NEW.samp_id_part_of is NULL) THEN\\012        IF (NEW.dbin_id is not NULL) THEN\\012            SELECT count(*) into counter FROM samples \\012                where id != NEW.id and code = NEW.code and samp_id_part_of is NULL and dbin_id = NEW.dbin_id;\\012            IF (counter > 0) THEN\\012                RAISE EXCEPTION 'Insert/Update of Sample (Code: %) failed because database instance sample with the same code already exists.', NEW.code;\\012            END IF;\\012        ELSIF (NEW.grou_id is not NULL) THEN\\012            SELECT count(*) into counter FROM samples \\012                where id != NEW.id and code = NEW.code and samp_id_part_of is NULL and grou_id = NEW.grou_id;\\012            IF (counter > 0) THEN\\012                RAISE EXCEPTION 'Insert/Update of Sample (Code: %) failed because group sample with the same code already exists.', NEW.code;\\012            END IF;\\012        END IF;\\012        ELSE\\012        IF (NEW.dbin_id is not NULL) THEN\\012            SELECT count(*) into counter FROM samples \\012                where id != NEW.id and code = NEW.code and samp_id_part_of = NEW.samp_id_part_of and dbin_id = NEW.dbin_id;\\012            IF (counter > 0) THEN\\012                RAISE EXCEPTION 'Insert/Update of Sample (Code: %) failed because database instance sample with the same code and being the part of the same parent already exists.', NEW.code;\\012            END IF;\\012        ELSIF (NEW.grou_id is not NULL) THEN\\012            SELECT count(*) into counter FROM samples \\012                where id != NEW.id and code = NEW.code and samp_id_part_of = NEW.samp_id_part_of and grou_id = NEW.grou_id;\\012            IF (counter > 0) THEN\\012                RAISE EXCEPTION 'Insert/Update of Sample (Code: %) failed because group sample with the same code and being the part of the same parent already exists.', NEW.code;\\012            END IF;\\012        END IF;\\012        END IF;   \\012   RETURN NEW;\\012END;\\012$$ LANGUAGE 'plpgsql';\\012	\N
+./sourceTest/sql/postgresql/026/.svn/text-base/009=database_version_logs.tsv.svn-base:025	../openbis/source/sql/postgresql/migration/migration-024-025.sql	SUCCESS	2008-09-15 14:46:20.011	-- move screenable plates to a group, because it's no longer possible\\012-- to have such plates on the instance level\\012\\012CREATE OR REPLACE FUNCTION move_exp_samples_to_group() RETURNS integer AS $$\\012DECLARE\\012    sample RECORD;\\012    groupId Integer;\\012BEGIN\\012  FOR sample IN \\012    (SELECT * FROM samples s inner join sample_types t on s.saty_id = t.id \\012\\011where t.code in ('CELL_PLATE', 'REINFECT_PLATE'))\\012  LOOP\\012\\011if (sample.dbin_id is not NULL) THEN\\012\\011\\011select proj.grou_id into groupId from\\012\\011\\011\\011samples sa\\012\\011\\011\\011left outer join sample_inputs si on sa.id = si.samp_id \\012\\011\\011\\011left outer join procedures proc on proc.id = si.proc_id  \\012\\011\\011\\011left outer join experiments ex on ex.id = proc.expe_id\\012\\011\\011\\011left outer join projects proj on proj.id = ex.proj_id\\012\\011\\011where sa.id = sample.id;\\012\\011\\011if (groupId is NULL) THEN\\012\\011\\011\\011select id into groupId from groups limit 1;\\012\\011\\011END IF;\\012\\011\\011if (groupId is NULL) THEN\\012\\011\\011\\011RAISE EXCEPTION 'There is no group in the database - internal error!';\\012\\011\\011END IF;\\012\\011\\011update samples set grou_id = groupId, dbin_id = NULL\\012\\011\\011  where id = sample.id;\\012\\011END IF;\\012  END LOOP;\\012  RETURN 1;\\012END;\\012$$ LANGUAGE 'plpgsql';\\012\\012select move_exp_samples_to_group();\\012\\012-- Create new table DATA_STORES.\\012\\012CREATE TABLE DATA_STORES (ID TECH_ID NOT NULL,DBIN_ID TECH_ID NOT NULL,CODE CODE NOT NULL,DOWNLOAD_URL VARCHAR(1024) NOT NULL,REGISTRATION_TIMESTAMP TIME_STAMP_DFL NOT NULL DEFAULT CURRENT_TIMESTAMP);\\012CREATE SEQUENCE DATA_STORE_ID_SEQ;\\012ALTER TABLE DATA_STORES ADD CONSTRAINT DAST_PK PRIMARY KEY(ID);\\012ALTER TABLE DATA_STORES ADD CONSTRAINT DAST_BK_UK UNIQUE(CODE,DBIN_ID);\\012ALTER TABLE DATA_STORES ADD CONSTRAINT DAST_DBIN_FK FOREIGN KEY (DBIN_ID) REFERENCES DATABASE_INSTANCES(ID);\\012CREATE INDEX DAST_DBIN_FK_I ON DATA_STORES (DBIN_ID);\\012\\012-- Add new column DAST_ID (connection to DATA_STORES table) to tables DATABASE_INSTANCES, GROUPS, PROJECTS, EXPERIMENTS.\\012\\012ALTER TABLE DATABASE_INSTANCES ADD COLUMN DAST_ID TECH_ID;\\012ALTER TABLE GROUPS ADD COLUMN DAST_ID TECH_ID;\\012ALTER TABLE PROJECTS ADD COLUMN DAST_ID TECH_ID;\\012ALTER TABLE EXPERIMENTS ADD COLUMN DAST_ID TECH_ID;\\012\\012-- Create the STANDARD data store and assign it to the home database instance.\\012 \\012insert into data_stores\\012(id\\012,code\\012,download_url\\012,dbin_id)\\012values \\012(nextval('DATA_STORE_ID_SEQ')\\012,'STANDARD'\\012,''\\012,(select id from database_instances where is_original_source = true)\\012);\\012\\012update database_instances set dast_id = (select id from data_stores where code = 'STANDARD') where is_original_source = true;\\012\\012-- Add foreign key constratints.\\012\\012ALTER TABLE DATABASE_INSTANCES ADD CONSTRAINT DBIN_DAST_FK FOREIGN KEY (DAST_ID) REFERENCES DATA_STORES(ID);\\012ALTER TABLE GROUPS ADD CONSTRAINT GROU_DAST_FK FOREIGN KEY (DAST_ID) REFERENCES DATA_STORES(ID);\\012ALTER TABLE PROJECTS ADD CONSTRAINT PROJ_DAST_FK FOREIGN KEY (DAST_ID) REFERENCES DATA_STORES(ID);\\012ALTER TABLE EXPERIMENTS ADD CONSTRAINT EXPE_DAST_FK FOREIGN KEY (DAST_ID) REFERENCES DATA_STORES(ID);\\012	\N
+./sourceTest/sql/postgresql/026/.svn/text-base/009=database_version_logs.tsv.svn-base:026	../openbis/source/sql/postgresql/migration/migration-025-026.sql	SUCCESS	2008-09-15 14:46:20.192	-- JAVA ch.systemsx.cisd.lims.server.dataaccess.migration.MigrationStepFrom025To026\\012-- Remove ID column from SAMPLE_INPUTS table\\012DROP SEQUENCE SAMPLE_INPUT_ID_SEQ;\\012-- There was a bug in migration to db 23 - the constraint was not created. So we drop it only if it exists.\\012create function remove_sain_pk_constraint() returns void AS $$\\012begin\\012   perform *\\012     FROM information_schema.table_constraints WHERE constraint_name='sain_pk';\\012   if found\\012   then\\012\\011ALTER TABLE SAMPLE_INPUTS DROP CONSTRAINT SAIN_PK;\\012   end if;\\012end;\\012$$ language 'plpgsql';\\012select remove_sain_pk_constraint();\\012drop function remove_sain_pk_constraint();\\012ALTER TABLE SAMPLE_INPUTS DROP COLUMN ID;\\012ALTER TABLE SAMPLE_INPUTS ADD CONSTRAINT SAIN_PK PRIMARY KEY(SAMP_ID,PROC_ID);\\012\\012-- Remove ID column from SAMPLE_MATERIAL_BATCHES table\\012DROP SEQUENCE SAMPLE_MATERIAL_BATCH_ID_SEQ;\\012-- There was a bug in migration to db 23 - the constraint was not created. So we drop it only if it exists.\\012create function remove_samb_pk_constraint() returns void AS $$\\012begin\\012   perform *\\012     FROM information_schema.table_constraints WHERE constraint_name='SAMB_PK';\\012   if found\\012   then\\012\\012   end if;\\012end;\\012$$ language 'plpgsql';\\012select remove_samb_pk_constraint();\\012drop function remove_samb_pk_constraint();\\012ALTER TABLE SAMPLE_MATERIAL_BATCHES DROP COLUMN ID;\\012ALTER TABLE SAMPLE_MATERIAL_BATCHES ADD CONSTRAINT SAMB_PK PRIMARY KEY(SAMP_ID,MABA_ID);\\012\\012-- Remove ID and REGISTRATION_TIMESTAMP column from DATA_SET_RELATIONSHIPS table\\012DROP SEQUENCE DATA_SET_RELATIONSHIP_ID_SEQ;\\012ALTER TABLE DATA_SET_RELATIONSHIPS DROP CONSTRAINT DSRE_PK;\\012ALTER TABLE DATA_SET_RELATIONSHIPS DROP CONSTRAINT DSRE_BK_UK;\\012ALTER TABLE DATA_SET_RELATIONSHIPS DROP COLUMN ID;\\012ALTER TABLE DATA_SET_RELATIONSHIPS DROP COLUMN REGISTRATION_TIMESTAMP;\\012ALTER TABLE DATA_SET_RELATIONSHIPS ADD CONSTRAINT DSRE_PK PRIMARY KEY(DATA_ID_PARENT,DATA_ID_CHILD);\\012\\012-- Rename: \\012-- OBSERVABLE_TYPES -> DATA_SET_TYPES\\012-- OBSERVABLE_TYPE_ID_SEQ -> DATA_SET_TYPE_ID_SEQ\\012-- DATA.OBTY_ID -> DATA.DSTY_ID\\012ALTER TABLE OBSERVABLE_TYPES RENAME TO DATA_SET_TYPES;\\012ALTER TABLE OBSERVABLE_TYPE_ID_SEQ RENAME TO DATA_SET_TYPE_ID_SEQ;\\012ALTER TABLE DATA RENAME COLUMN OBTY_ID TO DSTY_ID;\\012	\N
+./sourceTest/sql/postgresql/026/.svn/text-base/schema-026.sql.svn-base:    LANGUAGE plpgsql;
+./sourceTest/sql/postgresql/026/.svn/text-base/schema-026.sql.svn-base:    LANGUAGE plpgsql;
+./sourceTest/sql/postgresql/026/.svn/text-base/schema-026.sql.svn-base:    LANGUAGE plpgsql;
+./sourceTest/sql/postgresql/026/.svn/text-base/schema-026.sql.svn-base:    LANGUAGE plpgsql;
+./sourceTest/sql/postgresql/026/.svn/text-base/schema-026.sql.svn-base:    LANGUAGE plpgsql;
+./sourceTest/sql/postgresql/026/009=database_version_logs.tsv:007	source/sql/postgresql/007/schema-007.sql	SUCCESS	2008-01-05 14:51:36.56	-- D:\\\\DDL\\\\postgresql\\\\schema-007.sql\\012--\\012-- Generated for ANSI SQL92 on Thu Aug 23  19:02:15 2007 by Server Generator 10.1.2.6.18\\012-- Post generation PostgreSQL specific Changes:\\012-- \\012--  1. change domain FILE from BIT(32000) to BYTEA\\012--  2. change domain TECH_ID from NUMERIC(20) to BIGINT\\012--  3. Put single quotes around the default value NOW in the create domain statement for the domain TIME_STAMP\\012--     i.e. change CREATE DOMAIN TIME_STAMP AS TIMESTAMP DEFAULT now; to CREATE DOMAIN TIME_STAMP AS TIMESTAMP DEFAULT 'now';\\012--  4. Temporarily not created, due to data quality issues with the master plate layout data\\012--\\012-- ALTER TABLE MOLECULES ADD CONSTRAINT MOLE_BK_UK UNIQUE(SEQUENCE);\\012\\012\\012\\012CREATE DOMAIN DESCRIPTION_80 AS VARCHAR(80);\\012CREATE DOMAIN USER_ID AS VARCHAR(20);\\012CREATE DOMAIN DOUBLE_PRECISION_VALUE AS DOUBLE PRECISION;\\012CREATE DOMAIN FILE_NAME AS VARCHAR(100);\\012CREATE DOMAIN TECH_ID AS BIGINT;\\012CREATE DOMAIN OBJECT_NAME AS VARCHAR(50);\\012CREATE DOMAIN TIME_STAMP AS TIMESTAMP DEFAULT CURRENT_TIMESTAMP;\\012CREATE DOMAIN REAL_VALUE AS REAL;\\012CREATE DOMAIN FILE AS BYTEA;\\012CREATE DOMAIN CODE AS VARCHAR(20);\\012CREATE DOMAIN DESCRIPTION_250 AS VARCHAR(250);\\012CREATE TABLE EXPERIMENT_PROPERTIES  (ID TECH_ID NOT NULL,EXPE_ID TECH_ID NOT NULL,FILE_NAME FILE_NAME NOT NULL,REGISTRATION_TIMESTAMP TIME_STAMP NOT NULL DEFAULT CURRENT_TIMESTAMP,VALUE FILE NOT NULL,VERSION INTEGER NOT NULL,PERS_ID_REGISTERER TECH_ID NOT NULL) ;\\012CREATE TABLE EXPERIMENT_TYPES  (ID TECH_ID NOT NULL,CODE CODE NOT NULL,DESCRIPTION DESCRIPTION_80) ;\\012CREATE TABLE DATA_VALUES  (ID TECH_ID NOT NULL,DATA_ID TECH_ID NOT NULL,SACO_ID TECH_ID NOT NULL,VALUE DOUBLE_PRECISION_VALUE NOT NULL) ;\\012CREATE TABLE PERSONS  (ID TECH_ID NOT NULL,FIRST_NAME VARCHAR(30),LAST_NAME VARCHAR(30),USER_ID USER_ID,EMAIL OBJECT_NAME) ;\\012CREATE TABLE FILE_FORMAT_TYPES  (ID TECH_ID NOT NULL,CODE CODE NOT NULL,DESCRIPTION DESCRIPTION_80) ;\\012CREATE TABLE SAMPLE_INPUTS  (ID TECH_ID NOT NULL,SAMP_ID TECH_ID NOT NULL,PROC_ID TECH_ID NOT NULL) ;\\012CREATE TABLE OBSERVABLE_TYPES  (ID TECH_ID NOT NULL,CODE CODE NOT NULL,DESCRIPTION DESCRIPTION_80) ;\\012CREATE TABLE LOCATOR_TYPES  (ID TECH_ID NOT NULL,CODE CODE NOT NULL,DESCRIPTION DESCRIPTION_80) ;\\012CREATE TABLE SAMPLE_COMPONENTS  (ID TECH_ID NOT NULL,CODE CODE NOT NULL,SAMP_ID TECH_ID NOT NULL) ;\\012CREATE TABLE SAMPLE_TYPES  (ID TECH_ID NOT NULL,CODE CODE NOT NULL,DESCRIPTION DESCRIPTION_80) ;\\012CREATE TABLE ORGANIZATIONS  (ID TECH_ID NOT NULL,CODE CODE NOT NULL) ;\\012CREATE TABLE PROCEDURES  (ID TECH_ID NOT NULL,REGISTRATION_TIMESTAMP TIME_STAMP NOT NULL DEFAULT CURRENT_TIMESTAMP,EXPE_ID TECH_ID NOT NULL,PCTY_ID TECH_ID NOT NULL,PERS_ID TECH_ID) ;\\012CREATE TABLE PROCEDURE_TYPES  (ID TECH_ID NOT NULL,CODE CODE NOT NULL,DESCRIPTION DESCRIPTION_80 NOT NULL) ;\\012CREATE TABLE PROJECTS  (ID TECH_ID NOT NULL,CODE CODE NOT NULL,ORGA_ID TECH_ID NOT NULL) ;\\012CREATE TABLE SAMPLE_COMPONENT_MATERIALS  (ID TECH_ID NOT NULL,SACO_ID TECH_ID NOT NULL,MABA_ID TECH_ID NOT NULL) ;\\012CREATE TABLE EXTERNAL_DATA  (DATA_ID TECH_ID NOT NULL,LOCATION VARCHAR(200) NOT NULL,LOTY_ID TECH_ID NOT NULL,FFTY_ID TECH_ID NOT NULL) ;\\012CREATE TABLE DATA  (ID TECH_ID NOT NULL,REGISTRATION_TIMESTAMP TIME_STAMP NOT NULL DEFAULT CURRENT_TIMESTAMP,OBTY_ID TECH_ID NOT NULL,PROC_ID_ACQUIRED_BY TECH_ID NOT NULL,SAMP_ID_ACQUIRED_FROM TECH_ID,SAMP_ID_DERIVED_FROM TECH_ID) ;\\012CREATE TABLE SAMPLES  (ID TECH_ID NOT NULL,CODE CODE NOT NULL,CONT_ID TECH_ID,PROC_ID TECH_ID,SAMP_ID_TOP TECH_ID,SAMP_ID_GENERATED_FROM TECH_ID,SATY_ID TECH_ID NOT NULL,REGISTRATION_TIMESTAMP TIME_STAMP NOT NULL DEFAULT CURRENT_TIMESTAMP,PERS_ID_REGISTERER TECH_ID NOT NULL) ;\\012CREATE TABLE MATERIAL_TYPES  (ID TECH_ID NOT NULL,CODE CODE NOT NULL,DESCRIPTION DESCRIPTION_80) ;\\012CREATE TABLE MATERIAL_BATCHES  (ID TECH_ID NOT NULL,CODE CODE NOT NULL,AMOUNT REAL_VALUE,MATE_ID TECH_ID NOT NULL,CONT_ID TECH_ID,PROC_ID TECH_ID,REGISTRATION_TIMESTAMP TIME_STAMP NOT NULL DEFAULT CURRENT_TIMESTAMP,PERS_ID_REGISTERER TECH_ID NOT NULL) ;\\012CREATE TABLE MATERIALS  (ID TECH_ID NOT NULL,CODE CODE NOT NULL,DESCRIPTION DESCRIPTION_250,MATY_ID TECH_ID NOT NULL,REGISTRATION_TIMESTAMP TIME_STAMP NOT NULL DEFAULT CURRENT_TIMESTAMP,PERS_ID_REGISTERER TECH_ID NOT NULL) ;\\012CREATE TABLE MOLECULES  (MATE_ID TECH_ID NOT NULL,SEQUENCE VARCHAR(100),ACCESSION_NUMBER OBJECT_NAME,OFF_SET VARCHAR(20),MOLE_ID_INHIBITOR_OF TECH_ID,GENE_SYMBOL CODE) ;\\012CREATE TABLE EXPERIMENTS  (ID TECH_ID NOT NULL,CODE CODE NOT NULL,EXTY_ID TECH_ID NOT NULL,MATE_ID_STUDY_OBJECT TECH_ID,PERS_ID_REGISTERER TECH_ID,REGISTRATION_TIMESTAMP TIME_STAMP NOT NULL DEFAULT CURRENT_TIMESTAMP,DESCRIPTION DESCRIPTION_250,PROJ_ID TECH_ID NOT NULL) ;\\012\\012ALTER TABLE EXPERIMENT_PROPERTIES ADD CONSTRAINT EXPR_PK PRIMARY KEY(ID);\\012ALTER TABLE EXPERIMENT_TYPES ADD CONSTRAINT EXTY_PK PRIMARY KEY(ID);\\012ALTER TABLE DATA_VALUES ADD CONSTRAINT DAVA_PK PRIMARY KEY(ID);\\012ALTER TABLE PERSONS ADD CONSTRAINT PERS_PK PRIMARY KEY(ID);\\012ALTER TABLE FILE_FORMAT_TYPES ADD CONSTRAINT FFTY_PK PRIMARY KEY(ID);\\012ALTER TABLE SAMPLE_INPUTS ADD CONSTRAINT SAIN_PK PRIMARY KEY(ID);\\012ALTER TABLE OBSERVABLE_TYPES ADD CONSTRAINT OBTY_PK PRIMARY KEY(ID);\\012ALTER TABLE LOCATOR_TYPES ADD CONSTRAINT LOTY_PK PRIMARY KEY(ID);\\012ALTER TABLE SAMPLE_COMPONENTS ADD CONSTRAINT SACO_PK PRIMARY KEY(ID);\\012ALTER TABLE SAMPLE_TYPES ADD CONSTRAINT SATY_PK PRIMARY KEY(ID);\\012ALTER TABLE ORGANIZATIONS ADD CONSTRAINT ORGA_PK PRIMARY KEY(ID);\\012ALTER TABLE PROCEDURES ADD CONSTRAINT PROC_PK PRIMARY KEY(ID);\\012ALTER TABLE PROCEDURE_TYPES ADD CONSTRAINT PCTY_PK PRIMARY KEY(ID);\\012ALTER TABLE PROJECTS ADD CONSTRAINT PROJ_PK PRIMARY KEY(ID);\\012ALTER TABLE SAMPLE_COMPONENT_MATERIALS ADD CONSTRAINT SCMA_PK PRIMARY KEY(ID);\\012ALTER TABLE EXTERNAL_DATA ADD CONSTRAINT EXDA_PK PRIMARY KEY(DATA_ID);\\012ALTER TABLE DATA ADD CONSTRAINT DATA_PK PRIMARY KEY(ID);\\012ALTER TABLE SAMPLES ADD CONSTRAINT SAMP_PK PRIMARY KEY(ID);\\012ALTER TABLE MATERIAL_TYPES ADD CONSTRAINT MATY_PK PRIMARY KEY(ID);\\012ALTER TABLE MATERIAL_BATCHES ADD CONSTRAINT MABA_PK PRIMARY KEY(ID);\\012ALTER TABLE MATERIALS ADD CONSTRAINT MATE_PK PRIMARY KEY(ID);\\012ALTER TABLE MOLECULES ADD CONSTRAINT MOLE_PK PRIMARY KEY(MATE_ID);\\012ALTER TABLE EXPERIMENTS ADD CONSTRAINT EXPE_PK PRIMARY KEY(ID);\\012ALTER TABLE EXPERIMENT_PROPERTIES ADD CONSTRAINT EXPR_BK_UK UNIQUE(EXPE_ID,FILE_NAME,VERSION);\\012ALTER TABLE EXPERIMENT_TYPES ADD CONSTRAINT EXTY_BK_UK UNIQUE(CODE);\\012ALTER TABLE DATA_VALUES ADD CONSTRAINT DAVA_BK_UK UNIQUE(DATA_ID,SACO_ID);\\012ALTER TABLE PERSONS ADD CONSTRAINT PERS_BK_UK UNIQUE(USER_ID);\\012ALTER TABLE FILE_FORMAT_TYPES ADD CONSTRAINT FFTY_BK_UK UNIQUE(CODE);\\012ALTER TABLE SAMPLE_INPUTS ADD CONSTRAINT SAIN_BK_UK UNIQUE(SAMP_ID,PROC_ID);\\012ALTER TABLE OBSERVABLE_TYPES ADD CONSTRAINT OBTY_BK_UK UNIQUE(CODE);\\012ALTER TABLE LOCATOR_TYPES ADD CONSTRAINT LOTY_BK_UK UNIQUE(CODE);\\012ALTER TABLE SAMPLE_COMPONENTS ADD CONSTRAINT SACO_BK_UK UNIQUE(CODE,SAMP_ID);\\012ALTER TABLE SAMPLE_TYPES ADD CONSTRAINT SATY_BK_UK UNIQUE(CODE);\\012ALTER TABLE ORGANIZATIONS ADD CONSTRAINT ORGA_BK_UK UNIQUE(CODE);\\012ALTER TABLE PROCEDURE_TYPES ADD CONSTRAINT PCTY_BK_UK UNIQUE(CODE);\\012ALTER TABLE PROJECTS ADD CONSTRAINT PROJ_BK_UK UNIQUE(CODE,ORGA_ID);\\012ALTER TABLE SAMPLE_COMPONENT_MATERIALS ADD CONSTRAINT SCMA_BK_UK UNIQUE(MABA_ID,SACO_ID);\\012ALTER TABLE EXTERNAL_DATA ADD CONSTRAINT EXDA_BK_UK UNIQUE(LOCATION);\\012ALTER TABLE SAMPLES ADD CONSTRAINT SAMP_BK_UK UNIQUE(CODE);\\012ALTER TABLE MATERIAL_TYPES ADD CONSTRAINT MATY_UK UNIQUE(CODE);\\012ALTER TABLE MATERIAL_TYPES ADD CONSTRAINT MATY_BK_UK UNIQUE(CODE);\\012ALTER TABLE MATERIALS ADD CONSTRAINT MATE_BK_UK UNIQUE(CODE);\\012--\\012--  Temporarily not created, due to data quality issues with the master plate layout data\\012--\\012-- ALTER TABLE MOLECULES ADD CONSTRAINT MOLE_BK_UK UNIQUE(SEQUENCE);\\012ALTER TABLE EXPERIMENTS ADD CONSTRAINT EXPE_BK_UK UNIQUE(CODE,PROJ_ID);\\012\\012ALTER TABLE DATA ADD CONSTRAINT DATA_SAMP_ARC_CK CHECK ((samp_id_acquired_from IS NOT NULL \\012and samp_id_derived_from IS NULL) \\012or (samp_id_acquired_from IS NULL \\012and samp_id_derived_from IS NOT NULL)) ;\\012ALTER TABLE EXPERIMENT_PROPERTIES ADD CONSTRAINT EXPR_PERS_FK FOREIGN KEY (PERS_ID_REGISTERER)REFERENCES PERSONS(ID);\\012ALTER TABLE EXPERIMENT_PROPERTIES ADD CONSTRAINT EXPR_EXPE_FK FOREIGN KEY (EXPE_ID)REFERENCES EXPERIMENTS(ID);\\012ALTER TABLE DATA_VALUES ADD CONSTRAINT DAVA_DATA_FK FOREIGN KEY (DATA_ID)REFERENCES DATA(ID);\\012ALTER TABLE DATA_VALUES ADD CONSTRAINT DAVA_SACO_FK FOREIGN KEY (SACO_ID)REFERENCES SAMPLE_COMPONENTS(ID);\\012ALTER TABLE SAMPLE_INPUTS ADD CONSTRAINT SAIN_PROC_FK FOREIGN KEY (PROC_ID)REFERENCES PROCEDURES(ID);\\012ALTER TABLE SAMPLE_INPUTS ADD CONSTRAINT SAIN_SAMP_FK FOREIGN KEY (SAMP_ID)REFERENCES SAMPLES(ID);\\012ALTER TABLE SAMPLE_COMPONENTS ADD CONSTRAINT SACO_SAMP_FK FOREIGN KEY (SAMP_ID)REFERENCES SAMPLES(ID);\\012ALTER TABLE PROCEDURES ADD CONSTRAINT PROC_PCTY_FK FOREIGN KEY (PCTY_ID)REFERENCES PROCEDURE_TYPES(ID);\\012ALTER TABLE PROCEDURES ADD CONSTRAINT PROC_PERS_FK FOREIGN KEY (PERS_ID)REFERENCES PERSONS(ID);\\012ALTER TABLE PROCEDURES ADD CONSTRAINT PROC_EXPE_FK FOREIGN KEY (EXPE_ID)REFERENCES EXPERIMENTS(ID);\\012ALTER TABLE PROJECTS ADD CONSTRAINT PROJ_ORGA_FK FOREIGN KEY (ORGA_ID)REFERENCES ORGANIZATIONS(ID);\\012ALTER TABLE SAMPLE_COMPONENT_MATERIALS ADD CONSTRAINT SCMA_MABA_FK FOREIGN KEY (MABA_ID)REFERENCES MATERIAL_BATCHES(ID);\\012ALTER TABLE SAMPLE_COMPONENT_MATERIALS ADD CONSTRAINT SCMA_SACO_FK FOREIGN KEY (SACO_ID)REFERENCES SAMPLE_COMPONENTS(ID);\\012ALTER TABLE EXTERNAL_DATA ADD CONSTRAINT EXDA_DATA_FK FOREIGN KEY (DATA_ID)REFERENCES DATA(ID);\\012ALTER TABLE EXTERNAL_DATA ADD CONSTRAINT EXDA_LOTY_FK FOREIGN KEY (LOTY_ID)REFERENCES LOCATOR_TYPES(ID);\\012ALTER TABLE EXTERNAL_DATA ADD CONSTRAINT EXDA_FFTY_FK FOREIGN KEY (FFTY_ID)REFERENCES FILE_FORMAT_TYPES(ID);\\012ALTER TABLE DATA ADD CONSTRAINT DATA_SAMP_DERIVED_FROM_FK FOREIGN KEY (SAMP_ID_DERIVED_FROM)REFERENCES SAMPLES(ID);\\012ALTER TABLE DATA ADD CONSTRAINT DATA_SAMP_FK FOREIGN KEY (SAMP_ID_ACQUIRED_FROM)REFERENCES SAMPLES(ID);\\012ALTER TABLE DATA ADD CONSTRAINT DATA_PROC_FK FOREIGN KEY (PROC_ID_ACQUIRED_BY)REFERENCES PROCEDURES(ID);\\012ALTER TABLE DATA ADD CONSTRAINT DATA_OBTY_FK FOREIGN KEY (OBTY_ID)REFERENCES OBSERVABLE_TYPES(ID);\\012ALTER TABLE SAMPLES ADD CONSTRAINT SAMP_PERS_FK FOREIGN KEY (PERS_ID_REGISTERER)REFERENCES PERSONS(ID);\\012ALTER TABLE SAMPLES ADD CONSTRAINT SAMP_PROC_FK FOREIGN KEY (PROC_ID)REFERENCES PROCEDURES(ID);\\012ALTER TABLE SAMPLES ADD CONSTRAINT SAMP_SAMP_FK_GENERATED_FROM FOREIGN KEY (SAMP_ID_GENERATED_FROM)REFERENCES SAMPLES(ID);\\012ALTER TABLE SAMPLES ADD CONSTRAINT SAMP_SAMP_FK_TOP FOREIGN KEY (SAMP_ID_TOP)REFERENCES SAMPLES(ID);\\012ALTER TABLE SAMPLES ADD CONSTRAINT SAMP_SATY_FK FOREIGN KEY (SATY_ID)REFERENCES SAMPLE_TYPES(ID);\\012ALTER TABLE MATERIAL_BATCHES ADD CONSTRAINT MABA_PERS_FK FOREIGN KEY (PERS_ID_REGISTERER)REFERENCES PERSONS(ID);\\012ALTER TABLE MATERIAL_BATCHES ADD CONSTRAINT MABA_MATE_FK FOREIGN KEY (MATE_ID)REFERENCES MATERIALS(ID);\\012ALTER TABLE MATERIAL_BATCHES ADD CONSTRAINT MABA_PROC_FK FOREIGN KEY (PROC_ID)REFERENCES PROCEDURES(ID);\\012ALTER TABLE MATERIALS ADD CONSTRAINT MATE_MATY_FK FOREIGN KEY (MATY_ID)REFERENCES MATERIAL_TYPES(ID);\\012ALTER TABLE MATERIALS ADD CONSTRAINT MATE_PERS_FK FOREIGN KEY (PERS_ID_REGISTERER)REFERENCES PERSONS(ID);\\012ALTER TABLE MOLECULES ADD CONSTRAINT MOLE_MATE_FK FOREIGN KEY (MATE_ID)REFERENCES MATERIALS(ID);\\012ALTER TABLE MOLECULES ADD CONSTRAINT MOLE_MOLE_FK FOREIGN KEY (MOLE_ID_INHIBITOR_OF)REFERENCES MOLECULES(MATE_ID);\\012ALTER TABLE EXPERIMENTS ADD CONSTRAINT EXPE_MATE_FK FOREIGN KEY (MATE_ID_STUDY_OBJECT)REFERENCES MATERIALS(ID);\\012ALTER TABLE EXPERIMENTS ADD CONSTRAINT EXPE_EXTY_FK FOREIGN KEY (EXTY_ID)REFERENCES EXPERIMENT_TYPES(ID);\\012ALTER TABLE EXPERIMENTS ADD CONSTRAINT EXPE_PERS_FK FOREIGN KEY (PERS_ID_REGISTERER)REFERENCES PERSONS(ID);\\012ALTER TABLE EXPERIMENTS ADD CONSTRAINT EXPE_PROJ_FK FOREIGN KEY (PROJ_ID)REFERENCES PROJECTS(ID);\\012\\012\\012\\012--  Creating Sequences\\012\\012CREATE SEQUENCE EXPERIMENT_PROPERTY_ID_SEQ;\\012\\012CREATE SEQUENCE PROCEDURE_TYPE_ID_SEQ;\\012\\012CREATE SEQUENCE SAMPLE_INPUT_ID_SEQ;\\012\\012CREATE SEQUENCE SAMPLE_TYPE_ID_SEQ;\\012\\012CREATE SEQUENCE LOCATOR_TYPE_ID_SEQ;\\012\\012CREATE SEQUENCE SAMPLE_ID_SEQ;\\012\\012CREATE SEQUENCE EXPERIMENT_ID_SEQ;\\012\\012CREATE SEQUENCE MATERIAL_BATCH_ID_SEQ;\\012\\012CREATE SEQUENCE OBSERVABLE_TYPE_ID_SEQ;\\012\\012CREATE SEQUENCE SAMPLE_COMPONENT_ID_SEQ;\\012\\012CREATE SEQUENCE MATERIAL_ID_SEQ;\\012\\012CREATE SEQUENCE DATA_ID_SEQ;\\012\\012--  Creating Sequence for the SAMPLE_COMPONENT_MATERIALS table (standard naming convention was too long)\\012CREATE SEQUENCE SCMA_ID_SEQ;\\012\\012CREATE SEQUENCE PROCEDURE_ID_SEQ;\\012\\012CREATE SEQUENCE FILE_FORMAT_TYPE_ID_SEQ;\\012\\012CREATE SEQUENCE MATERIAL_TYPE_ID_SEQ;\\012\\012CREATE SEQUENCE EXPERIMENT_TYPE_ID_SEQ;\\012\\012CREATE SEQUENCE PERSON_ID_SEQ;\\012\\012CREATE SEQUENCE ORGANIZATION_ID_SEQ;\\012\\012CREATE SEQUENCE PROJECT_ID_SEQ;\\012\\012CREATE SEQUENCE DATA_VALUE_ID_SEQ;\\012\\012\\012\\012/*\\012   Trigger Section\\012   ===============*/\\012\\012CREATE OR REPLACE FUNCTION br001_crtl_plate_chk() RETURNS trigger AS $br001_crtl_plate_chk$\\012DECLARE\\012   cnt           INTEGER;\\012   v_cell_plate  CODE;\\012BEGIN\\012\\012   select code into v_cell_plate from sample_types where id  = NEW.saty_id;\\012\\012   -- Check if the sample is of type "Cell Plate"\\012   if v_cell_plate = 'CELL PLATE' then\\012\\012      -- Check that a Control Plate exists before registering the Cell Plate\\012      select count(*) into cnt from samples s, sample_types st where s.saty_id = st.id and st.code = 'CONTROL LAYOUT';\\011 \\012      IF cnt = 0 THEN\\012\\011\\011 -- Doens't make sense, so comment it out\\012         -- RAISE EXCEPTION 'A Control Plate must exist before you can register Cell Plate: %', NEW.code;\\012      END IF;\\012\\012   end if;\\012\\012   RETURN NEW;\\012\\012END;\\012$br001_crtl_plate_chk$ LANGUAGE plpgsql;\\012\\012\\012CREATE TRIGGER br001_crtl_plate_chk BEFORE INSERT ON samples\\012    FOR EACH ROW EXECUTE PROCEDURE br001_crtl_plate_chk();\\012	\N
+./sourceTest/sql/postgresql/026/009=database_version_logs.tsv:013	source/sql/postgresql/migration/migration-012-013.sql	SUCCESS	2008-05-09 10:11:20.487	----------------------------------------------------------------------------------------------\\012--  File: migration-012-013.sql\\012--\\012-- \\012--  This script enables the migration of the database schema from 012 to 013.\\012-- \\012--  Update History\\012--\\012--\\012--\\011Who\\011\\011\\011\\011\\011\\011\\011When\\011\\011\\011\\011What\\012--\\011---\\011\\011\\011\\011\\011\\011\\011----\\011\\011\\011\\011----\\012--\\011Bernd Rinn\\011\\0112008-01-04\\011Initial Version - add support for invalidations and material type BACTERIUM \\012--\\011Bernd Rinn\\011\\0112008-01-05\\011Add material type COMPOUND and material type property type entries for the new material types \\012--  \\012----------------------------------------------------------------------------------------------\\012\\012------------------------------------------------------------------------------------\\012--  Purpose:  Create function RENAME_SEQUENCE() that is required for renaming the sequences belonging to tables\\012------------------------------------------------------------------------------------\\012\\012CREATE FUNCTION RENAME_SEQUENCE(OLD_NAME VARCHAR, NEW_NAME VARCHAR) RETURNS INTEGER AS $$\\012DECLARE\\012  CURR_SEQ_VAL   INTEGER;\\012BEGIN\\012  SELECT INTO CURR_SEQ_VAL NEXTVAL(OLD_NAME);\\012  EXECUTE 'CREATE SEQUENCE ' || NEW_NAME || ' START WITH ' || CURR_SEQ_VAL;\\012  EXECUTE 'DROP SEQUENCE ' || OLD_NAME;\\012  RETURN CURR_SEQ_VAL;\\012END;\\012$$ LANGUAGE 'plpgsql';\\012\\012\\012------------------------------------------------------------------------------------\\012--  Purpose:  Add table INVALIDATIONS to store invalidations\\012------------------------------------------------------------------------------------\\012\\012CREATE TABLE INVALIDATIONS (ID TECH_ID NOT NULL,PERS_ID_REGISTERER TECH_ID NOT NULL,REGISTRATION_TIMESTAMP TIME_STAMP NOT NULL DEFAULT CURRENT_TIMESTAMP,REASON DESCRIPTION_250);\\012ALTER TABLE INVALIDATIONS ADD CONSTRAINT INVA_PK PRIMARY KEY(ID);\\012ALTER TABLE INVALIDATIONS ADD CONSTRAINT INVA_PERS_FK FOREIGN KEY (PERS_ID_REGISTERER) REFERENCES PERSONS(ID);\\012CREATE SEQUENCE INVALIDATION_ID_SEQ;\\012CREATE INDEX INVA_PERS_FK_I ON INVALIDATIONS (PERS_ID_REGISTERER);\\012\\012------------------------------------------------------------------------------------\\012--  Purpose:  Add column INVA_ID to table SAMPLES in order to allow invalidation of samples  \\012------------------------------------------------------------------------------------\\012\\012ALTER TABLE SAMPLES ADD INVA_ID TECH_ID;\\012ALTER TABLE SAMPLES ADD CONSTRAINT SAMP_INVA_FK FOREIGN KEY (INVA_ID) REFERENCES INVALIDATIONS(ID);\\012CREATE INDEX SAMP_INVA_FK_I ON SAMPLES (INVA_ID);\\012\\012\\012------------------------------------------------------------------------------------\\012--  Purpose:  Rename table EXPERIMENT_PROPERTIES TO EXPERIMENT_ATTACHMENTS  \\012------------------------------------------------------------------------------------\\012\\012ALTER TABLE EXPERIMENT_PROPERTIES DROP CONSTRAINT EXPR_PK;\\012ALTER TABLE EXPERIMENT_PROPERTIES DROP CONSTRAINT EXPR_BK_UK;\\012ALTER TABLE EXPERIMENT_PROPERTIES DROP CONSTRAINT EXPR_EXPE_FK;\\012ALTER TABLE EXPERIMENT_PROPERTIES DROP CONSTRAINT EXPR_PERS_FK;\\012\\012ALTER TABLE EXPERIMENT_PROPERTIES RENAME TO EXPERIMENT_ATTACHMENTS;\\012ALTER INDEX EXPR_EXPE_FK_I RENAME TO EXAT_EXPE_FK_I;\\012ALTER INDEX EXPR_PERS_FK_I RENAME TO EXAT_PERS_FK_I;\\012SELECT RENAME_SEQUENCE('EXPERIMENT_PROPERTY_ID_SEQ', 'EXPERIMENT_ATTACHMENT_ID_SEQ');\\012\\012ALTER TABLE EXPERIMENT_ATTACHMENTS ADD CONSTRAINT EXAT_PK PRIMARY KEY(ID);\\012ALTER TABLE EXPERIMENT_ATTACHMENTS ADD CONSTRAINT EXAT_BK_UK UNIQUE(EXPE_ID,FILE_NAME,VERSION);\\012ALTER TABLE EXPERIMENT_ATTACHMENTS ADD CONSTRAINT EXAT_EXPE_FK FOREIGN KEY (EXPE_ID) REFERENCES EXPERIMENTS(ID);\\012ALTER TABLE EXPERIMENT_ATTACHMENTS ADD CONSTRAINT EXAT_PERS_FK FOREIGN KEY (PERS_ID_REGISTERER) REFERENCES PERSONS(ID);\\012\\012\\012------------------------------------------------------------------------------------\\012--  Purpose:  Add the material type BACTERIUM\\012------------------------------------------------------------------------------------\\012\\012insert into material_types\\012(id\\012,code\\012,description)\\012values \\012(nextval('MATERIAL_TYPE_ID_SEQ')\\012,'BACTERIUM'\\012,'Bacterium'\\012);\\012\\012------------------------------------------------------------------------------------\\012--  Purpose:  Add the material type COMPOUND\\012------------------------------------------------------------------------------------\\012\\012insert into material_types\\012(id\\012,code\\012,description)\\012values \\012(nextval('MATERIAL_TYPE_ID_SEQ')\\012,'COMPOUND'\\012,'Compound'\\012);\\012\\012------------------------------------------------------------------------------------\\012--  Purpose:  Insert an initial data set into the table MATERIAL_TYPE_PROPERTY_TYPES\\012------------------------------------------------------------------------------------\\012\\012   -----------------------\\012   --  Material Type BACTERIUM\\012   -----------------------\\012\\012insert into material_type_property_types\\012(   id\\012   ,maty_id\\012   ,prty_id\\012   ,is_mandatory\\012   ,pers_id_registerer\\012   )\\012values \\012   (nextval('MTPT_ID_SEQ')\\012   ,(select id from material_types where code = 'BACTERIUM')\\012   ,(select id from property_types where code = 'DESCRIPTION')\\012   ,true\\012   ,(select id from persons where user_id ='system')\\012);\\012\\012   -----------------------\\012   --  Material Type COMPOUND\\012   -----------------------\\012\\012insert into material_type_property_types\\012(   id\\012   ,maty_id\\012   ,prty_id\\012   ,is_mandatory\\012   ,pers_id_registerer\\012   )\\012values \\012   (nextval('MTPT_ID_SEQ')\\012   ,(select id from material_types where code = 'COMPOUND')\\012   ,(select id from property_types where code = 'DESCRIPTION')\\012   ,true\\012   ,(select id from persons where user_id ='system')\\012);\\012\\012\\012------------------------------------------------------------------------------------\\012--  Purpose:  Change according to naming convention for CODEs\\012------------------------------------------------------------------------------------\\012\\012update procedure_types set code='DATA_ACQUISITION' where code='DATA ACQUISITION';\\012update procedure_types set code='IMAGE_ANALYSIS' where code='IMAGE ANALYSIS';\\012update locator_types set code='RELATIVE_LOCATION' where code='RELATIVE LOCATION';\\012update sample_types set code='MASTER_PLATE' where code='MASTER PLATE';\\012update sample_types set code='DILUTION_PLATE' where code='DILUTION PLATE';\\012update sample_types set code='CELL_PLATE' where code='CELL PLATE';\\012update sample_types set code='REINFECT_PLATE' where code='REINFECT PLATE';\\012update sample_types set description='Re-infection Plate' where code='REINFECT_PLATE';\\012update sample_types set code='CONTROL_LAYOUT' where code='CONTROL LAYOUT';\\012	\N
+./sourceTest/sql/postgresql/026/009=database_version_logs.tsv:014	source/sql/postgresql/migration/migration-013-014.sql	SUCCESS	2008-05-09 10:11:22.523	----------------------------------------------------------------------------------------------\\012--  File: migration-013-014.sql\\012--\\012-- \\012--  This script enables the migration of the database schema from 013 to 014.\\012-- \\012--  Update History\\012--\\012--\\012--\\011Who\\011\\011\\011When\\011\\011What\\012--\\011---\\011\\011\\011----\\011\\011----\\012--\\011Charles Ramin-Wright\\0112008-01-29\\011Initial Version \\012--  \\012----------------------------------------------------------------------------------------------\\012\\012--=================================\\012-- New Tables and related objects\\012--=================================\\012\\012------------------------------------------------------------------------------------\\012--  Purpose:  Add tables CONTROLLED_VOCABULARIES and CONTROLLED_VOCABULARY_TERMS\\012------------------------------------------------------------------------------------\\012\\012CREATE TABLE CONTROLLED_VOCABULARIES (ID TECH_ID NOT NULL,CODE CODE NOT NULL,DESCRIPTION DESCRIPTION_80,REGISTRATION_TIMESTAMP TIME_STAMP NOT NULL DEFAULT CURRENT_TIMESTAMP,PERS_ID TECH_ID NOT NULL);\\012CREATE TABLE CONTROLLED_VOCABULARY_TERMS (ID TECH_ID NOT NULL,CODE OBJECT_NAME NOT NULL,REGISTRATION_TIMESTAMP TIME_STAMP NOT NULL DEFAULT CURRENT_TIMESTAMP,COVO_ID TECH_ID NOT NULL,PERS_ID TECH_ID NOT NULL);\\012\\012\\012-- Creating primary key constraints\\012\\012ALTER TABLE CONTROLLED_VOCABULARIES ADD CONSTRAINT COVO_PK PRIMARY KEY(ID);\\012ALTER TABLE CONTROLLED_VOCABULARY_TERMS ADD CONSTRAINT CVTE_PK PRIMARY KEY(ID);\\012\\012-- Creating unique constraints\\012\\012ALTER TABLE CONTROLLED_VOCABULARIES ADD CONSTRAINT COVO_BK_UK UNIQUE(CODE);\\012ALTER TABLE CONTROLLED_VOCABULARY_TERMS ADD CONSTRAINT CVTE_BK_UK UNIQUE(CODE,COVO_ID);\\012\\012-- Creating foreign key constraints\\012\\012ALTER TABLE CONTROLLED_VOCABULARIES ADD CONSTRAINT COVO_PERS_FK FOREIGN KEY (PERS_ID) REFERENCES PERSONS(ID);\\012ALTER TABLE CONTROLLED_VOCABULARY_TERMS ADD CONSTRAINT CVTE_COVO_FK FOREIGN KEY (COVO_ID) REFERENCES CONTROLLED_VOCABULARIES(ID);\\012ALTER TABLE CONTROLLED_VOCABULARY_TERMS ADD CONSTRAINT CVTE_PERS_FK FOREIGN KEY (PERS_ID) REFERENCES PERSONS(ID);\\012\\012-- Creating sequences\\012\\012CREATE SEQUENCE CONTROLLED_VOCABULARY_ID_SEQ;\\012CREATE SEQUENCE CVTE_ID_SEQ;\\012\\012\\012-- Creating indexes\\012\\012CREATE INDEX COVO_PERS_FK_I ON CONTROLLED_VOCABULARIES (PERS_ID);\\012CREATE INDEX CVTE_COVO_FK_I ON CONTROLLED_VOCABULARY_TERMS (COVO_ID);\\012CREATE INDEX CVTE_PERS_FK_I ON CONTROLLED_VOCABULARY_TERMS (PERS_ID);\\012\\012\\012--====================================\\012-- Modifications of existing objects\\012--====================================\\012\\012---------------------------------------------------------------------------------------------------\\012--  Purpose:  Add column INVA_ID to table EXPERIMENTS in order to allow invalidation of experiments\\012---------------------------------------------------------------------------------------------------\\012\\012ALTER TABLE EXPERIMENTS ADD INVA_ID TECH_ID;\\012ALTER TABLE EXPERIMENTS ADD CONSTRAINT EXPE_INVA_FK FOREIGN KEY (INVA_ID) REFERENCES INVALIDATIONS(ID);\\012CREATE INDEX EXPE_INVA_FK_I ON EXPERIMENTS (INVA_ID);\\012\\012------------------------------------------------------------------------------------\\012--  Purpose:  Add column SAMP_ID_CONTROL_LAYOUT to table SAMPLES in order to allow \\012--            the association of a sample of type CONTROL_LAYOUT to samples\\012------------------------------------------------------------------------------------\\012\\012ALTER TABLE SAMPLES ADD SAMP_ID_CONTROL_LAYOUT TECH_ID;\\012ALTER TABLE SAMPLES ADD CONSTRAINT SAMP_SAMP_FK_CONTROL_LAYOUT FOREIGN KEY (SAMP_ID_CONTROL_LAYOUT) REFERENCES SAMPLES(ID);\\012CREATE INDEX SAMP_SAMP_FK_I_CONTROL_LAYOUT ON SAMPLES (SAMP_ID_CONTROL_LAYOUT);\\012\\012\\012--------------------------------------------------------------\\012--  Purpose:  Add column CVTE_ID to table MATERIAL_PROPERTIES \\012--------------------------------------------------------------\\012ALTER TABLE MATERIAL_PROPERTIES ADD CVTE_ID TECH_ID;\\012ALTER TABLE MATERIAL_PROPERTIES ADD CONSTRAINT MAPR_CVTE_FK FOREIGN KEY (CVTE_ID) REFERENCES CONTROLLED_VOCABULARY_TERMS(ID);\\012CREATE INDEX MAPR_CVTE_FK_I ON MATERIAL_PROPERTIES (CVTE_ID);\\012\\012--------------------------------------------------------------\\012--  Purpose:  Change column VALUE from mandatory to optional\\012--------------------------------------------------------------\\012ALTER TABLE MATERIAL_PROPERTIES ALTER VALUE DROP NOT NULL;\\012\\012-- Creating check constraints\\012\\012ALTER TABLE MATERIAL_PROPERTIES ADD CONSTRAINT VALUE_OR_CVTE_ID CHECK ((value IS NOT NULL and cvte_id IS NULL) or (value IS NULL and cvte_id IS NOT NULL));\\012\\012\\012--------------------------------------------------------------\\012--  Purpose:  Add column COVO_ID to table PROPERTY_TYPES  \\012--------------------------------------------------------------\\012ALTER TABLE PROPERTY_TYPES ADD COVO_ID TECH_ID;\\012ALTER TABLE PROPERTY_TYPES ADD CONSTRAINT PRTY_COVO_FK FOREIGN KEY (COVO_ID) REFERENCES CONTROLLED_VOCABULARIES(ID);\\012CREATE INDEX PRTY_COVO_FK_I ON PROPERTY_TYPES (COVO_ID);\\012\\012\\012------------------------------------------------------------------------------------\\012--  Purpose:  Create trigger CONTROLLED_VOCABULARY_CHECK \\012------------------------------------------------------------------------------------\\012\\012CREATE OR REPLACE FUNCTION CONTROLLED_VOCABULARY_CHECK() RETURNS trigger AS $$\\012DECLARE\\012   cnt     INTEGER;\\012   v_code  CODE;\\012BEGIN\\012\\012   select code into v_code from data_types where id  = NEW.daty_id;\\012\\012   -- Check if the data is of type "CONTROLLEDVOCABULARY"\\012   if v_code = 'CONTROLLEDVOCABULARY' then\\012      if NEW.covo_id IS NULL then\\012         RAISE EXCEPTION 'Insert/Update of Property Type (Code: %) failed, as its Data Type is CONTROLLEDVOCABULARY, but it is not linked to a Controlled Vocabulary.', NEW.code;\\012      end if;\\012   end if;\\012\\012   RETURN NEW;\\012\\012END;\\012$$ LANGUAGE 'plpgsql';\\012\\012\\012CREATE TRIGGER CONTROLLED_VOCABULARY_CHECK BEFORE INSERT OR UPDATE ON PROPERTY_TYPES\\012    FOR EACH ROW EXECUTE PROCEDURE CONTROLLED_VOCABULARY_CHECK();\\012\\012\\012--====================================\\012-- Deletion of existing objects\\012--====================================\\012\\012drop trigger br001_crtl_plate_chk on samples;\\012drop function br001_crtl_plate_chk();\\012\\012\\012--====================================\\012-- Add Master Data\\012--====================================\\012\\012-----------------------------------------------------------------------------------\\012--  Purpose:  Insert into the table DATA_TYPES\\012--\\012--            Create the data type CONTROLLEDVOCABULARY.\\012-----------------------------------------------------------------------------------\\012insert into data_types\\012(id\\012,code\\012,description)\\012values \\012(nextval('DATA_TYPE_ID_SEQ')\\012,'CONTROLLEDVOCABULARY'\\012,'Controlled Vocabulary'\\012);\\012\\012--==========================================\\012--\\012--   Data Migration\\012--\\012--==========================================\\012\\012-----------------------------------------------------------------------------------\\012--  Purpose:  Migrate the CONTROL_LAYOUTs from the SAMPLE_INPUTS table \\012--            to the foreign key SAMP_SAMP_FK_CONTROL_LAYOUT in the SAMPLES table\\012--\\012--            This results in having all CONTROL_LAYOUTs being directly linked \\012--            to CELL_PLATEs.            \\012-----------------------------------------------------------------------------------\\012\\012UPDATE samples cell_plate\\012   SET samp_id_control_layout = \\012          (select control_layout.samp_id\\012           from   sample_inputs control_layout inner join samples s \\012           on     control_layout.samp_id = s.id\\012           where  s.saty_id = (select id from sample_types where code = 'CONTROL_LAYOUT')\\012           and    proc_id = (\\012              select  proc_id\\012              from sample_inputs cp\\012              where cp.samp_id = cell_plate.id))\\012   WHERE saty_id = (select id from sample_types where code = 'CELL_PLATE')\\012   and   id = (select distinct (samp_id)\\012                  from   sample_inputs sain inner join samples s2 \\012                  on  sain.samp_id = cell_plate.id)\\012;\\012\\012-----------------------------------------------------------------------------------\\012--   Delete the CONTROL LAYOUTs from the SAMPLE_INPUTS table\\012-----------------------------------------------------------------------------------\\012\\012delete from sample_inputs\\012where  id in (select si.id \\012              from   sample_inputs si inner join samples s \\012              on     si.samp_id = s.id\\012              where  s.saty_id = (select id from sample_types where code = 'CONTROL_LAYOUT')\\012              )\\012;\\012\\012	\N
+./sourceTest/sql/postgresql/026/009=database_version_logs.tsv:016	source/sql/postgresql/migration/migration-015-016.sql	SUCCESS	2008-05-09 10:12:52.062	----------------------------------------------------------------------------------------------\\012--  File: migration-015-016.sql\\012--\\012-- \\012--  This script enables the migration of the database schema from 015 to 016.\\012-- \\012--  Update History\\012--\\012--\\012--\\011Who\\011\\011\\011When\\011\\011What\\012--\\011---\\011\\011\\011----\\011\\011----\\012--\\011Bernd Rinn\\0112008-03-22\\011Initial Version \\012--  \\012----------------------------------------------------------------------------------------------\\012\\012\\012--=================================\\012-- New Domains\\012--=================================\\012\\012-----------------------------------------------------------------------------------\\012--  Purpose:  Change all CODE columns to LONG_CODE, then re-create DOMAIN CODE identical to LONG_CODE\\012--  and change LONG_CODE columns back to the (new) CODE \\012-----------------------------------------------------------------------------------\\012\\012-- First step: create new domain LONG_CODE\\012CREATE DOMAIN LONG_CODE AS VARCHAR(40);\\012\\012-- Second step: change all CODE to LONG_CODE\\012ALTER TABLE CONTROLLED_VOCABULARIES ALTER COLUMN CODE TYPE LONG_CODE;\\012ALTER TABLE DATA_TYPES ALTER COLUMN CODE TYPE LONG_CODE;\\012ALTER TABLE EXPERIMENTS ALTER COLUMN CODE TYPE LONG_CODE;\\012ALTER TABLE EXPERIMENT_TYPES ALTER COLUMN CODE TYPE LONG_CODE;\\012ALTER TABLE FILE_FORMAT_TYPES ALTER COLUMN CODE TYPE LONG_CODE;\\012ALTER TABLE LOCATOR_TYPES ALTER COLUMN CODE TYPE LONG_CODE;\\012ALTER TABLE MATERIALS ALTER COLUMN CODE TYPE LONG_CODE;\\012ALTER TABLE MATERIAL_BATCHES ALTER COLUMN CODE TYPE LONG_CODE;\\012ALTER TABLE MATERIAL_TYPES ALTER COLUMN CODE TYPE LONG_CODE;\\012ALTER TABLE OBSERVABLE_TYPES ALTER COLUMN CODE TYPE LONG_CODE;\\012ALTER TABLE ORGANIZATIONS ALTER COLUMN CODE TYPE LONG_CODE;\\012ALTER TABLE PROCEDURE_TYPES ALTER COLUMN CODE TYPE LONG_CODE;\\012ALTER TABLE PROJECTS ALTER COLUMN CODE TYPE LONG_CODE;\\012ALTER TABLE PROPERTY_TYPES ALTER COLUMN CODE TYPE LONG_CODE;\\012ALTER TABLE SAMPLES ALTER COLUMN CODE TYPE LONG_CODE;\\012ALTER TABLE SAMPLE_COMPONENTS ALTER COLUMN CODE TYPE LONG_CODE;\\012ALTER TABLE SAMPLE_TYPES ALTER COLUMN CODE TYPE LONG_CODE;\\012\\012-- Third step: re-create CODE as VARCHAR(40)\\012DROP DOMAIN CODE;\\012CREATE DOMAIN CODE AS VARCHAR(40);\\012\\012-- Forth step: change all LONG_CODE columns back to CODE\\012ALTER TABLE CONTROLLED_VOCABULARIES ALTER COLUMN CODE TYPE CODE;\\012ALTER TABLE DATA_TYPES ALTER COLUMN CODE TYPE CODE;\\012ALTER TABLE EXPERIMENTS ALTER COLUMN CODE TYPE CODE;\\012ALTER TABLE EXPERIMENT_TYPES ALTER COLUMN CODE TYPE CODE;\\012ALTER TABLE FILE_FORMAT_TYPES ALTER COLUMN CODE TYPE CODE;\\012ALTER TABLE LOCATOR_TYPES ALTER COLUMN CODE TYPE CODE;\\012ALTER TABLE MATERIALS ALTER COLUMN CODE TYPE CODE;\\012ALTER TABLE MATERIAL_BATCHES ALTER COLUMN CODE TYPE CODE;\\012ALTER TABLE MATERIAL_TYPES ALTER COLUMN CODE TYPE CODE;\\012ALTER TABLE OBSERVABLE_TYPES ALTER COLUMN CODE TYPE CODE;\\012ALTER TABLE ORGANIZATIONS ALTER COLUMN CODE TYPE CODE;\\012ALTER TABLE PROCEDURE_TYPES ALTER COLUMN CODE TYPE CODE;\\012ALTER TABLE PROJECTS ALTER COLUMN CODE TYPE CODE;\\012ALTER TABLE PROPERTY_TYPES ALTER COLUMN CODE TYPE CODE;\\012ALTER TABLE SAMPLES ALTER COLUMN CODE TYPE CODE;\\012ALTER TABLE SAMPLE_COMPONENTS ALTER COLUMN CODE TYPE CODE;\\012ALTER TABLE SAMPLE_TYPES ALTER COLUMN CODE TYPE CODE;\\012\\012-- Fifth step: drop domain LONG_CODE\\012DROP DOMAIN LONG_CODE;\\012\\012-----------------------------------------------------------------------------------\\012--  Purpose:  Create new domain TIME_STAMP_DFL and change current users of TIME_STAMP to TIME_STAMP_DFL\\012--  This adds time zone information and allows for a clean separation between registration time stamps\\012--  which should have a default of CURRENT_TIMESTAMP and other time stamps which should not. \\012-----------------------------------------------------------------------------------\\012\\012-- First step: create new domain TIME_STAMP_DFL\\012CREATE DOMAIN TIME_STAMP_DFL AS TIMESTAMP WITH TIME ZONE NOT NULL DEFAULT CURRENT_TIMESTAMP;\\012\\012-- Second step: change all TIME_STAMP columns to TIME_STAMP_DFL\\012ALTER TABLE CONTROLLED_VOCABULARIES ALTER COLUMN REGISTRATION_TIMESTAMP TYPE TIME_STAMP_DFL;\\012ALTER TABLE CONTROLLED_VOCABULARIES ALTER COLUMN REGISTRATION_TIMESTAMP DROP NOT NULL;\\012ALTER TABLE CONTROLLED_VOCABULARIES ALTER COLUMN REGISTRATION_TIMESTAMP DROP DEFAULT;\\012ALTER TABLE CONTROLLED_VOCABULARY_TERMS ALTER COLUMN REGISTRATION_TIMESTAMP TYPE TIME_STAMP_DFL;\\012ALTER TABLE CONTROLLED_VOCABULARY_TERMS ALTER COLUMN REGISTRATION_TIMESTAMP DROP NOT NULL;\\012ALTER TABLE CONTROLLED_VOCABULARY_TERMS ALTER COLUMN REGISTRATION_TIMESTAMP DROP DEFAULT;\\012ALTER TABLE DATA ALTER COLUMN REGISTRATION_TIMESTAMP TYPE TIME_STAMP_DFL;\\012ALTER TABLE DATA ALTER COLUMN REGISTRATION_TIMESTAMP DROP NOT NULL;\\012ALTER TABLE DATA ALTER COLUMN REGISTRATION_TIMESTAMP DROP DEFAULT;\\012ALTER TABLE EXPERIMENTS ALTER COLUMN REGISTRATION_TIMESTAMP TYPE TIME_STAMP_DFL;\\012ALTER TABLE EXPERIMENTS ALTER COLUMN REGISTRATION_TIMESTAMP DROP NOT NULL;\\012ALTER TABLE EXPERIMENTS ALTER COLUMN REGISTRATION_TIMESTAMP DROP DEFAULT;\\012ALTER TABLE EXPERIMENT_ATTACHMENTS ALTER COLUMN REGISTRATION_TIMESTAMP TYPE TIME_STAMP_DFL;\\012ALTER TABLE EXPERIMENT_ATTACHMENTS ALTER COLUMN REGISTRATION_TIMESTAMP DROP NOT NULL;\\012ALTER TABLE EXPERIMENT_ATTACHMENTS ALTER COLUMN REGISTRATION_TIMESTAMP DROP DEFAULT;\\012ALTER TABLE EXPERIMENT_PROPERTIES ALTER COLUMN REGISTRATION_TIMESTAMP TYPE TIME_STAMP_DFL;\\012ALTER TABLE EXPERIMENT_PROPERTIES ALTER COLUMN REGISTRATION_TIMESTAMP DROP NOT NULL;\\012ALTER TABLE EXPERIMENT_PROPERTIES ALTER COLUMN REGISTRATION_TIMESTAMP DROP DEFAULT;\\012ALTER TABLE EXPERIMENT_TYPE_PROPERTY_TYPES ALTER COLUMN REGISTRATION_TIMESTAMP TYPE TIME_STAMP_DFL;\\012ALTER TABLE EXPERIMENT_TYPE_PROPERTY_TYPES ALTER COLUMN REGISTRATION_TIMESTAMP DROP NOT NULL;\\012ALTER TABLE EXPERIMENT_TYPE_PROPERTY_TYPES ALTER COLUMN REGISTRATION_TIMESTAMP DROP DEFAULT;\\012ALTER TABLE INVALIDATIONS ALTER COLUMN REGISTRATION_TIMESTAMP TYPE TIME_STAMP_DFL;\\012ALTER TABLE INVALIDATIONS ALTER COLUMN REGISTRATION_TIMESTAMP DROP NOT NULL;\\012ALTER TABLE INVALIDATIONS ALTER COLUMN REGISTRATION_TIMESTAMP DROP DEFAULT;\\012ALTER TABLE MATERIALS ALTER COLUMN REGISTRATION_TIMESTAMP TYPE TIME_STAMP_DFL;\\012ALTER TABLE MATERIALS ALTER COLUMN REGISTRATION_TIMESTAMP DROP NOT NULL;\\012ALTER TABLE MATERIALS ALTER COLUMN REGISTRATION_TIMESTAMP DROP DEFAULT;\\012ALTER TABLE MATERIAL_BATCHES ALTER COLUMN REGISTRATION_TIMESTAMP TYPE TIME_STAMP_DFL;\\012ALTER TABLE MATERIAL_BATCHES ALTER COLUMN REGISTRATION_TIMESTAMP DROP NOT NULL;\\012ALTER TABLE MATERIAL_BATCHES ALTER COLUMN REGISTRATION_TIMESTAMP DROP DEFAULT;\\012ALTER TABLE MATERIAL_PROPERTIES ALTER COLUMN REGISTRATION_TIMESTAMP TYPE TIME_STAMP_DFL;\\012ALTER TABLE MATERIAL_PROPERTIES ALTER COLUMN REGISTRATION_TIMESTAMP DROP NOT NULL;\\012ALTER TABLE MATERIAL_PROPERTIES ALTER COLUMN REGISTRATION_TIMESTAMP DROP DEFAULT;\\012ALTER TABLE MATERIAL_TYPE_PROPERTY_TYPES ALTER COLUMN REGISTRATION_TIMESTAMP TYPE TIME_STAMP_DFL;\\012ALTER TABLE MATERIAL_TYPE_PROPERTY_TYPES ALTER COLUMN REGISTRATION_TIMESTAMP DROP NOT NULL;\\012ALTER TABLE MATERIAL_TYPE_PROPERTY_TYPES ALTER COLUMN REGISTRATION_TIMESTAMP DROP DEFAULT;\\012ALTER TABLE PROCEDURES ALTER COLUMN REGISTRATION_TIMESTAMP TYPE TIME_STAMP_DFL;\\012ALTER TABLE PROCEDURES ALTER COLUMN REGISTRATION_TIMESTAMP DROP NOT NULL;\\012ALTER TABLE PROCEDURES ALTER COLUMN REGISTRATION_TIMESTAMP DROP DEFAULT;\\012ALTER TABLE PROPERTY_TYPES ALTER COLUMN REGISTRATION_TIMESTAMP TYPE TIME_STAMP_DFL;\\012ALTER TABLE PROPERTY_TYPES ALTER COLUMN REGISTRATION_TIMESTAMP DROP NOT NULL;\\012ALTER TABLE PROPERTY_TYPES ALTER COLUMN REGISTRATION_TIMESTAMP DROP DEFAULT;\\012ALTER TABLE SAMPLES ALTER COLUMN REGISTRATION_TIMESTAMP TYPE TIME_STAMP_DFL;\\012ALTER TABLE SAMPLES ALTER COLUMN REGISTRATION_TIMESTAMP DROP NOT NULL;\\012ALTER TABLE SAMPLES ALTER COLUMN REGISTRATION_TIMESTAMP DROP DEFAULT;\\012ALTER TABLE SAMPLE_PROPERTIES ALTER COLUMN REGISTRATION_TIMESTAMP TYPE TIME_STAMP_DFL;\\012ALTER TABLE SAMPLE_PROPERTIES ALTER COLUMN REGISTRATION_TIMESTAMP DROP NOT NULL;\\012ALTER TABLE SAMPLE_PROPERTIES ALTER COLUMN REGISTRATION_TIMESTAMP DROP DEFAULT;\\012ALTER TABLE SAMPLE_TYPE_PROPERTY_TYPES ALTER COLUMN REGISTRATION_TIMESTAMP TYPE TIME_STAMP_DFL;\\012ALTER TABLE SAMPLE_TYPE_PROPERTY_TYPES ALTER COLUMN REGISTRATION_TIMESTAMP DROP NOT NULL;\\012ALTER TABLE SAMPLE_TYPE_PROPERTY_TYPES ALTER COLUMN REGISTRATION_TIMESTAMP DROP DEFAULT;\\012\\012-- Third step: drop old domain TIME_STAMP\\012DROP DOMAIN TIME_STAMP;\\012\\012-- Forth step: create new domain time_stamp\\012CREATE DOMAIN TIME_STAMP AS TIMESTAMP WITH TIME ZONE;\\012\\012--=================================\\012-- New Tables and related objects\\012--=================================\\012\\012------------------------------------------------------------------------------------\\012-- table DATA_SET_RELATIONSHIPS (new)\\012------------------------------------------------------------------------------------\\012\\012-- Creating tables\\012\\012CREATE TABLE DATA_SET_RELATIONSHIPS (ID TECH_ID NOT NULL,DATA_ID_PARENT TECH_ID NOT NULL,DATA_ID_CHILD TECH_ID NOT NULL,REGISTRATION_TIMESTAMP TIME_STAMP_DFL);\\012\\012-- Creating primary key constraints\\012\\012ALTER TABLE DATA_SET_RELATIONSHIPS ADD CONSTRAINT DSRE_PK PRIMARY KEY(ID);\\012\\012-- Creating unique constraints\\012\\012ALTER TABLE DATA_SET_RELATIONSHIPS ADD CONSTRAINT DSRE_BK_UK UNIQUE(DATA_ID_CHILD,DATA_ID_PARENT);\\012\\012-- Creating foreign key constraints\\012\\012ALTER TABLE DATA_SET_RELATIONSHIPS ADD CONSTRAINT DSRE_DATA_FK_CHILD FOREIGN KEY (DATA_ID_CHILD) REFERENCES DATA(ID);\\012ALTER TABLE DATA_SET_RELATIONSHIPS ADD CONSTRAINT DSRE_DATA_FK_PARENT FOREIGN KEY (DATA_ID_PARENT) REFERENCES DATA(ID);\\012\\012-- Creating sequences\\012\\012CREATE SEQUENCE DATA_SET_RELATIONSHIP_ID_SEQ;\\012\\012-- Creating indexes\\012\\012CREATE INDEX DSRE_DATA_FK_I_CHILD ON DATA_SET_RELATIONSHIPS (DATA_ID_CHILD);\\012CREATE INDEX DSRE_DATA_FK_I_PARENT ON DATA_SET_RELATIONSHIPS (DATA_ID_PARENT);\\012\\012--====================================\\012-- Drop Tables and related objects\\012--====================================\\012\\012------------------------------------------------------------------------------------\\012-- table DATA_VALUES (deleted)\\012------------------------------------------------------------------------------------\\012\\012-- Delete constraints\\012\\012ALTER TABLE DATA_VALUES DROP CONSTRAINT DAVA_PK;\\012ALTER TABLE DATA_VALUES DROP CONSTRAINT DAVA_BK_UK;\\012ALTER TABLE DATA_VALUES DROP CONSTRAINT DAVA_DATA_FK;\\012ALTER TABLE DATA_VALUES DROP CONSTRAINT DAVA_SACO_FK;\\012\\012-- Delete indices\\012\\012DROP INDEX DAVA_DATA_FK_I;\\012DROP INDEX DAVA_SACO_FK_I;\\012\\012-- Delete sequences\\012\\012DROP SEQUENCE DATA_VALUE_ID_SEQ;\\012\\012-- Delete tables\\012\\012DROP TABLE DATA_VALUES;\\012\\012--====================================\\012-- Modifications of existing objects\\012--====================================\\012\\012------------------------------------------------------------------------------------\\012-- table ORGANIZATIONS (changed)\\012-- * rename to GROUPS\\012--\\012-- table DATA (changed)\\012-- * rename column PROC_ID_ACQUIRED_BY into: PROC_ID_PRODUCED_BY\\012-- * add columns:\\012-- ** IS_PLACEHOLDER BOOLEAN_CHAR\\012-- ** CODE CODE\\012-- ** DATA_PRODUCER_CODE CODE\\012-- ** PRODUCTION_TIMESTAMP TIME_STAMP\\012--\\012-- table EXTERNAL_DATA (changed)\\012-- * add column:\\012-- ** CVTE_ID_STOR_FMT TECH_ID NOT NULL\\012--\\012-- table PROPERTY_TYPES (changed)\\012-- * add column IS_MANAGED_INTERNALLY BOOLEAN_CHAR NOT NULL DEFAULT 'F'\\012-- * add unique constraint PRTY_BK_UK_LBL for column LABEL\\012--\\012-- tables EXPERIMENT_TYPE_PROPERTY_TYPES, MATERIAL_TYPE_PROPERTY_TYPES, SAMPLE_TYPE_PROPERTY_TYPES\\012-- * make the assignments of property types DESCRIPTION, NUCLEOTIDE_SEQUENCE, OFFSET and GENE_SYMBOL \\012--   to material types internally managed \\012--\\012-- table PROCEDURE_TYPES (changed)\\012-- * add column IS_DATA_ACQUISITION BOOLEAN_CHAR NOT NULL DEFAULT 'F'.\\012--\\012-- all tables\\012-- * convert all codes to upper case\\012------------------------------------------------------------------------------------\\012\\012---------------------------------------------------------------------------------------------------\\012--  Purpose:  Rename table ORGANIZATIONS to GROUPS.\\012---------------------------------------------------------------------------------------------------\\012\\012ALTER TABLE PROJECTS DROP CONSTRAINT PROJ_ORGA_FK;\\012ALTER TABLE ORGANIZATIONS DROP CONSTRAINT ORGA_BK_UK;\\012ALTER TABLE ORGANIZATIONS DROP CONSTRAINT ORGA_PK;\\012ALTER TABLE ORGANIZATIONS RENAME TO GROUPS;\\012ALTER INDEX PROJ_ORGA_FK_I RENAME TO PROJ_GROU_FK_I;\\012select RENAME_SEQUENCE('ORGANIZATION_ID_SEQ', 'GROUP_ID_SEQ');\\012ALTER TABLE PROJECTS RENAME COLUMN ORGA_ID TO GROU_ID;\\012ALTER TABLE GROUPS ADD CONSTRAINT GROU_PK PRIMARY KEY(ID);\\012ALTER TABLE GROUPS ADD CONSTRAINT GROU_BK_UK UNIQUE(CODE);\\012ALTER TABLE PROJECTS ADD CONSTRAINT PROJ_GROU_FK FOREIGN KEY (GROU_ID) REFERENCES GROUPS(ID);\\012\\012\\012---------------------------------------------------------------------------------------------------\\012--  Purpose:  Add columnd IS_PLACEHOLDER of table DATA.\\012---------------------------------------------------------------------------------------------------\\012\\012ALTER TABLE DATA ADD COLUMN IS_PLACEHOLDER BOOLEAN_CHAR NOT NULL;\\012\\012\\012---------------------------------------------------------------------------------------------------\\012--  Purpose:  Add and populate column CODE of table DATA.\\012---------------------------------------------------------------------------------------------------\\012\\012ALTER TABLE DATA ADD COLUMN CODE CODE;\\012\\012CREATE OR REPLACE FUNCTION populate_data_codes() RETURNS integer AS $$\\012DECLARE\\012    rec RECORD;\\012BEGIN\\012    FOR rec IN SELECT * FROM data LOOP\\012        rec.code := to_char(rec.registration_timestamp, 'YYYYMMDDHH24MISSMS') || '-' || to_char(rec.id, 'FM99999999999999999999');\\012        update data set code=rec.code where id=rec.id;\\012    END LOOP;\\012    RETURN 1;\\012END;\\012$$ LANGUAGE 'plpgsql';\\012\\012SELECT populate_data_codes();\\012DROP FUNCTION populate_data_codes();\\012\\012ALTER TABLE DATA ALTER COLUMN CODE SET NOT NULL;\\012ALTER TABLE DATA ADD CONSTRAINT DATA_BK_UK UNIQUE(CODE);\\012\\012---------------------------------------------------------------------------------------------------\\012--  Purpose:  Add and populate columns CVTE_ID_STOR_FMT.\\012---------------------------------------------------------------------------------------------------\\012\\012ALTER TABLE EXTERNAL_DATA ADD COLUMN CVTE_ID_STOR_FMT TECH_ID;\\012ALTER TABLE EXTERNAL_DATA ADD CONSTRAINT EXDA_STOR_FMT_FK FOREIGN KEY (CVTE_ID_STOR_FMT) REFERENCES CONTROLLED_VOCABULARY_TERMS(ID);\\012\\012------------------------------------------------------------------------------------\\012--  Purpose:  Create trigger EXTERNAL_DATA_STORAGE_FORMAT_CHECK \\012------------------------------------------------------------------------------------\\012\\012CREATE OR REPLACE FUNCTION EXTERNAL_DATA_STORAGE_FORMAT_CHECK() RETURNS trigger AS $$\\012DECLARE\\012   v_covo_code  CODE;\\012BEGIN\\012\\012   select code into v_covo_code from controlled_vocabularies\\012      where id = (select covo_id from controlled_vocabulary_terms where id = NEW.cvte_id_stor_fmt);\\012\\012   -- Check if the data storage format is a term of the controlled vocabulary "STORAGE_FORMAT"\\012   if v_covo_code != '.STORAGE_FORMAT' then\\012      RAISE EXCEPTION 'Insert/Update of Data (Code: %) failed, as its Storage Format is %, but is required to be STORAGE_FORMAT.', NEW.code, v_covo_code;\\012   end if;\\012\\012   RETURN NEW;\\012\\012END;\\012$$ LANGUAGE 'plpgsql';\\012\\012CREATE TRIGGER EXTERNAL_DATA_STORAGE_FORMAT_CHECK BEFORE INSERT OR UPDATE ON EXTERNAL_DATA\\012    FOR EACH ROW EXECUTE PROCEDURE EXTERNAL_DATA_STORAGE_FORMAT_CHECK();\\012\\012-----------------------------------------------------------------------------------\\012--  Purpose:  Create Controlled Vocabulary .STORAGE_FORMAT\\012-----------------------------------------------------------------------------------\\012insert into controlled_vocabularies \\012       ( id\\012       , code\\012       , description\\012       , pers_id_registerer\\012       , is_managed_internally )\\012values  (nextval('CONTROLLED_VOCABULARY_ID_SEQ')\\012       , '.STORAGE_FORMAT'\\012       , 'The on-disk storage format of a data set'\\012       , (select id from persons where user_id ='system')\\012       , true);\\012\\012\\012-----------------------------------------------------------------------------------\\012--  Purpose:  Create Controlled Vocabulary Terms for STORAGE_FORMAT\\012-----------------------------------------------------------------------------------\\012insert into controlled_vocabulary_terms \\012       ( id\\012       , code\\012       , covo_id \\012       , pers_id_registerer )\\012values  (nextval('CVTE_ID_SEQ')\\012       , 'PROPRIETARY'\\012       , (select id from controlled_vocabularies where code = '.STORAGE_FORMAT')\\012       , (select id from persons where user_id ='system'));\\012\\012insert into controlled_vocabulary_terms \\012       ( id\\012       , code\\012       , covo_id \\012       , pers_id_registerer )\\012values  (nextval('CVTE_ID_SEQ')\\012       , 'BDS_DIRECTORY'\\012       , (select id from controlled_vocabularies where code = '.STORAGE_FORMAT')\\012       , (select id from persons where user_id ='system'));\\012\\012\\012--------------------------------------------------------------------------\\012--  Purpose:  Insert an entry for OBSERVABLE_TYPE UNKNOWN\\012--------------------------------------------------------------------------\\012\\012insert into observable_types\\012(id\\012,code\\012,description)\\012values \\012(nextval('OBSERVABLE_TYPE_ID_SEQ')\\012,'UNKNOWN'\\012,'Unknown'\\012);\\012\\012----------------------------------------------------------------------\\012--  Purpose:  Insert an entry for PROCEDURE_TYPE UNKNOWN\\012-----------------------------------------------------------------------\\012\\012insert into procedure_types\\012(id\\012,code\\012,description)\\012values \\012(nextval('PROCEDURE_TYPE_ID_SEQ')\\012,'UNKNOWN'\\012,'Unknown'\\012);\\012\\012\\012---------------------------------------------------------------------------------------------------\\012--  Purpose:  Populate external_data.cvte_id_stor_fmt with a default value.\\012---------------------------------------------------------------------------------------------------\\012\\012CREATE OR REPLACE FUNCTION polulate_external_data_cvte_id_stor_fmt() RETURNS integer AS $$\\012DECLARE\\012    rec RECORD;\\012    dfl_stor_fmt_code VARCHAR := 'PROPRIETARY';\\012    dfl_stor_fmt_id TECH_ID;\\012BEGIN\\012    select cvte.id into dfl_stor_fmt_id from controlled_vocabulary_terms cvte, controlled_vocabularies cv \\012        where cvte.code = dfl_stor_fmt_code and cvte.covo_id = cv.id and cv.code = '.STORAGE_FORMAT'; \\012    update external_data set cvte_id_stor_fmt = dfl_stor_fmt_id;\\012    RETURN 1;\\012END;\\012$$ LANGUAGE 'plpgsql';\\012\\012SELECT polulate_external_data_cvte_id_stor_fmt();\\012DROP FUNCTION polulate_external_data_cvte_id_stor_fmt();\\012\\012-- Now that the field is populated, create the not null constraint for it.\\012\\012ALTER TABLE EXTERNAL_DATA ALTER COLUMN CVTE_ID_STOR_FMT SET NOT NULL;\\012\\012---------------------------------------------------------------------------------------------------\\012--  Purpose:  Add and populate columns DATA_PRODUCER_CODE and PRODUCTION_TIMESTAMP to table DATA.\\012---------------------------------------------------------------------------------------------------\\012\\012ALTER TABLE DATA ADD COLUMN DATA_PRODUCER_CODE CODE;\\012ALTER TABLE DATA ADD COLUMN PRODUCTION_TIMESTAMP TIME_STAMP;\\012\\012CREATE OR REPLACE FUNCTION populate_data_producer_code_and_production_timestamp() RETURNS integer AS $$\\012DECLARE\\012    rec RECORD;\\012    loty_rel_code VARCHAR := 'RELATIVE_LOCATION';\\012    loty_rel_id TECH_ID;\\012    meas_ts TIMESTAMP;\\012    ds_code CODE;\\012    meas_ts_str TEXT;\\012BEGIN\\012    select id into loty_rel_id from locator_types where code = loty_rel_code; \\012    FOR rec IN SELECT d.id, ed.location FROM data d, external_data ed where d.id = ed.data_id and ed.loty_id = loty_rel_id LOOP\\012        meas_ts_str = substring(rec.location from '^.*/([0-9]{14})_[^_]+_(.*)$');\\012        ds_code := substring(rec.location from '^.*/[0-9]{14}_([^_]+)_(.*)$');\\012        IF meas_ts_str is not null and ds_code is not null THEN\\012            meas_ts := to_timestamp(meas_ts_str, 'YYYYMMDDHH24MISS');\\012            update data set production_timestamp=meas_ts, data_producer_code=ds_code where id=rec.id;\\012        END IF;\\012    END LOOP;\\012    RETURN 1;\\012END;\\012$$ LANGUAGE 'plpgsql';\\012\\012SELECT populate_data_producer_code_and_production_timestamp();\\012DROP FUNCTION populate_data_producer_code_and_production_timestamp();\\012\\012-- Rename columns\\012\\012ALTER TABLE DATA RENAME COLUMN PROC_ID_ACQUIRED_BY to PROC_ID_PRODUCED_BY;\\012\\012---------------------------------------------------------------------------------------------------\\012--  Purpose:  Populate table DATA_SET_RELATIONSHIPS, by using heuristics.\\012---------------------------------------------------------------------------------------------------\\012\\012CREATE OR REPLACE FUNCTION abs_interval(ts1 time_stamp_dfl, ts2 time_stamp_dfl) returns interval AS $$\\012BEGIN\\012    IF ts1 < ts2 THEN\\012        RETURN ts2 - ts1;\\012    ELSE\\012        RETURN ts1 - ts2;\\012    END IF;\\012END;\\012$$ LANGUAGE 'plpgsql';\\012\\012CREATE OR REPLACE FUNCTION populate_data_set_relationships() RETURNS INTEGER AS $$\\012DECLARE\\012    source_id TECH_ID;\\012    rec_derived RECORD;\\012    rec_acquired RECORD;\\012    rel_location TEXT;\\012    data_set_code TEXT;\\012    data_set_code_trial TEXT;\\012    loty_rel_code TEXT := 'RELATIVE_LOCATION';\\012    loty_rel_id TECH_ID;\\012    count INTEGER := 0;\\012BEGIN\\012    select id into loty_rel_id from locator_types where code = loty_rel_code;\\012    FOR rec_derived IN select id, samp_id_derived_from, registration_timestamp from data where samp_id_derived_from is not null LOOP\\012        source_id := NULL;\\012        select location into rel_location from external_data where data_id = rec_derived.id and loty_id = loty_rel_id;\\012        IF rel_location is not null then\\012            data_set_code := substring(rel_location from '^.*/([0-9]{14}_[^_]+)_.*$');\\012            IF data_set_code is not null THEN\\012                FOR rec_acquired IN select id, samp_id_acquired_from from data where samp_id_acquired_from = rec_derived.samp_id_derived_from LOOP\\012                    select location into rel_location from external_data where data_id = rec_acquired.id and loty_id = loty_rel_id;\\012                    IF rel_location is not null THEN\\012                        data_set_code_trial := substring(rel_location from '^.*/([0-9]{14}_[^_]+)_.*$');\\012                        IF data_set_code_trial = data_set_code THEN\\012                            source_id = rec_acquired.id;\\012                            EXIT;\\012                        END IF;\\012                    END IF;\\012                END LOOP;\\012            END IF;\\012        END IF;\\012        -- If the location didn't tell us about data set relationships, try the backup strategy.\\012        IF source_id is null THEN\\012            -- Use the measured data set as source that is closest in registration timestamp.\\012            select id into source_id from data where samp_id_acquired_from = rec_derived.samp_id_derived_from \\012                and abs_interval(registration_timestamp, rec_derived.registration_timestamp) \\012                    = (select min(abs_interval(registration_timestamp, rec_derived.registration_timestamp)) \\012                        from data where samp_id_acquired_from = rec_derived.samp_id_derived_from);\\012        END IF;\\012        IF source_id is not null THEN\\012            insert into data_set_relationships (id, data_id_parent, data_id_child)\\012                values (nextval('DATA_SET_RELATIONSHIP_ID_SEQ'), source_id, rec_derived.id);\\012            count := count + 1;\\012        END IF;\\012    END LOOP;\\012    RETURN count;\\012END;\\012$$ LANGUAGE 'plpgsql';\\012\\012SELECT populate_data_set_relationships();\\012DROP FUNCTION populate_data_set_relationships();\\012DROP FUNCTION abs_interval(time_stamp_dfl, time_stamp_dfl);\\012\\012---------------------------------------------------------------------------------------------------\\012--  Purpose:  Add column IS_MANAGED_INTERNALLY to table PROPERTY_TYPES. Internally managed \\012--  properties can not be assigned by users of openBIS, but only by the system. \\012---------------------------------------------------------------------------------------------------\\012\\012ALTER TABLE PROPERTY_TYPES ADD COLUMN IS_MANAGED_INTERNALLY BOOLEAN_CHAR NOT NULL DEFAULT 'F';\\012\\012-- Update already existing property type PLATE_GEOMETRY\\012update property_types set is_managed_internally = true, code = '.' || code where code = 'PLATE_GEOMETRY';\\012\\012-- Update already existing controlled vocabulary PLATE_GEOMETRY \\012update controlled_vocabularies set code = '.' || code where code = 'PLATE_GEOMETRY';\\012\\012---------------------------------------------------------------------------------------------------\\012--  Purpose:  Add unique constraint on column LABEL. \\012---------------------------------------------------------------------------------------------------\\012\\012CREATE OR REPLACE FUNCTION make_prty_labels_unique() RETURNS INTEGER AS $$\\012DECLARE\\012    prev_key TEXT := NULL;\\012    this_key TEXT;\\012    dup_count INTEGER;\\012    cnt INTEGER := 0;\\012    already_exists INTEGER;\\012    new_label TEXT;\\012    this_id TECH_ID;\\012BEGIN\\012    FOR this_id, this_key IN select id, label from property_types order by label,id LOOP\\012        IF this_key = prev_key THEN\\012            dup_count := dup_count + 1;\\012            cnt := cnt + 1;\\012        ELSE\\012            dup_count := 0;\\012        END IF;\\012        IF dup_count > 0 THEN\\012            -- Check whether the new key already exists.\\012            LOOP\\012                new_label := this_key || '(' || dup_count::text || ')';\\012                select count(*) into already_exists from property_types where label = new_label;\\012                IF already_exists = 0 THEN\\012                    EXIT;\\012                END IF;\\012                dup_count := dup_count + 1;\\012            END LOOP;\\012            update property_types set label = new_label where id = this_id;\\012        END IF;\\012        prev_key := this_key;\\012    END LOOP;\\012    RETURN cnt;\\012END;\\012$$ LANGUAGE 'plpgsql';\\012\\012SELECT make_prty_labels_unique();\\012DROP FUNCTION make_prty_labels_unique();\\012\\012ALTER TABLE PROPERTY_TYPES ADD CONSTRAINT PRTY_BK_UK_LBL UNIQUE(LABEL);\\012\\012-----------------------------------------------------------------------------------\\012--  Purpose:  Add Controlled Vocabulary Terms to PLATE_GEOMETRY\\012-----------------------------------------------------------------------------------\\012\\012insert into controlled_vocabulary_terms \\012       ( id\\012       , code\\012       , covo_id \\012       , pers_id_registerer)\\012values  (nextval('CVTE_ID_SEQ')\\012       , '96_WELLS_8X12'\\012       , (select id from controlled_vocabularies where code = '.PLATE_GEOMETRY')\\012       , (select id from persons where user_id = 'system'));\\012\\012insert into controlled_vocabulary_terms \\012       ( id\\012       , code\\012       , covo_id \\012       , pers_id_registerer)\\012values  (nextval('CVTE_ID_SEQ')\\012       , '1536_WELLS_32X48'\\012       , (select id from controlled_vocabularies where code = '.PLATE_GEOMETRY')\\012       , (select id from persons where user_id = 'system'));\\012\\012\\012-----------------------------------------------------------------------------------\\012--  Purpose:  Rename Observable Types: IMAGE -> HCS_IMAGE, IMAGE_ANALYSIS_DATA -> HCS_IMAGE_ANALYSIS_DATA\\012--  and descriptions accordingly\\012-----------------------------------------------------------------------------------\\012\\012update observable_types set code = 'HCS_IMAGE', description = 'Data derived from analysis of HCS images' where code = 'IMAGE';\\012update observable_types set code = 'HCS_IMAGE_ANALYSIS_DATA', description = 'Data derived from analysis of HCS images' where code = 'IMAGE_ANALYSIS_DATA';\\012\\012\\012-----------------------------------------------------------------------------------\\012--  Purpose: Make the assignments of property types DESCRIPTION, NUCLEOTIDE_SEQUENCE, OFFSET \\012--  and GENE_SYMBOL to material types internally managed. \\012-----------------------------------------------------------------------------------\\012\\012update material_type_property_types set is_managed_internally = true\\012    where prty_id in (select id from property_types where code = 'DESCRIPTION' \\012        or code = 'NUCLEOTIDE_SEQUENCE' or code = 'OFFSET' or code = 'GENE_SYMBOL');\\012\\012-----------------------------------------------------------------------------------\\012--  Purpose: Add column IS_DATA_ACQUISITION BOOLEAN_CHAR NOT NULL DEFAULT 'F' to table PROCEDURE_TYPES.\\012-----------------------------------------------------------------------------------\\012\\012ALTER TABLE PROCEDURE_TYPES ADD COLUMN IS_DATA_ACQUISITION BOOLEAN_CHAR NOT NULL DEFAULT 'F';\\012\\012-- Set the new attribute for procedure type DATA_ACQUISITION\\012update procedure_types set is_data_acquisition = true where code = 'DATA_ACQUISITION';\\012\\012-----------------------------------------------------------------------------------\\012--  Purpose: Convert all codes to upper case. \\012-----------------------------------------------------------------------------------\\012\\012CREATE OR REPLACE FUNCTION column_to_uppercase_fix_duplicates(tbl TEXT, clm TEXT) RETURNS INTEGER AS $$\\012DECLARE\\012    prev_key TEXT := NULL;\\012    this_key TEXT;\\012    dup_count INTEGER;\\012    count INTEGER := 0;\\012    already_exists INTEGER;\\012    new_clm TEXT;\\012BEGIN\\012    FOR this_key IN EXECUTE 'select ' || clm || ' from ' || tbl \\012        || ' order by upper(' || clm || '),id' LOOP\\012        IF upper(this_key) = upper(prev_key) THEN\\012            dup_count := dup_count + 1;\\012            count := count + 1;\\012        ELSE\\012            dup_count := 0;\\012        END IF;\\012        IF dup_count > 0 THEN\\012            -- Check whether the new key already exists.\\012            LOOP\\012                new_clm := this_key || '(' || dup_count::text || ')';\\012                EXECUTE 'select count(*) from ' || tbl \\012                    || ' where upper(' || clm || ') = ' || quote_literal(upper(new_clm)) \\012                    into already_exists;\\012                IF already_exists = 0 THEN\\012                    EXIT;\\012                END IF;\\012                dup_count := dup_count + 1;\\012            END LOOP;\\012            EXECUTE 'update ' || tbl || ' set ' || clm || ' = ' || quote_literal(new_clm) || \\012                ' where ' || clm || ' = ' || quote_literal(this_key);\\012        END IF;\\012        prev_key := this_key;\\012    END LOOP;\\012    EXECUTE 'update ' || tbl || ' set ' || clm || ' = upper(' || clm || ')';\\012    RETURN count;\\012END;\\012$$ LANGUAGE 'plpgsql';\\012\\012\\012CREATE OR REPLACE FUNCTION column_to_uppercase_fix_duplicates(tbl TEXT, clm TEXT, clm2 TEXT) RETURNS INTEGER AS $$\\012DECLARE\\012    prev_key TEXT := NULL;\\012    prev_key2 TECH_ID;\\012    this_key TEXT;\\012    this_key2 TECH_ID;\\012    dup_count INTEGER;\\012    count INTEGER := 0;\\012    already_exists INTEGER;\\012    new_clm TEXT;\\012BEGIN\\012    FOR this_key, this_key2 IN EXECUTE 'select ' || clm || ',' || clm2 || ' from ' || tbl \\012        || ' order by ' || clm2 || ',upper(' ||  clm || '),id' LOOP\\012        IF upper(this_key) = upper(prev_key) and this_key2 = prev_key2 THEN\\012            dup_count := dup_count + 1;\\012            count := count + 1;\\012        ELSE\\012            dup_count := 0;\\012        END IF;\\012        IF dup_count > 0 THEN\\012            -- Check whether the new key already exists.\\012            LOOP\\012                new_clm := this_key || '(' || dup_count::text || ')';\\012                EXECUTE 'select count(*) from ' || tbl \\012                    || ' where upper(' || clm || ') = ' || quote_literal(upper(new_clm)) \\012                    || ' and ' || clm2 || ' = ' || quote_literal(this_key2) \\012                    into already_exists;\\012                IF already_exists = 0 THEN\\012                    EXIT;\\012                END IF;\\012                dup_count := dup_count + 1;\\012            END LOOP;\\012            EXECUTE 'update ' || tbl || ' set ' || clm || ' = ' || quote_literal(new_clm) || \\012                ' where ' || clm || ' = ' || quote_literal(this_key) || ' and ' \\012                || clm2 || ' = ' || quote_literal(this_key2);\\012        END IF;\\012        prev_key := this_key;\\012        prev_key2 := this_key2;\\012    END LOOP;\\012    EXECUTE 'update ' || tbl || ' set ' || clm || ' = upper(' || clm || ')';\\012    RETURN count;\\012END;\\012$$ LANGUAGE 'plpgsql';\\012\\012\\012SELECT column_to_uppercase_fix_duplicates('samples', 'code');\\012SELECT column_to_uppercase_fix_duplicates('property_types', 'code');\\012SELECT column_to_uppercase_fix_duplicates('controlled_vocabularies', 'code');\\012\\012SELECT column_to_uppercase_fix_duplicates('projects', 'code', 'grou_id');\\012SELECT column_to_uppercase_fix_duplicates('experiments', 'code', 'proj_id');\\012SELECT column_to_uppercase_fix_duplicates('controlled_vocabulary_terms', 'code', 'covo_id');\\012SELECT column_to_uppercase_fix_duplicates('materials', 'code', 'maty_id');\\012SELECT column_to_uppercase_fix_duplicates('material_batches', 'code', 'mate_id');\\012SELECT column_to_uppercase_fix_duplicates('sample_components', 'code', 'samp_id');\\012\\012-- These will only need changes if someone entered them through the 'back door' directly on the server.\\012\\012SELECT column_to_uppercase_fix_duplicates('groups', 'code');\\012SELECT column_to_uppercase_fix_duplicates('sample_types', 'code');\\012SELECT column_to_uppercase_fix_duplicates('material_types', 'code');\\012SELECT column_to_uppercase_fix_duplicates('experiment_types', 'code');\\012SELECT column_to_uppercase_fix_duplicates('procedure_types', 'code');\\012SELECT column_to_uppercase_fix_duplicates('observable_types', 'code');\\012SELECT column_to_uppercase_fix_duplicates('locator_types', 'code');\\012SELECT column_to_uppercase_fix_duplicates('file_format_types', 'code');\\012SELECT column_to_uppercase_fix_duplicates('data_types', 'code');\\012\\012DROP FUNCTION column_to_uppercase_fix_duplicates(TEXT, TEXT);\\012DROP FUNCTION column_to_uppercase_fix_duplicates(TEXT, TEXT, TEXT);\\012\\012-----------------------------------------------------------------------------------\\012--  Purpose:  Delete sample_components with no associated material_batches.\\012--  This deletes superfluous controls of master plates\\012-----------------------------------------------------------------------------------\\012\\012delete from sample_components\\012where  id in (select sc.id \\012              from   sample_components as sc left join sample_component_materials as scm \\012              on     scm.saco_id = sc.id \\012              where  scm.saco_id is null\\012              )\\012;\\012	\N
+./sourceTest/sql/postgresql/026/009=database_version_logs.tsv:017	source/sql/postgresql/migration/migration-016-017.sql	SUCCESS	2008-05-09 10:12:57.473	----------------------------------------------------------------------------------------------\\012--  File: migration-016-017.sql\\012--\\012-- \\012--  This script enables the migration of the database schema from 016 to 017.\\012-- \\012--  Update History\\012--\\012--\\012--\\011Who\\011\\011\\011              When\\011\\011    What\\012--\\011---\\011\\011\\011              ----      \\011----\\012--\\011Charles Ramin-Wright\\0112008-04-11\\011Initial Version \\012--  \\012----------------------------------------------------------------------------------------------\\012\\012\\012--=================================\\012-- Create Objects\\012--=================================\\012\\012-- Domains\\012\\012-- 'F' is false, 'T' is true and 'U' is unknown\\012CREATE DOMAIN BOOLEAN_CHAR_OR_UNKNOWN AS CHAR(1) CHECK (VALUE in ('F', 'T', 'U'));\\012\\012-- Tables and related objects\\012\\012-- Sequences\\012\\012-- Indices\\012\\012--====================================\\012-- Delete Objects\\012--====================================\\012\\012-- Domains\\012\\012-- Tables\\012\\012-- Sequences\\012\\012-- Indices\\012\\012--====================================\\012-- Alter Objects\\012--====================================\\012\\012-- Add column IS_INTERNAL_NAMESPACE to table CONTROLLED_VOCABULARIES \\012\\012ALTER TABLE CONTROLLED_VOCABULARIES ADD IS_INTERNAL_NAMESPACE BOOLEAN_CHAR NOT NULL DEFAULT 'F';\\012\\012-- Add column IS_INTERNAL_NAMESPACE to table PROPERTY_TYPES \\012\\012ALTER TABLE PROPERTY_TYPES ADD IS_INTERNAL_NAMESPACE BOOLEAN_CHAR NOT NULL DEFAULT 'F';\\012\\012-- Add column IS_INTERNAL_NAMESPACE as key component to the unique key constraint COVO_BK_UK\\012\\012ALTER TABLE CONTROLLED_VOCABULARIES DROP CONSTRAINT COVO_BK_UK;\\012ALTER TABLE CONTROLLED_VOCABULARIES ADD CONSTRAINT COVO_BK_UK UNIQUE(CODE,IS_INTERNAL_NAMESPACE);\\012\\012-- Add column IS_INTERNAL_NAMESPACE as key component to the unique key constraint PRTY_BK_UK\\012\\012ALTER TABLE PROPERTY_TYPES DROP CONSTRAINT PRTY_BK_UK;\\012ALTER TABLE PROPERTY_TYPES ADD CONSTRAINT PRTY_BK_UK UNIQUE(CODE,IS_INTERNAL_NAMESPACE);\\012\\012-- Delete unique key constraint PRTY_BK_UK_LBL (which was for column LABEL) from table PROPERTY_TYPES\\012\\012ALTER TABLE PROPERTY_TYPES DROP CONSTRAINT PRTY_BK_UK_LBL;\\012\\012\\012-- Change unique constraint EXDA_BK_UK to contain EXTERNAL_DATA.LOTY_ID \\012\\012ALTER TABLE EXTERNAL_DATA DROP CONSTRAINT EXDA_BK_UK;\\012ALTER TABLE EXTERNAL_DATA ADD CONSTRAINT EXDA_BK_UK UNIQUE(LOCATION,LOTY_ID);\\012\\012\\012-- Increase length of EXTERNAL_DATA.LOCATION from 200 to 1024\\012\\012ALTER TABLE EXTERNAL_DATA ALTER COLUMN LOCATION TYPE VARCHAR(1024);\\012\\012\\012-- Add column IS_COMPLETE to table EXTERNAL_DATA\\012\\012ALTER TABLE EXTERNAL_DATA ADD COLUMN IS_COMPLETE BOOLEAN_CHAR_OR_UNKNOWN NOT NULL DEFAULT 'U';\\012\\012\\012--=================================\\012-- Replace EXTERNAL_DATA_STORAGE_FORMAT_CHECK() function\\012--=================================\\012\\012CREATE OR REPLACE FUNCTION EXTERNAL_DATA_STORAGE_FORMAT_CHECK() RETURNS trigger AS $$\\012DECLARE\\012   v_covo_code  CODE;\\012   data_code CODE;\\012BEGIN\\012\\012   select code into v_covo_code from controlled_vocabularies\\012      where is_internal_namespace = true and \\012         id = (select covo_id from controlled_vocabulary_terms where id = NEW.cvte_id_stor_fmt);\\012\\012-- Check if the data storage format is a term of the controlled vocabulary "STORAGE_FORMAT"\\012   if v_covo_code != 'STORAGE_FORMAT' then\\012      select code into data_code from data where id = NEW.data_id; \\012      RAISE EXCEPTION 'Insert/Update of Data (Code: %) failed, as its Storage Format is %, but is required to be STORAGE_FORMAT.', data_code, v_covo_code;\\012   end if;\\012\\012   RETURN NEW;\\012\\012END;\\012$$ LANGUAGE 'plpgsql';\\012\\012\\012--=================================\\012-- Data Migration\\012--=================================\\012\\012\\012---------------------------------------------------------------------------------------\\012--   Translate the internally managed CODES which are represented by the Dot-Prefix to:\\012--\\012--   CODE without a Dot-Prefix plus the new column IS_INTERNAL_NAMESPACE = true.\\012---------------------------------------------------------------------------------------\\012\\012UPDATE property_types\\012SET    code = substr(code,2,length(code))\\012     , is_internal_namespace = true \\012WHERE  substr(code,1,1) = '.';\\012\\012UPDATE controlled_vocabularies\\012SET    code = substr(code,2,length(code))\\012     , is_internal_namespace = true \\012WHERE  substr(code,1,1) = '.';\\012\\012------------------------------------------------------------------------------------\\012--  Purpose: Move experiment descriptions from column to property DESCRIPTION\\012------------------------------------------------------------------------------------\\012\\012   -----------------------\\012   --  Material Type SIRNHACS\\012   -----------------------\\012\\012insert into experiment_type_property_types\\012(   id\\012   ,exty_id\\012   ,prty_id\\012   ,is_mandatory\\012   ,is_managed_internally\\012   ,pers_id_registerer\\012   )\\012values \\012(   nextval('ETPT_ID_SEQ')\\012   ,(select id from experiment_types where code = 'SIRNAHCS')\\012   ,(select id from property_types where code = 'DESCRIPTION')\\012   ,true\\012   ,true\\012   ,(select id from persons where user_id ='system')\\012);\\012\\012-- Add experiment_properties for descriptions of all experiments of type SIRNAHCS \\012\\012insert into experiment_properties\\012(   id\\012   ,expe_id\\012   ,value\\012   ,etpt_id\\012   ,pers_id_registerer\\012)\\012select\\012    nextval('EXPERIMENT_PROPERTY_ID_SEQ')\\012   ,id\\012   ,case when description is not null then description else 'No description given' end\\012   ,currval('ETPT_ID_SEQ')\\012   ,(select id from persons where user_id ='system')  \\012from experiments where exty_id = (select id from experiment_types where code = 'SIRNAHCS');\\012\\012-- Finally: drop column\\012\\012ALTER TABLE EXPERIMENTS DROP COLUMN DESCRIPTION;\\012	\N
+./sourceTest/sql/postgresql/026/009=database_version_logs.tsv:023	../openbis/source/sql/postgresql/migration/migration-022-023.sql	SUCCESS	2008-09-15 14:46:19.697	-- JAVA ch.systemsx.cisd.lims.server.dataaccess.migration.MigrationStepFrom022To023\\012\\012-- Add column GLOBAL_CODE to the DATABASE_INSTANCES table.\\012-- Set it's value from the code, it will be updated later from java.\\012\\012ALTER TABLE DATABASE_INSTANCES ADD COLUMN GLOBAL_CODE CODE;\\012update DATABASE_INSTANCES set GLOBAL_CODE = CODE;\\012ALTER TABLE DATABASE_INSTANCES ADD CONSTRAINT DBIN_GLOBAL_CODE_UK UNIQUE(GLOBAL_CODE);\\012ALTER TABLE DATABASE_INSTANCES alter column GLOBAL_CODE set NOT NULL;\\012\\012-- Add column the new FK column SAMP_ID_PART_OF of the SAMPLES table\\012\\012ALTER TABLE SAMPLES ADD COLUMN SAMP_ID_PART_OF TECH_ID;\\012\\012-- Drop constraint SAMP_BK_DBIN_UK of SAMPLES table\\012\\012ALTER TABLE SAMPLES DROP CONSTRAINT SAMP_BK_DBIN_UK;\\012\\012-- Drop constraint SAMP_BK_GROU_UK of SAMPLES table\\012\\012ALTER TABLE SAMPLES DROP CONSTRAINT SAMP_BK_GROU_UK;\\012\\012-- Add FK PART_OF to the SAMPLES table\\012\\012ALTER TABLE SAMPLES ADD CONSTRAINT SAMP_SAMP_FK_PART_OF FOREIGN KEY (SAMP_ID_PART_OF) REFERENCES SAMPLES(ID);\\012\\012-- Add Index for the FK Part Of of the SAMPLES table\\012CREATE INDEX SAMP_SAMP_FK_I_PART_OF ON SAMPLES (SAMP_ID_PART_OF);\\012\\012-- Create the SAMPLE_MATERIAL_BATCHES table\\012\\012CREATE TABLE SAMPLE_MATERIAL_BATCHES (ID TECH_ID NOT NULL,SAMP_ID TECH_ID NOT NULL,MABA_ID TECH_ID NOT NULL);\\012\\012-- Create the sequence for the SAMPLE_MATERIAL_BATCHES table\\012\\012CREATE SEQUENCE SAMPLE_MATERIAL_BATCH_ID_SEQ;\\012\\012\\012--  Create WELL as a new SAMPLE_TYPE\\012\\012insert into sample_types\\012(id\\012,code\\012,description\\012,dbin_id)\\012values \\012(nextval('SAMPLE_TYPE_ID_SEQ')\\012,'WELL'\\012,'Plate Well'\\012,(select id from database_instances where is_original_source = true)\\012);\\012\\012\\012-- Transfer data from the SAMPLE_COMPONENTS table to the SAMPLES table\\012\\012INSERT INTO samples(\\012              id\\012            , code\\012            , samp_id_top\\012            , samp_id_generated_from\\012            , saty_id\\012            , pers_id_registerer\\012            , inva_id\\012            , samp_id_control_layout\\012            , dbin_id\\012            , grou_id\\012            , samp_id_part_of)\\012SELECT        nextval('sample_id_seq')\\012            , saco.code\\012            , null\\012            , null\\012            , (select id from sample_types where code = 'WELL')\\012            , (select id from persons where user_id ='system')\\012            , samp.inva_id\\012            , null\\012            , samp.dbin_id\\012            , samp.grou_id\\012            , saco.samp_id\\012FROM samples samp INNER JOIN sample_components saco\\012     ON   samp.id = saco.samp_id;\\012\\012\\012-- Fill the SAMPLE_MATERIAL_BATCHES table via SAMPLE_C0MPONENT_MATERIALS, SAMPLE_C0MPONENTS, SAMPLES and MATERIAL_BATCHES tables\\012\\012INSERT INTO sample_material_batches(\\012              id\\012            , samp_id\\012            , maba_id)\\012SELECT        nextval('sample_material_batch_id_seq')\\012            , well.id\\012            , scma.maba_id\\012FROM sample_component_materials scma \\012   INNER JOIN material_batches maba\\012     ON scma.maba_id = maba.id\\012        INNER JOIN sample_components saco\\012           ON scma.saco_id = saco.id\\012              INNER JOIN samples well\\012                 ON saco.code = well.code and saco.samp_id = well.samp_id_part_of\\012;\\012\\012\\012-- Drop the retired Database Objects\\012\\012DROP TABLE SAMPLE_COMPONENT_MATERIALS;\\012DROP TABLE SAMPLE_COMPONENTS;\\012\\012DROP SEQUENCE SCMA_ID_SEQ;\\012DROP SEQUENCE SAMPLE_COMPONENT_ID_SEQ;\\012\\012------------------------------------------------------------------------------------\\012--  Purpose:  Create trigger SAMPLE_CODE_UNIQUENESS_CHECK \\012------------------------------------------------------------------------------------\\012\\012CREATE OR REPLACE FUNCTION SAMPLE_CODE_UNIQUENESS_CHECK() RETURNS trigger AS $$\\012DECLARE\\012   counter  INTEGER;\\012BEGIN\\012\\011IF (NEW.samp_id_part_of is NULL) THEN\\012\\011\\011IF (NEW.dbin_id is not NULL) THEN\\012\\011\\011\\011SELECT count(*) into counter FROM samples \\012\\011\\011\\011\\011where id != NEW.id and code = NEW.code and dbin_id = NEW.dbin_id;\\012\\011\\011\\011IF (counter > 0) THEN\\012\\011\\011\\011\\011RAISE EXCEPTION 'Insert/Update of Sample (Code: %) failed because database instance sample with the same code already exists.', NEW.code;\\012\\011\\011\\011END IF;\\012\\011\\011ELSIF (NEW.grou_id is not NULL) THEN\\012\\011\\011\\011SELECT count(*) into counter FROM samples \\012\\011\\011\\011\\011where id != NEW.id and code = NEW.code and grou_id = NEW.grou_id;\\012\\011\\011\\011IF (counter > 0) THEN\\012\\011\\011\\011\\011RAISE EXCEPTION 'Insert/Update of Sample (Code: %) failed because group sample with the same code already exists.', NEW.code;\\012\\011\\011\\011END IF;\\012\\011\\011END IF;\\012        ELSE\\012\\011\\011IF (NEW.dbin_id is not NULL) THEN\\012\\011\\011\\011SELECT count(*) into counter FROM samples \\012\\011\\011\\011\\011where id != NEW.id and code = NEW.code and samp_id_part_of = NEW.samp_id_part_of and dbin_id = NEW.dbin_id;\\012\\011\\011\\011IF (counter > 0) THEN\\012\\011\\011\\011\\011RAISE EXCEPTION 'Insert/Update of Sample (Code: %) failed because database instance sample with the same code and being the part of the same parent already exists.', NEW.code;\\012\\011\\011\\011END IF;\\012\\011\\011ELSIF (NEW.grou_id is not NULL) THEN\\012\\011\\011\\011SELECT count(*) into counter FROM samples \\012\\011\\011\\011\\011where id != NEW.id and code = NEW.code and samp_id_part_of = NEW.samp_id_part_of and grou_id = NEW.grou_id;\\012\\011\\011\\011IF (counter > 0) THEN\\012\\011\\011\\011\\011RAISE EXCEPTION 'Insert/Update of Sample (Code: %) failed because group sample with the same code and being the part of the same parent already exists.', NEW.code;\\012\\011\\011\\011END IF;\\012\\011\\011END IF;\\012        END IF;   \\012   RETURN NEW;\\012END;\\012$$ LANGUAGE 'plpgsql';\\012\\012CREATE TRIGGER SAMPLE_CODE_UNIQUENESS_CHECK BEFORE INSERT OR UPDATE ON SAMPLES\\012    FOR EACH ROW EXECUTE PROCEDURE SAMPLE_CODE_UNIQUENESS_CHECK();\\012	\N
+./sourceTest/sql/postgresql/026/009=database_version_logs.tsv:024	../openbis/source/sql/postgresql/migration/migration-023-024.sql	SUCCESS	2008-09-15 14:46:19.886	-- JAVA ch.systemsx.cisd.lims.server.dataaccess.migration.MigrationStepFrom023To024\\012\\012-- Drop constraint DBIN_GLOBAL_CODE_UK of DATABASE_INSTANCES table\\012\\012ALTER TABLE DATABASE_INSTANCES DROP CONSTRAINT DBIN_GLOBAL_CODE_UK;\\012\\012-- Name changes\\012\\012ALTER TABLE DATABASE_INSTANCES RENAME COLUMN GLOBAL_CODE TO UUID;\\012\\012-- Add constraint DBIN_UUID_UK to the DATABASE_INSTANCES table\\012\\012ALTER TABLE DATABASE_INSTANCES ADD CONSTRAINT DBIN_UUID_UK UNIQUE(UUID);\\012\\012-- Drop column in EXPERIMENTS\\012\\012ALTER TABLE EXPERIMENTS DROP COLUMN DESCRIPTION;\\012\\012-- Add index to SAMPLES table\\012\\012CREATE INDEX SAMP_CODE_I ON SAMPLES (CODE);\\012\\012-- Bug fix in trigger function SAMPLE_CODE_UNIQUENESS_CHECK()\\012\\012CREATE OR REPLACE FUNCTION SAMPLE_CODE_UNIQUENESS_CHECK() RETURNS trigger AS $$\\012DECLARE\\012   counter  INTEGER;\\012BEGIN\\012    IF (NEW.samp_id_part_of is NULL) THEN\\012        IF (NEW.dbin_id is not NULL) THEN\\012            SELECT count(*) into counter FROM samples \\012                where id != NEW.id and code = NEW.code and samp_id_part_of is NULL and dbin_id = NEW.dbin_id;\\012            IF (counter > 0) THEN\\012                RAISE EXCEPTION 'Insert/Update of Sample (Code: %) failed because database instance sample with the same code already exists.', NEW.code;\\012            END IF;\\012        ELSIF (NEW.grou_id is not NULL) THEN\\012            SELECT count(*) into counter FROM samples \\012                where id != NEW.id and code = NEW.code and samp_id_part_of is NULL and grou_id = NEW.grou_id;\\012            IF (counter > 0) THEN\\012                RAISE EXCEPTION 'Insert/Update of Sample (Code: %) failed because group sample with the same code already exists.', NEW.code;\\012            END IF;\\012        END IF;\\012        ELSE\\012        IF (NEW.dbin_id is not NULL) THEN\\012            SELECT count(*) into counter FROM samples \\012                where id != NEW.id and code = NEW.code and samp_id_part_of = NEW.samp_id_part_of and dbin_id = NEW.dbin_id;\\012            IF (counter > 0) THEN\\012                RAISE EXCEPTION 'Insert/Update of Sample (Code: %) failed because database instance sample with the same code and being the part of the same parent already exists.', NEW.code;\\012            END IF;\\012        ELSIF (NEW.grou_id is not NULL) THEN\\012            SELECT count(*) into counter FROM samples \\012                where id != NEW.id and code = NEW.code and samp_id_part_of = NEW.samp_id_part_of and grou_id = NEW.grou_id;\\012            IF (counter > 0) THEN\\012                RAISE EXCEPTION 'Insert/Update of Sample (Code: %) failed because group sample with the same code and being the part of the same parent already exists.', NEW.code;\\012            END IF;\\012        END IF;\\012        END IF;   \\012   RETURN NEW;\\012END;\\012$$ LANGUAGE 'plpgsql';\\012	\N
+./sourceTest/sql/postgresql/026/009=database_version_logs.tsv:025	../openbis/source/sql/postgresql/migration/migration-024-025.sql	SUCCESS	2008-09-15 14:46:20.011	-- move screenable plates to a group, because it's no longer possible\\012-- to have such plates on the instance level\\012\\012CREATE OR REPLACE FUNCTION move_exp_samples_to_group() RETURNS integer AS $$\\012DECLARE\\012    sample RECORD;\\012    groupId Integer;\\012BEGIN\\012  FOR sample IN \\012    (SELECT * FROM samples s inner join sample_types t on s.saty_id = t.id \\012\\011where t.code in ('CELL_PLATE', 'REINFECT_PLATE'))\\012  LOOP\\012\\011if (sample.dbin_id is not NULL) THEN\\012\\011\\011select proj.grou_id into groupId from\\012\\011\\011\\011samples sa\\012\\011\\011\\011left outer join sample_inputs si on sa.id = si.samp_id \\012\\011\\011\\011left outer join procedures proc on proc.id = si.proc_id  \\012\\011\\011\\011left outer join experiments ex on ex.id = proc.expe_id\\012\\011\\011\\011left outer join projects proj on proj.id = ex.proj_id\\012\\011\\011where sa.id = sample.id;\\012\\011\\011if (groupId is NULL) THEN\\012\\011\\011\\011select id into groupId from groups limit 1;\\012\\011\\011END IF;\\012\\011\\011if (groupId is NULL) THEN\\012\\011\\011\\011RAISE EXCEPTION 'There is no group in the database - internal error!';\\012\\011\\011END IF;\\012\\011\\011update samples set grou_id = groupId, dbin_id = NULL\\012\\011\\011  where id = sample.id;\\012\\011END IF;\\012  END LOOP;\\012  RETURN 1;\\012END;\\012$$ LANGUAGE 'plpgsql';\\012\\012select move_exp_samples_to_group();\\012\\012-- Create new table DATA_STORES.\\012\\012CREATE TABLE DATA_STORES (ID TECH_ID NOT NULL,DBIN_ID TECH_ID NOT NULL,CODE CODE NOT NULL,DOWNLOAD_URL VARCHAR(1024) NOT NULL,REGISTRATION_TIMESTAMP TIME_STAMP_DFL NOT NULL DEFAULT CURRENT_TIMESTAMP);\\012CREATE SEQUENCE DATA_STORE_ID_SEQ;\\012ALTER TABLE DATA_STORES ADD CONSTRAINT DAST_PK PRIMARY KEY(ID);\\012ALTER TABLE DATA_STORES ADD CONSTRAINT DAST_BK_UK UNIQUE(CODE,DBIN_ID);\\012ALTER TABLE DATA_STORES ADD CONSTRAINT DAST_DBIN_FK FOREIGN KEY (DBIN_ID) REFERENCES DATABASE_INSTANCES(ID);\\012CREATE INDEX DAST_DBIN_FK_I ON DATA_STORES (DBIN_ID);\\012\\012-- Add new column DAST_ID (connection to DATA_STORES table) to tables DATABASE_INSTANCES, GROUPS, PROJECTS, EXPERIMENTS.\\012\\012ALTER TABLE DATABASE_INSTANCES ADD COLUMN DAST_ID TECH_ID;\\012ALTER TABLE GROUPS ADD COLUMN DAST_ID TECH_ID;\\012ALTER TABLE PROJECTS ADD COLUMN DAST_ID TECH_ID;\\012ALTER TABLE EXPERIMENTS ADD COLUMN DAST_ID TECH_ID;\\012\\012-- Create the STANDARD data store and assign it to the home database instance.\\012 \\012insert into data_stores\\012(id\\012,code\\012,download_url\\012,dbin_id)\\012values \\012(nextval('DATA_STORE_ID_SEQ')\\012,'STANDARD'\\012,''\\012,(select id from database_instances where is_original_source = true)\\012);\\012\\012update database_instances set dast_id = (select id from data_stores where code = 'STANDARD') where is_original_source = true;\\012\\012-- Add foreign key constratints.\\012\\012ALTER TABLE DATABASE_INSTANCES ADD CONSTRAINT DBIN_DAST_FK FOREIGN KEY (DAST_ID) REFERENCES DATA_STORES(ID);\\012ALTER TABLE GROUPS ADD CONSTRAINT GROU_DAST_FK FOREIGN KEY (DAST_ID) REFERENCES DATA_STORES(ID);\\012ALTER TABLE PROJECTS ADD CONSTRAINT PROJ_DAST_FK FOREIGN KEY (DAST_ID) REFERENCES DATA_STORES(ID);\\012ALTER TABLE EXPERIMENTS ADD CONSTRAINT EXPE_DAST_FK FOREIGN KEY (DAST_ID) REFERENCES DATA_STORES(ID);\\012	\N
+./sourceTest/sql/postgresql/026/009=database_version_logs.tsv:026	../openbis/source/sql/postgresql/migration/migration-025-026.sql	SUCCESS	2008-09-15 14:46:20.192	-- JAVA ch.systemsx.cisd.lims.server.dataaccess.migration.MigrationStepFrom025To026\\012-- Remove ID column from SAMPLE_INPUTS table\\012DROP SEQUENCE SAMPLE_INPUT_ID_SEQ;\\012-- There was a bug in migration to db 23 - the constraint was not created. So we drop it only if it exists.\\012create function remove_sain_pk_constraint() returns void AS $$\\012begin\\012   perform *\\012     FROM information_schema.table_constraints WHERE constraint_name='sain_pk';\\012   if found\\012   then\\012\\011ALTER TABLE SAMPLE_INPUTS DROP CONSTRAINT SAIN_PK;\\012   end if;\\012end;\\012$$ language 'plpgsql';\\012select remove_sain_pk_constraint();\\012drop function remove_sain_pk_constraint();\\012ALTER TABLE SAMPLE_INPUTS DROP COLUMN ID;\\012ALTER TABLE SAMPLE_INPUTS ADD CONSTRAINT SAIN_PK PRIMARY KEY(SAMP_ID,PROC_ID);\\012\\012-- Remove ID column from SAMPLE_MATERIAL_BATCHES table\\012DROP SEQUENCE SAMPLE_MATERIAL_BATCH_ID_SEQ;\\012-- There was a bug in migration to db 23 - the constraint was not created. So we drop it only if it exists.\\012create function remove_samb_pk_constraint() returns void AS $$\\012begin\\012   perform *\\012     FROM information_schema.table_constraints WHERE constraint_name='SAMB_PK';\\012   if found\\012   then\\012\\012   end if;\\012end;\\012$$ language 'plpgsql';\\012select remove_samb_pk_constraint();\\012drop function remove_samb_pk_constraint();\\012ALTER TABLE SAMPLE_MATERIAL_BATCHES DROP COLUMN ID;\\012ALTER TABLE SAMPLE_MATERIAL_BATCHES ADD CONSTRAINT SAMB_PK PRIMARY KEY(SAMP_ID,MABA_ID);\\012\\012-- Remove ID and REGISTRATION_TIMESTAMP column from DATA_SET_RELATIONSHIPS table\\012DROP SEQUENCE DATA_SET_RELATIONSHIP_ID_SEQ;\\012ALTER TABLE DATA_SET_RELATIONSHIPS DROP CONSTRAINT DSRE_PK;\\012ALTER TABLE DATA_SET_RELATIONSHIPS DROP CONSTRAINT DSRE_BK_UK;\\012ALTER TABLE DATA_SET_RELATIONSHIPS DROP COLUMN ID;\\012ALTER TABLE DATA_SET_RELATIONSHIPS DROP COLUMN REGISTRATION_TIMESTAMP;\\012ALTER TABLE DATA_SET_RELATIONSHIPS ADD CONSTRAINT DSRE_PK PRIMARY KEY(DATA_ID_PARENT,DATA_ID_CHILD);\\012\\012-- Rename: \\012-- OBSERVABLE_TYPES -> DATA_SET_TYPES\\012-- OBSERVABLE_TYPE_ID_SEQ -> DATA_SET_TYPE_ID_SEQ\\012-- DATA.OBTY_ID -> DATA.DSTY_ID\\012ALTER TABLE OBSERVABLE_TYPES RENAME TO DATA_SET_TYPES;\\012ALTER TABLE OBSERVABLE_TYPE_ID_SEQ RENAME TO DATA_SET_TYPE_ID_SEQ;\\012ALTER TABLE DATA RENAME COLUMN OBTY_ID TO DSTY_ID;\\012	\N
+./sourceTest/sql/postgresql/026/schema-026.sql:    LANGUAGE plpgsql;
+./sourceTest/sql/postgresql/026/schema-026.sql:    LANGUAGE plpgsql;
+./sourceTest/sql/postgresql/026/schema-026.sql:    LANGUAGE plpgsql;
+./sourceTest/sql/postgresql/026/schema-026.sql:    LANGUAGE plpgsql;
+./sourceTest/sql/postgresql/026/schema-026.sql:    LANGUAGE plpgsql;
+./sourceTest/sql/postgresql/027/.svn/text-base/009=database_version_logs.tsv.svn-base:027	D:\\User\\felmer\\dev-workspace\\openbis/source/sql/postgresql/027/function-027.sql	SUCCESS	2008-11-05 09:18:00.403	-- Creating Functions\\012\\012------------------------------------------------------------------------------------\\012--  Purpose:  Create function RENAME_SEQUENCE() that is required for renaming the sequences belonging to tables\\012------------------------------------------------------------------------------------\\012CREATE FUNCTION RENAME_SEQUENCE(OLD_NAME VARCHAR, NEW_NAME VARCHAR) RETURNS INTEGER AS $$\\012DECLARE\\012  CURR_SEQ_VAL   INTEGER;\\012BEGIN\\012  SELECT INTO CURR_SEQ_VAL NEXTVAL(OLD_NAME);\\012  EXECUTE 'CREATE SEQUENCE ' || NEW_NAME || ' START WITH ' || CURR_SEQ_VAL;\\012  EXECUTE 'DROP SEQUENCE ' || OLD_NAME;\\012  RETURN CURR_SEQ_VAL;\\012END;\\012$$ LANGUAGE 'plpgsql';\\012\\012\\012------------------------------------------------------------------------------------\\012--  Purpose:  Create trigger CONTROLLED_VOCABULARY_CHECK \\012------------------------------------------------------------------------------------\\012\\012CREATE OR REPLACE FUNCTION CONTROLLED_VOCABULARY_CHECK() RETURNS trigger AS $$\\012DECLARE\\012   v_code  CODE;\\012BEGIN\\012\\012   select code into v_code from data_types where id = NEW.daty_id;\\012\\012   -- Check if the data is of type "CONTROLLEDVOCABULARY"\\012   if v_code = 'CONTROLLEDVOCABULARY' then\\012      if NEW.covo_id IS NULL then\\012         RAISE EXCEPTION 'Insert/Update of Property Type (Code: %) failed, as its Data Type is CONTROLLEDVOCABULARY, but it is not linked to a Controlled Vocabulary.', NEW.code;\\012      end if;\\012   end if;\\012\\012   RETURN NEW;\\012\\012END;\\012$$ LANGUAGE 'plpgsql';\\012\\012CREATE TRIGGER CONTROLLED_VOCABULARY_CHECK BEFORE INSERT OR UPDATE ON PROPERTY_TYPES\\012    FOR EACH ROW EXECUTE PROCEDURE CONTROLLED_VOCABULARY_CHECK();\\012\\012\\012------------------------------------------------------------------------------------\\012--  Purpose:  Create trigger EXTERNAL_DATA_STORAGE_FORMAT_CHECK \\012------------------------------------------------------------------------------------\\012\\012CREATE OR REPLACE FUNCTION EXTERNAL_DATA_STORAGE_FORMAT_CHECK() RETURNS trigger AS $$\\012DECLARE\\012   v_covo_code  CODE;\\012   data_code CODE;\\012BEGIN\\012\\012   select code into v_covo_code from controlled_vocabularies\\012      where is_internal_namespace = true and \\012         id = (select covo_id from controlled_vocabulary_terms where id = NEW.cvte_id_stor_fmt);\\012   -- Check if the data storage format is a term of the controlled vocabulary "STORAGE_FORMAT"\\012   if v_covo_code != 'STORAGE_FORMAT' then\\012      select code into data_code from data where id = NEW.data_id; \\012      RAISE EXCEPTION 'Insert/Update of Data (Code: %) failed, as its Storage Format is %, but is required to be STORAGE_FORMAT.', data_code, v_covo_code;\\012   end if;\\012\\012   RETURN NEW;\\012\\012END;\\012$$ LANGUAGE 'plpgsql';\\012\\012CREATE TRIGGER EXTERNAL_DATA_STORAGE_FORMAT_CHECK BEFORE INSERT OR UPDATE ON EXTERNAL_DATA\\012    FOR EACH ROW EXECUTE PROCEDURE EXTERNAL_DATA_STORAGE_FORMAT_CHECK();\\012\\012------------------------------------------------------------------------------------\\012--  Purpose:  Create trigger SAMPLE_CODE_UNIQUENESS_CHECK \\012------------------------------------------------------------------------------------\\012\\012CREATE OR REPLACE FUNCTION SAMPLE_CODE_UNIQUENESS_CHECK() RETURNS trigger AS $$\\012DECLARE\\012   counter  INTEGER;\\012BEGIN\\012\\011IF (NEW.samp_id_part_of is NULL) THEN\\012\\011\\011IF (NEW.dbin_id is not NULL) THEN\\012\\011\\011\\011SELECT count(*) into counter FROM samples \\012\\011\\011\\011\\011where id != NEW.id and code = NEW.code and samp_id_part_of is NULL and dbin_id = NEW.dbin_id;\\012\\011\\011\\011IF (counter > 0) THEN\\012\\011\\011\\011\\011RAISE EXCEPTION 'Insert/Update of Sample (Code: %) failed because database instance sample with the same code already exists.', NEW.code;\\012\\011\\011\\011END IF;\\012\\011\\011ELSIF (NEW.grou_id is not NULL) THEN\\012\\011\\011\\011SELECT count(*) into counter FROM samples \\012\\011\\011\\011\\011where id != NEW.id and code = NEW.code and samp_id_part_of is NULL and grou_id = NEW.grou_id;\\012\\011\\011\\011IF (counter > 0) THEN\\012\\011\\011\\011\\011RAISE EXCEPTION 'Insert/Update of Sample (Code: %) failed because group sample with the same code already exists.', NEW.code;\\012\\011\\011\\011END IF;\\012\\011\\011END IF;\\012        ELSE\\012\\011\\011IF (NEW.dbin_id is not NULL) THEN\\012\\011\\011\\011SELECT count(*) into counter FROM samples \\012\\011\\011\\011\\011where id != NEW.id and code = NEW.code and samp_id_part_of = NEW.samp_id_part_of and dbin_id = NEW.dbin_id;\\012\\011\\011\\011IF (counter > 0) THEN\\012\\011\\011\\011\\011RAISE EXCEPTION 'Insert/Update of Sample (Code: %) failed because database instance sample with the same code and being the part of the same parent already exists.', NEW.code;\\012\\011\\011\\011END IF;\\012\\011\\011ELSIF (NEW.grou_id is not NULL) THEN\\012\\011\\011\\011SELECT count(*) into counter FROM samples \\012\\011\\011\\011\\011where id != NEW.id and code = NEW.code and samp_id_part_of = NEW.samp_id_part_of and grou_id = NEW.grou_id;\\012\\011\\011\\011IF (counter > 0) THEN\\012\\011\\011\\011\\011RAISE EXCEPTION 'Insert/Update of Sample (Code: %) failed because group sample with the same code and being the part of the same parent already exists.', NEW.code;\\012\\011\\011\\011END IF;\\012\\011\\011END IF;\\012        END IF;   \\012   RETURN NEW;\\012END;\\012$$ LANGUAGE 'plpgsql';\\012\\012CREATE TRIGGER SAMPLE_CODE_UNIQUENESS_CHECK BEFORE INSERT OR UPDATE ON SAMPLES\\012    FOR EACH ROW EXECUTE PROCEDURE SAMPLE_CODE_UNIQUENESS_CHECK();\\012	\N
+./sourceTest/sql/postgresql/027/.svn/text-base/schema-027.sql.svn-base:    LANGUAGE plpgsql;
+./sourceTest/sql/postgresql/027/.svn/text-base/schema-027.sql.svn-base:    LANGUAGE plpgsql;
+./sourceTest/sql/postgresql/027/.svn/text-base/schema-027.sql.svn-base:    LANGUAGE plpgsql;
+./sourceTest/sql/postgresql/027/.svn/text-base/schema-027.sql.svn-base:    LANGUAGE plpgsql;
+./sourceTest/sql/postgresql/027/009=database_version_logs.tsv:027	D:\\User\\felmer\\dev-workspace\\openbis/source/sql/postgresql/027/function-027.sql	SUCCESS	2008-11-05 09:18:00.403	-- Creating Functions\\012\\012------------------------------------------------------------------------------------\\012--  Purpose:  Create function RENAME_SEQUENCE() that is required for renaming the sequences belonging to tables\\012------------------------------------------------------------------------------------\\012CREATE FUNCTION RENAME_SEQUENCE(OLD_NAME VARCHAR, NEW_NAME VARCHAR) RETURNS INTEGER AS $$\\012DECLARE\\012  CURR_SEQ_VAL   INTEGER;\\012BEGIN\\012  SELECT INTO CURR_SEQ_VAL NEXTVAL(OLD_NAME);\\012  EXECUTE 'CREATE SEQUENCE ' || NEW_NAME || ' START WITH ' || CURR_SEQ_VAL;\\012  EXECUTE 'DROP SEQUENCE ' || OLD_NAME;\\012  RETURN CURR_SEQ_VAL;\\012END;\\012$$ LANGUAGE 'plpgsql';\\012\\012\\012------------------------------------------------------------------------------------\\012--  Purpose:  Create trigger CONTROLLED_VOCABULARY_CHECK \\012------------------------------------------------------------------------------------\\012\\012CREATE OR REPLACE FUNCTION CONTROLLED_VOCABULARY_CHECK() RETURNS trigger AS $$\\012DECLARE\\012   v_code  CODE;\\012BEGIN\\012\\012   select code into v_code from data_types where id = NEW.daty_id;\\012\\012   -- Check if the data is of type "CONTROLLEDVOCABULARY"\\012   if v_code = 'CONTROLLEDVOCABULARY' then\\012      if NEW.covo_id IS NULL then\\012         RAISE EXCEPTION 'Insert/Update of Property Type (Code: %) failed, as its Data Type is CONTROLLEDVOCABULARY, but it is not linked to a Controlled Vocabulary.', NEW.code;\\012      end if;\\012   end if;\\012\\012   RETURN NEW;\\012\\012END;\\012$$ LANGUAGE 'plpgsql';\\012\\012CREATE TRIGGER CONTROLLED_VOCABULARY_CHECK BEFORE INSERT OR UPDATE ON PROPERTY_TYPES\\012    FOR EACH ROW EXECUTE PROCEDURE CONTROLLED_VOCABULARY_CHECK();\\012\\012\\012------------------------------------------------------------------------------------\\012--  Purpose:  Create trigger EXTERNAL_DATA_STORAGE_FORMAT_CHECK \\012------------------------------------------------------------------------------------\\012\\012CREATE OR REPLACE FUNCTION EXTERNAL_DATA_STORAGE_FORMAT_CHECK() RETURNS trigger AS $$\\012DECLARE\\012   v_covo_code  CODE;\\012   data_code CODE;\\012BEGIN\\012\\012   select code into v_covo_code from controlled_vocabularies\\012      where is_internal_namespace = true and \\012         id = (select covo_id from controlled_vocabulary_terms where id = NEW.cvte_id_stor_fmt);\\012   -- Check if the data storage format is a term of the controlled vocabulary "STORAGE_FORMAT"\\012   if v_covo_code != 'STORAGE_FORMAT' then\\012      select code into data_code from data where id = NEW.data_id; \\012      RAISE EXCEPTION 'Insert/Update of Data (Code: %) failed, as its Storage Format is %, but is required to be STORAGE_FORMAT.', data_code, v_covo_code;\\012   end if;\\012\\012   RETURN NEW;\\012\\012END;\\012$$ LANGUAGE 'plpgsql';\\012\\012CREATE TRIGGER EXTERNAL_DATA_STORAGE_FORMAT_CHECK BEFORE INSERT OR UPDATE ON EXTERNAL_DATA\\012    FOR EACH ROW EXECUTE PROCEDURE EXTERNAL_DATA_STORAGE_FORMAT_CHECK();\\012\\012------------------------------------------------------------------------------------\\012--  Purpose:  Create trigger SAMPLE_CODE_UNIQUENESS_CHECK \\012------------------------------------------------------------------------------------\\012\\012CREATE OR REPLACE FUNCTION SAMPLE_CODE_UNIQUENESS_CHECK() RETURNS trigger AS $$\\012DECLARE\\012   counter  INTEGER;\\012BEGIN\\012\\011IF (NEW.samp_id_part_of is NULL) THEN\\012\\011\\011IF (NEW.dbin_id is not NULL) THEN\\012\\011\\011\\011SELECT count(*) into counter FROM samples \\012\\011\\011\\011\\011where id != NEW.id and code = NEW.code and samp_id_part_of is NULL and dbin_id = NEW.dbin_id;\\012\\011\\011\\011IF (counter > 0) THEN\\012\\011\\011\\011\\011RAISE EXCEPTION 'Insert/Update of Sample (Code: %) failed because database instance sample with the same code already exists.', NEW.code;\\012\\011\\011\\011END IF;\\012\\011\\011ELSIF (NEW.grou_id is not NULL) THEN\\012\\011\\011\\011SELECT count(*) into counter FROM samples \\012\\011\\011\\011\\011where id != NEW.id and code = NEW.code and samp_id_part_of is NULL and grou_id = NEW.grou_id;\\012\\011\\011\\011IF (counter > 0) THEN\\012\\011\\011\\011\\011RAISE EXCEPTION 'Insert/Update of Sample (Code: %) failed because group sample with the same code already exists.', NEW.code;\\012\\011\\011\\011END IF;\\012\\011\\011END IF;\\012        ELSE\\012\\011\\011IF (NEW.dbin_id is not NULL) THEN\\012\\011\\011\\011SELECT count(*) into counter FROM samples \\012\\011\\011\\011\\011where id != NEW.id and code = NEW.code and samp_id_part_of = NEW.samp_id_part_of and dbin_id = NEW.dbin_id;\\012\\011\\011\\011IF (counter > 0) THEN\\012\\011\\011\\011\\011RAISE EXCEPTION 'Insert/Update of Sample (Code: %) failed because database instance sample with the same code and being the part of the same parent already exists.', NEW.code;\\012\\011\\011\\011END IF;\\012\\011\\011ELSIF (NEW.grou_id is not NULL) THEN\\012\\011\\011\\011SELECT count(*) into counter FROM samples \\012\\011\\011\\011\\011where id != NEW.id and code = NEW.code and samp_id_part_of = NEW.samp_id_part_of and grou_id = NEW.grou_id;\\012\\011\\011\\011IF (counter > 0) THEN\\012\\011\\011\\011\\011RAISE EXCEPTION 'Insert/Update of Sample (Code: %) failed because group sample with the same code and being the part of the same parent already exists.', NEW.code;\\012\\011\\011\\011END IF;\\012\\011\\011END IF;\\012        END IF;   \\012   RETURN NEW;\\012END;\\012$$ LANGUAGE 'plpgsql';\\012\\012CREATE TRIGGER SAMPLE_CODE_UNIQUENESS_CHECK BEFORE INSERT OR UPDATE ON SAMPLES\\012    FOR EACH ROW EXECUTE PROCEDURE SAMPLE_CODE_UNIQUENESS_CHECK();\\012	\N
+./sourceTest/sql/postgresql/027/schema-027.sql:    LANGUAGE plpgsql;
+./sourceTest/sql/postgresql/027/schema-027.sql:    LANGUAGE plpgsql;
+./sourceTest/sql/postgresql/027/schema-027.sql:    LANGUAGE plpgsql;
+./sourceTest/sql/postgresql/027/schema-027.sql:    LANGUAGE plpgsql;
+./sourceTest/sql/postgresql/028/.svn/text-base/009=database_version_logs.tsv.svn-base:027	D:\\User\\felmer\\dev-workspace\\openbis/source/sql/postgresql/027/function-027.sql	SUCCESS	2008-11-05 09:18:00.403	-- Creating Functions\\012\\012------------------------------------------------------------------------------------\\012--  Purpose:  Create function RENAME_SEQUENCE() that is required for renaming the sequences belonging to tables\\012------------------------------------------------------------------------------------\\012CREATE FUNCTION RENAME_SEQUENCE(OLD_NAME VARCHAR, NEW_NAME VARCHAR) RETURNS INTEGER AS $$\\012DECLARE\\012  CURR_SEQ_VAL   INTEGER;\\012BEGIN\\012  SELECT INTO CURR_SEQ_VAL NEXTVAL(OLD_NAME);\\012  EXECUTE 'CREATE SEQUENCE ' || NEW_NAME || ' START WITH ' || CURR_SEQ_VAL;\\012  EXECUTE 'DROP SEQUENCE ' || OLD_NAME;\\012  RETURN CURR_SEQ_VAL;\\012END;\\012$$ LANGUAGE 'plpgsql';\\012\\012\\012------------------------------------------------------------------------------------\\012--  Purpose:  Create trigger CONTROLLED_VOCABULARY_CHECK \\012------------------------------------------------------------------------------------\\012\\012CREATE OR REPLACE FUNCTION CONTROLLED_VOCABULARY_CHECK() RETURNS trigger AS $$\\012DECLARE\\012   v_code  CODE;\\012BEGIN\\012\\012   select code into v_code from data_types where id = NEW.daty_id;\\012\\012   -- Check if the data is of type "CONTROLLEDVOCABULARY"\\012   if v_code = 'CONTROLLEDVOCABULARY' then\\012      if NEW.covo_id IS NULL then\\012         RAISE EXCEPTION 'Insert/Update of Property Type (Code: %) failed, as its Data Type is CONTROLLEDVOCABULARY, but it is not linked to a Controlled Vocabulary.', NEW.code;\\012      end if;\\012   end if;\\012\\012   RETURN NEW;\\012\\012END;\\012$$ LANGUAGE 'plpgsql';\\012\\012CREATE TRIGGER CONTROLLED_VOCABULARY_CHECK BEFORE INSERT OR UPDATE ON PROPERTY_TYPES\\012    FOR EACH ROW EXECUTE PROCEDURE CONTROLLED_VOCABULARY_CHECK();\\012\\012\\012------------------------------------------------------------------------------------\\012--  Purpose:  Create trigger EXTERNAL_DATA_STORAGE_FORMAT_CHECK \\012------------------------------------------------------------------------------------\\012\\012CREATE OR REPLACE FUNCTION EXTERNAL_DATA_STORAGE_FORMAT_CHECK() RETURNS trigger AS $$\\012DECLARE\\012   v_covo_code  CODE;\\012   data_code CODE;\\012BEGIN\\012\\012   select code into v_covo_code from controlled_vocabularies\\012      where is_internal_namespace = true and \\012         id = (select covo_id from controlled_vocabulary_terms where id = NEW.cvte_id_stor_fmt);\\012   -- Check if the data storage format is a term of the controlled vocabulary "STORAGE_FORMAT"\\012   if v_covo_code != 'STORAGE_FORMAT' then\\012      select code into data_code from data where id = NEW.data_id; \\012      RAISE EXCEPTION 'Insert/Update of Data (Code: %) failed, as its Storage Format is %, but is required to be STORAGE_FORMAT.', data_code, v_covo_code;\\012   end if;\\012\\012   RETURN NEW;\\012\\012END;\\012$$ LANGUAGE 'plpgsql';\\012\\012CREATE TRIGGER EXTERNAL_DATA_STORAGE_FORMAT_CHECK BEFORE INSERT OR UPDATE ON EXTERNAL_DATA\\012    FOR EACH ROW EXECUTE PROCEDURE EXTERNAL_DATA_STORAGE_FORMAT_CHECK();\\012\\012------------------------------------------------------------------------------------\\012--  Purpose:  Create trigger SAMPLE_CODE_UNIQUENESS_CHECK \\012------------------------------------------------------------------------------------\\012\\012CREATE OR REPLACE FUNCTION SAMPLE_CODE_UNIQUENESS_CHECK() RETURNS trigger AS $$\\012DECLARE\\012   counter  INTEGER;\\012BEGIN\\012\\011IF (NEW.samp_id_part_of is NULL) THEN\\012\\011\\011IF (NEW.dbin_id is not NULL) THEN\\012\\011\\011\\011SELECT count(*) into counter FROM samples \\012\\011\\011\\011\\011where id != NEW.id and code = NEW.code and samp_id_part_of is NULL and dbin_id = NEW.dbin_id;\\012\\011\\011\\011IF (counter > 0) THEN\\012\\011\\011\\011\\011RAISE EXCEPTION 'Insert/Update of Sample (Code: %) failed because database instance sample with the same code already exists.', NEW.code;\\012\\011\\011\\011END IF;\\012\\011\\011ELSIF (NEW.grou_id is not NULL) THEN\\012\\011\\011\\011SELECT count(*) into counter FROM samples \\012\\011\\011\\011\\011where id != NEW.id and code = NEW.code and samp_id_part_of is NULL and grou_id = NEW.grou_id;\\012\\011\\011\\011IF (counter > 0) THEN\\012\\011\\011\\011\\011RAISE EXCEPTION 'Insert/Update of Sample (Code: %) failed because group sample with the same code already exists.', NEW.code;\\012\\011\\011\\011END IF;\\012\\011\\011END IF;\\012        ELSE\\012\\011\\011IF (NEW.dbin_id is not NULL) THEN\\012\\011\\011\\011SELECT count(*) into counter FROM samples \\012\\011\\011\\011\\011where id != NEW.id and code = NEW.code and samp_id_part_of = NEW.samp_id_part_of and dbin_id = NEW.dbin_id;\\012\\011\\011\\011IF (counter > 0) THEN\\012\\011\\011\\011\\011RAISE EXCEPTION 'Insert/Update of Sample (Code: %) failed because database instance sample with the same code and being the part of the same parent already exists.', NEW.code;\\012\\011\\011\\011END IF;\\012\\011\\011ELSIF (NEW.grou_id is not NULL) THEN\\012\\011\\011\\011SELECT count(*) into counter FROM samples \\012\\011\\011\\011\\011where id != NEW.id and code = NEW.code and samp_id_part_of = NEW.samp_id_part_of and grou_id = NEW.grou_id;\\012\\011\\011\\011IF (counter > 0) THEN\\012\\011\\011\\011\\011RAISE EXCEPTION 'Insert/Update of Sample (Code: %) failed because group sample with the same code and being the part of the same parent already exists.', NEW.code;\\012\\011\\011\\011END IF;\\012\\011\\011END IF;\\012        END IF;   \\012   RETURN NEW;\\012END;\\012$$ LANGUAGE 'plpgsql';\\012\\012CREATE TRIGGER SAMPLE_CODE_UNIQUENESS_CHECK BEFORE INSERT OR UPDATE ON SAMPLES\\012    FOR EACH ROW EXECUTE PROCEDURE SAMPLE_CODE_UNIQUENESS_CHECK();\\012	\N
+./sourceTest/sql/postgresql/028/.svn/text-base/009=database_version_logs.tsv.svn-base:028	source/sql/postgresql/migration/migration-027-028.sql	SUCCESS	2008-11-18 13:24:17.508	-- Create EXPERIMENT_ATTACHMENT_CONTENTS.\\012CREATE TABLE EXPERIMENT_ATTACHMENT_CONTENTS (ID TECH_ID NOT NULL,VALUE FILE NOT NULL);\\012CREATE SEQUENCE EXPERIMENT_ATTACHMENT_CONTENT_ID_SEQ;\\012ALTER TABLE EXPERIMENT_ATTACHMENT_CONTENTS ADD CONSTRAINT EXAC_PK PRIMARY KEY(ID);\\012\\012-- Alter EXPERIMENT_ATTACHMENTS by adding the new column which has a NULL constraint.\\012-- The NOT NULL constraint is added later on.\\012ALTER TABLE EXPERIMENT_ATTACHMENTS ADD COLUMN EXAC_ID TECH_ID;\\012\\012-- Does the VALUE migration between EXPERIMENT_ATTACHMENTS to EXPERIMENT_ATTACHMENT_CONTENTS.\\012CREATE OR REPLACE FUNCTION move_exp_att_content() RETURNS integer AS $$\\012DECLARE\\012    rec RECORD;\\012    seq BIGINT;\\012BEGIN\\012  FOR rec IN SELECT id, value FROM EXPERIMENT_ATTACHMENTS LOOP\\012  \\011seq := nextval('EXPERIMENT_ATTACHMENT_CONTENT_ID_SEQ');\\012    INSERT INTO EXPERIMENT_ATTACHMENT_CONTENTS (id, value) VALUES (seq, rec.value);\\012    UPDATE EXPERIMENT_ATTACHMENTS SET exac_id = seq WHERE id = rec.id;\\012  END LOOP;\\012  RETURN 1;\\012END;\\012$$ LANGUAGE 'plpgsql';\\012\\012-- Call the function.\\012SELECT move_exp_att_content();\\012DROP FUNCTION move_exp_att_content();\\012\\012\\012-- Finish EXPERIMENT_ATTACHMENTS changes.\\012ALTER TABLE EXPERIMENT_ATTACHMENTS ADD CONSTRAINT EXAT_CONT_FK FOREIGN KEY (EXAC_ID) REFERENCES EXPERIMENT_ATTACHMENT_CONTENTS(ID);\\012ALTER TABLE EXPERIMENT_ATTACHMENTS DROP COLUMN VALUE;\\012ALTER TABLE EXPERIMENT_ATTACHMENTS ALTER COLUMN EXAC_ID SET NOT NULL;\\012	\N
+./sourceTest/sql/postgresql/028/.svn/text-base/schema-028.sql.svn-base:    LANGUAGE plpgsql;
+./sourceTest/sql/postgresql/028/.svn/text-base/schema-028.sql.svn-base:    LANGUAGE plpgsql;
+./sourceTest/sql/postgresql/028/.svn/text-base/schema-028.sql.svn-base:    LANGUAGE plpgsql;
+./sourceTest/sql/postgresql/028/.svn/text-base/schema-028.sql.svn-base:    LANGUAGE plpgsql;
+./sourceTest/sql/postgresql/028/009=database_version_logs.tsv:027	D:\\User\\felmer\\dev-workspace\\openbis/source/sql/postgresql/027/function-027.sql	SUCCESS	2008-11-05 09:18:00.403	-- Creating Functions\\012\\012------------------------------------------------------------------------------------\\012--  Purpose:  Create function RENAME_SEQUENCE() that is required for renaming the sequences belonging to tables\\012------------------------------------------------------------------------------------\\012CREATE FUNCTION RENAME_SEQUENCE(OLD_NAME VARCHAR, NEW_NAME VARCHAR) RETURNS INTEGER AS $$\\012DECLARE\\012  CURR_SEQ_VAL   INTEGER;\\012BEGIN\\012  SELECT INTO CURR_SEQ_VAL NEXTVAL(OLD_NAME);\\012  EXECUTE 'CREATE SEQUENCE ' || NEW_NAME || ' START WITH ' || CURR_SEQ_VAL;\\012  EXECUTE 'DROP SEQUENCE ' || OLD_NAME;\\012  RETURN CURR_SEQ_VAL;\\012END;\\012$$ LANGUAGE 'plpgsql';\\012\\012\\012------------------------------------------------------------------------------------\\012--  Purpose:  Create trigger CONTROLLED_VOCABULARY_CHECK \\012------------------------------------------------------------------------------------\\012\\012CREATE OR REPLACE FUNCTION CONTROLLED_VOCABULARY_CHECK() RETURNS trigger AS $$\\012DECLARE\\012   v_code  CODE;\\012BEGIN\\012\\012   select code into v_code from data_types where id = NEW.daty_id;\\012\\012   -- Check if the data is of type "CONTROLLEDVOCABULARY"\\012   if v_code = 'CONTROLLEDVOCABULARY' then\\012      if NEW.covo_id IS NULL then\\012         RAISE EXCEPTION 'Insert/Update of Property Type (Code: %) failed, as its Data Type is CONTROLLEDVOCABULARY, but it is not linked to a Controlled Vocabulary.', NEW.code;\\012      end if;\\012   end if;\\012\\012   RETURN NEW;\\012\\012END;\\012$$ LANGUAGE 'plpgsql';\\012\\012CREATE TRIGGER CONTROLLED_VOCABULARY_CHECK BEFORE INSERT OR UPDATE ON PROPERTY_TYPES\\012    FOR EACH ROW EXECUTE PROCEDURE CONTROLLED_VOCABULARY_CHECK();\\012\\012\\012------------------------------------------------------------------------------------\\012--  Purpose:  Create trigger EXTERNAL_DATA_STORAGE_FORMAT_CHECK \\012------------------------------------------------------------------------------------\\012\\012CREATE OR REPLACE FUNCTION EXTERNAL_DATA_STORAGE_FORMAT_CHECK() RETURNS trigger AS $$\\012DECLARE\\012   v_covo_code  CODE;\\012   data_code CODE;\\012BEGIN\\012\\012   select code into v_covo_code from controlled_vocabularies\\012      where is_internal_namespace = true and \\012         id = (select covo_id from controlled_vocabulary_terms where id = NEW.cvte_id_stor_fmt);\\012   -- Check if the data storage format is a term of the controlled vocabulary "STORAGE_FORMAT"\\012   if v_covo_code != 'STORAGE_FORMAT' then\\012      select code into data_code from data where id = NEW.data_id; \\012      RAISE EXCEPTION 'Insert/Update of Data (Code: %) failed, as its Storage Format is %, but is required to be STORAGE_FORMAT.', data_code, v_covo_code;\\012   end if;\\012\\012   RETURN NEW;\\012\\012END;\\012$$ LANGUAGE 'plpgsql';\\012\\012CREATE TRIGGER EXTERNAL_DATA_STORAGE_FORMAT_CHECK BEFORE INSERT OR UPDATE ON EXTERNAL_DATA\\012    FOR EACH ROW EXECUTE PROCEDURE EXTERNAL_DATA_STORAGE_FORMAT_CHECK();\\012\\012------------------------------------------------------------------------------------\\012--  Purpose:  Create trigger SAMPLE_CODE_UNIQUENESS_CHECK \\012------------------------------------------------------------------------------------\\012\\012CREATE OR REPLACE FUNCTION SAMPLE_CODE_UNIQUENESS_CHECK() RETURNS trigger AS $$\\012DECLARE\\012   counter  INTEGER;\\012BEGIN\\012\\011IF (NEW.samp_id_part_of is NULL) THEN\\012\\011\\011IF (NEW.dbin_id is not NULL) THEN\\012\\011\\011\\011SELECT count(*) into counter FROM samples \\012\\011\\011\\011\\011where id != NEW.id and code = NEW.code and samp_id_part_of is NULL and dbin_id = NEW.dbin_id;\\012\\011\\011\\011IF (counter > 0) THEN\\012\\011\\011\\011\\011RAISE EXCEPTION 'Insert/Update of Sample (Code: %) failed because database instance sample with the same code already exists.', NEW.code;\\012\\011\\011\\011END IF;\\012\\011\\011ELSIF (NEW.grou_id is not NULL) THEN\\012\\011\\011\\011SELECT count(*) into counter FROM samples \\012\\011\\011\\011\\011where id != NEW.id and code = NEW.code and samp_id_part_of is NULL and grou_id = NEW.grou_id;\\012\\011\\011\\011IF (counter > 0) THEN\\012\\011\\011\\011\\011RAISE EXCEPTION 'Insert/Update of Sample (Code: %) failed because group sample with the same code already exists.', NEW.code;\\012\\011\\011\\011END IF;\\012\\011\\011END IF;\\012        ELSE\\012\\011\\011IF (NEW.dbin_id is not NULL) THEN\\012\\011\\011\\011SELECT count(*) into counter FROM samples \\012\\011\\011\\011\\011where id != NEW.id and code = NEW.code and samp_id_part_of = NEW.samp_id_part_of and dbin_id = NEW.dbin_id;\\012\\011\\011\\011IF (counter > 0) THEN\\012\\011\\011\\011\\011RAISE EXCEPTION 'Insert/Update of Sample (Code: %) failed because database instance sample with the same code and being the part of the same parent already exists.', NEW.code;\\012\\011\\011\\011END IF;\\012\\011\\011ELSIF (NEW.grou_id is not NULL) THEN\\012\\011\\011\\011SELECT count(*) into counter FROM samples \\012\\011\\011\\011\\011where id != NEW.id and code = NEW.code and samp_id_part_of = NEW.samp_id_part_of and grou_id = NEW.grou_id;\\012\\011\\011\\011IF (counter > 0) THEN\\012\\011\\011\\011\\011RAISE EXCEPTION 'Insert/Update of Sample (Code: %) failed because group sample with the same code and being the part of the same parent already exists.', NEW.code;\\012\\011\\011\\011END IF;\\012\\011\\011END IF;\\012        END IF;   \\012   RETURN NEW;\\012END;\\012$$ LANGUAGE 'plpgsql';\\012\\012CREATE TRIGGER SAMPLE_CODE_UNIQUENESS_CHECK BEFORE INSERT OR UPDATE ON SAMPLES\\012    FOR EACH ROW EXECUTE PROCEDURE SAMPLE_CODE_UNIQUENESS_CHECK();\\012	\N
+./sourceTest/sql/postgresql/028/009=database_version_logs.tsv:028	source/sql/postgresql/migration/migration-027-028.sql	SUCCESS	2008-11-18 13:24:17.508	-- Create EXPERIMENT_ATTACHMENT_CONTENTS.\\012CREATE TABLE EXPERIMENT_ATTACHMENT_CONTENTS (ID TECH_ID NOT NULL,VALUE FILE NOT NULL);\\012CREATE SEQUENCE EXPERIMENT_ATTACHMENT_CONTENT_ID_SEQ;\\012ALTER TABLE EXPERIMENT_ATTACHMENT_CONTENTS ADD CONSTRAINT EXAC_PK PRIMARY KEY(ID);\\012\\012-- Alter EXPERIMENT_ATTACHMENTS by adding the new column which has a NULL constraint.\\012-- The NOT NULL constraint is added later on.\\012ALTER TABLE EXPERIMENT_ATTACHMENTS ADD COLUMN EXAC_ID TECH_ID;\\012\\012-- Does the VALUE migration between EXPERIMENT_ATTACHMENTS to EXPERIMENT_ATTACHMENT_CONTENTS.\\012CREATE OR REPLACE FUNCTION move_exp_att_content() RETURNS integer AS $$\\012DECLARE\\012    rec RECORD;\\012    seq BIGINT;\\012BEGIN\\012  FOR rec IN SELECT id, value FROM EXPERIMENT_ATTACHMENTS LOOP\\012  \\011seq := nextval('EXPERIMENT_ATTACHMENT_CONTENT_ID_SEQ');\\012    INSERT INTO EXPERIMENT_ATTACHMENT_CONTENTS (id, value) VALUES (seq, rec.value);\\012    UPDATE EXPERIMENT_ATTACHMENTS SET exac_id = seq WHERE id = rec.id;\\012  END LOOP;\\012  RETURN 1;\\012END;\\012$$ LANGUAGE 'plpgsql';\\012\\012-- Call the function.\\012SELECT move_exp_att_content();\\012DROP FUNCTION move_exp_att_content();\\012\\012\\012-- Finish EXPERIMENT_ATTACHMENTS changes.\\012ALTER TABLE EXPERIMENT_ATTACHMENTS ADD CONSTRAINT EXAT_CONT_FK FOREIGN KEY (EXAC_ID) REFERENCES EXPERIMENT_ATTACHMENT_CONTENTS(ID);\\012ALTER TABLE EXPERIMENT_ATTACHMENTS DROP COLUMN VALUE;\\012ALTER TABLE EXPERIMENT_ATTACHMENTS ALTER COLUMN EXAC_ID SET NOT NULL;\\012	\N
+./sourceTest/sql/postgresql/028/migration/018/experiment-attachments-check/.svn/text-base/buildup.sql.svn-base:$$ LANGUAGE 'plpgsql';
+./sourceTest/sql/postgresql/028/migration/018/experiment-attachments-check/buildup.sql:$$ LANGUAGE 'plpgsql';
+./sourceTest/sql/postgresql/028/schema-028.sql:    LANGUAGE plpgsql;
+./sourceTest/sql/postgresql/028/schema-028.sql:    LANGUAGE plpgsql;
+./sourceTest/sql/postgresql/028/schema-028.sql:    LANGUAGE plpgsql;
+./sourceTest/sql/postgresql/028/schema-028.sql:    LANGUAGE plpgsql;
+./sourceTest/sql/postgresql/029/.svn/text-base/009=database_version_logs.tsv.svn-base:027	D:\\User\\felmer\\dev-workspace\\openbis/source/sql/postgresql/027/function-027.sql	SUCCESS	2008-11-05 09:18:00.403	-- Creating Functions\\012\\012------------------------------------------------------------------------------------\\012--  Purpose:  Create function RENAME_SEQUENCE() that is required for renaming the sequences belonging to tables\\012------------------------------------------------------------------------------------\\012CREATE FUNCTION RENAME_SEQUENCE(OLD_NAME VARCHAR, NEW_NAME VARCHAR) RETURNS INTEGER AS $$\\012DECLARE\\012  CURR_SEQ_VAL   INTEGER;\\012BEGIN\\012  SELECT INTO CURR_SEQ_VAL NEXTVAL(OLD_NAME);\\012  EXECUTE 'CREATE SEQUENCE ' || NEW_NAME || ' START WITH ' || CURR_SEQ_VAL;\\012  EXECUTE 'DROP SEQUENCE ' || OLD_NAME;\\012  RETURN CURR_SEQ_VAL;\\012END;\\012$$ LANGUAGE 'plpgsql';\\012\\012\\012------------------------------------------------------------------------------------\\012--  Purpose:  Create trigger CONTROLLED_VOCABULARY_CHECK \\012------------------------------------------------------------------------------------\\012\\012CREATE OR REPLACE FUNCTION CONTROLLED_VOCABULARY_CHECK() RETURNS trigger AS $$\\012DECLARE\\012   v_code  CODE;\\012BEGIN\\012\\012   select code into v_code from data_types where id = NEW.daty_id;\\012\\012   -- Check if the data is of type "CONTROLLEDVOCABULARY"\\012   if v_code = 'CONTROLLEDVOCABULARY' then\\012      if NEW.covo_id IS NULL then\\012         RAISE EXCEPTION 'Insert/Update of Property Type (Code: %) failed, as its Data Type is CONTROLLEDVOCABULARY, but it is not linked to a Controlled Vocabulary.', NEW.code;\\012      end if;\\012   end if;\\012\\012   RETURN NEW;\\012\\012END;\\012$$ LANGUAGE 'plpgsql';\\012\\012CREATE TRIGGER CONTROLLED_VOCABULARY_CHECK BEFORE INSERT OR UPDATE ON PROPERTY_TYPES\\012    FOR EACH ROW EXECUTE PROCEDURE CONTROLLED_VOCABULARY_CHECK();\\012\\012\\012------------------------------------------------------------------------------------\\012--  Purpose:  Create trigger EXTERNAL_DATA_STORAGE_FORMAT_CHECK \\012------------------------------------------------------------------------------------\\012\\012CREATE OR REPLACE FUNCTION EXTERNAL_DATA_STORAGE_FORMAT_CHECK() RETURNS trigger AS $$\\012DECLARE\\012   v_covo_code  CODE;\\012   data_code CODE;\\012BEGIN\\012\\012   select code into v_covo_code from controlled_vocabularies\\012      where is_internal_namespace = true and \\012         id = (select covo_id from controlled_vocabulary_terms where id = NEW.cvte_id_stor_fmt);\\012   -- Check if the data storage format is a term of the controlled vocabulary "STORAGE_FORMAT"\\012   if v_covo_code != 'STORAGE_FORMAT' then\\012      select code into data_code from data where id = NEW.data_id; \\012      RAISE EXCEPTION 'Insert/Update of Data (Code: %) failed, as its Storage Format is %, but is required to be STORAGE_FORMAT.', data_code, v_covo_code;\\012   end if;\\012\\012   RETURN NEW;\\012\\012END;\\012$$ LANGUAGE 'plpgsql';\\012\\012CREATE TRIGGER EXTERNAL_DATA_STORAGE_FORMAT_CHECK BEFORE INSERT OR UPDATE ON EXTERNAL_DATA\\012    FOR EACH ROW EXECUTE PROCEDURE EXTERNAL_DATA_STORAGE_FORMAT_CHECK();\\012\\012------------------------------------------------------------------------------------\\012--  Purpose:  Create trigger SAMPLE_CODE_UNIQUENESS_CHECK \\012------------------------------------------------------------------------------------\\012\\012CREATE OR REPLACE FUNCTION SAMPLE_CODE_UNIQUENESS_CHECK() RETURNS trigger AS $$\\012DECLARE\\012   counter  INTEGER;\\012BEGIN\\012\\011IF (NEW.samp_id_part_of is NULL) THEN\\012\\011\\011IF (NEW.dbin_id is not NULL) THEN\\012\\011\\011\\011SELECT count(*) into counter FROM samples \\012\\011\\011\\011\\011where id != NEW.id and code = NEW.code and samp_id_part_of is NULL and dbin_id = NEW.dbin_id;\\012\\011\\011\\011IF (counter > 0) THEN\\012\\011\\011\\011\\011RAISE EXCEPTION 'Insert/Update of Sample (Code: %) failed because database instance sample with the same code already exists.', NEW.code;\\012\\011\\011\\011END IF;\\012\\011\\011ELSIF (NEW.grou_id is not NULL) THEN\\012\\011\\011\\011SELECT count(*) into counter FROM samples \\012\\011\\011\\011\\011where id != NEW.id and code = NEW.code and samp_id_part_of is NULL and grou_id = NEW.grou_id;\\012\\011\\011\\011IF (counter > 0) THEN\\012\\011\\011\\011\\011RAISE EXCEPTION 'Insert/Update of Sample (Code: %) failed because group sample with the same code already exists.', NEW.code;\\012\\011\\011\\011END IF;\\012\\011\\011END IF;\\012        ELSE\\012\\011\\011IF (NEW.dbin_id is not NULL) THEN\\012\\011\\011\\011SELECT count(*) into counter FROM samples \\012\\011\\011\\011\\011where id != NEW.id and code = NEW.code and samp_id_part_of = NEW.samp_id_part_of and dbin_id = NEW.dbin_id;\\012\\011\\011\\011IF (counter > 0) THEN\\012\\011\\011\\011\\011RAISE EXCEPTION 'Insert/Update of Sample (Code: %) failed because database instance sample with the same code and being the part of the same parent already exists.', NEW.code;\\012\\011\\011\\011END IF;\\012\\011\\011ELSIF (NEW.grou_id is not NULL) THEN\\012\\011\\011\\011SELECT count(*) into counter FROM samples \\012\\011\\011\\011\\011where id != NEW.id and code = NEW.code and samp_id_part_of = NEW.samp_id_part_of and grou_id = NEW.grou_id;\\012\\011\\011\\011IF (counter > 0) THEN\\012\\011\\011\\011\\011RAISE EXCEPTION 'Insert/Update of Sample (Code: %) failed because group sample with the same code and being the part of the same parent already exists.', NEW.code;\\012\\011\\011\\011END IF;\\012\\011\\011END IF;\\012        END IF;   \\012   RETURN NEW;\\012END;\\012$$ LANGUAGE 'plpgsql';\\012\\012CREATE TRIGGER SAMPLE_CODE_UNIQUENESS_CHECK BEFORE INSERT OR UPDATE ON SAMPLES\\012    FOR EACH ROW EXECUTE PROCEDURE SAMPLE_CODE_UNIQUENESS_CHECK();\\012	\N
+./sourceTest/sql/postgresql/029/.svn/text-base/009=database_version_logs.tsv.svn-base:028	source/sql/postgresql/migration/migration-027-028.sql	SUCCESS	2008-11-18 13:24:17.508	-- Create EXPERIMENT_ATTACHMENT_CONTENTS.\\012CREATE TABLE EXPERIMENT_ATTACHMENT_CONTENTS (ID TECH_ID NOT NULL,VALUE FILE NOT NULL);\\012CREATE SEQUENCE EXPERIMENT_ATTACHMENT_CONTENT_ID_SEQ;\\012ALTER TABLE EXPERIMENT_ATTACHMENT_CONTENTS ADD CONSTRAINT EXAC_PK PRIMARY KEY(ID);\\012\\012-- Alter EXPERIMENT_ATTACHMENTS by adding the new column which has a NULL constraint.\\012-- The NOT NULL constraint is added later on.\\012ALTER TABLE EXPERIMENT_ATTACHMENTS ADD COLUMN EXAC_ID TECH_ID;\\012\\012-- Does the VALUE migration between EXPERIMENT_ATTACHMENTS to EXPERIMENT_ATTACHMENT_CONTENTS.\\012CREATE OR REPLACE FUNCTION move_exp_att_content() RETURNS integer AS $$\\012DECLARE\\012    rec RECORD;\\012    seq BIGINT;\\012BEGIN\\012  FOR rec IN SELECT id, value FROM EXPERIMENT_ATTACHMENTS LOOP\\012  \\011seq := nextval('EXPERIMENT_ATTACHMENT_CONTENT_ID_SEQ');\\012    INSERT INTO EXPERIMENT_ATTACHMENT_CONTENTS (id, value) VALUES (seq, rec.value);\\012    UPDATE EXPERIMENT_ATTACHMENTS SET exac_id = seq WHERE id = rec.id;\\012  END LOOP;\\012  RETURN 1;\\012END;\\012$$ LANGUAGE 'plpgsql';\\012\\012-- Call the function.\\012SELECT move_exp_att_content();\\012DROP FUNCTION move_exp_att_content();\\012\\012\\012-- Finish EXPERIMENT_ATTACHMENTS changes.\\012ALTER TABLE EXPERIMENT_ATTACHMENTS ADD CONSTRAINT EXAT_CONT_FK FOREIGN KEY (EXAC_ID) REFERENCES EXPERIMENT_ATTACHMENT_CONTENTS(ID);\\012ALTER TABLE EXPERIMENT_ATTACHMENTS DROP COLUMN VALUE;\\012ALTER TABLE EXPERIMENT_ATTACHMENTS ALTER COLUMN EXAC_ID SET NOT NULL;\\012	\N
+./sourceTest/sql/postgresql/029/.svn/text-base/009=database_version_logs.tsv.svn-base:029	source/sql/postgresql/migration/migration-028-029.sql	SUCCESS	2009-03-18 10:50:20.105	-- -------\\012-- add modification_timestamp field to allow edition with Hibernate\\012-- -------\\012\\012ALTER TABLE samples\\012\\011ADD COLUMN modification_timestamp TIME_STAMP DEFAULT CURRENT_TIMESTAMP;\\012\\012ALTER TABLE experiments\\012\\011ADD COLUMN modification_timestamp TIME_STAMP DEFAULT CURRENT_TIMESTAMP;\\012\\012ALTER TABLE materials\\012\\011ADD COLUMN modification_timestamp TIME_STAMP DEFAULT CURRENT_TIMESTAMP;\\012\\012ALTER TABLE experiment_properties\\012\\011ADD COLUMN modification_timestamp TIME_STAMP DEFAULT CURRENT_TIMESTAMP;\\012\\012ALTER TABLE material_properties\\012\\011ADD COLUMN modification_timestamp TIME_STAMP DEFAULT CURRENT_TIMESTAMP;\\012\\012ALTER TABLE sample_properties\\012\\011ADD COLUMN modification_timestamp TIME_STAMP DEFAULT CURRENT_TIMESTAMP;\\012\\012-- -------\\012-- add property data type which references materials\\012-- -------\\012\\012ALTER TABLE property_types\\012\\011ADD COLUMN maty_prop_id tech_id;\\012\\012ALTER TABLE property_types\\012\\011ADD CONSTRAINT prty_maty_fk FOREIGN KEY (maty_prop_id) REFERENCES material_types(id);\\012\\012ALTER TABLE experiment_properties\\012\\011ADD COLUMN mate_prop_id tech_id;\\012\\012ALTER TABLE material_properties\\012\\011ADD COLUMN mate_prop_id tech_id;\\012\\012ALTER TABLE sample_properties\\012\\011ADD COLUMN mate_prop_id tech_id;\\012\\012ALTER TABLE experiment_properties\\012\\011ADD CONSTRAINT expr_mapr_fk FOREIGN KEY (mate_prop_id) REFERENCES materials(id);\\012\\012ALTER TABLE material_properties\\012\\011ADD CONSTRAINT mapr_mapr_fk FOREIGN KEY (mate_prop_id) REFERENCES materials(id);\\012\\012ALTER TABLE sample_properties\\012\\011ADD CONSTRAINT sapr_mapr_fk FOREIGN KEY (mate_prop_id) REFERENCES materials(id);\\012\\012insert into data_types\\012(id\\012 ,code\\012 ,description)\\012 values \\012 (nextval('DATA_TYPE_ID_SEQ')\\012 ,'MATERIAL'\\012 ,'Reference to a material'\\012);\\012\\012ALTER TABLE MATERIAL_PROPERTIES DROP CONSTRAINT MAPR_CK;\\012ALTER TABLE MATERIAL_PROPERTIES ADD CONSTRAINT MAPR_CK CHECK \\012\\011((VALUE IS NOT NULL AND CVTE_ID IS NULL AND MATE_PROP_ID IS NULL) OR \\012\\011 (VALUE IS NULL AND CVTE_ID IS NOT NULL AND MATE_PROP_ID IS NULL) OR\\012\\011 (VALUE IS NULL AND CVTE_ID IS NULL AND MATE_PROP_ID IS NOT NULL)\\012\\011);\\012\\012ALTER TABLE EXPERIMENT_PROPERTIES DROP CONSTRAINT EXPR_CK;\\012ALTER TABLE EXPERIMENT_PROPERTIES ADD CONSTRAINT EXPR_CK CHECK \\012\\011((VALUE IS NOT NULL AND CVTE_ID IS NULL AND MATE_PROP_ID IS NULL) OR \\012\\011 (VALUE IS NULL AND CVTE_ID IS NOT NULL AND MATE_PROP_ID IS NULL) OR\\012\\011 (VALUE IS NULL AND CVTE_ID IS NULL AND MATE_PROP_ID IS NOT NULL)\\012\\011);\\012\\012ALTER TABLE SAMPLE_PROPERTIES DROP CONSTRAINT SAPR_CK;\\012ALTER TABLE SAMPLE_PROPERTIES ADD CONSTRAINT SAPR_CK CHECK \\012\\011((VALUE IS NOT NULL AND CVTE_ID IS NULL AND MATE_PROP_ID IS NULL) OR \\012\\011 (VALUE IS NULL AND CVTE_ID IS NOT NULL AND MATE_PROP_ID IS NULL) OR\\012\\011 (VALUE IS NULL AND CVTE_ID IS NULL AND MATE_PROP_ID IS NOT NULL)\\012\\011);\\012\\012------------------------------------------------------------------------------------\\012--  Purpose:  Create trigger MATERIAL/SAMPLE/EXPERIMENT _PROPERTY_WITH_MATERIAL_DATA_TYPE_CHECK\\012--            It checks that if material property value is assigned to the entity,\\012--\\011\\011\\011\\011\\011\\011then the material type is equal to the one described by property type.\\012------------------------------------------------------------------------------------\\012\\012CREATE OR REPLACE FUNCTION MATERIAL_PROPERTY_WITH_MATERIAL_DATA_TYPE_CHECK() RETURNS trigger AS $$\\012DECLARE\\012   v_type_id  CODE;\\012   v_type_id_prop  CODE;\\012BEGIN\\012   if NEW.mate_prop_id IS NOT NULL then\\012\\011\\011\\011-- find material type id of the property type \\012\\011\\011\\011select pt.maty_prop_id into v_type_id_prop \\012\\011\\011\\011  from material_type_property_types etpt, property_types pt \\012\\011\\011\\011 where NEW.mtpt_id = etpt.id AND etpt.prty_id = pt.id;\\012\\011\\011\\012\\011\\011\\011if v_type_id_prop IS NOT NULL then\\012\\011\\011\\011\\011-- find material type id of the material which consists the entity's property value\\012\\011\\011\\011\\011select entity.maty_id into v_type_id \\012\\011\\011\\011\\011  from materials entity\\012\\011\\011\\011\\011 where NEW.mate_prop_id = entity.id;\\012\\011\\011\\011\\011if v_type_id != v_type_id_prop then\\012\\011\\011\\011\\011\\011RAISE EXCEPTION 'Insert/Update of property value referencing material (id: %) failed, as referenced material type is different than expected (id %, expected id: %).', \\012\\011\\011\\011\\011\\011\\011\\011 NEW.mate_prop_id, v_type_id, v_type_id_prop;\\012\\011\\011\\011\\011end if;\\012\\011\\011\\011end if;\\012   end if;\\012   RETURN NEW;\\012END;\\012$$ LANGUAGE 'plpgsql';\\012\\012CREATE TRIGGER MATERIAL_PROPERTY_WITH_MATERIAL_DATA_TYPE_CHECK BEFORE INSERT OR UPDATE ON material_properties\\012    FOR EACH ROW EXECUTE PROCEDURE MATERIAL_PROPERTY_WITH_MATERIAL_DATA_TYPE_CHECK();\\012    \\012CREATE OR REPLACE FUNCTION SAMPLE_PROPERTY_WITH_MATERIAL_DATA_TYPE_CHECK() RETURNS trigger AS $$\\012DECLARE\\012   v_type_id  CODE;\\012   v_type_id_prop  CODE;\\012BEGIN\\012   if NEW.mate_prop_id IS NOT NULL then\\012\\011\\011\\011-- find material type id of the property type \\012\\011\\011\\011select pt.maty_prop_id into v_type_id_prop \\012\\011\\011\\011  from sample_type_property_types etpt, property_types pt \\012\\011\\011\\011 where NEW.stpt_id = etpt.id AND etpt.prty_id = pt.id;\\012\\011\\011\\012\\011\\011\\011if v_type_id_prop IS NOT NULL then\\012\\011\\011\\011\\011-- find material type id of the material which consists the entity's property value\\012\\011\\011\\011\\011select entity.maty_id into v_type_id \\012\\011\\011\\011\\011  from materials entity\\012\\011\\011\\011\\011 where NEW.mate_prop_id = entity.id;\\012\\011\\011\\011\\011if v_type_id != v_type_id_prop then\\012\\011\\011\\011\\011\\011RAISE EXCEPTION 'Insert/Update of property value referencing material (id: %) failed, as referenced material type is different than expected (id %, expected id: %).', \\012\\011\\011\\011\\011\\011\\011\\011\\011\\011\\011\\011\\011 NEW.mate_prop_id, v_type_id, v_type_id_prop;\\012\\011\\011\\011\\011end if;\\012\\011\\011\\011end if;\\012   end if;\\012   RETURN NEW;\\012END;\\012$$ LANGUAGE 'plpgsql';\\012\\012CREATE TRIGGER SAMPLE_PROPERTY_WITH_MATERIAL_DATA_TYPE_CHECK BEFORE INSERT OR UPDATE ON sample_properties\\012    FOR EACH ROW EXECUTE PROCEDURE SAMPLE_PROPERTY_WITH_MATERIAL_DATA_TYPE_CHECK();\\012    \\012CREATE OR REPLACE FUNCTION EXPERIMENT_PROPERTY_WITH_MATERIAL_DATA_TYPE_CHECK() RETURNS trigger AS $$\\012DECLARE\\012   v_type_id  CODE;\\012   v_type_id_prop  CODE;\\012BEGIN\\012   if NEW.mate_prop_id IS NOT NULL then\\012\\011\\011\\011-- find material type id of the property type \\012\\011\\011\\011select pt.maty_prop_id into v_type_id_prop \\012\\011\\011\\011  from experiment_type_property_types etpt, property_types pt \\012\\011\\011\\011 where NEW.etpt_id = etpt.id AND etpt.prty_id = pt.id;\\012\\011\\011\\012\\011\\011\\011if v_type_id_prop IS NOT NULL then\\012\\011\\011\\011\\011-- find material type id of the material which consists the entity's property value\\012\\011\\011\\011\\011select entity.maty_id into v_type_id \\012\\011\\011\\011\\011  from materials entity\\012\\011\\011\\011\\011 where NEW.mate_prop_id = entity.id;\\012\\011\\011\\011\\011if v_type_id != v_type_id_prop then\\012\\011\\011\\011\\011\\011RAISE EXCEPTION 'Insert/Update of property value referencing material (id: %) failed, as referenced material type is different than expected (id %, expected id: %).', \\012\\011\\011\\011\\011\\011\\011\\011\\011\\011\\011\\011\\011 NEW.mate_prop_id, v_type_id, v_type_id_prop;\\012\\011\\011\\011\\011end if;\\012\\011\\011\\011end if;\\012   end if;\\012   RETURN NEW;\\012END;\\012$$ LANGUAGE 'plpgsql';\\012\\012CREATE TRIGGER EXPERIMENT_PROPERTY_WITH_MATERIAL_DATA_TYPE_CHECK BEFORE INSERT OR UPDATE ON experiment_properties\\012    FOR EACH ROW EXECUTE PROCEDURE EXPERIMENT_PROPERTY_WITH_MATERIAL_DATA_TYPE_CHECK();\\012       \\012-- -------\\012-- remove the reminescents of the OBSERVABLE_TYPE\\012-- -------\\012\\012ALTER TABLE data\\012\\011DROP CONSTRAINT data_obty_fk;\\012\\012ALTER TABLE data_set_types\\012\\011DROP CONSTRAINT obty_pk;\\012\\012ALTER TABLE data_set_types\\012\\011ADD CONSTRAINT dsty_pk PRIMARY KEY (id);\\012\\012ALTER TABLE data\\012\\011ADD CONSTRAINT data_dsty_fk FOREIGN KEY (dsty_id) REFERENCES data_set_types(id);\\012\\012ALTER TABLE data_set_types\\012\\011DROP CONSTRAINT obty_bk_uk;\\012\\012ALTER TABLE data_set_types\\012\\011DROP CONSTRAINT obty_dbin_fk;\\012\\012ALTER TABLE data_set_types\\012\\011ADD CONSTRAINT dsty_bk_uk UNIQUE (code, dbin_id);\\012\\012ALTER TABLE data_set_types\\012\\011ADD CONSTRAINT dsty_dbin_fk FOREIGN KEY (dbin_id) REFERENCES database_instances(id);\\012\\012DROP INDEX data_obty_fk_i;\\012\\012CREATE INDEX data_dsty_fk_i ON data(dsty_id);\\012	\N
+./sourceTest/sql/postgresql/029/.svn/text-base/schema-029.sql.svn-base:    LANGUAGE plpgsql;
+./sourceTest/sql/postgresql/029/.svn/text-base/schema-029.sql.svn-base:    LANGUAGE plpgsql;
+./sourceTest/sql/postgresql/029/.svn/text-base/schema-029.sql.svn-base:    LANGUAGE plpgsql;
+./sourceTest/sql/postgresql/029/.svn/text-base/schema-029.sql.svn-base:    LANGUAGE plpgsql;
+./sourceTest/sql/postgresql/029/.svn/text-base/schema-029.sql.svn-base:    LANGUAGE plpgsql;
+./sourceTest/sql/postgresql/029/.svn/text-base/schema-029.sql.svn-base:    LANGUAGE plpgsql;
+./sourceTest/sql/postgresql/029/.svn/text-base/schema-029.sql.svn-base:    LANGUAGE plpgsql;
+./sourceTest/sql/postgresql/029/009=database_version_logs.tsv:027	D:\\User\\felmer\\dev-workspace\\openbis/source/sql/postgresql/027/function-027.sql	SUCCESS	2008-11-05 09:18:00.403	-- Creating Functions\\012\\012------------------------------------------------------------------------------------\\012--  Purpose:  Create function RENAME_SEQUENCE() that is required for renaming the sequences belonging to tables\\012------------------------------------------------------------------------------------\\012CREATE FUNCTION RENAME_SEQUENCE(OLD_NAME VARCHAR, NEW_NAME VARCHAR) RETURNS INTEGER AS $$\\012DECLARE\\012  CURR_SEQ_VAL   INTEGER;\\012BEGIN\\012  SELECT INTO CURR_SEQ_VAL NEXTVAL(OLD_NAME);\\012  EXECUTE 'CREATE SEQUENCE ' || NEW_NAME || ' START WITH ' || CURR_SEQ_VAL;\\012  EXECUTE 'DROP SEQUENCE ' || OLD_NAME;\\012  RETURN CURR_SEQ_VAL;\\012END;\\012$$ LANGUAGE 'plpgsql';\\012\\012\\012------------------------------------------------------------------------------------\\012--  Purpose:  Create trigger CONTROLLED_VOCABULARY_CHECK \\012------------------------------------------------------------------------------------\\012\\012CREATE OR REPLACE FUNCTION CONTROLLED_VOCABULARY_CHECK() RETURNS trigger AS $$\\012DECLARE\\012   v_code  CODE;\\012BEGIN\\012\\012   select code into v_code from data_types where id = NEW.daty_id;\\012\\012   -- Check if the data is of type "CONTROLLEDVOCABULARY"\\012   if v_code = 'CONTROLLEDVOCABULARY' then\\012      if NEW.covo_id IS NULL then\\012         RAISE EXCEPTION 'Insert/Update of Property Type (Code: %) failed, as its Data Type is CONTROLLEDVOCABULARY, but it is not linked to a Controlled Vocabulary.', NEW.code;\\012      end if;\\012   end if;\\012\\012   RETURN NEW;\\012\\012END;\\012$$ LANGUAGE 'plpgsql';\\012\\012CREATE TRIGGER CONTROLLED_VOCABULARY_CHECK BEFORE INSERT OR UPDATE ON PROPERTY_TYPES\\012    FOR EACH ROW EXECUTE PROCEDURE CONTROLLED_VOCABULARY_CHECK();\\012\\012\\012------------------------------------------------------------------------------------\\012--  Purpose:  Create trigger EXTERNAL_DATA_STORAGE_FORMAT_CHECK \\012------------------------------------------------------------------------------------\\012\\012CREATE OR REPLACE FUNCTION EXTERNAL_DATA_STORAGE_FORMAT_CHECK() RETURNS trigger AS $$\\012DECLARE\\012   v_covo_code  CODE;\\012   data_code CODE;\\012BEGIN\\012\\012   select code into v_covo_code from controlled_vocabularies\\012      where is_internal_namespace = true and \\012         id = (select covo_id from controlled_vocabulary_terms where id = NEW.cvte_id_stor_fmt);\\012   -- Check if the data storage format is a term of the controlled vocabulary "STORAGE_FORMAT"\\012   if v_covo_code != 'STORAGE_FORMAT' then\\012      select code into data_code from data where id = NEW.data_id; \\012      RAISE EXCEPTION 'Insert/Update of Data (Code: %) failed, as its Storage Format is %, but is required to be STORAGE_FORMAT.', data_code, v_covo_code;\\012   end if;\\012\\012   RETURN NEW;\\012\\012END;\\012$$ LANGUAGE 'plpgsql';\\012\\012CREATE TRIGGER EXTERNAL_DATA_STORAGE_FORMAT_CHECK BEFORE INSERT OR UPDATE ON EXTERNAL_DATA\\012    FOR EACH ROW EXECUTE PROCEDURE EXTERNAL_DATA_STORAGE_FORMAT_CHECK();\\012\\012------------------------------------------------------------------------------------\\012--  Purpose:  Create trigger SAMPLE_CODE_UNIQUENESS_CHECK \\012------------------------------------------------------------------------------------\\012\\012CREATE OR REPLACE FUNCTION SAMPLE_CODE_UNIQUENESS_CHECK() RETURNS trigger AS $$\\012DECLARE\\012   counter  INTEGER;\\012BEGIN\\012\\011IF (NEW.samp_id_part_of is NULL) THEN\\012\\011\\011IF (NEW.dbin_id is not NULL) THEN\\012\\011\\011\\011SELECT count(*) into counter FROM samples \\012\\011\\011\\011\\011where id != NEW.id and code = NEW.code and samp_id_part_of is NULL and dbin_id = NEW.dbin_id;\\012\\011\\011\\011IF (counter > 0) THEN\\012\\011\\011\\011\\011RAISE EXCEPTION 'Insert/Update of Sample (Code: %) failed because database instance sample with the same code already exists.', NEW.code;\\012\\011\\011\\011END IF;\\012\\011\\011ELSIF (NEW.grou_id is not NULL) THEN\\012\\011\\011\\011SELECT count(*) into counter FROM samples \\012\\011\\011\\011\\011where id != NEW.id and code = NEW.code and samp_id_part_of is NULL and grou_id = NEW.grou_id;\\012\\011\\011\\011IF (counter > 0) THEN\\012\\011\\011\\011\\011RAISE EXCEPTION 'Insert/Update of Sample (Code: %) failed because group sample with the same code already exists.', NEW.code;\\012\\011\\011\\011END IF;\\012\\011\\011END IF;\\012        ELSE\\012\\011\\011IF (NEW.dbin_id is not NULL) THEN\\012\\011\\011\\011SELECT count(*) into counter FROM samples \\012\\011\\011\\011\\011where id != NEW.id and code = NEW.code and samp_id_part_of = NEW.samp_id_part_of and dbin_id = NEW.dbin_id;\\012\\011\\011\\011IF (counter > 0) THEN\\012\\011\\011\\011\\011RAISE EXCEPTION 'Insert/Update of Sample (Code: %) failed because database instance sample with the same code and being the part of the same parent already exists.', NEW.code;\\012\\011\\011\\011END IF;\\012\\011\\011ELSIF (NEW.grou_id is not NULL) THEN\\012\\011\\011\\011SELECT count(*) into counter FROM samples \\012\\011\\011\\011\\011where id != NEW.id and code = NEW.code and samp_id_part_of = NEW.samp_id_part_of and grou_id = NEW.grou_id;\\012\\011\\011\\011IF (counter > 0) THEN\\012\\011\\011\\011\\011RAISE EXCEPTION 'Insert/Update of Sample (Code: %) failed because group sample with the same code and being the part of the same parent already exists.', NEW.code;\\012\\011\\011\\011END IF;\\012\\011\\011END IF;\\012        END IF;   \\012   RETURN NEW;\\012END;\\012$$ LANGUAGE 'plpgsql';\\012\\012CREATE TRIGGER SAMPLE_CODE_UNIQUENESS_CHECK BEFORE INSERT OR UPDATE ON SAMPLES\\012    FOR EACH ROW EXECUTE PROCEDURE SAMPLE_CODE_UNIQUENESS_CHECK();\\012	\N
+./sourceTest/sql/postgresql/029/009=database_version_logs.tsv:028	source/sql/postgresql/migration/migration-027-028.sql	SUCCESS	2008-11-18 13:24:17.508	-- Create EXPERIMENT_ATTACHMENT_CONTENTS.\\012CREATE TABLE EXPERIMENT_ATTACHMENT_CONTENTS (ID TECH_ID NOT NULL,VALUE FILE NOT NULL);\\012CREATE SEQUENCE EXPERIMENT_ATTACHMENT_CONTENT_ID_SEQ;\\012ALTER TABLE EXPERIMENT_ATTACHMENT_CONTENTS ADD CONSTRAINT EXAC_PK PRIMARY KEY(ID);\\012\\012-- Alter EXPERIMENT_ATTACHMENTS by adding the new column which has a NULL constraint.\\012-- The NOT NULL constraint is added later on.\\012ALTER TABLE EXPERIMENT_ATTACHMENTS ADD COLUMN EXAC_ID TECH_ID;\\012\\012-- Does the VALUE migration between EXPERIMENT_ATTACHMENTS to EXPERIMENT_ATTACHMENT_CONTENTS.\\012CREATE OR REPLACE FUNCTION move_exp_att_content() RETURNS integer AS $$\\012DECLARE\\012    rec RECORD;\\012    seq BIGINT;\\012BEGIN\\012  FOR rec IN SELECT id, value FROM EXPERIMENT_ATTACHMENTS LOOP\\012  \\011seq := nextval('EXPERIMENT_ATTACHMENT_CONTENT_ID_SEQ');\\012    INSERT INTO EXPERIMENT_ATTACHMENT_CONTENTS (id, value) VALUES (seq, rec.value);\\012    UPDATE EXPERIMENT_ATTACHMENTS SET exac_id = seq WHERE id = rec.id;\\012  END LOOP;\\012  RETURN 1;\\012END;\\012$$ LANGUAGE 'plpgsql';\\012\\012-- Call the function.\\012SELECT move_exp_att_content();\\012DROP FUNCTION move_exp_att_content();\\012\\012\\012-- Finish EXPERIMENT_ATTACHMENTS changes.\\012ALTER TABLE EXPERIMENT_ATTACHMENTS ADD CONSTRAINT EXAT_CONT_FK FOREIGN KEY (EXAC_ID) REFERENCES EXPERIMENT_ATTACHMENT_CONTENTS(ID);\\012ALTER TABLE EXPERIMENT_ATTACHMENTS DROP COLUMN VALUE;\\012ALTER TABLE EXPERIMENT_ATTACHMENTS ALTER COLUMN EXAC_ID SET NOT NULL;\\012	\N
+./sourceTest/sql/postgresql/029/009=database_version_logs.tsv:029	source/sql/postgresql/migration/migration-028-029.sql	SUCCESS	2009-03-18 10:50:20.105	-- -------\\012-- add modification_timestamp field to allow edition with Hibernate\\012-- -------\\012\\012ALTER TABLE samples\\012\\011ADD COLUMN modification_timestamp TIME_STAMP DEFAULT CURRENT_TIMESTAMP;\\012\\012ALTER TABLE experiments\\012\\011ADD COLUMN modification_timestamp TIME_STAMP DEFAULT CURRENT_TIMESTAMP;\\012\\012ALTER TABLE materials\\012\\011ADD COLUMN modification_timestamp TIME_STAMP DEFAULT CURRENT_TIMESTAMP;\\012\\012ALTER TABLE experiment_properties\\012\\011ADD COLUMN modification_timestamp TIME_STAMP DEFAULT CURRENT_TIMESTAMP;\\012\\012ALTER TABLE material_properties\\012\\011ADD COLUMN modification_timestamp TIME_STAMP DEFAULT CURRENT_TIMESTAMP;\\012\\012ALTER TABLE sample_properties\\012\\011ADD COLUMN modification_timestamp TIME_STAMP DEFAULT CURRENT_TIMESTAMP;\\012\\012-- -------\\012-- add property data type which references materials\\012-- -------\\012\\012ALTER TABLE property_types\\012\\011ADD COLUMN maty_prop_id tech_id;\\012\\012ALTER TABLE property_types\\012\\011ADD CONSTRAINT prty_maty_fk FOREIGN KEY (maty_prop_id) REFERENCES material_types(id);\\012\\012ALTER TABLE experiment_properties\\012\\011ADD COLUMN mate_prop_id tech_id;\\012\\012ALTER TABLE material_properties\\012\\011ADD COLUMN mate_prop_id tech_id;\\012\\012ALTER TABLE sample_properties\\012\\011ADD COLUMN mate_prop_id tech_id;\\012\\012ALTER TABLE experiment_properties\\012\\011ADD CONSTRAINT expr_mapr_fk FOREIGN KEY (mate_prop_id) REFERENCES materials(id);\\012\\012ALTER TABLE material_properties\\012\\011ADD CONSTRAINT mapr_mapr_fk FOREIGN KEY (mate_prop_id) REFERENCES materials(id);\\012\\012ALTER TABLE sample_properties\\012\\011ADD CONSTRAINT sapr_mapr_fk FOREIGN KEY (mate_prop_id) REFERENCES materials(id);\\012\\012insert into data_types\\012(id\\012 ,code\\012 ,description)\\012 values \\012 (nextval('DATA_TYPE_ID_SEQ')\\012 ,'MATERIAL'\\012 ,'Reference to a material'\\012);\\012\\012ALTER TABLE MATERIAL_PROPERTIES DROP CONSTRAINT MAPR_CK;\\012ALTER TABLE MATERIAL_PROPERTIES ADD CONSTRAINT MAPR_CK CHECK \\012\\011((VALUE IS NOT NULL AND CVTE_ID IS NULL AND MATE_PROP_ID IS NULL) OR \\012\\011 (VALUE IS NULL AND CVTE_ID IS NOT NULL AND MATE_PROP_ID IS NULL) OR\\012\\011 (VALUE IS NULL AND CVTE_ID IS NULL AND MATE_PROP_ID IS NOT NULL)\\012\\011);\\012\\012ALTER TABLE EXPERIMENT_PROPERTIES DROP CONSTRAINT EXPR_CK;\\012ALTER TABLE EXPERIMENT_PROPERTIES ADD CONSTRAINT EXPR_CK CHECK \\012\\011((VALUE IS NOT NULL AND CVTE_ID IS NULL AND MATE_PROP_ID IS NULL) OR \\012\\011 (VALUE IS NULL AND CVTE_ID IS NOT NULL AND MATE_PROP_ID IS NULL) OR\\012\\011 (VALUE IS NULL AND CVTE_ID IS NULL AND MATE_PROP_ID IS NOT NULL)\\012\\011);\\012\\012ALTER TABLE SAMPLE_PROPERTIES DROP CONSTRAINT SAPR_CK;\\012ALTER TABLE SAMPLE_PROPERTIES ADD CONSTRAINT SAPR_CK CHECK \\012\\011((VALUE IS NOT NULL AND CVTE_ID IS NULL AND MATE_PROP_ID IS NULL) OR \\012\\011 (VALUE IS NULL AND CVTE_ID IS NOT NULL AND MATE_PROP_ID IS NULL) OR\\012\\011 (VALUE IS NULL AND CVTE_ID IS NULL AND MATE_PROP_ID IS NOT NULL)\\012\\011);\\012\\012------------------------------------------------------------------------------------\\012--  Purpose:  Create trigger MATERIAL/SAMPLE/EXPERIMENT _PROPERTY_WITH_MATERIAL_DATA_TYPE_CHECK\\012--            It checks that if material property value is assigned to the entity,\\012--\\011\\011\\011\\011\\011\\011then the material type is equal to the one described by property type.\\012------------------------------------------------------------------------------------\\012\\012CREATE OR REPLACE FUNCTION MATERIAL_PROPERTY_WITH_MATERIAL_DATA_TYPE_CHECK() RETURNS trigger AS $$\\012DECLARE\\012   v_type_id  CODE;\\012   v_type_id_prop  CODE;\\012BEGIN\\012   if NEW.mate_prop_id IS NOT NULL then\\012\\011\\011\\011-- find material type id of the property type \\012\\011\\011\\011select pt.maty_prop_id into v_type_id_prop \\012\\011\\011\\011  from material_type_property_types etpt, property_types pt \\012\\011\\011\\011 where NEW.mtpt_id = etpt.id AND etpt.prty_id = pt.id;\\012\\011\\011\\012\\011\\011\\011if v_type_id_prop IS NOT NULL then\\012\\011\\011\\011\\011-- find material type id of the material which consists the entity's property value\\012\\011\\011\\011\\011select entity.maty_id into v_type_id \\012\\011\\011\\011\\011  from materials entity\\012\\011\\011\\011\\011 where NEW.mate_prop_id = entity.id;\\012\\011\\011\\011\\011if v_type_id != v_type_id_prop then\\012\\011\\011\\011\\011\\011RAISE EXCEPTION 'Insert/Update of property value referencing material (id: %) failed, as referenced material type is different than expected (id %, expected id: %).', \\012\\011\\011\\011\\011\\011\\011\\011 NEW.mate_prop_id, v_type_id, v_type_id_prop;\\012\\011\\011\\011\\011end if;\\012\\011\\011\\011end if;\\012   end if;\\012   RETURN NEW;\\012END;\\012$$ LANGUAGE 'plpgsql';\\012\\012CREATE TRIGGER MATERIAL_PROPERTY_WITH_MATERIAL_DATA_TYPE_CHECK BEFORE INSERT OR UPDATE ON material_properties\\012    FOR EACH ROW EXECUTE PROCEDURE MATERIAL_PROPERTY_WITH_MATERIAL_DATA_TYPE_CHECK();\\012    \\012CREATE OR REPLACE FUNCTION SAMPLE_PROPERTY_WITH_MATERIAL_DATA_TYPE_CHECK() RETURNS trigger AS $$\\012DECLARE\\012   v_type_id  CODE;\\012   v_type_id_prop  CODE;\\012BEGIN\\012   if NEW.mate_prop_id IS NOT NULL then\\012\\011\\011\\011-- find material type id of the property type \\012\\011\\011\\011select pt.maty_prop_id into v_type_id_prop \\012\\011\\011\\011  from sample_type_property_types etpt, property_types pt \\012\\011\\011\\011 where NEW.stpt_id = etpt.id AND etpt.prty_id = pt.id;\\012\\011\\011\\012\\011\\011\\011if v_type_id_prop IS NOT NULL then\\012\\011\\011\\011\\011-- find material type id of the material which consists the entity's property value\\012\\011\\011\\011\\011select entity.maty_id into v_type_id \\012\\011\\011\\011\\011  from materials entity\\012\\011\\011\\011\\011 where NEW.mate_prop_id = entity.id;\\012\\011\\011\\011\\011if v_type_id != v_type_id_prop then\\012\\011\\011\\011\\011\\011RAISE EXCEPTION 'Insert/Update of property value referencing material (id: %) failed, as referenced material type is different than expected (id %, expected id: %).', \\012\\011\\011\\011\\011\\011\\011\\011\\011\\011\\011\\011\\011 NEW.mate_prop_id, v_type_id, v_type_id_prop;\\012\\011\\011\\011\\011end if;\\012\\011\\011\\011end if;\\012   end if;\\012   RETURN NEW;\\012END;\\012$$ LANGUAGE 'plpgsql';\\012\\012CREATE TRIGGER SAMPLE_PROPERTY_WITH_MATERIAL_DATA_TYPE_CHECK BEFORE INSERT OR UPDATE ON sample_properties\\012    FOR EACH ROW EXECUTE PROCEDURE SAMPLE_PROPERTY_WITH_MATERIAL_DATA_TYPE_CHECK();\\012    \\012CREATE OR REPLACE FUNCTION EXPERIMENT_PROPERTY_WITH_MATERIAL_DATA_TYPE_CHECK() RETURNS trigger AS $$\\012DECLARE\\012   v_type_id  CODE;\\012   v_type_id_prop  CODE;\\012BEGIN\\012   if NEW.mate_prop_id IS NOT NULL then\\012\\011\\011\\011-- find material type id of the property type \\012\\011\\011\\011select pt.maty_prop_id into v_type_id_prop \\012\\011\\011\\011  from experiment_type_property_types etpt, property_types pt \\012\\011\\011\\011 where NEW.etpt_id = etpt.id AND etpt.prty_id = pt.id;\\012\\011\\011\\012\\011\\011\\011if v_type_id_prop IS NOT NULL then\\012\\011\\011\\011\\011-- find material type id of the material which consists the entity's property value\\012\\011\\011\\011\\011select entity.maty_id into v_type_id \\012\\011\\011\\011\\011  from materials entity\\012\\011\\011\\011\\011 where NEW.mate_prop_id = entity.id;\\012\\011\\011\\011\\011if v_type_id != v_type_id_prop then\\012\\011\\011\\011\\011\\011RAISE EXCEPTION 'Insert/Update of property value referencing material (id: %) failed, as referenced material type is different than expected (id %, expected id: %).', \\012\\011\\011\\011\\011\\011\\011\\011\\011\\011\\011\\011\\011 NEW.mate_prop_id, v_type_id, v_type_id_prop;\\012\\011\\011\\011\\011end if;\\012\\011\\011\\011end if;\\012   end if;\\012   RETURN NEW;\\012END;\\012$$ LANGUAGE 'plpgsql';\\012\\012CREATE TRIGGER EXPERIMENT_PROPERTY_WITH_MATERIAL_DATA_TYPE_CHECK BEFORE INSERT OR UPDATE ON experiment_properties\\012    FOR EACH ROW EXECUTE PROCEDURE EXPERIMENT_PROPERTY_WITH_MATERIAL_DATA_TYPE_CHECK();\\012       \\012-- -------\\012-- remove the reminescents of the OBSERVABLE_TYPE\\012-- -------\\012\\012ALTER TABLE data\\012\\011DROP CONSTRAINT data_obty_fk;\\012\\012ALTER TABLE data_set_types\\012\\011DROP CONSTRAINT obty_pk;\\012\\012ALTER TABLE data_set_types\\012\\011ADD CONSTRAINT dsty_pk PRIMARY KEY (id);\\012\\012ALTER TABLE data\\012\\011ADD CONSTRAINT data_dsty_fk FOREIGN KEY (dsty_id) REFERENCES data_set_types(id);\\012\\012ALTER TABLE data_set_types\\012\\011DROP CONSTRAINT obty_bk_uk;\\012\\012ALTER TABLE data_set_types\\012\\011DROP CONSTRAINT obty_dbin_fk;\\012\\012ALTER TABLE data_set_types\\012\\011ADD CONSTRAINT dsty_bk_uk UNIQUE (code, dbin_id);\\012\\012ALTER TABLE data_set_types\\012\\011ADD CONSTRAINT dsty_dbin_fk FOREIGN KEY (dbin_id) REFERENCES database_instances(id);\\012\\012DROP INDEX data_obty_fk_i;\\012\\012CREATE INDEX data_dsty_fk_i ON data(dsty_id);\\012	\N
+./sourceTest/sql/postgresql/029/schema-029.sql:    LANGUAGE plpgsql;
+./sourceTest/sql/postgresql/029/schema-029.sql:    LANGUAGE plpgsql;
+./sourceTest/sql/postgresql/029/schema-029.sql:    LANGUAGE plpgsql;
+./sourceTest/sql/postgresql/029/schema-029.sql:    LANGUAGE plpgsql;
+./sourceTest/sql/postgresql/029/schema-029.sql:    LANGUAGE plpgsql;
+./sourceTest/sql/postgresql/029/schema-029.sql:    LANGUAGE plpgsql;
+./sourceTest/sql/postgresql/029/schema-029.sql:    LANGUAGE plpgsql;
+./sourceTest/sql/postgresql/030/.svn/text-base/011=database_version_logs.tsv.svn-base:027	D:\\User\\felmer\\dev-workspace\\openbis/source/sql/postgresql/027/function-027.sql	SUCCESS	2008-11-05 09:18:00.403	-- Creating Functions\\012\\012------------------------------------------------------------------------------------\\012--  Purpose:  Create function RENAME_SEQUENCE() that is required for renaming the sequences belonging to tables\\012------------------------------------------------------------------------------------\\012CREATE FUNCTION RENAME_SEQUENCE(OLD_NAME VARCHAR, NEW_NAME VARCHAR) RETURNS INTEGER AS $$\\012DECLARE\\012  CURR_SEQ_VAL   INTEGER;\\012BEGIN\\012  SELECT INTO CURR_SEQ_VAL NEXTVAL(OLD_NAME);\\012  EXECUTE 'CREATE SEQUENCE ' || NEW_NAME || ' START WITH ' || CURR_SEQ_VAL;\\012  EXECUTE 'DROP SEQUENCE ' || OLD_NAME;\\012  RETURN CURR_SEQ_VAL;\\012END;\\012$$ LANGUAGE 'plpgsql';\\012\\012\\012------------------------------------------------------------------------------------\\012--  Purpose:  Create trigger CONTROLLED_VOCABULARY_CHECK \\012------------------------------------------------------------------------------------\\012\\012CREATE OR REPLACE FUNCTION CONTROLLED_VOCABULARY_CHECK() RETURNS trigger AS $$\\012DECLARE\\012   v_code  CODE;\\012BEGIN\\012\\012   select code into v_code from data_types where id = NEW.daty_id;\\012\\012   -- Check if the data is of type "CONTROLLEDVOCABULARY"\\012   if v_code = 'CONTROLLEDVOCABULARY' then\\012      if NEW.covo_id IS NULL then\\012         RAISE EXCEPTION 'Insert/Update of Property Type (Code: %) failed, as its Data Type is CONTROLLEDVOCABULARY, but it is not linked to a Controlled Vocabulary.', NEW.code;\\012      end if;\\012   end if;\\012\\012   RETURN NEW;\\012\\012END;\\012$$ LANGUAGE 'plpgsql';\\012\\012CREATE TRIGGER CONTROLLED_VOCABULARY_CHECK BEFORE INSERT OR UPDATE ON PROPERTY_TYPES\\012    FOR EACH ROW EXECUTE PROCEDURE CONTROLLED_VOCABULARY_CHECK();\\012\\012\\012------------------------------------------------------------------------------------\\012--  Purpose:  Create trigger EXTERNAL_DATA_STORAGE_FORMAT_CHECK \\012------------------------------------------------------------------------------------\\012\\012CREATE OR REPLACE FUNCTION EXTERNAL_DATA_STORAGE_FORMAT_CHECK() RETURNS trigger AS $$\\012DECLARE\\012   v_covo_code  CODE;\\012   data_code CODE;\\012BEGIN\\012\\012   select code into v_covo_code from controlled_vocabularies\\012      where is_internal_namespace = true and \\012         id = (select covo_id from controlled_vocabulary_terms where id = NEW.cvte_id_stor_fmt);\\012   -- Check if the data storage format is a term of the controlled vocabulary "STORAGE_FORMAT"\\012   if v_covo_code != 'STORAGE_FORMAT' then\\012      select code into data_code from data where id = NEW.data_id; \\012      RAISE EXCEPTION 'Insert/Update of Data (Code: %) failed, as its Storage Format is %, but is required to be STORAGE_FORMAT.', data_code, v_covo_code;\\012   end if;\\012\\012   RETURN NEW;\\012\\012END;\\012$$ LANGUAGE 'plpgsql';\\012\\012CREATE TRIGGER EXTERNAL_DATA_STORAGE_FORMAT_CHECK BEFORE INSERT OR UPDATE ON EXTERNAL_DATA\\012    FOR EACH ROW EXECUTE PROCEDURE EXTERNAL_DATA_STORAGE_FORMAT_CHECK();\\012\\012------------------------------------------------------------------------------------\\012--  Purpose:  Create trigger SAMPLE_CODE_UNIQUENESS_CHECK \\012------------------------------------------------------------------------------------\\012\\012CREATE OR REPLACE FUNCTION SAMPLE_CODE_UNIQUENESS_CHECK() RETURNS trigger AS $$\\012DECLARE\\012   counter  INTEGER;\\012BEGIN\\012\\011IF (NEW.samp_id_part_of is NULL) THEN\\012\\011\\011IF (NEW.dbin_id is not NULL) THEN\\012\\011\\011\\011SELECT count(*) into counter FROM samples \\012\\011\\011\\011\\011where id != NEW.id and code = NEW.code and samp_id_part_of is NULL and dbin_id = NEW.dbin_id;\\012\\011\\011\\011IF (counter > 0) THEN\\012\\011\\011\\011\\011RAISE EXCEPTION 'Insert/Update of Sample (Code: %) failed because database instance sample with the same code already exists.', NEW.code;\\012\\011\\011\\011END IF;\\012\\011\\011ELSIF (NEW.grou_id is not NULL) THEN\\012\\011\\011\\011SELECT count(*) into counter FROM samples \\012\\011\\011\\011\\011where id != NEW.id and code = NEW.code and samp_id_part_of is NULL and grou_id = NEW.grou_id;\\012\\011\\011\\011IF (counter > 0) THEN\\012\\011\\011\\011\\011RAISE EXCEPTION 'Insert/Update of Sample (Code: %) failed because group sample with the same code already exists.', NEW.code;\\012\\011\\011\\011END IF;\\012\\011\\011END IF;\\012        ELSE\\012\\011\\011IF (NEW.dbin_id is not NULL) THEN\\012\\011\\011\\011SELECT count(*) into counter FROM samples \\012\\011\\011\\011\\011where id != NEW.id and code = NEW.code and samp_id_part_of = NEW.samp_id_part_of and dbin_id = NEW.dbin_id;\\012\\011\\011\\011IF (counter > 0) THEN\\012\\011\\011\\011\\011RAISE EXCEPTION 'Insert/Update of Sample (Code: %) failed because database instance sample with the same code and being the part of the same parent already exists.', NEW.code;\\012\\011\\011\\011END IF;\\012\\011\\011ELSIF (NEW.grou_id is not NULL) THEN\\012\\011\\011\\011SELECT count(*) into counter FROM samples \\012\\011\\011\\011\\011where id != NEW.id and code = NEW.code and samp_id_part_of = NEW.samp_id_part_of and grou_id = NEW.grou_id;\\012\\011\\011\\011IF (counter > 0) THEN\\012\\011\\011\\011\\011RAISE EXCEPTION 'Insert/Update of Sample (Code: %) failed because group sample with the same code and being the part of the same parent already exists.', NEW.code;\\012\\011\\011\\011END IF;\\012\\011\\011END IF;\\012        END IF;   \\012   RETURN NEW;\\012END;\\012$$ LANGUAGE 'plpgsql';\\012\\012CREATE TRIGGER SAMPLE_CODE_UNIQUENESS_CHECK BEFORE INSERT OR UPDATE ON SAMPLES\\012    FOR EACH ROW EXECUTE PROCEDURE SAMPLE_CODE_UNIQUENESS_CHECK();\\012	\N
+./sourceTest/sql/postgresql/030/.svn/text-base/011=database_version_logs.tsv.svn-base:028	source/sql/postgresql/migration/migration-027-028.sql	SUCCESS	2008-11-18 13:24:17.508	-- Create EXPERIMENT_ATTACHMENT_CONTENTS.\\012CREATE TABLE EXPERIMENT_ATTACHMENT_CONTENTS (ID TECH_ID NOT NULL,VALUE FILE NOT NULL);\\012CREATE SEQUENCE EXPERIMENT_ATTACHMENT_CONTENT_ID_SEQ;\\012ALTER TABLE EXPERIMENT_ATTACHMENT_CONTENTS ADD CONSTRAINT EXAC_PK PRIMARY KEY(ID);\\012\\012-- Alter EXPERIMENT_ATTACHMENTS by adding the new column which has a NULL constraint.\\012-- The NOT NULL constraint is added later on.\\012ALTER TABLE EXPERIMENT_ATTACHMENTS ADD COLUMN EXAC_ID TECH_ID;\\012\\012-- Does the VALUE migration between EXPERIMENT_ATTACHMENTS to EXPERIMENT_ATTACHMENT_CONTENTS.\\012CREATE OR REPLACE FUNCTION move_exp_att_content() RETURNS integer AS $$\\012DECLARE\\012    rec RECORD;\\012    seq BIGINT;\\012BEGIN\\012  FOR rec IN SELECT id, value FROM EXPERIMENT_ATTACHMENTS LOOP\\012  \\011seq := nextval('EXPERIMENT_ATTACHMENT_CONTENT_ID_SEQ');\\012    INSERT INTO EXPERIMENT_ATTACHMENT_CONTENTS (id, value) VALUES (seq, rec.value);\\012    UPDATE EXPERIMENT_ATTACHMENTS SET exac_id = seq WHERE id = rec.id;\\012  END LOOP;\\012  RETURN 1;\\012END;\\012$$ LANGUAGE 'plpgsql';\\012\\012-- Call the function.\\012SELECT move_exp_att_content();\\012DROP FUNCTION move_exp_att_content();\\012\\012\\012-- Finish EXPERIMENT_ATTACHMENTS changes.\\012ALTER TABLE EXPERIMENT_ATTACHMENTS ADD CONSTRAINT EXAT_CONT_FK FOREIGN KEY (EXAC_ID) REFERENCES EXPERIMENT_ATTACHMENT_CONTENTS(ID);\\012ALTER TABLE EXPERIMENT_ATTACHMENTS DROP COLUMN VALUE;\\012ALTER TABLE EXPERIMENT_ATTACHMENTS ALTER COLUMN EXAC_ID SET NOT NULL;\\012	\N
+./sourceTest/sql/postgresql/030/.svn/text-base/011=database_version_logs.tsv.svn-base:029	source/sql/postgresql/migration/migration-028-029.sql	SUCCESS	2009-03-18 10:50:20.105	-- -------\\012-- add modification_timestamp field to allow edition with Hibernate\\012-- -------\\012\\012ALTER TABLE samples\\012\\011ADD COLUMN modification_timestamp TIME_STAMP DEFAULT CURRENT_TIMESTAMP;\\012\\012ALTER TABLE experiments\\012\\011ADD COLUMN modification_timestamp TIME_STAMP DEFAULT CURRENT_TIMESTAMP;\\012\\012ALTER TABLE materials\\012\\011ADD COLUMN modification_timestamp TIME_STAMP DEFAULT CURRENT_TIMESTAMP;\\012\\012ALTER TABLE experiment_properties\\012\\011ADD COLUMN modification_timestamp TIME_STAMP DEFAULT CURRENT_TIMESTAMP;\\012\\012ALTER TABLE material_properties\\012\\011ADD COLUMN modification_timestamp TIME_STAMP DEFAULT CURRENT_TIMESTAMP;\\012\\012ALTER TABLE sample_properties\\012\\011ADD COLUMN modification_timestamp TIME_STAMP DEFAULT CURRENT_TIMESTAMP;\\012\\012-- -------\\012-- add property data type which references materials\\012-- -------\\012\\012ALTER TABLE property_types\\012\\011ADD COLUMN maty_prop_id tech_id;\\012\\012ALTER TABLE property_types\\012\\011ADD CONSTRAINT prty_maty_fk FOREIGN KEY (maty_prop_id) REFERENCES material_types(id);\\012\\012ALTER TABLE experiment_properties\\012\\011ADD COLUMN mate_prop_id tech_id;\\012\\012ALTER TABLE material_properties\\012\\011ADD COLUMN mate_prop_id tech_id;\\012\\012ALTER TABLE sample_properties\\012\\011ADD COLUMN mate_prop_id tech_id;\\012\\012ALTER TABLE experiment_properties\\012\\011ADD CONSTRAINT expr_mapr_fk FOREIGN KEY (mate_prop_id) REFERENCES materials(id);\\012\\012ALTER TABLE material_properties\\012\\011ADD CONSTRAINT mapr_mapr_fk FOREIGN KEY (mate_prop_id) REFERENCES materials(id);\\012\\012ALTER TABLE sample_properties\\012\\011ADD CONSTRAINT sapr_mapr_fk FOREIGN KEY (mate_prop_id) REFERENCES materials(id);\\012\\012insert into data_types\\012(id\\012 ,code\\012 ,description)\\012 values \\012 (nextval('DATA_TYPE_ID_SEQ')\\012 ,'MATERIAL'\\012 ,'Reference to a material'\\012);\\012\\012ALTER TABLE MATERIAL_PROPERTIES DROP CONSTRAINT MAPR_CK;\\012ALTER TABLE MATERIAL_PROPERTIES ADD CONSTRAINT MAPR_CK CHECK \\012\\011((VALUE IS NOT NULL AND CVTE_ID IS NULL AND MATE_PROP_ID IS NULL) OR \\012\\011 (VALUE IS NULL AND CVTE_ID IS NOT NULL AND MATE_PROP_ID IS NULL) OR\\012\\011 (VALUE IS NULL AND CVTE_ID IS NULL AND MATE_PROP_ID IS NOT NULL)\\012\\011);\\012\\012ALTER TABLE EXPERIMENT_PROPERTIES DROP CONSTRAINT EXPR_CK;\\012ALTER TABLE EXPERIMENT_PROPERTIES ADD CONSTRAINT EXPR_CK CHECK \\012\\011((VALUE IS NOT NULL AND CVTE_ID IS NULL AND MATE_PROP_ID IS NULL) OR \\012\\011 (VALUE IS NULL AND CVTE_ID IS NOT NULL AND MATE_PROP_ID IS NULL) OR\\012\\011 (VALUE IS NULL AND CVTE_ID IS NULL AND MATE_PROP_ID IS NOT NULL)\\012\\011);\\012\\012ALTER TABLE SAMPLE_PROPERTIES DROP CONSTRAINT SAPR_CK;\\012ALTER TABLE SAMPLE_PROPERTIES ADD CONSTRAINT SAPR_CK CHECK \\012\\011((VALUE IS NOT NULL AND CVTE_ID IS NULL AND MATE_PROP_ID IS NULL) OR \\012\\011 (VALUE IS NULL AND CVTE_ID IS NOT NULL AND MATE_PROP_ID IS NULL) OR\\012\\011 (VALUE IS NULL AND CVTE_ID IS NULL AND MATE_PROP_ID IS NOT NULL)\\012\\011);\\012\\012------------------------------------------------------------------------------------\\012--  Purpose:  Create trigger MATERIAL/SAMPLE/EXPERIMENT _PROPERTY_WITH_MATERIAL_DATA_TYPE_CHECK\\012--            It checks that if material property value is assigned to the entity,\\012--\\011\\011\\011\\011\\011\\011then the material type is equal to the one described by property type.\\012------------------------------------------------------------------------------------\\012\\012CREATE OR REPLACE FUNCTION MATERIAL_PROPERTY_WITH_MATERIAL_DATA_TYPE_CHECK() RETURNS trigger AS $$\\012DECLARE\\012   v_type_id  CODE;\\012   v_type_id_prop  CODE;\\012BEGIN\\012   if NEW.mate_prop_id IS NOT NULL then\\012\\011\\011\\011-- find material type id of the property type \\012\\011\\011\\011select pt.maty_prop_id into v_type_id_prop \\012\\011\\011\\011  from material_type_property_types etpt, property_types pt \\012\\011\\011\\011 where NEW.mtpt_id = etpt.id AND etpt.prty_id = pt.id;\\012\\011\\011\\012\\011\\011\\011if v_type_id_prop IS NOT NULL then\\012\\011\\011\\011\\011-- find material type id of the material which consists the entity's property value\\012\\011\\011\\011\\011select entity.maty_id into v_type_id \\012\\011\\011\\011\\011  from materials entity\\012\\011\\011\\011\\011 where NEW.mate_prop_id = entity.id;\\012\\011\\011\\011\\011if v_type_id != v_type_id_prop then\\012\\011\\011\\011\\011\\011RAISE EXCEPTION 'Insert/Update of property value referencing material (id: %) failed, as referenced material type is different than expected (id %, expected id: %).', \\012\\011\\011\\011\\011\\011\\011\\011 NEW.mate_prop_id, v_type_id, v_type_id_prop;\\012\\011\\011\\011\\011end if;\\012\\011\\011\\011end if;\\012   end if;\\012   RETURN NEW;\\012END;\\012$$ LANGUAGE 'plpgsql';\\012\\012CREATE TRIGGER MATERIAL_PROPERTY_WITH_MATERIAL_DATA_TYPE_CHECK BEFORE INSERT OR UPDATE ON material_properties\\012    FOR EACH ROW EXECUTE PROCEDURE MATERIAL_PROPERTY_WITH_MATERIAL_DATA_TYPE_CHECK();\\012    \\012CREATE OR REPLACE FUNCTION SAMPLE_PROPERTY_WITH_MATERIAL_DATA_TYPE_CHECK() RETURNS trigger AS $$\\012DECLARE\\012   v_type_id  CODE;\\012   v_type_id_prop  CODE;\\012BEGIN\\012   if NEW.mate_prop_id IS NOT NULL then\\012\\011\\011\\011-- find material type id of the property type \\012\\011\\011\\011select pt.maty_prop_id into v_type_id_prop \\012\\011\\011\\011  from sample_type_property_types etpt, property_types pt \\012\\011\\011\\011 where NEW.stpt_id = etpt.id AND etpt.prty_id = pt.id;\\012\\011\\011\\012\\011\\011\\011if v_type_id_prop IS NOT NULL then\\012\\011\\011\\011\\011-- find material type id of the material which consists the entity's property value\\012\\011\\011\\011\\011select entity.maty_id into v_type_id \\012\\011\\011\\011\\011  from materials entity\\012\\011\\011\\011\\011 where NEW.mate_prop_id = entity.id;\\012\\011\\011\\011\\011if v_type_id != v_type_id_prop then\\012\\011\\011\\011\\011\\011RAISE EXCEPTION 'Insert/Update of property value referencing material (id: %) failed, as referenced material type is different than expected (id %, expected id: %).', \\012\\011\\011\\011\\011\\011\\011\\011\\011\\011\\011\\011\\011 NEW.mate_prop_id, v_type_id, v_type_id_prop;\\012\\011\\011\\011\\011end if;\\012\\011\\011\\011end if;\\012   end if;\\012   RETURN NEW;\\012END;\\012$$ LANGUAGE 'plpgsql';\\012\\012CREATE TRIGGER SAMPLE_PROPERTY_WITH_MATERIAL_DATA_TYPE_CHECK BEFORE INSERT OR UPDATE ON sample_properties\\012    FOR EACH ROW EXECUTE PROCEDURE SAMPLE_PROPERTY_WITH_MATERIAL_DATA_TYPE_CHECK();\\012    \\012CREATE OR REPLACE FUNCTION EXPERIMENT_PROPERTY_WITH_MATERIAL_DATA_TYPE_CHECK() RETURNS trigger AS $$\\012DECLARE\\012   v_type_id  CODE;\\012   v_type_id_prop  CODE;\\012BEGIN\\012   if NEW.mate_prop_id IS NOT NULL then\\012\\011\\011\\011-- find material type id of the property type \\012\\011\\011\\011select pt.maty_prop_id into v_type_id_prop \\012\\011\\011\\011  from experiment_type_property_types etpt, property_types pt \\012\\011\\011\\011 where NEW.etpt_id = etpt.id AND etpt.prty_id = pt.id;\\012\\011\\011\\012\\011\\011\\011if v_type_id_prop IS NOT NULL then\\012\\011\\011\\011\\011-- find material type id of the material which consists the entity's property value\\012\\011\\011\\011\\011select entity.maty_id into v_type_id \\012\\011\\011\\011\\011  from materials entity\\012\\011\\011\\011\\011 where NEW.mate_prop_id = entity.id;\\012\\011\\011\\011\\011if v_type_id != v_type_id_prop then\\012\\011\\011\\011\\011\\011RAISE EXCEPTION 'Insert/Update of property value referencing material (id: %) failed, as referenced material type is different than expected (id %, expected id: %).', \\012\\011\\011\\011\\011\\011\\011\\011\\011\\011\\011\\011\\011 NEW.mate_prop_id, v_type_id, v_type_id_prop;\\012\\011\\011\\011\\011end if;\\012\\011\\011\\011end if;\\012   end if;\\012   RETURN NEW;\\012END;\\012$$ LANGUAGE 'plpgsql';\\012\\012CREATE TRIGGER EXPERIMENT_PROPERTY_WITH_MATERIAL_DATA_TYPE_CHECK BEFORE INSERT OR UPDATE ON experiment_properties\\012    FOR EACH ROW EXECUTE PROCEDURE EXPERIMENT_PROPERTY_WITH_MATERIAL_DATA_TYPE_CHECK();\\012       \\012-- -------\\012-- remove the reminescents of the OBSERVABLE_TYPE\\012-- -------\\012\\012ALTER TABLE data\\012\\011DROP CONSTRAINT data_obty_fk;\\012\\012ALTER TABLE data_set_types\\012\\011DROP CONSTRAINT obty_pk;\\012\\012ALTER TABLE data_set_types\\012\\011ADD CONSTRAINT dsty_pk PRIMARY KEY (id);\\012\\012ALTER TABLE data\\012\\011ADD CONSTRAINT data_dsty_fk FOREIGN KEY (dsty_id) REFERENCES data_set_types(id);\\012\\012ALTER TABLE data_set_types\\012\\011DROP CONSTRAINT obty_bk_uk;\\012\\012ALTER TABLE data_set_types\\012\\011DROP CONSTRAINT obty_dbin_fk;\\012\\012ALTER TABLE data_set_types\\012\\011ADD CONSTRAINT dsty_bk_uk UNIQUE (code, dbin_id);\\012\\012ALTER TABLE data_set_types\\012\\011ADD CONSTRAINT dsty_dbin_fk FOREIGN KEY (dbin_id) REFERENCES database_instances(id);\\012\\012DROP INDEX data_obty_fk_i;\\012\\012CREATE INDEX data_dsty_fk_i ON data(dsty_id);\\012	\N
+./sourceTest/sql/postgresql/030/.svn/text-base/011=database_version_logs.tsv.svn-base:030	source/sql/postgresql/migration/migration-029-030.sql	SUCCESS	2009-03-23 15:34:44.72	-- -------\\012-- add modification_timestamp field to allow edition with Hibernate\\012-- -------\\012ALTER TABLE data\\012\\011ADD COLUMN modification_timestamp TIME_STAMP DEFAULT CURRENT_TIMESTAMP;\\012ALTER TABLE experiment_types\\012\\011ADD COLUMN modification_timestamp TIME_STAMP DEFAULT CURRENT_TIMESTAMP;\\012ALTER TABLE sample_types\\012\\011ADD COLUMN modification_timestamp TIME_STAMP DEFAULT CURRENT_TIMESTAMP;\\012ALTER TABLE material_types\\012\\011ADD COLUMN modification_timestamp TIME_STAMP DEFAULT CURRENT_TIMESTAMP;\\012ALTER TABLE data_set_types\\012\\011ADD COLUMN modification_timestamp TIME_STAMP DEFAULT CURRENT_TIMESTAMP;\\012ALTER TABLE controlled_vocabularies\\012\\011ADD COLUMN modification_timestamp TIME_STAMP DEFAULT CURRENT_TIMESTAMP;\\012-- -------\\012-- add properties to data sets\\012-- -------\\012CREATE TABLE DATA_SET_PROPERTIES (ID TECH_ID NOT NULL,DS_ID TECH_ID NOT NULL,DSTPT_ID TECH_ID NOT NULL,VALUE GENERIC_VALUE,CVTE_ID TECH_ID, MATE_PROP_ID TECH_ID, PERS_ID_REGISTERER TECH_ID NOT NULL,REGISTRATION_TIMESTAMP TIME_STAMP_DFL NOT NULL DEFAULT CURRENT_TIMESTAMP, MODIFICATION_TIMESTAMP TIME_STAMP DEFAULT CURRENT_TIMESTAMP);\\012CREATE TABLE DATA_SET_TYPE_PROPERTY_TYPES (ID TECH_ID NOT NULL,DSTY_ID TECH_ID NOT NULL,PRTY_ID TECH_ID NOT NULL,IS_MANDATORY BOOLEAN_CHAR NOT NULL DEFAULT 'F',IS_MANAGED_INTERNALLY BOOLEAN_CHAR NOT NULL DEFAULT 'F',PERS_ID_REGISTERER TECH_ID NOT NULL,REGISTRATION_TIMESTAMP TIME_STAMP_DFL NOT NULL DEFAULT CURRENT_TIMESTAMP);\\012\\012CREATE SEQUENCE DATA_SET_PROPERTY_ID_SEQ;\\012CREATE SEQUENCE DSTPT_ID_SEQ;\\012\\012ALTER TABLE DATA_SET_TYPE_PROPERTY_TYPES ADD CONSTRAINT DSTPT_PK PRIMARY KEY(ID);\\012ALTER TABLE DATA_SET_PROPERTIES ADD CONSTRAINT DSPR_PK PRIMARY KEY(ID);\\012\\012ALTER TABLE DATA_SET_TYPE_PROPERTY_TYPES ADD CONSTRAINT DSTPT_BK_UK UNIQUE(DSTY_ID,PRTY_ID);\\012ALTER TABLE DATA_SET_PROPERTIES ADD CONSTRAINT DSPR_BK_UK UNIQUE(DS_ID,DSTPT_ID);\\012\\012\\012ALTER TABLE DATA_SET_TYPE_PROPERTY_TYPES ADD CONSTRAINT DSTPT_DSTY_FK FOREIGN KEY (DSTY_ID) REFERENCES DATA_SET_TYPES(ID);\\012ALTER TABLE DATA_SET_TYPE_PROPERTY_TYPES ADD CONSTRAINT DSTPT_PERS_FK FOREIGN KEY (PERS_ID_REGISTERER) REFERENCES PERSONS(ID);\\012ALTER TABLE DATA_SET_TYPE_PROPERTY_TYPES ADD CONSTRAINT DSTPT_PRTY_FK FOREIGN KEY (PRTY_ID) REFERENCES PROPERTY_TYPES(ID);\\012ALTER TABLE DATA_SET_PROPERTIES ADD CONSTRAINT DSPR_CVTE_FK FOREIGN KEY (CVTE_ID) REFERENCES CONTROLLED_VOCABULARY_TERMS(ID);\\012ALTER TABLE DATA_SET_PROPERTIES ADD CONSTRAINT DSPR_DSTPT_FK FOREIGN KEY (DSTPT_ID) REFERENCES DATA_SET_TYPE_PROPERTY_TYPES(ID) ON DELETE CASCADE;\\012ALTER TABLE DATA_SET_PROPERTIES ADD CONSTRAINT DSPR_DS_FK FOREIGN KEY (DS_ID) REFERENCES DATA(ID);\\012ALTER TABLE DATA_SET_PROPERTIES ADD CONSTRAINT DSPR_PERS_FK FOREIGN KEY (PERS_ID_REGISTERER) REFERENCES PERSONS(ID);\\012ALTER TABLE DATA_SET_PROPERTIES ADD CONSTRAINT DSPR_MAPR_FK FOREIGN KEY (MATE_PROP_ID) REFERENCES MATERIALS(ID);\\012\\012ALTER TABLE DATA_SET_PROPERTIES ADD CONSTRAINT DSPR_CK CHECK \\012\\011((VALUE IS NOT NULL AND CVTE_ID IS NULL AND MATE_PROP_ID IS NULL) OR \\012\\011 (VALUE IS NULL AND CVTE_ID IS NOT NULL AND MATE_PROP_ID IS NULL) OR\\012\\011 (VALUE IS NULL AND CVTE_ID IS NULL AND MATE_PROP_ID IS NOT NULL)\\012\\011);\\012\\012CREATE INDEX DSPR_CVTE_FK_I ON DATA_SET_PROPERTIES (CVTE_ID);\\012CREATE INDEX DSPR_DSTPT_FK_I ON DATA_SET_PROPERTIES (DSTPT_ID);\\012CREATE INDEX DSPR_DS_FK_I ON DATA_SET_PROPERTIES (DS_ID);\\012CREATE INDEX DSPR_PERS_FK_I ON DATA_SET_PROPERTIES (PERS_ID_REGISTERER);\\012CREATE INDEX DSTPT_DSTY_FK_I ON DATA_SET_TYPE_PROPERTY_TYPES (DSTY_ID);\\012CREATE INDEX DSTPT_PERS_FK_I ON DATA_SET_TYPE_PROPERTY_TYPES (PERS_ID_REGISTERER);\\012CREATE INDEX DSTPT_PRTY_FK_I ON DATA_SET_TYPE_PROPERTY_TYPES (PRTY_ID);\\012\\012CREATE OR REPLACE FUNCTION DATA_SET_PROPERTY_WITH_MATERIAL_DATA_TYPE_CHECK() RETURNS trigger AS $$\\012DECLARE\\012   v_type_id  CODE;\\012   v_type_id_prop  CODE;\\012BEGIN\\012   if NEW.mate_prop_id IS NOT NULL then\\012\\011\\011\\011-- find material type id of the property type \\012\\011\\011\\011select pt.maty_prop_id into v_type_id_prop \\012\\011\\011\\011  from data_set_type_property_types dstpt, property_types pt \\012\\011\\011\\011 where NEW.dstpt_id = dstpt.id AND dstpt.prty_id = pt.id;\\012\\011\\011\\012\\011\\011\\011if v_type_id_prop IS NOT NULL then\\012\\011\\011\\011\\011-- find material type id of the material which consists the entity's property value\\012\\011\\011\\011\\011select entity.maty_id into v_type_id \\012\\011\\011\\011\\011  from materials entity\\012\\011\\011\\011\\011 where NEW.mate_prop_id = entity.id;\\012\\011\\011\\011\\011if v_type_id != v_type_id_prop then\\012\\011\\011\\011\\011\\011RAISE EXCEPTION 'Insert/Update of property value referencing material (id: %) failed, as referenced material type is different than expected (id %, expected id: %).', \\012\\011\\011\\011\\011\\011\\011\\011\\011\\011\\011\\011\\011 NEW.mate_prop_id, v_type_id, v_type_id_prop;\\012\\011\\011\\011\\011end if;\\012\\011\\011\\011end if;\\012   end if;\\012   RETURN NEW;\\012END;\\012$$ LANGUAGE 'plpgsql';\\012\\012CREATE TRIGGER DATA_SET_PROPERTY_WITH_MATERIAL_DATA_TYPE_CHECK BEFORE INSERT OR UPDATE ON data_set_properties\\012    FOR EACH ROW EXECUTE PROCEDURE DATA_SET_PROPERTY_WITH_MATERIAL_DATA_TYPE_CHECK();   \\012	\N
+./sourceTest/sql/postgresql/030/.svn/text-base/schema-030.sql.svn-base:    LANGUAGE plpgsql;
+./sourceTest/sql/postgresql/030/.svn/text-base/schema-030.sql.svn-base:    LANGUAGE plpgsql;
+./sourceTest/sql/postgresql/030/.svn/text-base/schema-030.sql.svn-base:    LANGUAGE plpgsql;
+./sourceTest/sql/postgresql/030/.svn/text-base/schema-030.sql.svn-base:    LANGUAGE plpgsql;
+./sourceTest/sql/postgresql/030/.svn/text-base/schema-030.sql.svn-base:    LANGUAGE plpgsql;
+./sourceTest/sql/postgresql/030/.svn/text-base/schema-030.sql.svn-base:    LANGUAGE plpgsql;
+./sourceTest/sql/postgresql/030/.svn/text-base/schema-030.sql.svn-base:    LANGUAGE plpgsql;
+./sourceTest/sql/postgresql/030/.svn/text-base/schema-030.sql.svn-base:    LANGUAGE plpgsql;
+./sourceTest/sql/postgresql/030/011=database_version_logs.tsv:027	D:\\User\\felmer\\dev-workspace\\openbis/source/sql/postgresql/027/function-027.sql	SUCCESS	2008-11-05 09:18:00.403	-- Creating Functions\\012\\012------------------------------------------------------------------------------------\\012--  Purpose:  Create function RENAME_SEQUENCE() that is required for renaming the sequences belonging to tables\\012------------------------------------------------------------------------------------\\012CREATE FUNCTION RENAME_SEQUENCE(OLD_NAME VARCHAR, NEW_NAME VARCHAR) RETURNS INTEGER AS $$\\012DECLARE\\012  CURR_SEQ_VAL   INTEGER;\\012BEGIN\\012  SELECT INTO CURR_SEQ_VAL NEXTVAL(OLD_NAME);\\012  EXECUTE 'CREATE SEQUENCE ' || NEW_NAME || ' START WITH ' || CURR_SEQ_VAL;\\012  EXECUTE 'DROP SEQUENCE ' || OLD_NAME;\\012  RETURN CURR_SEQ_VAL;\\012END;\\012$$ LANGUAGE 'plpgsql';\\012\\012\\012------------------------------------------------------------------------------------\\012--  Purpose:  Create trigger CONTROLLED_VOCABULARY_CHECK \\012------------------------------------------------------------------------------------\\012\\012CREATE OR REPLACE FUNCTION CONTROLLED_VOCABULARY_CHECK() RETURNS trigger AS $$\\012DECLARE\\012   v_code  CODE;\\012BEGIN\\012\\012   select code into v_code from data_types where id = NEW.daty_id;\\012\\012   -- Check if the data is of type "CONTROLLEDVOCABULARY"\\012   if v_code = 'CONTROLLEDVOCABULARY' then\\012      if NEW.covo_id IS NULL then\\012         RAISE EXCEPTION 'Insert/Update of Property Type (Code: %) failed, as its Data Type is CONTROLLEDVOCABULARY, but it is not linked to a Controlled Vocabulary.', NEW.code;\\012      end if;\\012   end if;\\012\\012   RETURN NEW;\\012\\012END;\\012$$ LANGUAGE 'plpgsql';\\012\\012CREATE TRIGGER CONTROLLED_VOCABULARY_CHECK BEFORE INSERT OR UPDATE ON PROPERTY_TYPES\\012    FOR EACH ROW EXECUTE PROCEDURE CONTROLLED_VOCABULARY_CHECK();\\012\\012\\012------------------------------------------------------------------------------------\\012--  Purpose:  Create trigger EXTERNAL_DATA_STORAGE_FORMAT_CHECK \\012------------------------------------------------------------------------------------\\012\\012CREATE OR REPLACE FUNCTION EXTERNAL_DATA_STORAGE_FORMAT_CHECK() RETURNS trigger AS $$\\012DECLARE\\012   v_covo_code  CODE;\\012   data_code CODE;\\012BEGIN\\012\\012   select code into v_covo_code from controlled_vocabularies\\012      where is_internal_namespace = true and \\012         id = (select covo_id from controlled_vocabulary_terms where id = NEW.cvte_id_stor_fmt);\\012   -- Check if the data storage format is a term of the controlled vocabulary "STORAGE_FORMAT"\\012   if v_covo_code != 'STORAGE_FORMAT' then\\012      select code into data_code from data where id = NEW.data_id; \\012      RAISE EXCEPTION 'Insert/Update of Data (Code: %) failed, as its Storage Format is %, but is required to be STORAGE_FORMAT.', data_code, v_covo_code;\\012   end if;\\012\\012   RETURN NEW;\\012\\012END;\\012$$ LANGUAGE 'plpgsql';\\012\\012CREATE TRIGGER EXTERNAL_DATA_STORAGE_FORMAT_CHECK BEFORE INSERT OR UPDATE ON EXTERNAL_DATA\\012    FOR EACH ROW EXECUTE PROCEDURE EXTERNAL_DATA_STORAGE_FORMAT_CHECK();\\012\\012------------------------------------------------------------------------------------\\012--  Purpose:  Create trigger SAMPLE_CODE_UNIQUENESS_CHECK \\012------------------------------------------------------------------------------------\\012\\012CREATE OR REPLACE FUNCTION SAMPLE_CODE_UNIQUENESS_CHECK() RETURNS trigger AS $$\\012DECLARE\\012   counter  INTEGER;\\012BEGIN\\012\\011IF (NEW.samp_id_part_of is NULL) THEN\\012\\011\\011IF (NEW.dbin_id is not NULL) THEN\\012\\011\\011\\011SELECT count(*) into counter FROM samples \\012\\011\\011\\011\\011where id != NEW.id and code = NEW.code and samp_id_part_of is NULL and dbin_id = NEW.dbin_id;\\012\\011\\011\\011IF (counter > 0) THEN\\012\\011\\011\\011\\011RAISE EXCEPTION 'Insert/Update of Sample (Code: %) failed because database instance sample with the same code already exists.', NEW.code;\\012\\011\\011\\011END IF;\\012\\011\\011ELSIF (NEW.grou_id is not NULL) THEN\\012\\011\\011\\011SELECT count(*) into counter FROM samples \\012\\011\\011\\011\\011where id != NEW.id and code = NEW.code and samp_id_part_of is NULL and grou_id = NEW.grou_id;\\012\\011\\011\\011IF (counter > 0) THEN\\012\\011\\011\\011\\011RAISE EXCEPTION 'Insert/Update of Sample (Code: %) failed because group sample with the same code already exists.', NEW.code;\\012\\011\\011\\011END IF;\\012\\011\\011END IF;\\012        ELSE\\012\\011\\011IF (NEW.dbin_id is not NULL) THEN\\012\\011\\011\\011SELECT count(*) into counter FROM samples \\012\\011\\011\\011\\011where id != NEW.id and code = NEW.code and samp_id_part_of = NEW.samp_id_part_of and dbin_id = NEW.dbin_id;\\012\\011\\011\\011IF (counter > 0) THEN\\012\\011\\011\\011\\011RAISE EXCEPTION 'Insert/Update of Sample (Code: %) failed because database instance sample with the same code and being the part of the same parent already exists.', NEW.code;\\012\\011\\011\\011END IF;\\012\\011\\011ELSIF (NEW.grou_id is not NULL) THEN\\012\\011\\011\\011SELECT count(*) into counter FROM samples \\012\\011\\011\\011\\011where id != NEW.id and code = NEW.code and samp_id_part_of = NEW.samp_id_part_of and grou_id = NEW.grou_id;\\012\\011\\011\\011IF (counter > 0) THEN\\012\\011\\011\\011\\011RAISE EXCEPTION 'Insert/Update of Sample (Code: %) failed because group sample with the same code and being the part of the same parent already exists.', NEW.code;\\012\\011\\011\\011END IF;\\012\\011\\011END IF;\\012        END IF;   \\012   RETURN NEW;\\012END;\\012$$ LANGUAGE 'plpgsql';\\012\\012CREATE TRIGGER SAMPLE_CODE_UNIQUENESS_CHECK BEFORE INSERT OR UPDATE ON SAMPLES\\012    FOR EACH ROW EXECUTE PROCEDURE SAMPLE_CODE_UNIQUENESS_CHECK();\\012	\N
+./sourceTest/sql/postgresql/030/011=database_version_logs.tsv:028	source/sql/postgresql/migration/migration-027-028.sql	SUCCESS	2008-11-18 13:24:17.508	-- Create EXPERIMENT_ATTACHMENT_CONTENTS.\\012CREATE TABLE EXPERIMENT_ATTACHMENT_CONTENTS (ID TECH_ID NOT NULL,VALUE FILE NOT NULL);\\012CREATE SEQUENCE EXPERIMENT_ATTACHMENT_CONTENT_ID_SEQ;\\012ALTER TABLE EXPERIMENT_ATTACHMENT_CONTENTS ADD CONSTRAINT EXAC_PK PRIMARY KEY(ID);\\012\\012-- Alter EXPERIMENT_ATTACHMENTS by adding the new column which has a NULL constraint.\\012-- The NOT NULL constraint is added later on.\\012ALTER TABLE EXPERIMENT_ATTACHMENTS ADD COLUMN EXAC_ID TECH_ID;\\012\\012-- Does the VALUE migration between EXPERIMENT_ATTACHMENTS to EXPERIMENT_ATTACHMENT_CONTENTS.\\012CREATE OR REPLACE FUNCTION move_exp_att_content() RETURNS integer AS $$\\012DECLARE\\012    rec RECORD;\\012    seq BIGINT;\\012BEGIN\\012  FOR rec IN SELECT id, value FROM EXPERIMENT_ATTACHMENTS LOOP\\012  \\011seq := nextval('EXPERIMENT_ATTACHMENT_CONTENT_ID_SEQ');\\012    INSERT INTO EXPERIMENT_ATTACHMENT_CONTENTS (id, value) VALUES (seq, rec.value);\\012    UPDATE EXPERIMENT_ATTACHMENTS SET exac_id = seq WHERE id = rec.id;\\012  END LOOP;\\012  RETURN 1;\\012END;\\012$$ LANGUAGE 'plpgsql';\\012\\012-- Call the function.\\012SELECT move_exp_att_content();\\012DROP FUNCTION move_exp_att_content();\\012\\012\\012-- Finish EXPERIMENT_ATTACHMENTS changes.\\012ALTER TABLE EXPERIMENT_ATTACHMENTS ADD CONSTRAINT EXAT_CONT_FK FOREIGN KEY (EXAC_ID) REFERENCES EXPERIMENT_ATTACHMENT_CONTENTS(ID);\\012ALTER TABLE EXPERIMENT_ATTACHMENTS DROP COLUMN VALUE;\\012ALTER TABLE EXPERIMENT_ATTACHMENTS ALTER COLUMN EXAC_ID SET NOT NULL;\\012	\N
+./sourceTest/sql/postgresql/030/011=database_version_logs.tsv:029	source/sql/postgresql/migration/migration-028-029.sql	SUCCESS	2009-03-18 10:50:20.105	-- -------\\012-- add modification_timestamp field to allow edition with Hibernate\\012-- -------\\012\\012ALTER TABLE samples\\012\\011ADD COLUMN modification_timestamp TIME_STAMP DEFAULT CURRENT_TIMESTAMP;\\012\\012ALTER TABLE experiments\\012\\011ADD COLUMN modification_timestamp TIME_STAMP DEFAULT CURRENT_TIMESTAMP;\\012\\012ALTER TABLE materials\\012\\011ADD COLUMN modification_timestamp TIME_STAMP DEFAULT CURRENT_TIMESTAMP;\\012\\012ALTER TABLE experiment_properties\\012\\011ADD COLUMN modification_timestamp TIME_STAMP DEFAULT CURRENT_TIMESTAMP;\\012\\012ALTER TABLE material_properties\\012\\011ADD COLUMN modification_timestamp TIME_STAMP DEFAULT CURRENT_TIMESTAMP;\\012\\012ALTER TABLE sample_properties\\012\\011ADD COLUMN modification_timestamp TIME_STAMP DEFAULT CURRENT_TIMESTAMP;\\012\\012-- -------\\012-- add property data type which references materials\\012-- -------\\012\\012ALTER TABLE property_types\\012\\011ADD COLUMN maty_prop_id tech_id;\\012\\012ALTER TABLE property_types\\012\\011ADD CONSTRAINT prty_maty_fk FOREIGN KEY (maty_prop_id) REFERENCES material_types(id);\\012\\012ALTER TABLE experiment_properties\\012\\011ADD COLUMN mate_prop_id tech_id;\\012\\012ALTER TABLE material_properties\\012\\011ADD COLUMN mate_prop_id tech_id;\\012\\012ALTER TABLE sample_properties\\012\\011ADD COLUMN mate_prop_id tech_id;\\012\\012ALTER TABLE experiment_properties\\012\\011ADD CONSTRAINT expr_mapr_fk FOREIGN KEY (mate_prop_id) REFERENCES materials(id);\\012\\012ALTER TABLE material_properties\\012\\011ADD CONSTRAINT mapr_mapr_fk FOREIGN KEY (mate_prop_id) REFERENCES materials(id);\\012\\012ALTER TABLE sample_properties\\012\\011ADD CONSTRAINT sapr_mapr_fk FOREIGN KEY (mate_prop_id) REFERENCES materials(id);\\012\\012insert into data_types\\012(id\\012 ,code\\012 ,description)\\012 values \\012 (nextval('DATA_TYPE_ID_SEQ')\\012 ,'MATERIAL'\\012 ,'Reference to a material'\\012);\\012\\012ALTER TABLE MATERIAL_PROPERTIES DROP CONSTRAINT MAPR_CK;\\012ALTER TABLE MATERIAL_PROPERTIES ADD CONSTRAINT MAPR_CK CHECK \\012\\011((VALUE IS NOT NULL AND CVTE_ID IS NULL AND MATE_PROP_ID IS NULL) OR \\012\\011 (VALUE IS NULL AND CVTE_ID IS NOT NULL AND MATE_PROP_ID IS NULL) OR\\012\\011 (VALUE IS NULL AND CVTE_ID IS NULL AND MATE_PROP_ID IS NOT NULL)\\012\\011);\\012\\012ALTER TABLE EXPERIMENT_PROPERTIES DROP CONSTRAINT EXPR_CK;\\012ALTER TABLE EXPERIMENT_PROPERTIES ADD CONSTRAINT EXPR_CK CHECK \\012\\011((VALUE IS NOT NULL AND CVTE_ID IS NULL AND MATE_PROP_ID IS NULL) OR \\012\\011 (VALUE IS NULL AND CVTE_ID IS NOT NULL AND MATE_PROP_ID IS NULL) OR\\012\\011 (VALUE IS NULL AND CVTE_ID IS NULL AND MATE_PROP_ID IS NOT NULL)\\012\\011);\\012\\012ALTER TABLE SAMPLE_PROPERTIES DROP CONSTRAINT SAPR_CK;\\012ALTER TABLE SAMPLE_PROPERTIES ADD CONSTRAINT SAPR_CK CHECK \\012\\011((VALUE IS NOT NULL AND CVTE_ID IS NULL AND MATE_PROP_ID IS NULL) OR \\012\\011 (VALUE IS NULL AND CVTE_ID IS NOT NULL AND MATE_PROP_ID IS NULL) OR\\012\\011 (VALUE IS NULL AND CVTE_ID IS NULL AND MATE_PROP_ID IS NOT NULL)\\012\\011);\\012\\012------------------------------------------------------------------------------------\\012--  Purpose:  Create trigger MATERIAL/SAMPLE/EXPERIMENT _PROPERTY_WITH_MATERIAL_DATA_TYPE_CHECK\\012--            It checks that if material property value is assigned to the entity,\\012--\\011\\011\\011\\011\\011\\011then the material type is equal to the one described by property type.\\012------------------------------------------------------------------------------------\\012\\012CREATE OR REPLACE FUNCTION MATERIAL_PROPERTY_WITH_MATERIAL_DATA_TYPE_CHECK() RETURNS trigger AS $$\\012DECLARE\\012   v_type_id  CODE;\\012   v_type_id_prop  CODE;\\012BEGIN\\012   if NEW.mate_prop_id IS NOT NULL then\\012\\011\\011\\011-- find material type id of the property type \\012\\011\\011\\011select pt.maty_prop_id into v_type_id_prop \\012\\011\\011\\011  from material_type_property_types etpt, property_types pt \\012\\011\\011\\011 where NEW.mtpt_id = etpt.id AND etpt.prty_id = pt.id;\\012\\011\\011\\012\\011\\011\\011if v_type_id_prop IS NOT NULL then\\012\\011\\011\\011\\011-- find material type id of the material which consists the entity's property value\\012\\011\\011\\011\\011select entity.maty_id into v_type_id \\012\\011\\011\\011\\011  from materials entity\\012\\011\\011\\011\\011 where NEW.mate_prop_id = entity.id;\\012\\011\\011\\011\\011if v_type_id != v_type_id_prop then\\012\\011\\011\\011\\011\\011RAISE EXCEPTION 'Insert/Update of property value referencing material (id: %) failed, as referenced material type is different than expected (id %, expected id: %).', \\012\\011\\011\\011\\011\\011\\011\\011 NEW.mate_prop_id, v_type_id, v_type_id_prop;\\012\\011\\011\\011\\011end if;\\012\\011\\011\\011end if;\\012   end if;\\012   RETURN NEW;\\012END;\\012$$ LANGUAGE 'plpgsql';\\012\\012CREATE TRIGGER MATERIAL_PROPERTY_WITH_MATERIAL_DATA_TYPE_CHECK BEFORE INSERT OR UPDATE ON material_properties\\012    FOR EACH ROW EXECUTE PROCEDURE MATERIAL_PROPERTY_WITH_MATERIAL_DATA_TYPE_CHECK();\\012    \\012CREATE OR REPLACE FUNCTION SAMPLE_PROPERTY_WITH_MATERIAL_DATA_TYPE_CHECK() RETURNS trigger AS $$\\012DECLARE\\012   v_type_id  CODE;\\012   v_type_id_prop  CODE;\\012BEGIN\\012   if NEW.mate_prop_id IS NOT NULL then\\012\\011\\011\\011-- find material type id of the property type \\012\\011\\011\\011select pt.maty_prop_id into v_type_id_prop \\012\\011\\011\\011  from sample_type_property_types etpt, property_types pt \\012\\011\\011\\011 where NEW.stpt_id = etpt.id AND etpt.prty_id = pt.id;\\012\\011\\011\\012\\011\\011\\011if v_type_id_prop IS NOT NULL then\\012\\011\\011\\011\\011-- find material type id of the material which consists the entity's property value\\012\\011\\011\\011\\011select entity.maty_id into v_type_id \\012\\011\\011\\011\\011  from materials entity\\012\\011\\011\\011\\011 where NEW.mate_prop_id = entity.id;\\012\\011\\011\\011\\011if v_type_id != v_type_id_prop then\\012\\011\\011\\011\\011\\011RAISE EXCEPTION 'Insert/Update of property value referencing material (id: %) failed, as referenced material type is different than expected (id %, expected id: %).', \\012\\011\\011\\011\\011\\011\\011\\011\\011\\011\\011\\011\\011 NEW.mate_prop_id, v_type_id, v_type_id_prop;\\012\\011\\011\\011\\011end if;\\012\\011\\011\\011end if;\\012   end if;\\012   RETURN NEW;\\012END;\\012$$ LANGUAGE 'plpgsql';\\012\\012CREATE TRIGGER SAMPLE_PROPERTY_WITH_MATERIAL_DATA_TYPE_CHECK BEFORE INSERT OR UPDATE ON sample_properties\\012    FOR EACH ROW EXECUTE PROCEDURE SAMPLE_PROPERTY_WITH_MATERIAL_DATA_TYPE_CHECK();\\012    \\012CREATE OR REPLACE FUNCTION EXPERIMENT_PROPERTY_WITH_MATERIAL_DATA_TYPE_CHECK() RETURNS trigger AS $$\\012DECLARE\\012   v_type_id  CODE;\\012   v_type_id_prop  CODE;\\012BEGIN\\012   if NEW.mate_prop_id IS NOT NULL then\\012\\011\\011\\011-- find material type id of the property type \\012\\011\\011\\011select pt.maty_prop_id into v_type_id_prop \\012\\011\\011\\011  from experiment_type_property_types etpt, property_types pt \\012\\011\\011\\011 where NEW.etpt_id = etpt.id AND etpt.prty_id = pt.id;\\012\\011\\011\\012\\011\\011\\011if v_type_id_prop IS NOT NULL then\\012\\011\\011\\011\\011-- find material type id of the material which consists the entity's property value\\012\\011\\011\\011\\011select entity.maty_id into v_type_id \\012\\011\\011\\011\\011  from materials entity\\012\\011\\011\\011\\011 where NEW.mate_prop_id = entity.id;\\012\\011\\011\\011\\011if v_type_id != v_type_id_prop then\\012\\011\\011\\011\\011\\011RAISE EXCEPTION 'Insert/Update of property value referencing material (id: %) failed, as referenced material type is different than expected (id %, expected id: %).', \\012\\011\\011\\011\\011\\011\\011\\011\\011\\011\\011\\011\\011 NEW.mate_prop_id, v_type_id, v_type_id_prop;\\012\\011\\011\\011\\011end if;\\012\\011\\011\\011end if;\\012   end if;\\012   RETURN NEW;\\012END;\\012$$ LANGUAGE 'plpgsql';\\012\\012CREATE TRIGGER EXPERIMENT_PROPERTY_WITH_MATERIAL_DATA_TYPE_CHECK BEFORE INSERT OR UPDATE ON experiment_properties\\012    FOR EACH ROW EXECUTE PROCEDURE EXPERIMENT_PROPERTY_WITH_MATERIAL_DATA_TYPE_CHECK();\\012       \\012-- -------\\012-- remove the reminescents of the OBSERVABLE_TYPE\\012-- -------\\012\\012ALTER TABLE data\\012\\011DROP CONSTRAINT data_obty_fk;\\012\\012ALTER TABLE data_set_types\\012\\011DROP CONSTRAINT obty_pk;\\012\\012ALTER TABLE data_set_types\\012\\011ADD CONSTRAINT dsty_pk PRIMARY KEY (id);\\012\\012ALTER TABLE data\\012\\011ADD CONSTRAINT data_dsty_fk FOREIGN KEY (dsty_id) REFERENCES data_set_types(id);\\012\\012ALTER TABLE data_set_types\\012\\011DROP CONSTRAINT obty_bk_uk;\\012\\012ALTER TABLE data_set_types\\012\\011DROP CONSTRAINT obty_dbin_fk;\\012\\012ALTER TABLE data_set_types\\012\\011ADD CONSTRAINT dsty_bk_uk UNIQUE (code, dbin_id);\\012\\012ALTER TABLE data_set_types\\012\\011ADD CONSTRAINT dsty_dbin_fk FOREIGN KEY (dbin_id) REFERENCES database_instances(id);\\012\\012DROP INDEX data_obty_fk_i;\\012\\012CREATE INDEX data_dsty_fk_i ON data(dsty_id);\\012	\N
+./sourceTest/sql/postgresql/030/011=database_version_logs.tsv:030	source/sql/postgresql/migration/migration-029-030.sql	SUCCESS	2009-03-23 15:34:44.72	-- -------\\012-- add modification_timestamp field to allow edition with Hibernate\\012-- -------\\012ALTER TABLE data\\012\\011ADD COLUMN modification_timestamp TIME_STAMP DEFAULT CURRENT_TIMESTAMP;\\012ALTER TABLE experiment_types\\012\\011ADD COLUMN modification_timestamp TIME_STAMP DEFAULT CURRENT_TIMESTAMP;\\012ALTER TABLE sample_types\\012\\011ADD COLUMN modification_timestamp TIME_STAMP DEFAULT CURRENT_TIMESTAMP;\\012ALTER TABLE material_types\\012\\011ADD COLUMN modification_timestamp TIME_STAMP DEFAULT CURRENT_TIMESTAMP;\\012ALTER TABLE data_set_types\\012\\011ADD COLUMN modification_timestamp TIME_STAMP DEFAULT CURRENT_TIMESTAMP;\\012ALTER TABLE controlled_vocabularies\\012\\011ADD COLUMN modification_timestamp TIME_STAMP DEFAULT CURRENT_TIMESTAMP;\\012-- -------\\012-- add properties to data sets\\012-- -------\\012CREATE TABLE DATA_SET_PROPERTIES (ID TECH_ID NOT NULL,DS_ID TECH_ID NOT NULL,DSTPT_ID TECH_ID NOT NULL,VALUE GENERIC_VALUE,CVTE_ID TECH_ID, MATE_PROP_ID TECH_ID, PERS_ID_REGISTERER TECH_ID NOT NULL,REGISTRATION_TIMESTAMP TIME_STAMP_DFL NOT NULL DEFAULT CURRENT_TIMESTAMP, MODIFICATION_TIMESTAMP TIME_STAMP DEFAULT CURRENT_TIMESTAMP);\\012CREATE TABLE DATA_SET_TYPE_PROPERTY_TYPES (ID TECH_ID NOT NULL,DSTY_ID TECH_ID NOT NULL,PRTY_ID TECH_ID NOT NULL,IS_MANDATORY BOOLEAN_CHAR NOT NULL DEFAULT 'F',IS_MANAGED_INTERNALLY BOOLEAN_CHAR NOT NULL DEFAULT 'F',PERS_ID_REGISTERER TECH_ID NOT NULL,REGISTRATION_TIMESTAMP TIME_STAMP_DFL NOT NULL DEFAULT CURRENT_TIMESTAMP);\\012\\012CREATE SEQUENCE DATA_SET_PROPERTY_ID_SEQ;\\012CREATE SEQUENCE DSTPT_ID_SEQ;\\012\\012ALTER TABLE DATA_SET_TYPE_PROPERTY_TYPES ADD CONSTRAINT DSTPT_PK PRIMARY KEY(ID);\\012ALTER TABLE DATA_SET_PROPERTIES ADD CONSTRAINT DSPR_PK PRIMARY KEY(ID);\\012\\012ALTER TABLE DATA_SET_TYPE_PROPERTY_TYPES ADD CONSTRAINT DSTPT_BK_UK UNIQUE(DSTY_ID,PRTY_ID);\\012ALTER TABLE DATA_SET_PROPERTIES ADD CONSTRAINT DSPR_BK_UK UNIQUE(DS_ID,DSTPT_ID);\\012\\012\\012ALTER TABLE DATA_SET_TYPE_PROPERTY_TYPES ADD CONSTRAINT DSTPT_DSTY_FK FOREIGN KEY (DSTY_ID) REFERENCES DATA_SET_TYPES(ID);\\012ALTER TABLE DATA_SET_TYPE_PROPERTY_TYPES ADD CONSTRAINT DSTPT_PERS_FK FOREIGN KEY (PERS_ID_REGISTERER) REFERENCES PERSONS(ID);\\012ALTER TABLE DATA_SET_TYPE_PROPERTY_TYPES ADD CONSTRAINT DSTPT_PRTY_FK FOREIGN KEY (PRTY_ID) REFERENCES PROPERTY_TYPES(ID);\\012ALTER TABLE DATA_SET_PROPERTIES ADD CONSTRAINT DSPR_CVTE_FK FOREIGN KEY (CVTE_ID) REFERENCES CONTROLLED_VOCABULARY_TERMS(ID);\\012ALTER TABLE DATA_SET_PROPERTIES ADD CONSTRAINT DSPR_DSTPT_FK FOREIGN KEY (DSTPT_ID) REFERENCES DATA_SET_TYPE_PROPERTY_TYPES(ID) ON DELETE CASCADE;\\012ALTER TABLE DATA_SET_PROPERTIES ADD CONSTRAINT DSPR_DS_FK FOREIGN KEY (DS_ID) REFERENCES DATA(ID);\\012ALTER TABLE DATA_SET_PROPERTIES ADD CONSTRAINT DSPR_PERS_FK FOREIGN KEY (PERS_ID_REGISTERER) REFERENCES PERSONS(ID);\\012ALTER TABLE DATA_SET_PROPERTIES ADD CONSTRAINT DSPR_MAPR_FK FOREIGN KEY (MATE_PROP_ID) REFERENCES MATERIALS(ID);\\012\\012ALTER TABLE DATA_SET_PROPERTIES ADD CONSTRAINT DSPR_CK CHECK \\012\\011((VALUE IS NOT NULL AND CVTE_ID IS NULL AND MATE_PROP_ID IS NULL) OR \\012\\011 (VALUE IS NULL AND CVTE_ID IS NOT NULL AND MATE_PROP_ID IS NULL) OR\\012\\011 (VALUE IS NULL AND CVTE_ID IS NULL AND MATE_PROP_ID IS NOT NULL)\\012\\011);\\012\\012CREATE INDEX DSPR_CVTE_FK_I ON DATA_SET_PROPERTIES (CVTE_ID);\\012CREATE INDEX DSPR_DSTPT_FK_I ON DATA_SET_PROPERTIES (DSTPT_ID);\\012CREATE INDEX DSPR_DS_FK_I ON DATA_SET_PROPERTIES (DS_ID);\\012CREATE INDEX DSPR_PERS_FK_I ON DATA_SET_PROPERTIES (PERS_ID_REGISTERER);\\012CREATE INDEX DSTPT_DSTY_FK_I ON DATA_SET_TYPE_PROPERTY_TYPES (DSTY_ID);\\012CREATE INDEX DSTPT_PERS_FK_I ON DATA_SET_TYPE_PROPERTY_TYPES (PERS_ID_REGISTERER);\\012CREATE INDEX DSTPT_PRTY_FK_I ON DATA_SET_TYPE_PROPERTY_TYPES (PRTY_ID);\\012\\012CREATE OR REPLACE FUNCTION DATA_SET_PROPERTY_WITH_MATERIAL_DATA_TYPE_CHECK() RETURNS trigger AS $$\\012DECLARE\\012   v_type_id  CODE;\\012   v_type_id_prop  CODE;\\012BEGIN\\012   if NEW.mate_prop_id IS NOT NULL then\\012\\011\\011\\011-- find material type id of the property type \\012\\011\\011\\011select pt.maty_prop_id into v_type_id_prop \\012\\011\\011\\011  from data_set_type_property_types dstpt, property_types pt \\012\\011\\011\\011 where NEW.dstpt_id = dstpt.id AND dstpt.prty_id = pt.id;\\012\\011\\011\\012\\011\\011\\011if v_type_id_prop IS NOT NULL then\\012\\011\\011\\011\\011-- find material type id of the material which consists the entity's property value\\012\\011\\011\\011\\011select entity.maty_id into v_type_id \\012\\011\\011\\011\\011  from materials entity\\012\\011\\011\\011\\011 where NEW.mate_prop_id = entity.id;\\012\\011\\011\\011\\011if v_type_id != v_type_id_prop then\\012\\011\\011\\011\\011\\011RAISE EXCEPTION 'Insert/Update of property value referencing material (id: %) failed, as referenced material type is different than expected (id %, expected id: %).', \\012\\011\\011\\011\\011\\011\\011\\011\\011\\011\\011\\011\\011 NEW.mate_prop_id, v_type_id, v_type_id_prop;\\012\\011\\011\\011\\011end if;\\012\\011\\011\\011end if;\\012   end if;\\012   RETURN NEW;\\012END;\\012$$ LANGUAGE 'plpgsql';\\012\\012CREATE TRIGGER DATA_SET_PROPERTY_WITH_MATERIAL_DATA_TYPE_CHECK BEFORE INSERT OR UPDATE ON data_set_properties\\012    FOR EACH ROW EXECUTE PROCEDURE DATA_SET_PROPERTY_WITH_MATERIAL_DATA_TYPE_CHECK();   \\012	\N
+./sourceTest/sql/postgresql/030/schema-030.sql:    LANGUAGE plpgsql;
+./sourceTest/sql/postgresql/030/schema-030.sql:    LANGUAGE plpgsql;
+./sourceTest/sql/postgresql/030/schema-030.sql:    LANGUAGE plpgsql;
+./sourceTest/sql/postgresql/030/schema-030.sql:    LANGUAGE plpgsql;
+./sourceTest/sql/postgresql/030/schema-030.sql:    LANGUAGE plpgsql;
+./sourceTest/sql/postgresql/030/schema-030.sql:    LANGUAGE plpgsql;
+./sourceTest/sql/postgresql/030/schema-030.sql:    LANGUAGE plpgsql;
+./sourceTest/sql/postgresql/030/schema-030.sql:    LANGUAGE plpgsql;
+./sourceTest/sql/postgresql/031/.svn/text-base/013=database_version_logs.tsv.svn-base:027	D:\\User\\felmer\\dev-workspace\\openbis/source/sql/postgresql/027/function-027.sql	SUCCESS	2008-11-05 09:18:00.403	-- Creating Functions\\012\\012------------------------------------------------------------------------------------\\012--  Purpose:  Create function RENAME_SEQUENCE() that is required for renaming the sequences belonging to tables\\012------------------------------------------------------------------------------------\\012CREATE FUNCTION RENAME_SEQUENCE(OLD_NAME VARCHAR, NEW_NAME VARCHAR) RETURNS INTEGER AS $$\\012DECLARE\\012  CURR_SEQ_VAL   INTEGER;\\012BEGIN\\012  SELECT INTO CURR_SEQ_VAL NEXTVAL(OLD_NAME);\\012  EXECUTE 'CREATE SEQUENCE ' || NEW_NAME || ' START WITH ' || CURR_SEQ_VAL;\\012  EXECUTE 'DROP SEQUENCE ' || OLD_NAME;\\012  RETURN CURR_SEQ_VAL;\\012END;\\012$$ LANGUAGE 'plpgsql';\\012\\012\\012------------------------------------------------------------------------------------\\012--  Purpose:  Create trigger CONTROLLED_VOCABULARY_CHECK \\012------------------------------------------------------------------------------------\\012\\012CREATE OR REPLACE FUNCTION CONTROLLED_VOCABULARY_CHECK() RETURNS trigger AS $$\\012DECLARE\\012   v_code  CODE;\\012BEGIN\\012\\012   select code into v_code from data_types where id = NEW.daty_id;\\012\\012   -- Check if the data is of type "CONTROLLEDVOCABULARY"\\012   if v_code = 'CONTROLLEDVOCABULARY' then\\012      if NEW.covo_id IS NULL then\\012         RAISE EXCEPTION 'Insert/Update of Property Type (Code: %) failed, as its Data Type is CONTROLLEDVOCABULARY, but it is not linked to a Controlled Vocabulary.', NEW.code;\\012      end if;\\012   end if;\\012\\012   RETURN NEW;\\012\\012END;\\012$$ LANGUAGE 'plpgsql';\\012\\012CREATE TRIGGER CONTROLLED_VOCABULARY_CHECK BEFORE INSERT OR UPDATE ON PROPERTY_TYPES\\012    FOR EACH ROW EXECUTE PROCEDURE CONTROLLED_VOCABULARY_CHECK();\\012\\012\\012------------------------------------------------------------------------------------\\012--  Purpose:  Create trigger EXTERNAL_DATA_STORAGE_FORMAT_CHECK \\012------------------------------------------------------------------------------------\\012\\012CREATE OR REPLACE FUNCTION EXTERNAL_DATA_STORAGE_FORMAT_CHECK() RETURNS trigger AS $$\\012DECLARE\\012   v_covo_code  CODE;\\012   data_code CODE;\\012BEGIN\\012\\012   select code into v_covo_code from controlled_vocabularies\\012      where is_internal_namespace = true and \\012         id = (select covo_id from controlled_vocabulary_terms where id = NEW.cvte_id_stor_fmt);\\012   -- Check if the data storage format is a term of the controlled vocabulary "STORAGE_FORMAT"\\012   if v_covo_code != 'STORAGE_FORMAT' then\\012      select code into data_code from data where id = NEW.data_id; \\012      RAISE EXCEPTION 'Insert/Update of Data (Code: %) failed, as its Storage Format is %, but is required to be STORAGE_FORMAT.', data_code, v_covo_code;\\012   end if;\\012\\012   RETURN NEW;\\012\\012END;\\012$$ LANGUAGE 'plpgsql';\\012\\012CREATE TRIGGER EXTERNAL_DATA_STORAGE_FORMAT_CHECK BEFORE INSERT OR UPDATE ON EXTERNAL_DATA\\012    FOR EACH ROW EXECUTE PROCEDURE EXTERNAL_DATA_STORAGE_FORMAT_CHECK();\\012\\012------------------------------------------------------------------------------------\\012--  Purpose:  Create trigger SAMPLE_CODE_UNIQUENESS_CHECK \\012------------------------------------------------------------------------------------\\012\\012CREATE OR REPLACE FUNCTION SAMPLE_CODE_UNIQUENESS_CHECK() RETURNS trigger AS $$\\012DECLARE\\012   counter  INTEGER;\\012BEGIN\\012\\011IF (NEW.samp_id_part_of is NULL) THEN\\012\\011\\011IF (NEW.dbin_id is not NULL) THEN\\012\\011\\011\\011SELECT count(*) into counter FROM samples \\012\\011\\011\\011\\011where id != NEW.id and code = NEW.code and samp_id_part_of is NULL and dbin_id = NEW.dbin_id;\\012\\011\\011\\011IF (counter > 0) THEN\\012\\011\\011\\011\\011RAISE EXCEPTION 'Insert/Update of Sample (Code: %) failed because database instance sample with the same code already exists.', NEW.code;\\012\\011\\011\\011END IF;\\012\\011\\011ELSIF (NEW.grou_id is not NULL) THEN\\012\\011\\011\\011SELECT count(*) into counter FROM samples \\012\\011\\011\\011\\011where id != NEW.id and code = NEW.code and samp_id_part_of is NULL and grou_id = NEW.grou_id;\\012\\011\\011\\011IF (counter > 0) THEN\\012\\011\\011\\011\\011RAISE EXCEPTION 'Insert/Update of Sample (Code: %) failed because group sample with the same code already exists.', NEW.code;\\012\\011\\011\\011END IF;\\012\\011\\011END IF;\\012        ELSE\\012\\011\\011IF (NEW.dbin_id is not NULL) THEN\\012\\011\\011\\011SELECT count(*) into counter FROM samples \\012\\011\\011\\011\\011where id != NEW.id and code = NEW.code and samp_id_part_of = NEW.samp_id_part_of and dbin_id = NEW.dbin_id;\\012\\011\\011\\011IF (counter > 0) THEN\\012\\011\\011\\011\\011RAISE EXCEPTION 'Insert/Update of Sample (Code: %) failed because database instance sample with the same code and being the part of the same parent already exists.', NEW.code;\\012\\011\\011\\011END IF;\\012\\011\\011ELSIF (NEW.grou_id is not NULL) THEN\\012\\011\\011\\011SELECT count(*) into counter FROM samples \\012\\011\\011\\011\\011where id != NEW.id and code = NEW.code and samp_id_part_of = NEW.samp_id_part_of and grou_id = NEW.grou_id;\\012\\011\\011\\011IF (counter > 0) THEN\\012\\011\\011\\011\\011RAISE EXCEPTION 'Insert/Update of Sample (Code: %) failed because group sample with the same code and being the part of the same parent already exists.', NEW.code;\\012\\011\\011\\011END IF;\\012\\011\\011END IF;\\012        END IF;   \\012   RETURN NEW;\\012END;\\012$$ LANGUAGE 'plpgsql';\\012\\012CREATE TRIGGER SAMPLE_CODE_UNIQUENESS_CHECK BEFORE INSERT OR UPDATE ON SAMPLES\\012    FOR EACH ROW EXECUTE PROCEDURE SAMPLE_CODE_UNIQUENESS_CHECK();\\012	\N
+./sourceTest/sql/postgresql/031/.svn/text-base/013=database_version_logs.tsv.svn-base:028	source/sql/postgresql/migration/migration-027-028.sql	SUCCESS	2008-11-18 13:24:17.508	-- Create EXPERIMENT_ATTACHMENT_CONTENTS.\\012CREATE TABLE EXPERIMENT_ATTACHMENT_CONTENTS (ID TECH_ID NOT NULL,VALUE FILE NOT NULL);\\012CREATE SEQUENCE EXPERIMENT_ATTACHMENT_CONTENT_ID_SEQ;\\012ALTER TABLE EXPERIMENT_ATTACHMENT_CONTENTS ADD CONSTRAINT EXAC_PK PRIMARY KEY(ID);\\012\\012-- Alter EXPERIMENT_ATTACHMENTS by adding the new column which has a NULL constraint.\\012-- The NOT NULL constraint is added later on.\\012ALTER TABLE EXPERIMENT_ATTACHMENTS ADD COLUMN EXAC_ID TECH_ID;\\012\\012-- Does the VALUE migration between EXPERIMENT_ATTACHMENTS to EXPERIMENT_ATTACHMENT_CONTENTS.\\012CREATE OR REPLACE FUNCTION move_exp_att_content() RETURNS integer AS $$\\012DECLARE\\012    rec RECORD;\\012    seq BIGINT;\\012BEGIN\\012  FOR rec IN SELECT id, value FROM EXPERIMENT_ATTACHMENTS LOOP\\012  \\011seq := nextval('EXPERIMENT_ATTACHMENT_CONTENT_ID_SEQ');\\012    INSERT INTO EXPERIMENT_ATTACHMENT_CONTENTS (id, value) VALUES (seq, rec.value);\\012    UPDATE EXPERIMENT_ATTACHMENTS SET exac_id = seq WHERE id = rec.id;\\012  END LOOP;\\012  RETURN 1;\\012END;\\012$$ LANGUAGE 'plpgsql';\\012\\012-- Call the function.\\012SELECT move_exp_att_content();\\012DROP FUNCTION move_exp_att_content();\\012\\012\\012-- Finish EXPERIMENT_ATTACHMENTS changes.\\012ALTER TABLE EXPERIMENT_ATTACHMENTS ADD CONSTRAINT EXAT_CONT_FK FOREIGN KEY (EXAC_ID) REFERENCES EXPERIMENT_ATTACHMENT_CONTENTS(ID);\\012ALTER TABLE EXPERIMENT_ATTACHMENTS DROP COLUMN VALUE;\\012ALTER TABLE EXPERIMENT_ATTACHMENTS ALTER COLUMN EXAC_ID SET NOT NULL;\\012	\N
+./sourceTest/sql/postgresql/031/.svn/text-base/013=database_version_logs.tsv.svn-base:029	source/sql/postgresql/migration/migration-028-029.sql	SUCCESS	2009-03-18 10:50:20.105	-- -------\\012-- add modification_timestamp field to allow edition with Hibernate\\012-- -------\\012\\012ALTER TABLE samples\\012\\011ADD COLUMN modification_timestamp TIME_STAMP DEFAULT CURRENT_TIMESTAMP;\\012\\012ALTER TABLE experiments\\012\\011ADD COLUMN modification_timestamp TIME_STAMP DEFAULT CURRENT_TIMESTAMP;\\012\\012ALTER TABLE materials\\012\\011ADD COLUMN modification_timestamp TIME_STAMP DEFAULT CURRENT_TIMESTAMP;\\012\\012ALTER TABLE experiment_properties\\012\\011ADD COLUMN modification_timestamp TIME_STAMP DEFAULT CURRENT_TIMESTAMP;\\012\\012ALTER TABLE material_properties\\012\\011ADD COLUMN modification_timestamp TIME_STAMP DEFAULT CURRENT_TIMESTAMP;\\012\\012ALTER TABLE sample_properties\\012\\011ADD COLUMN modification_timestamp TIME_STAMP DEFAULT CURRENT_TIMESTAMP;\\012\\012-- -------\\012-- add property data type which references materials\\012-- -------\\012\\012ALTER TABLE property_types\\012\\011ADD COLUMN maty_prop_id tech_id;\\012\\012ALTER TABLE property_types\\012\\011ADD CONSTRAINT prty_maty_fk FOREIGN KEY (maty_prop_id) REFERENCES material_types(id);\\012\\012ALTER TABLE experiment_properties\\012\\011ADD COLUMN mate_prop_id tech_id;\\012\\012ALTER TABLE material_properties\\012\\011ADD COLUMN mate_prop_id tech_id;\\012\\012ALTER TABLE sample_properties\\012\\011ADD COLUMN mate_prop_id tech_id;\\012\\012ALTER TABLE experiment_properties\\012\\011ADD CONSTRAINT expr_mapr_fk FOREIGN KEY (mate_prop_id) REFERENCES materials(id);\\012\\012ALTER TABLE material_properties\\012\\011ADD CONSTRAINT mapr_mapr_fk FOREIGN KEY (mate_prop_id) REFERENCES materials(id);\\012\\012ALTER TABLE sample_properties\\012\\011ADD CONSTRAINT sapr_mapr_fk FOREIGN KEY (mate_prop_id) REFERENCES materials(id);\\012\\012insert into data_types\\012(id\\012 ,code\\012 ,description)\\012 values \\012 (nextval('DATA_TYPE_ID_SEQ')\\012 ,'MATERIAL'\\012 ,'Reference to a material'\\012);\\012\\012ALTER TABLE MATERIAL_PROPERTIES DROP CONSTRAINT MAPR_CK;\\012ALTER TABLE MATERIAL_PROPERTIES ADD CONSTRAINT MAPR_CK CHECK \\012\\011((VALUE IS NOT NULL AND CVTE_ID IS NULL AND MATE_PROP_ID IS NULL) OR \\012\\011 (VALUE IS NULL AND CVTE_ID IS NOT NULL AND MATE_PROP_ID IS NULL) OR\\012\\011 (VALUE IS NULL AND CVTE_ID IS NULL AND MATE_PROP_ID IS NOT NULL)\\012\\011);\\012\\012ALTER TABLE EXPERIMENT_PROPERTIES DROP CONSTRAINT EXPR_CK;\\012ALTER TABLE EXPERIMENT_PROPERTIES ADD CONSTRAINT EXPR_CK CHECK \\012\\011((VALUE IS NOT NULL AND CVTE_ID IS NULL AND MATE_PROP_ID IS NULL) OR \\012\\011 (VALUE IS NULL AND CVTE_ID IS NOT NULL AND MATE_PROP_ID IS NULL) OR\\012\\011 (VALUE IS NULL AND CVTE_ID IS NULL AND MATE_PROP_ID IS NOT NULL)\\012\\011);\\012\\012ALTER TABLE SAMPLE_PROPERTIES DROP CONSTRAINT SAPR_CK;\\012ALTER TABLE SAMPLE_PROPERTIES ADD CONSTRAINT SAPR_CK CHECK \\012\\011((VALUE IS NOT NULL AND CVTE_ID IS NULL AND MATE_PROP_ID IS NULL) OR \\012\\011 (VALUE IS NULL AND CVTE_ID IS NOT NULL AND MATE_PROP_ID IS NULL) OR\\012\\011 (VALUE IS NULL AND CVTE_ID IS NULL AND MATE_PROP_ID IS NOT NULL)\\012\\011);\\012\\012------------------------------------------------------------------------------------\\012--  Purpose:  Create trigger MATERIAL/SAMPLE/EXPERIMENT _PROPERTY_WITH_MATERIAL_DATA_TYPE_CHECK\\012--            It checks that if material property value is assigned to the entity,\\012--\\011\\011\\011\\011\\011\\011then the material type is equal to the one described by property type.\\012------------------------------------------------------------------------------------\\012\\012CREATE OR REPLACE FUNCTION MATERIAL_PROPERTY_WITH_MATERIAL_DATA_TYPE_CHECK() RETURNS trigger AS $$\\012DECLARE\\012   v_type_id  CODE;\\012   v_type_id_prop  CODE;\\012BEGIN\\012   if NEW.mate_prop_id IS NOT NULL then\\012\\011\\011\\011-- find material type id of the property type \\012\\011\\011\\011select pt.maty_prop_id into v_type_id_prop \\012\\011\\011\\011  from material_type_property_types etpt, property_types pt \\012\\011\\011\\011 where NEW.mtpt_id = etpt.id AND etpt.prty_id = pt.id;\\012\\011\\011\\012\\011\\011\\011if v_type_id_prop IS NOT NULL then\\012\\011\\011\\011\\011-- find material type id of the material which consists the entity's property value\\012\\011\\011\\011\\011select entity.maty_id into v_type_id \\012\\011\\011\\011\\011  from materials entity\\012\\011\\011\\011\\011 where NEW.mate_prop_id = entity.id;\\012\\011\\011\\011\\011if v_type_id != v_type_id_prop then\\012\\011\\011\\011\\011\\011RAISE EXCEPTION 'Insert/Update of property value referencing material (id: %) failed, as referenced material type is different than expected (id %, expected id: %).', \\012\\011\\011\\011\\011\\011\\011\\011 NEW.mate_prop_id, v_type_id, v_type_id_prop;\\012\\011\\011\\011\\011end if;\\012\\011\\011\\011end if;\\012   end if;\\012   RETURN NEW;\\012END;\\012$$ LANGUAGE 'plpgsql';\\012\\012CREATE TRIGGER MATERIAL_PROPERTY_WITH_MATERIAL_DATA_TYPE_CHECK BEFORE INSERT OR UPDATE ON material_properties\\012    FOR EACH ROW EXECUTE PROCEDURE MATERIAL_PROPERTY_WITH_MATERIAL_DATA_TYPE_CHECK();\\012    \\012CREATE OR REPLACE FUNCTION SAMPLE_PROPERTY_WITH_MATERIAL_DATA_TYPE_CHECK() RETURNS trigger AS $$\\012DECLARE\\012   v_type_id  CODE;\\012   v_type_id_prop  CODE;\\012BEGIN\\012   if NEW.mate_prop_id IS NOT NULL then\\012\\011\\011\\011-- find material type id of the property type \\012\\011\\011\\011select pt.maty_prop_id into v_type_id_prop \\012\\011\\011\\011  from sample_type_property_types etpt, property_types pt \\012\\011\\011\\011 where NEW.stpt_id = etpt.id AND etpt.prty_id = pt.id;\\012\\011\\011\\012\\011\\011\\011if v_type_id_prop IS NOT NULL then\\012\\011\\011\\011\\011-- find material type id of the material which consists the entity's property value\\012\\011\\011\\011\\011select entity.maty_id into v_type_id \\012\\011\\011\\011\\011  from materials entity\\012\\011\\011\\011\\011 where NEW.mate_prop_id = entity.id;\\012\\011\\011\\011\\011if v_type_id != v_type_id_prop then\\012\\011\\011\\011\\011\\011RAISE EXCEPTION 'Insert/Update of property value referencing material (id: %) failed, as referenced material type is different than expected (id %, expected id: %).', \\012\\011\\011\\011\\011\\011\\011\\011\\011\\011\\011\\011\\011 NEW.mate_prop_id, v_type_id, v_type_id_prop;\\012\\011\\011\\011\\011end if;\\012\\011\\011\\011end if;\\012   end if;\\012   RETURN NEW;\\012END;\\012$$ LANGUAGE 'plpgsql';\\012\\012CREATE TRIGGER SAMPLE_PROPERTY_WITH_MATERIAL_DATA_TYPE_CHECK BEFORE INSERT OR UPDATE ON sample_properties\\012    FOR EACH ROW EXECUTE PROCEDURE SAMPLE_PROPERTY_WITH_MATERIAL_DATA_TYPE_CHECK();\\012    \\012CREATE OR REPLACE FUNCTION EXPERIMENT_PROPERTY_WITH_MATERIAL_DATA_TYPE_CHECK() RETURNS trigger AS $$\\012DECLARE\\012   v_type_id  CODE;\\012   v_type_id_prop  CODE;\\012BEGIN\\012   if NEW.mate_prop_id IS NOT NULL then\\012\\011\\011\\011-- find material type id of the property type \\012\\011\\011\\011select pt.maty_prop_id into v_type_id_prop \\012\\011\\011\\011  from experiment_type_property_types etpt, property_types pt \\012\\011\\011\\011 where NEW.etpt_id = etpt.id AND etpt.prty_id = pt.id;\\012\\011\\011\\012\\011\\011\\011if v_type_id_prop IS NOT NULL then\\012\\011\\011\\011\\011-- find material type id of the material which consists the entity's property value\\012\\011\\011\\011\\011select entity.maty_id into v_type_id \\012\\011\\011\\011\\011  from materials entity\\012\\011\\011\\011\\011 where NEW.mate_prop_id = entity.id;\\012\\011\\011\\011\\011if v_type_id != v_type_id_prop then\\012\\011\\011\\011\\011\\011RAISE EXCEPTION 'Insert/Update of property value referencing material (id: %) failed, as referenced material type is different than expected (id %, expected id: %).', \\012\\011\\011\\011\\011\\011\\011\\011\\011\\011\\011\\011\\011 NEW.mate_prop_id, v_type_id, v_type_id_prop;\\012\\011\\011\\011\\011end if;\\012\\011\\011\\011end if;\\012   end if;\\012   RETURN NEW;\\012END;\\012$$ LANGUAGE 'plpgsql';\\012\\012CREATE TRIGGER EXPERIMENT_PROPERTY_WITH_MATERIAL_DATA_TYPE_CHECK BEFORE INSERT OR UPDATE ON experiment_properties\\012    FOR EACH ROW EXECUTE PROCEDURE EXPERIMENT_PROPERTY_WITH_MATERIAL_DATA_TYPE_CHECK();\\012       \\012-- -------\\012-- remove the reminescents of the OBSERVABLE_TYPE\\012-- -------\\012\\012ALTER TABLE data\\012\\011DROP CONSTRAINT data_obty_fk;\\012\\012ALTER TABLE data_set_types\\012\\011DROP CONSTRAINT obty_pk;\\012\\012ALTER TABLE data_set_types\\012\\011ADD CONSTRAINT dsty_pk PRIMARY KEY (id);\\012\\012ALTER TABLE data\\012\\011ADD CONSTRAINT data_dsty_fk FOREIGN KEY (dsty_id) REFERENCES data_set_types(id);\\012\\012ALTER TABLE data_set_types\\012\\011DROP CONSTRAINT obty_bk_uk;\\012\\012ALTER TABLE data_set_types\\012\\011DROP CONSTRAINT obty_dbin_fk;\\012\\012ALTER TABLE data_set_types\\012\\011ADD CONSTRAINT dsty_bk_uk UNIQUE (code, dbin_id);\\012\\012ALTER TABLE data_set_types\\012\\011ADD CONSTRAINT dsty_dbin_fk FOREIGN KEY (dbin_id) REFERENCES database_instances(id);\\012\\012DROP INDEX data_obty_fk_i;\\012\\012CREATE INDEX data_dsty_fk_i ON data(dsty_id);\\012	\N
+./sourceTest/sql/postgresql/031/.svn/text-base/013=database_version_logs.tsv.svn-base:030	source/sql/postgresql/migration/migration-029-030.sql	SUCCESS	2009-03-23 15:34:44.72	-- -------\\012-- add modification_timestamp field to allow edition with Hibernate\\012-- -------\\012ALTER TABLE data\\012\\011ADD COLUMN modification_timestamp TIME_STAMP DEFAULT CURRENT_TIMESTAMP;\\012ALTER TABLE experiment_types\\012\\011ADD COLUMN modification_timestamp TIME_STAMP DEFAULT CURRENT_TIMESTAMP;\\012ALTER TABLE sample_types\\012\\011ADD COLUMN modification_timestamp TIME_STAMP DEFAULT CURRENT_TIMESTAMP;\\012ALTER TABLE material_types\\012\\011ADD COLUMN modification_timestamp TIME_STAMP DEFAULT CURRENT_TIMESTAMP;\\012ALTER TABLE data_set_types\\012\\011ADD COLUMN modification_timestamp TIME_STAMP DEFAULT CURRENT_TIMESTAMP;\\012ALTER TABLE controlled_vocabularies\\012\\011ADD COLUMN modification_timestamp TIME_STAMP DEFAULT CURRENT_TIMESTAMP;\\012-- -------\\012-- add properties to data sets\\012-- -------\\012CREATE TABLE DATA_SET_PROPERTIES (ID TECH_ID NOT NULL,DS_ID TECH_ID NOT NULL,DSTPT_ID TECH_ID NOT NULL,VALUE GENERIC_VALUE,CVTE_ID TECH_ID, MATE_PROP_ID TECH_ID, PERS_ID_REGISTERER TECH_ID NOT NULL,REGISTRATION_TIMESTAMP TIME_STAMP_DFL NOT NULL DEFAULT CURRENT_TIMESTAMP, MODIFICATION_TIMESTAMP TIME_STAMP DEFAULT CURRENT_TIMESTAMP);\\012CREATE TABLE DATA_SET_TYPE_PROPERTY_TYPES (ID TECH_ID NOT NULL,DSTY_ID TECH_ID NOT NULL,PRTY_ID TECH_ID NOT NULL,IS_MANDATORY BOOLEAN_CHAR NOT NULL DEFAULT 'F',IS_MANAGED_INTERNALLY BOOLEAN_CHAR NOT NULL DEFAULT 'F',PERS_ID_REGISTERER TECH_ID NOT NULL,REGISTRATION_TIMESTAMP TIME_STAMP_DFL NOT NULL DEFAULT CURRENT_TIMESTAMP);\\012\\012CREATE SEQUENCE DATA_SET_PROPERTY_ID_SEQ;\\012CREATE SEQUENCE DSTPT_ID_SEQ;\\012\\012ALTER TABLE DATA_SET_TYPE_PROPERTY_TYPES ADD CONSTRAINT DSTPT_PK PRIMARY KEY(ID);\\012ALTER TABLE DATA_SET_PROPERTIES ADD CONSTRAINT DSPR_PK PRIMARY KEY(ID);\\012\\012ALTER TABLE DATA_SET_TYPE_PROPERTY_TYPES ADD CONSTRAINT DSTPT_BK_UK UNIQUE(DSTY_ID,PRTY_ID);\\012ALTER TABLE DATA_SET_PROPERTIES ADD CONSTRAINT DSPR_BK_UK UNIQUE(DS_ID,DSTPT_ID);\\012\\012\\012ALTER TABLE DATA_SET_TYPE_PROPERTY_TYPES ADD CONSTRAINT DSTPT_DSTY_FK FOREIGN KEY (DSTY_ID) REFERENCES DATA_SET_TYPES(ID);\\012ALTER TABLE DATA_SET_TYPE_PROPERTY_TYPES ADD CONSTRAINT DSTPT_PERS_FK FOREIGN KEY (PERS_ID_REGISTERER) REFERENCES PERSONS(ID);\\012ALTER TABLE DATA_SET_TYPE_PROPERTY_TYPES ADD CONSTRAINT DSTPT_PRTY_FK FOREIGN KEY (PRTY_ID) REFERENCES PROPERTY_TYPES(ID);\\012ALTER TABLE DATA_SET_PROPERTIES ADD CONSTRAINT DSPR_CVTE_FK FOREIGN KEY (CVTE_ID) REFERENCES CONTROLLED_VOCABULARY_TERMS(ID);\\012ALTER TABLE DATA_SET_PROPERTIES ADD CONSTRAINT DSPR_DSTPT_FK FOREIGN KEY (DSTPT_ID) REFERENCES DATA_SET_TYPE_PROPERTY_TYPES(ID) ON DELETE CASCADE;\\012ALTER TABLE DATA_SET_PROPERTIES ADD CONSTRAINT DSPR_DS_FK FOREIGN KEY (DS_ID) REFERENCES DATA(ID);\\012ALTER TABLE DATA_SET_PROPERTIES ADD CONSTRAINT DSPR_PERS_FK FOREIGN KEY (PERS_ID_REGISTERER) REFERENCES PERSONS(ID);\\012ALTER TABLE DATA_SET_PROPERTIES ADD CONSTRAINT DSPR_MAPR_FK FOREIGN KEY (MATE_PROP_ID) REFERENCES MATERIALS(ID);\\012\\012ALTER TABLE DATA_SET_PROPERTIES ADD CONSTRAINT DSPR_CK CHECK \\012\\011((VALUE IS NOT NULL AND CVTE_ID IS NULL AND MATE_PROP_ID IS NULL) OR \\012\\011 (VALUE IS NULL AND CVTE_ID IS NOT NULL AND MATE_PROP_ID IS NULL) OR\\012\\011 (VALUE IS NULL AND CVTE_ID IS NULL AND MATE_PROP_ID IS NOT NULL)\\012\\011);\\012\\012CREATE INDEX DSPR_CVTE_FK_I ON DATA_SET_PROPERTIES (CVTE_ID);\\012CREATE INDEX DSPR_DSTPT_FK_I ON DATA_SET_PROPERTIES (DSTPT_ID);\\012CREATE INDEX DSPR_DS_FK_I ON DATA_SET_PROPERTIES (DS_ID);\\012CREATE INDEX DSPR_PERS_FK_I ON DATA_SET_PROPERTIES (PERS_ID_REGISTERER);\\012CREATE INDEX DSTPT_DSTY_FK_I ON DATA_SET_TYPE_PROPERTY_TYPES (DSTY_ID);\\012CREATE INDEX DSTPT_PERS_FK_I ON DATA_SET_TYPE_PROPERTY_TYPES (PERS_ID_REGISTERER);\\012CREATE INDEX DSTPT_PRTY_FK_I ON DATA_SET_TYPE_PROPERTY_TYPES (PRTY_ID);\\012\\012CREATE OR REPLACE FUNCTION DATA_SET_PROPERTY_WITH_MATERIAL_DATA_TYPE_CHECK() RETURNS trigger AS $$\\012DECLARE\\012   v_type_id  CODE;\\012   v_type_id_prop  CODE;\\012BEGIN\\012   if NEW.mate_prop_id IS NOT NULL then\\012\\011\\011\\011-- find material type id of the property type \\012\\011\\011\\011select pt.maty_prop_id into v_type_id_prop \\012\\011\\011\\011  from data_set_type_property_types dstpt, property_types pt \\012\\011\\011\\011 where NEW.dstpt_id = dstpt.id AND dstpt.prty_id = pt.id;\\012\\011\\011\\012\\011\\011\\011if v_type_id_prop IS NOT NULL then\\012\\011\\011\\011\\011-- find material type id of the material which consists the entity's property value\\012\\011\\011\\011\\011select entity.maty_id into v_type_id \\012\\011\\011\\011\\011  from materials entity\\012\\011\\011\\011\\011 where NEW.mate_prop_id = entity.id;\\012\\011\\011\\011\\011if v_type_id != v_type_id_prop then\\012\\011\\011\\011\\011\\011RAISE EXCEPTION 'Insert/Update of property value referencing material (id: %) failed, as referenced material type is different than expected (id %, expected id: %).', \\012\\011\\011\\011\\011\\011\\011\\011\\011\\011\\011\\011\\011 NEW.mate_prop_id, v_type_id, v_type_id_prop;\\012\\011\\011\\011\\011end if;\\012\\011\\011\\011end if;\\012   end if;\\012   RETURN NEW;\\012END;\\012$$ LANGUAGE 'plpgsql';\\012\\012CREATE TRIGGER DATA_SET_PROPERTY_WITH_MATERIAL_DATA_TYPE_CHECK BEFORE INSERT OR UPDATE ON data_set_properties\\012    FOR EACH ROW EXECUTE PROCEDURE DATA_SET_PROPERTY_WITH_MATERIAL_DATA_TYPE_CHECK();   \\012	\N
+./sourceTest/sql/postgresql/031/.svn/text-base/schema-031.sql.svn-base:    LANGUAGE plpgsql;
+./sourceTest/sql/postgresql/031/.svn/text-base/schema-031.sql.svn-base:    LANGUAGE plpgsql;
+./sourceTest/sql/postgresql/031/.svn/text-base/schema-031.sql.svn-base:    LANGUAGE plpgsql;
+./sourceTest/sql/postgresql/031/.svn/text-base/schema-031.sql.svn-base:    LANGUAGE plpgsql;
+./sourceTest/sql/postgresql/031/.svn/text-base/schema-031.sql.svn-base:    LANGUAGE plpgsql;
+./sourceTest/sql/postgresql/031/.svn/text-base/schema-031.sql.svn-base:    LANGUAGE plpgsql;
+./sourceTest/sql/postgresql/031/.svn/text-base/schema-031.sql.svn-base:    LANGUAGE plpgsql;
+./sourceTest/sql/postgresql/031/.svn/text-base/schema-031.sql.svn-base:    LANGUAGE plpgsql;
+./sourceTest/sql/postgresql/031/013=database_version_logs.tsv:027	D:\\User\\felmer\\dev-workspace\\openbis/source/sql/postgresql/027/function-027.sql	SUCCESS	2008-11-05 09:18:00.403	-- Creating Functions\\012\\012------------------------------------------------------------------------------------\\012--  Purpose:  Create function RENAME_SEQUENCE() that is required for renaming the sequences belonging to tables\\012------------------------------------------------------------------------------------\\012CREATE FUNCTION RENAME_SEQUENCE(OLD_NAME VARCHAR, NEW_NAME VARCHAR) RETURNS INTEGER AS $$\\012DECLARE\\012  CURR_SEQ_VAL   INTEGER;\\012BEGIN\\012  SELECT INTO CURR_SEQ_VAL NEXTVAL(OLD_NAME);\\012  EXECUTE 'CREATE SEQUENCE ' || NEW_NAME || ' START WITH ' || CURR_SEQ_VAL;\\012  EXECUTE 'DROP SEQUENCE ' || OLD_NAME;\\012  RETURN CURR_SEQ_VAL;\\012END;\\012$$ LANGUAGE 'plpgsql';\\012\\012\\012------------------------------------------------------------------------------------\\012--  Purpose:  Create trigger CONTROLLED_VOCABULARY_CHECK \\012------------------------------------------------------------------------------------\\012\\012CREATE OR REPLACE FUNCTION CONTROLLED_VOCABULARY_CHECK() RETURNS trigger AS $$\\012DECLARE\\012   v_code  CODE;\\012BEGIN\\012\\012   select code into v_code from data_types where id = NEW.daty_id;\\012\\012   -- Check if the data is of type "CONTROLLEDVOCABULARY"\\012   if v_code = 'CONTROLLEDVOCABULARY' then\\012      if NEW.covo_id IS NULL then\\012         RAISE EXCEPTION 'Insert/Update of Property Type (Code: %) failed, as its Data Type is CONTROLLEDVOCABULARY, but it is not linked to a Controlled Vocabulary.', NEW.code;\\012      end if;\\012   end if;\\012\\012   RETURN NEW;\\012\\012END;\\012$$ LANGUAGE 'plpgsql';\\012\\012CREATE TRIGGER CONTROLLED_VOCABULARY_CHECK BEFORE INSERT OR UPDATE ON PROPERTY_TYPES\\012    FOR EACH ROW EXECUTE PROCEDURE CONTROLLED_VOCABULARY_CHECK();\\012\\012\\012------------------------------------------------------------------------------------\\012--  Purpose:  Create trigger EXTERNAL_DATA_STORAGE_FORMAT_CHECK \\012------------------------------------------------------------------------------------\\012\\012CREATE OR REPLACE FUNCTION EXTERNAL_DATA_STORAGE_FORMAT_CHECK() RETURNS trigger AS $$\\012DECLARE\\012   v_covo_code  CODE;\\012   data_code CODE;\\012BEGIN\\012\\012   select code into v_covo_code from controlled_vocabularies\\012      where is_internal_namespace = true and \\012         id = (select covo_id from controlled_vocabulary_terms where id = NEW.cvte_id_stor_fmt);\\012   -- Check if the data storage format is a term of the controlled vocabulary "STORAGE_FORMAT"\\012   if v_covo_code != 'STORAGE_FORMAT' then\\012      select code into data_code from data where id = NEW.data_id; \\012      RAISE EXCEPTION 'Insert/Update of Data (Code: %) failed, as its Storage Format is %, but is required to be STORAGE_FORMAT.', data_code, v_covo_code;\\012   end if;\\012\\012   RETURN NEW;\\012\\012END;\\012$$ LANGUAGE 'plpgsql';\\012\\012CREATE TRIGGER EXTERNAL_DATA_STORAGE_FORMAT_CHECK BEFORE INSERT OR UPDATE ON EXTERNAL_DATA\\012    FOR EACH ROW EXECUTE PROCEDURE EXTERNAL_DATA_STORAGE_FORMAT_CHECK();\\012\\012------------------------------------------------------------------------------------\\012--  Purpose:  Create trigger SAMPLE_CODE_UNIQUENESS_CHECK \\012------------------------------------------------------------------------------------\\012\\012CREATE OR REPLACE FUNCTION SAMPLE_CODE_UNIQUENESS_CHECK() RETURNS trigger AS $$\\012DECLARE\\012   counter  INTEGER;\\012BEGIN\\012\\011IF (NEW.samp_id_part_of is NULL) THEN\\012\\011\\011IF (NEW.dbin_id is not NULL) THEN\\012\\011\\011\\011SELECT count(*) into counter FROM samples \\012\\011\\011\\011\\011where id != NEW.id and code = NEW.code and samp_id_part_of is NULL and dbin_id = NEW.dbin_id;\\012\\011\\011\\011IF (counter > 0) THEN\\012\\011\\011\\011\\011RAISE EXCEPTION 'Insert/Update of Sample (Code: %) failed because database instance sample with the same code already exists.', NEW.code;\\012\\011\\011\\011END IF;\\012\\011\\011ELSIF (NEW.grou_id is not NULL) THEN\\012\\011\\011\\011SELECT count(*) into counter FROM samples \\012\\011\\011\\011\\011where id != NEW.id and code = NEW.code and samp_id_part_of is NULL and grou_id = NEW.grou_id;\\012\\011\\011\\011IF (counter > 0) THEN\\012\\011\\011\\011\\011RAISE EXCEPTION 'Insert/Update of Sample (Code: %) failed because group sample with the same code already exists.', NEW.code;\\012\\011\\011\\011END IF;\\012\\011\\011END IF;\\012        ELSE\\012\\011\\011IF (NEW.dbin_id is not NULL) THEN\\012\\011\\011\\011SELECT count(*) into counter FROM samples \\012\\011\\011\\011\\011where id != NEW.id and code = NEW.code and samp_id_part_of = NEW.samp_id_part_of and dbin_id = NEW.dbin_id;\\012\\011\\011\\011IF (counter > 0) THEN\\012\\011\\011\\011\\011RAISE EXCEPTION 'Insert/Update of Sample (Code: %) failed because database instance sample with the same code and being the part of the same parent already exists.', NEW.code;\\012\\011\\011\\011END IF;\\012\\011\\011ELSIF (NEW.grou_id is not NULL) THEN\\012\\011\\011\\011SELECT count(*) into counter FROM samples \\012\\011\\011\\011\\011where id != NEW.id and code = NEW.code and samp_id_part_of = NEW.samp_id_part_of and grou_id = NEW.grou_id;\\012\\011\\011\\011IF (counter > 0) THEN\\012\\011\\011\\011\\011RAISE EXCEPTION 'Insert/Update of Sample (Code: %) failed because group sample with the same code and being the part of the same parent already exists.', NEW.code;\\012\\011\\011\\011END IF;\\012\\011\\011END IF;\\012        END IF;   \\012   RETURN NEW;\\012END;\\012$$ LANGUAGE 'plpgsql';\\012\\012CREATE TRIGGER SAMPLE_CODE_UNIQUENESS_CHECK BEFORE INSERT OR UPDATE ON SAMPLES\\012    FOR EACH ROW EXECUTE PROCEDURE SAMPLE_CODE_UNIQUENESS_CHECK();\\012	\N
+./sourceTest/sql/postgresql/031/013=database_version_logs.tsv:028	source/sql/postgresql/migration/migration-027-028.sql	SUCCESS	2008-11-18 13:24:17.508	-- Create EXPERIMENT_ATTACHMENT_CONTENTS.\\012CREATE TABLE EXPERIMENT_ATTACHMENT_CONTENTS (ID TECH_ID NOT NULL,VALUE FILE NOT NULL);\\012CREATE SEQUENCE EXPERIMENT_ATTACHMENT_CONTENT_ID_SEQ;\\012ALTER TABLE EXPERIMENT_ATTACHMENT_CONTENTS ADD CONSTRAINT EXAC_PK PRIMARY KEY(ID);\\012\\012-- Alter EXPERIMENT_ATTACHMENTS by adding the new column which has a NULL constraint.\\012-- The NOT NULL constraint is added later on.\\012ALTER TABLE EXPERIMENT_ATTACHMENTS ADD COLUMN EXAC_ID TECH_ID;\\012\\012-- Does the VALUE migration between EXPERIMENT_ATTACHMENTS to EXPERIMENT_ATTACHMENT_CONTENTS.\\012CREATE OR REPLACE FUNCTION move_exp_att_content() RETURNS integer AS $$\\012DECLARE\\012    rec RECORD;\\012    seq BIGINT;\\012BEGIN\\012  FOR rec IN SELECT id, value FROM EXPERIMENT_ATTACHMENTS LOOP\\012  \\011seq := nextval('EXPERIMENT_ATTACHMENT_CONTENT_ID_SEQ');\\012    INSERT INTO EXPERIMENT_ATTACHMENT_CONTENTS (id, value) VALUES (seq, rec.value);\\012    UPDATE EXPERIMENT_ATTACHMENTS SET exac_id = seq WHERE id = rec.id;\\012  END LOOP;\\012  RETURN 1;\\012END;\\012$$ LANGUAGE 'plpgsql';\\012\\012-- Call the function.\\012SELECT move_exp_att_content();\\012DROP FUNCTION move_exp_att_content();\\012\\012\\012-- Finish EXPERIMENT_ATTACHMENTS changes.\\012ALTER TABLE EXPERIMENT_ATTACHMENTS ADD CONSTRAINT EXAT_CONT_FK FOREIGN KEY (EXAC_ID) REFERENCES EXPERIMENT_ATTACHMENT_CONTENTS(ID);\\012ALTER TABLE EXPERIMENT_ATTACHMENTS DROP COLUMN VALUE;\\012ALTER TABLE EXPERIMENT_ATTACHMENTS ALTER COLUMN EXAC_ID SET NOT NULL;\\012	\N
+./sourceTest/sql/postgresql/031/013=database_version_logs.tsv:029	source/sql/postgresql/migration/migration-028-029.sql	SUCCESS	2009-03-18 10:50:20.105	-- -------\\012-- add modification_timestamp field to allow edition with Hibernate\\012-- -------\\012\\012ALTER TABLE samples\\012\\011ADD COLUMN modification_timestamp TIME_STAMP DEFAULT CURRENT_TIMESTAMP;\\012\\012ALTER TABLE experiments\\012\\011ADD COLUMN modification_timestamp TIME_STAMP DEFAULT CURRENT_TIMESTAMP;\\012\\012ALTER TABLE materials\\012\\011ADD COLUMN modification_timestamp TIME_STAMP DEFAULT CURRENT_TIMESTAMP;\\012\\012ALTER TABLE experiment_properties\\012\\011ADD COLUMN modification_timestamp TIME_STAMP DEFAULT CURRENT_TIMESTAMP;\\012\\012ALTER TABLE material_properties\\012\\011ADD COLUMN modification_timestamp TIME_STAMP DEFAULT CURRENT_TIMESTAMP;\\012\\012ALTER TABLE sample_properties\\012\\011ADD COLUMN modification_timestamp TIME_STAMP DEFAULT CURRENT_TIMESTAMP;\\012\\012-- -------\\012-- add property data type which references materials\\012-- -------\\012\\012ALTER TABLE property_types\\012\\011ADD COLUMN maty_prop_id tech_id;\\012\\012ALTER TABLE property_types\\012\\011ADD CONSTRAINT prty_maty_fk FOREIGN KEY (maty_prop_id) REFERENCES material_types(id);\\012\\012ALTER TABLE experiment_properties\\012\\011ADD COLUMN mate_prop_id tech_id;\\012\\012ALTER TABLE material_properties\\012\\011ADD COLUMN mate_prop_id tech_id;\\012\\012ALTER TABLE sample_properties\\012\\011ADD COLUMN mate_prop_id tech_id;\\012\\012ALTER TABLE experiment_properties\\012\\011ADD CONSTRAINT expr_mapr_fk FOREIGN KEY (mate_prop_id) REFERENCES materials(id);\\012\\012ALTER TABLE material_properties\\012\\011ADD CONSTRAINT mapr_mapr_fk FOREIGN KEY (mate_prop_id) REFERENCES materials(id);\\012\\012ALTER TABLE sample_properties\\012\\011ADD CONSTRAINT sapr_mapr_fk FOREIGN KEY (mate_prop_id) REFERENCES materials(id);\\012\\012insert into data_types\\012(id\\012 ,code\\012 ,description)\\012 values \\012 (nextval('DATA_TYPE_ID_SEQ')\\012 ,'MATERIAL'\\012 ,'Reference to a material'\\012);\\012\\012ALTER TABLE MATERIAL_PROPERTIES DROP CONSTRAINT MAPR_CK;\\012ALTER TABLE MATERIAL_PROPERTIES ADD CONSTRAINT MAPR_CK CHECK \\012\\011((VALUE IS NOT NULL AND CVTE_ID IS NULL AND MATE_PROP_ID IS NULL) OR \\012\\011 (VALUE IS NULL AND CVTE_ID IS NOT NULL AND MATE_PROP_ID IS NULL) OR\\012\\011 (VALUE IS NULL AND CVTE_ID IS NULL AND MATE_PROP_ID IS NOT NULL)\\012\\011);\\012\\012ALTER TABLE EXPERIMENT_PROPERTIES DROP CONSTRAINT EXPR_CK;\\012ALTER TABLE EXPERIMENT_PROPERTIES ADD CONSTRAINT EXPR_CK CHECK \\012\\011((VALUE IS NOT NULL AND CVTE_ID IS NULL AND MATE_PROP_ID IS NULL) OR \\012\\011 (VALUE IS NULL AND CVTE_ID IS NOT NULL AND MATE_PROP_ID IS NULL) OR\\012\\011 (VALUE IS NULL AND CVTE_ID IS NULL AND MATE_PROP_ID IS NOT NULL)\\012\\011);\\012\\012ALTER TABLE SAMPLE_PROPERTIES DROP CONSTRAINT SAPR_CK;\\012ALTER TABLE SAMPLE_PROPERTIES ADD CONSTRAINT SAPR_CK CHECK \\012\\011((VALUE IS NOT NULL AND CVTE_ID IS NULL AND MATE_PROP_ID IS NULL) OR \\012\\011 (VALUE IS NULL AND CVTE_ID IS NOT NULL AND MATE_PROP_ID IS NULL) OR\\012\\011 (VALUE IS NULL AND CVTE_ID IS NULL AND MATE_PROP_ID IS NOT NULL)\\012\\011);\\012\\012------------------------------------------------------------------------------------\\012--  Purpose:  Create trigger MATERIAL/SAMPLE/EXPERIMENT _PROPERTY_WITH_MATERIAL_DATA_TYPE_CHECK\\012--            It checks that if material property value is assigned to the entity,\\012--\\011\\011\\011\\011\\011\\011then the material type is equal to the one described by property type.\\012------------------------------------------------------------------------------------\\012\\012CREATE OR REPLACE FUNCTION MATERIAL_PROPERTY_WITH_MATERIAL_DATA_TYPE_CHECK() RETURNS trigger AS $$\\012DECLARE\\012   v_type_id  CODE;\\012   v_type_id_prop  CODE;\\012BEGIN\\012   if NEW.mate_prop_id IS NOT NULL then\\012\\011\\011\\011-- find material type id of the property type \\012\\011\\011\\011select pt.maty_prop_id into v_type_id_prop \\012\\011\\011\\011  from material_type_property_types etpt, property_types pt \\012\\011\\011\\011 where NEW.mtpt_id = etpt.id AND etpt.prty_id = pt.id;\\012\\011\\011\\012\\011\\011\\011if v_type_id_prop IS NOT NULL then\\012\\011\\011\\011\\011-- find material type id of the material which consists the entity's property value\\012\\011\\011\\011\\011select entity.maty_id into v_type_id \\012\\011\\011\\011\\011  from materials entity\\012\\011\\011\\011\\011 where NEW.mate_prop_id = entity.id;\\012\\011\\011\\011\\011if v_type_id != v_type_id_prop then\\012\\011\\011\\011\\011\\011RAISE EXCEPTION 'Insert/Update of property value referencing material (id: %) failed, as referenced material type is different than expected (id %, expected id: %).', \\012\\011\\011\\011\\011\\011\\011\\011 NEW.mate_prop_id, v_type_id, v_type_id_prop;\\012\\011\\011\\011\\011end if;\\012\\011\\011\\011end if;\\012   end if;\\012   RETURN NEW;\\012END;\\012$$ LANGUAGE 'plpgsql';\\012\\012CREATE TRIGGER MATERIAL_PROPERTY_WITH_MATERIAL_DATA_TYPE_CHECK BEFORE INSERT OR UPDATE ON material_properties\\012    FOR EACH ROW EXECUTE PROCEDURE MATERIAL_PROPERTY_WITH_MATERIAL_DATA_TYPE_CHECK();\\012    \\012CREATE OR REPLACE FUNCTION SAMPLE_PROPERTY_WITH_MATERIAL_DATA_TYPE_CHECK() RETURNS trigger AS $$\\012DECLARE\\012   v_type_id  CODE;\\012   v_type_id_prop  CODE;\\012BEGIN\\012   if NEW.mate_prop_id IS NOT NULL then\\012\\011\\011\\011-- find material type id of the property type \\012\\011\\011\\011select pt.maty_prop_id into v_type_id_prop \\012\\011\\011\\011  from sample_type_property_types etpt, property_types pt \\012\\011\\011\\011 where NEW.stpt_id = etpt.id AND etpt.prty_id = pt.id;\\012\\011\\011\\012\\011\\011\\011if v_type_id_prop IS NOT NULL then\\012\\011\\011\\011\\011-- find material type id of the material which consists the entity's property value\\012\\011\\011\\011\\011select entity.maty_id into v_type_id \\012\\011\\011\\011\\011  from materials entity\\012\\011\\011\\011\\011 where NEW.mate_prop_id = entity.id;\\012\\011\\011\\011\\011if v_type_id != v_type_id_prop then\\012\\011\\011\\011\\011\\011RAISE EXCEPTION 'Insert/Update of property value referencing material (id: %) failed, as referenced material type is different than expected (id %, expected id: %).', \\012\\011\\011\\011\\011\\011\\011\\011\\011\\011\\011\\011\\011 NEW.mate_prop_id, v_type_id, v_type_id_prop;\\012\\011\\011\\011\\011end if;\\012\\011\\011\\011end if;\\012   end if;\\012   RETURN NEW;\\012END;\\012$$ LANGUAGE 'plpgsql';\\012\\012CREATE TRIGGER SAMPLE_PROPERTY_WITH_MATERIAL_DATA_TYPE_CHECK BEFORE INSERT OR UPDATE ON sample_properties\\012    FOR EACH ROW EXECUTE PROCEDURE SAMPLE_PROPERTY_WITH_MATERIAL_DATA_TYPE_CHECK();\\012    \\012CREATE OR REPLACE FUNCTION EXPERIMENT_PROPERTY_WITH_MATERIAL_DATA_TYPE_CHECK() RETURNS trigger AS $$\\012DECLARE\\012   v_type_id  CODE;\\012   v_type_id_prop  CODE;\\012BEGIN\\012   if NEW.mate_prop_id IS NOT NULL then\\012\\011\\011\\011-- find material type id of the property type \\012\\011\\011\\011select pt.maty_prop_id into v_type_id_prop \\012\\011\\011\\011  from experiment_type_property_types etpt, property_types pt \\012\\011\\011\\011 where NEW.etpt_id = etpt.id AND etpt.prty_id = pt.id;\\012\\011\\011\\012\\011\\011\\011if v_type_id_prop IS NOT NULL then\\012\\011\\011\\011\\011-- find material type id of the material which consists the entity's property value\\012\\011\\011\\011\\011select entity.maty_id into v_type_id \\012\\011\\011\\011\\011  from materials entity\\012\\011\\011\\011\\011 where NEW.mate_prop_id = entity.id;\\012\\011\\011\\011\\011if v_type_id != v_type_id_prop then\\012\\011\\011\\011\\011\\011RAISE EXCEPTION 'Insert/Update of property value referencing material (id: %) failed, as referenced material type is different than expected (id %, expected id: %).', \\012\\011\\011\\011\\011\\011\\011\\011\\011\\011\\011\\011\\011 NEW.mate_prop_id, v_type_id, v_type_id_prop;\\012\\011\\011\\011\\011end if;\\012\\011\\011\\011end if;\\012   end if;\\012   RETURN NEW;\\012END;\\012$$ LANGUAGE 'plpgsql';\\012\\012CREATE TRIGGER EXPERIMENT_PROPERTY_WITH_MATERIAL_DATA_TYPE_CHECK BEFORE INSERT OR UPDATE ON experiment_properties\\012    FOR EACH ROW EXECUTE PROCEDURE EXPERIMENT_PROPERTY_WITH_MATERIAL_DATA_TYPE_CHECK();\\012       \\012-- -------\\012-- remove the reminescents of the OBSERVABLE_TYPE\\012-- -------\\012\\012ALTER TABLE data\\012\\011DROP CONSTRAINT data_obty_fk;\\012\\012ALTER TABLE data_set_types\\012\\011DROP CONSTRAINT obty_pk;\\012\\012ALTER TABLE data_set_types\\012\\011ADD CONSTRAINT dsty_pk PRIMARY KEY (id);\\012\\012ALTER TABLE data\\012\\011ADD CONSTRAINT data_dsty_fk FOREIGN KEY (dsty_id) REFERENCES data_set_types(id);\\012\\012ALTER TABLE data_set_types\\012\\011DROP CONSTRAINT obty_bk_uk;\\012\\012ALTER TABLE data_set_types\\012\\011DROP CONSTRAINT obty_dbin_fk;\\012\\012ALTER TABLE data_set_types\\012\\011ADD CONSTRAINT dsty_bk_uk UNIQUE (code, dbin_id);\\012\\012ALTER TABLE data_set_types\\012\\011ADD CONSTRAINT dsty_dbin_fk FOREIGN KEY (dbin_id) REFERENCES database_instances(id);\\012\\012DROP INDEX data_obty_fk_i;\\012\\012CREATE INDEX data_dsty_fk_i ON data(dsty_id);\\012	\N
+./sourceTest/sql/postgresql/031/013=database_version_logs.tsv:030	source/sql/postgresql/migration/migration-029-030.sql	SUCCESS	2009-03-23 15:34:44.72	-- -------\\012-- add modification_timestamp field to allow edition with Hibernate\\012-- -------\\012ALTER TABLE data\\012\\011ADD COLUMN modification_timestamp TIME_STAMP DEFAULT CURRENT_TIMESTAMP;\\012ALTER TABLE experiment_types\\012\\011ADD COLUMN modification_timestamp TIME_STAMP DEFAULT CURRENT_TIMESTAMP;\\012ALTER TABLE sample_types\\012\\011ADD COLUMN modification_timestamp TIME_STAMP DEFAULT CURRENT_TIMESTAMP;\\012ALTER TABLE material_types\\012\\011ADD COLUMN modification_timestamp TIME_STAMP DEFAULT CURRENT_TIMESTAMP;\\012ALTER TABLE data_set_types\\012\\011ADD COLUMN modification_timestamp TIME_STAMP DEFAULT CURRENT_TIMESTAMP;\\012ALTER TABLE controlled_vocabularies\\012\\011ADD COLUMN modification_timestamp TIME_STAMP DEFAULT CURRENT_TIMESTAMP;\\012-- -------\\012-- add properties to data sets\\012-- -------\\012CREATE TABLE DATA_SET_PROPERTIES (ID TECH_ID NOT NULL,DS_ID TECH_ID NOT NULL,DSTPT_ID TECH_ID NOT NULL,VALUE GENERIC_VALUE,CVTE_ID TECH_ID, MATE_PROP_ID TECH_ID, PERS_ID_REGISTERER TECH_ID NOT NULL,REGISTRATION_TIMESTAMP TIME_STAMP_DFL NOT NULL DEFAULT CURRENT_TIMESTAMP, MODIFICATION_TIMESTAMP TIME_STAMP DEFAULT CURRENT_TIMESTAMP);\\012CREATE TABLE DATA_SET_TYPE_PROPERTY_TYPES (ID TECH_ID NOT NULL,DSTY_ID TECH_ID NOT NULL,PRTY_ID TECH_ID NOT NULL,IS_MANDATORY BOOLEAN_CHAR NOT NULL DEFAULT 'F',IS_MANAGED_INTERNALLY BOOLEAN_CHAR NOT NULL DEFAULT 'F',PERS_ID_REGISTERER TECH_ID NOT NULL,REGISTRATION_TIMESTAMP TIME_STAMP_DFL NOT NULL DEFAULT CURRENT_TIMESTAMP);\\012\\012CREATE SEQUENCE DATA_SET_PROPERTY_ID_SEQ;\\012CREATE SEQUENCE DSTPT_ID_SEQ;\\012\\012ALTER TABLE DATA_SET_TYPE_PROPERTY_TYPES ADD CONSTRAINT DSTPT_PK PRIMARY KEY(ID);\\012ALTER TABLE DATA_SET_PROPERTIES ADD CONSTRAINT DSPR_PK PRIMARY KEY(ID);\\012\\012ALTER TABLE DATA_SET_TYPE_PROPERTY_TYPES ADD CONSTRAINT DSTPT_BK_UK UNIQUE(DSTY_ID,PRTY_ID);\\012ALTER TABLE DATA_SET_PROPERTIES ADD CONSTRAINT DSPR_BK_UK UNIQUE(DS_ID,DSTPT_ID);\\012\\012\\012ALTER TABLE DATA_SET_TYPE_PROPERTY_TYPES ADD CONSTRAINT DSTPT_DSTY_FK FOREIGN KEY (DSTY_ID) REFERENCES DATA_SET_TYPES(ID);\\012ALTER TABLE DATA_SET_TYPE_PROPERTY_TYPES ADD CONSTRAINT DSTPT_PERS_FK FOREIGN KEY (PERS_ID_REGISTERER) REFERENCES PERSONS(ID);\\012ALTER TABLE DATA_SET_TYPE_PROPERTY_TYPES ADD CONSTRAINT DSTPT_PRTY_FK FOREIGN KEY (PRTY_ID) REFERENCES PROPERTY_TYPES(ID);\\012ALTER TABLE DATA_SET_PROPERTIES ADD CONSTRAINT DSPR_CVTE_FK FOREIGN KEY (CVTE_ID) REFERENCES CONTROLLED_VOCABULARY_TERMS(ID);\\012ALTER TABLE DATA_SET_PROPERTIES ADD CONSTRAINT DSPR_DSTPT_FK FOREIGN KEY (DSTPT_ID) REFERENCES DATA_SET_TYPE_PROPERTY_TYPES(ID) ON DELETE CASCADE;\\012ALTER TABLE DATA_SET_PROPERTIES ADD CONSTRAINT DSPR_DS_FK FOREIGN KEY (DS_ID) REFERENCES DATA(ID);\\012ALTER TABLE DATA_SET_PROPERTIES ADD CONSTRAINT DSPR_PERS_FK FOREIGN KEY (PERS_ID_REGISTERER) REFERENCES PERSONS(ID);\\012ALTER TABLE DATA_SET_PROPERTIES ADD CONSTRAINT DSPR_MAPR_FK FOREIGN KEY (MATE_PROP_ID) REFERENCES MATERIALS(ID);\\012\\012ALTER TABLE DATA_SET_PROPERTIES ADD CONSTRAINT DSPR_CK CHECK \\012\\011((VALUE IS NOT NULL AND CVTE_ID IS NULL AND MATE_PROP_ID IS NULL) OR \\012\\011 (VALUE IS NULL AND CVTE_ID IS NOT NULL AND MATE_PROP_ID IS NULL) OR\\012\\011 (VALUE IS NULL AND CVTE_ID IS NULL AND MATE_PROP_ID IS NOT NULL)\\012\\011);\\012\\012CREATE INDEX DSPR_CVTE_FK_I ON DATA_SET_PROPERTIES (CVTE_ID);\\012CREATE INDEX DSPR_DSTPT_FK_I ON DATA_SET_PROPERTIES (DSTPT_ID);\\012CREATE INDEX DSPR_DS_FK_I ON DATA_SET_PROPERTIES (DS_ID);\\012CREATE INDEX DSPR_PERS_FK_I ON DATA_SET_PROPERTIES (PERS_ID_REGISTERER);\\012CREATE INDEX DSTPT_DSTY_FK_I ON DATA_SET_TYPE_PROPERTY_TYPES (DSTY_ID);\\012CREATE INDEX DSTPT_PERS_FK_I ON DATA_SET_TYPE_PROPERTY_TYPES (PERS_ID_REGISTERER);\\012CREATE INDEX DSTPT_PRTY_FK_I ON DATA_SET_TYPE_PROPERTY_TYPES (PRTY_ID);\\012\\012CREATE OR REPLACE FUNCTION DATA_SET_PROPERTY_WITH_MATERIAL_DATA_TYPE_CHECK() RETURNS trigger AS $$\\012DECLARE\\012   v_type_id  CODE;\\012   v_type_id_prop  CODE;\\012BEGIN\\012   if NEW.mate_prop_id IS NOT NULL then\\012\\011\\011\\011-- find material type id of the property type \\012\\011\\011\\011select pt.maty_prop_id into v_type_id_prop \\012\\011\\011\\011  from data_set_type_property_types dstpt, property_types pt \\012\\011\\011\\011 where NEW.dstpt_id = dstpt.id AND dstpt.prty_id = pt.id;\\012\\011\\011\\012\\011\\011\\011if v_type_id_prop IS NOT NULL then\\012\\011\\011\\011\\011-- find material type id of the material which consists the entity's property value\\012\\011\\011\\011\\011select entity.maty_id into v_type_id \\012\\011\\011\\011\\011  from materials entity\\012\\011\\011\\011\\011 where NEW.mate_prop_id = entity.id;\\012\\011\\011\\011\\011if v_type_id != v_type_id_prop then\\012\\011\\011\\011\\011\\011RAISE EXCEPTION 'Insert/Update of property value referencing material (id: %) failed, as referenced material type is different than expected (id %, expected id: %).', \\012\\011\\011\\011\\011\\011\\011\\011\\011\\011\\011\\011\\011 NEW.mate_prop_id, v_type_id, v_type_id_prop;\\012\\011\\011\\011\\011end if;\\012\\011\\011\\011end if;\\012   end if;\\012   RETURN NEW;\\012END;\\012$$ LANGUAGE 'plpgsql';\\012\\012CREATE TRIGGER DATA_SET_PROPERTY_WITH_MATERIAL_DATA_TYPE_CHECK BEFORE INSERT OR UPDATE ON data_set_properties\\012    FOR EACH ROW EXECUTE PROCEDURE DATA_SET_PROPERTY_WITH_MATERIAL_DATA_TYPE_CHECK();   \\012	\N
+./sourceTest/sql/postgresql/031/schema-031.sql:    LANGUAGE plpgsql;
+./sourceTest/sql/postgresql/031/schema-031.sql:    LANGUAGE plpgsql;
+./sourceTest/sql/postgresql/031/schema-031.sql:    LANGUAGE plpgsql;
+./sourceTest/sql/postgresql/031/schema-031.sql:    LANGUAGE plpgsql;
+./sourceTest/sql/postgresql/031/schema-031.sql:    LANGUAGE plpgsql;
+./sourceTest/sql/postgresql/031/schema-031.sql:    LANGUAGE plpgsql;
+./sourceTest/sql/postgresql/031/schema-031.sql:    LANGUAGE plpgsql;
+./sourceTest/sql/postgresql/031/schema-031.sql:    LANGUAGE plpgsql;
+./sourceTest/sql/postgresql/032/.svn/text-base/013=database_version_logs.tsv.svn-base:027	D:\\User\\felmer\\dev-workspace\\openbis/source/sql/postgresql/027/function-027.sql	SUCCESS	2008-11-05 09:18:00.403	-- Creating Functions\\012\\012------------------------------------------------------------------------------------\\012--  Purpose:  Create function RENAME_SEQUENCE() that is required for renaming the sequences belonging to tables\\012------------------------------------------------------------------------------------\\012CREATE FUNCTION RENAME_SEQUENCE(OLD_NAME VARCHAR, NEW_NAME VARCHAR) RETURNS INTEGER AS $$\\012DECLARE\\012  CURR_SEQ_VAL   INTEGER;\\012BEGIN\\012  SELECT INTO CURR_SEQ_VAL NEXTVAL(OLD_NAME);\\012  EXECUTE 'CREATE SEQUENCE ' || NEW_NAME || ' START WITH ' || CURR_SEQ_VAL;\\012  EXECUTE 'DROP SEQUENCE ' || OLD_NAME;\\012  RETURN CURR_SEQ_VAL;\\012END;\\012$$ LANGUAGE 'plpgsql';\\012\\012\\012------------------------------------------------------------------------------------\\012--  Purpose:  Create trigger CONTROLLED_VOCABULARY_CHECK \\012------------------------------------------------------------------------------------\\012\\012CREATE OR REPLACE FUNCTION CONTROLLED_VOCABULARY_CHECK() RETURNS trigger AS $$\\012DECLARE\\012   v_code  CODE;\\012BEGIN\\012\\012   select code into v_code from data_types where id = NEW.daty_id;\\012\\012   -- Check if the data is of type "CONTROLLEDVOCABULARY"\\012   if v_code = 'CONTROLLEDVOCABULARY' then\\012      if NEW.covo_id IS NULL then\\012         RAISE EXCEPTION 'Insert/Update of Property Type (Code: %) failed, as its Data Type is CONTROLLEDVOCABULARY, but it is not linked to a Controlled Vocabulary.', NEW.code;\\012      end if;\\012   end if;\\012\\012   RETURN NEW;\\012\\012END;\\012$$ LANGUAGE 'plpgsql';\\012\\012CREATE TRIGGER CONTROLLED_VOCABULARY_CHECK BEFORE INSERT OR UPDATE ON PROPERTY_TYPES\\012    FOR EACH ROW EXECUTE PROCEDURE CONTROLLED_VOCABULARY_CHECK();\\012\\012\\012------------------------------------------------------------------------------------\\012--  Purpose:  Create trigger EXTERNAL_DATA_STORAGE_FORMAT_CHECK \\012------------------------------------------------------------------------------------\\012\\012CREATE OR REPLACE FUNCTION EXTERNAL_DATA_STORAGE_FORMAT_CHECK() RETURNS trigger AS $$\\012DECLARE\\012   v_covo_code  CODE;\\012   data_code CODE;\\012BEGIN\\012\\012   select code into v_covo_code from controlled_vocabularies\\012      where is_internal_namespace = true and \\012         id = (select covo_id from controlled_vocabulary_terms where id = NEW.cvte_id_stor_fmt);\\012   -- Check if the data storage format is a term of the controlled vocabulary "STORAGE_FORMAT"\\012   if v_covo_code != 'STORAGE_FORMAT' then\\012      select code into data_code from data where id = NEW.data_id; \\012      RAISE EXCEPTION 'Insert/Update of Data (Code: %) failed, as its Storage Format is %, but is required to be STORAGE_FORMAT.', data_code, v_covo_code;\\012   end if;\\012\\012   RETURN NEW;\\012\\012END;\\012$$ LANGUAGE 'plpgsql';\\012\\012CREATE TRIGGER EXTERNAL_DATA_STORAGE_FORMAT_CHECK BEFORE INSERT OR UPDATE ON EXTERNAL_DATA\\012    FOR EACH ROW EXECUTE PROCEDURE EXTERNAL_DATA_STORAGE_FORMAT_CHECK();\\012\\012------------------------------------------------------------------------------------\\012--  Purpose:  Create trigger SAMPLE_CODE_UNIQUENESS_CHECK \\012------------------------------------------------------------------------------------\\012\\012CREATE OR REPLACE FUNCTION SAMPLE_CODE_UNIQUENESS_CHECK() RETURNS trigger AS $$\\012DECLARE\\012   counter  INTEGER;\\012BEGIN\\012\\011IF (NEW.samp_id_part_of is NULL) THEN\\012\\011\\011IF (NEW.dbin_id is not NULL) THEN\\012\\011\\011\\011SELECT count(*) into counter FROM samples \\012\\011\\011\\011\\011where id != NEW.id and code = NEW.code and samp_id_part_of is NULL and dbin_id = NEW.dbin_id;\\012\\011\\011\\011IF (counter > 0) THEN\\012\\011\\011\\011\\011RAISE EXCEPTION 'Insert/Update of Sample (Code: %) failed because database instance sample with the same code already exists.', NEW.code;\\012\\011\\011\\011END IF;\\012\\011\\011ELSIF (NEW.grou_id is not NULL) THEN\\012\\011\\011\\011SELECT count(*) into counter FROM samples \\012\\011\\011\\011\\011where id != NEW.id and code = NEW.code and samp_id_part_of is NULL and grou_id = NEW.grou_id;\\012\\011\\011\\011IF (counter > 0) THEN\\012\\011\\011\\011\\011RAISE EXCEPTION 'Insert/Update of Sample (Code: %) failed because group sample with the same code already exists.', NEW.code;\\012\\011\\011\\011END IF;\\012\\011\\011END IF;\\012        ELSE\\012\\011\\011IF (NEW.dbin_id is not NULL) THEN\\012\\011\\011\\011SELECT count(*) into counter FROM samples \\012\\011\\011\\011\\011where id != NEW.id and code = NEW.code and samp_id_part_of = NEW.samp_id_part_of and dbin_id = NEW.dbin_id;\\012\\011\\011\\011IF (counter > 0) THEN\\012\\011\\011\\011\\011RAISE EXCEPTION 'Insert/Update of Sample (Code: %) failed because database instance sample with the same code and being the part of the same parent already exists.', NEW.code;\\012\\011\\011\\011END IF;\\012\\011\\011ELSIF (NEW.grou_id is not NULL) THEN\\012\\011\\011\\011SELECT count(*) into counter FROM samples \\012\\011\\011\\011\\011where id != NEW.id and code = NEW.code and samp_id_part_of = NEW.samp_id_part_of and grou_id = NEW.grou_id;\\012\\011\\011\\011IF (counter > 0) THEN\\012\\011\\011\\011\\011RAISE EXCEPTION 'Insert/Update of Sample (Code: %) failed because group sample with the same code and being the part of the same parent already exists.', NEW.code;\\012\\011\\011\\011END IF;\\012\\011\\011END IF;\\012        END IF;   \\012   RETURN NEW;\\012END;\\012$$ LANGUAGE 'plpgsql';\\012\\012CREATE TRIGGER SAMPLE_CODE_UNIQUENESS_CHECK BEFORE INSERT OR UPDATE ON SAMPLES\\012    FOR EACH ROW EXECUTE PROCEDURE SAMPLE_CODE_UNIQUENESS_CHECK();\\012	\N
+./sourceTest/sql/postgresql/032/.svn/text-base/013=database_version_logs.tsv.svn-base:028	source/sql/postgresql/migration/migration-027-028.sql	SUCCESS	2008-11-18 13:24:17.508	-- Create EXPERIMENT_ATTACHMENT_CONTENTS.\\012CREATE TABLE EXPERIMENT_ATTACHMENT_CONTENTS (ID TECH_ID NOT NULL,VALUE FILE NOT NULL);\\012CREATE SEQUENCE EXPERIMENT_ATTACHMENT_CONTENT_ID_SEQ;\\012ALTER TABLE EXPERIMENT_ATTACHMENT_CONTENTS ADD CONSTRAINT EXAC_PK PRIMARY KEY(ID);\\012\\012-- Alter EXPERIMENT_ATTACHMENTS by adding the new column which has a NULL constraint.\\012-- The NOT NULL constraint is added later on.\\012ALTER TABLE EXPERIMENT_ATTACHMENTS ADD COLUMN EXAC_ID TECH_ID;\\012\\012-- Does the VALUE migration between EXPERIMENT_ATTACHMENTS to EXPERIMENT_ATTACHMENT_CONTENTS.\\012CREATE OR REPLACE FUNCTION move_exp_att_content() RETURNS integer AS $$\\012DECLARE\\012    rec RECORD;\\012    seq BIGINT;\\012BEGIN\\012  FOR rec IN SELECT id, value FROM EXPERIMENT_ATTACHMENTS LOOP\\012  \\011seq := nextval('EXPERIMENT_ATTACHMENT_CONTENT_ID_SEQ');\\012    INSERT INTO EXPERIMENT_ATTACHMENT_CONTENTS (id, value) VALUES (seq, rec.value);\\012    UPDATE EXPERIMENT_ATTACHMENTS SET exac_id = seq WHERE id = rec.id;\\012  END LOOP;\\012  RETURN 1;\\012END;\\012$$ LANGUAGE 'plpgsql';\\012\\012-- Call the function.\\012SELECT move_exp_att_content();\\012DROP FUNCTION move_exp_att_content();\\012\\012\\012-- Finish EXPERIMENT_ATTACHMENTS changes.\\012ALTER TABLE EXPERIMENT_ATTACHMENTS ADD CONSTRAINT EXAT_CONT_FK FOREIGN KEY (EXAC_ID) REFERENCES EXPERIMENT_ATTACHMENT_CONTENTS(ID);\\012ALTER TABLE EXPERIMENT_ATTACHMENTS DROP COLUMN VALUE;\\012ALTER TABLE EXPERIMENT_ATTACHMENTS ALTER COLUMN EXAC_ID SET NOT NULL;\\012	\N
+./sourceTest/sql/postgresql/032/.svn/text-base/013=database_version_logs.tsv.svn-base:029	source/sql/postgresql/migration/migration-028-029.sql	SUCCESS	2009-03-18 10:50:20.105	-- -------\\012-- add modification_timestamp field to allow edition with Hibernate\\012-- -------\\012\\012ALTER TABLE samples\\012\\011ADD COLUMN modification_timestamp TIME_STAMP DEFAULT CURRENT_TIMESTAMP;\\012\\012ALTER TABLE experiments\\012\\011ADD COLUMN modification_timestamp TIME_STAMP DEFAULT CURRENT_TIMESTAMP;\\012\\012ALTER TABLE materials\\012\\011ADD COLUMN modification_timestamp TIME_STAMP DEFAULT CURRENT_TIMESTAMP;\\012\\012ALTER TABLE experiment_properties\\012\\011ADD COLUMN modification_timestamp TIME_STAMP DEFAULT CURRENT_TIMESTAMP;\\012\\012ALTER TABLE material_properties\\012\\011ADD COLUMN modification_timestamp TIME_STAMP DEFAULT CURRENT_TIMESTAMP;\\012\\012ALTER TABLE sample_properties\\012\\011ADD COLUMN modification_timestamp TIME_STAMP DEFAULT CURRENT_TIMESTAMP;\\012\\012-- -------\\012-- add property data type which references materials\\012-- -------\\012\\012ALTER TABLE property_types\\012\\011ADD COLUMN maty_prop_id tech_id;\\012\\012ALTER TABLE property_types\\012\\011ADD CONSTRAINT prty_maty_fk FOREIGN KEY (maty_prop_id) REFERENCES material_types(id);\\012\\012ALTER TABLE experiment_properties\\012\\011ADD COLUMN mate_prop_id tech_id;\\012\\012ALTER TABLE material_properties\\012\\011ADD COLUMN mate_prop_id tech_id;\\012\\012ALTER TABLE sample_properties\\012\\011ADD COLUMN mate_prop_id tech_id;\\012\\012ALTER TABLE experiment_properties\\012\\011ADD CONSTRAINT expr_mapr_fk FOREIGN KEY (mate_prop_id) REFERENCES materials(id);\\012\\012ALTER TABLE material_properties\\012\\011ADD CONSTRAINT mapr_mapr_fk FOREIGN KEY (mate_prop_id) REFERENCES materials(id);\\012\\012ALTER TABLE sample_properties\\012\\011ADD CONSTRAINT sapr_mapr_fk FOREIGN KEY (mate_prop_id) REFERENCES materials(id);\\012\\012insert into data_types\\012(id\\012 ,code\\012 ,description)\\012 values \\012 (nextval('DATA_TYPE_ID_SEQ')\\012 ,'MATERIAL'\\012 ,'Reference to a material'\\012);\\012\\012ALTER TABLE MATERIAL_PROPERTIES DROP CONSTRAINT MAPR_CK;\\012ALTER TABLE MATERIAL_PROPERTIES ADD CONSTRAINT MAPR_CK CHECK \\012\\011((VALUE IS NOT NULL AND CVTE_ID IS NULL AND MATE_PROP_ID IS NULL) OR \\012\\011 (VALUE IS NULL AND CVTE_ID IS NOT NULL AND MATE_PROP_ID IS NULL) OR\\012\\011 (VALUE IS NULL AND CVTE_ID IS NULL AND MATE_PROP_ID IS NOT NULL)\\012\\011);\\012\\012ALTER TABLE EXPERIMENT_PROPERTIES DROP CONSTRAINT EXPR_CK;\\012ALTER TABLE EXPERIMENT_PROPERTIES ADD CONSTRAINT EXPR_CK CHECK \\012\\011((VALUE IS NOT NULL AND CVTE_ID IS NULL AND MATE_PROP_ID IS NULL) OR \\012\\011 (VALUE IS NULL AND CVTE_ID IS NOT NULL AND MATE_PROP_ID IS NULL) OR\\012\\011 (VALUE IS NULL AND CVTE_ID IS NULL AND MATE_PROP_ID IS NOT NULL)\\012\\011);\\012\\012ALTER TABLE SAMPLE_PROPERTIES DROP CONSTRAINT SAPR_CK;\\012ALTER TABLE SAMPLE_PROPERTIES ADD CONSTRAINT SAPR_CK CHECK \\012\\011((VALUE IS NOT NULL AND CVTE_ID IS NULL AND MATE_PROP_ID IS NULL) OR \\012\\011 (VALUE IS NULL AND CVTE_ID IS NOT NULL AND MATE_PROP_ID IS NULL) OR\\012\\011 (VALUE IS NULL AND CVTE_ID IS NULL AND MATE_PROP_ID IS NOT NULL)\\012\\011);\\012\\012------------------------------------------------------------------------------------\\012--  Purpose:  Create trigger MATERIAL/SAMPLE/EXPERIMENT _PROPERTY_WITH_MATERIAL_DATA_TYPE_CHECK\\012--            It checks that if material property value is assigned to the entity,\\012--\\011\\011\\011\\011\\011\\011then the material type is equal to the one described by property type.\\012------------------------------------------------------------------------------------\\012\\012CREATE OR REPLACE FUNCTION MATERIAL_PROPERTY_WITH_MATERIAL_DATA_TYPE_CHECK() RETURNS trigger AS $$\\012DECLARE\\012   v_type_id  CODE;\\012   v_type_id_prop  CODE;\\012BEGIN\\012   if NEW.mate_prop_id IS NOT NULL then\\012\\011\\011\\011-- find material type id of the property type \\012\\011\\011\\011select pt.maty_prop_id into v_type_id_prop \\012\\011\\011\\011  from material_type_property_types etpt, property_types pt \\012\\011\\011\\011 where NEW.mtpt_id = etpt.id AND etpt.prty_id = pt.id;\\012\\011\\011\\012\\011\\011\\011if v_type_id_prop IS NOT NULL then\\012\\011\\011\\011\\011-- find material type id of the material which consists the entity's property value\\012\\011\\011\\011\\011select entity.maty_id into v_type_id \\012\\011\\011\\011\\011  from materials entity\\012\\011\\011\\011\\011 where NEW.mate_prop_id = entity.id;\\012\\011\\011\\011\\011if v_type_id != v_type_id_prop then\\012\\011\\011\\011\\011\\011RAISE EXCEPTION 'Insert/Update of property value referencing material (id: %) failed, as referenced material type is different than expected (id %, expected id: %).', \\012\\011\\011\\011\\011\\011\\011\\011 NEW.mate_prop_id, v_type_id, v_type_id_prop;\\012\\011\\011\\011\\011end if;\\012\\011\\011\\011end if;\\012   end if;\\012   RETURN NEW;\\012END;\\012$$ LANGUAGE 'plpgsql';\\012\\012CREATE TRIGGER MATERIAL_PROPERTY_WITH_MATERIAL_DATA_TYPE_CHECK BEFORE INSERT OR UPDATE ON material_properties\\012    FOR EACH ROW EXECUTE PROCEDURE MATERIAL_PROPERTY_WITH_MATERIAL_DATA_TYPE_CHECK();\\012    \\012CREATE OR REPLACE FUNCTION SAMPLE_PROPERTY_WITH_MATERIAL_DATA_TYPE_CHECK() RETURNS trigger AS $$\\012DECLARE\\012   v_type_id  CODE;\\012   v_type_id_prop  CODE;\\012BEGIN\\012   if NEW.mate_prop_id IS NOT NULL then\\012\\011\\011\\011-- find material type id of the property type \\012\\011\\011\\011select pt.maty_prop_id into v_type_id_prop \\012\\011\\011\\011  from sample_type_property_types etpt, property_types pt \\012\\011\\011\\011 where NEW.stpt_id = etpt.id AND etpt.prty_id = pt.id;\\012\\011\\011\\012\\011\\011\\011if v_type_id_prop IS NOT NULL then\\012\\011\\011\\011\\011-- find material type id of the material which consists the entity's property value\\012\\011\\011\\011\\011select entity.maty_id into v_type_id \\012\\011\\011\\011\\011  from materials entity\\012\\011\\011\\011\\011 where NEW.mate_prop_id = entity.id;\\012\\011\\011\\011\\011if v_type_id != v_type_id_prop then\\012\\011\\011\\011\\011\\011RAISE EXCEPTION 'Insert/Update of property value referencing material (id: %) failed, as referenced material type is different than expected (id %, expected id: %).', \\012\\011\\011\\011\\011\\011\\011\\011\\011\\011\\011\\011\\011 NEW.mate_prop_id, v_type_id, v_type_id_prop;\\012\\011\\011\\011\\011end if;\\012\\011\\011\\011end if;\\012   end if;\\012   RETURN NEW;\\012END;\\012$$ LANGUAGE 'plpgsql';\\012\\012CREATE TRIGGER SAMPLE_PROPERTY_WITH_MATERIAL_DATA_TYPE_CHECK BEFORE INSERT OR UPDATE ON sample_properties\\012    FOR EACH ROW EXECUTE PROCEDURE SAMPLE_PROPERTY_WITH_MATERIAL_DATA_TYPE_CHECK();\\012    \\012CREATE OR REPLACE FUNCTION EXPERIMENT_PROPERTY_WITH_MATERIAL_DATA_TYPE_CHECK() RETURNS trigger AS $$\\012DECLARE\\012   v_type_id  CODE;\\012   v_type_id_prop  CODE;\\012BEGIN\\012   if NEW.mate_prop_id IS NOT NULL then\\012\\011\\011\\011-- find material type id of the property type \\012\\011\\011\\011select pt.maty_prop_id into v_type_id_prop \\012\\011\\011\\011  from experiment_type_property_types etpt, property_types pt \\012\\011\\011\\011 where NEW.etpt_id = etpt.id AND etpt.prty_id = pt.id;\\012\\011\\011\\012\\011\\011\\011if v_type_id_prop IS NOT NULL then\\012\\011\\011\\011\\011-- find material type id of the material which consists the entity's property value\\012\\011\\011\\011\\011select entity.maty_id into v_type_id \\012\\011\\011\\011\\011  from materials entity\\012\\011\\011\\011\\011 where NEW.mate_prop_id = entity.id;\\012\\011\\011\\011\\011if v_type_id != v_type_id_prop then\\012\\011\\011\\011\\011\\011RAISE EXCEPTION 'Insert/Update of property value referencing material (id: %) failed, as referenced material type is different than expected (id %, expected id: %).', \\012\\011\\011\\011\\011\\011\\011\\011\\011\\011\\011\\011\\011 NEW.mate_prop_id, v_type_id, v_type_id_prop;\\012\\011\\011\\011\\011end if;\\012\\011\\011\\011end if;\\012   end if;\\012   RETURN NEW;\\012END;\\012$$ LANGUAGE 'plpgsql';\\012\\012CREATE TRIGGER EXPERIMENT_PROPERTY_WITH_MATERIAL_DATA_TYPE_CHECK BEFORE INSERT OR UPDATE ON experiment_properties\\012    FOR EACH ROW EXECUTE PROCEDURE EXPERIMENT_PROPERTY_WITH_MATERIAL_DATA_TYPE_CHECK();\\012       \\012-- -------\\012-- remove the reminescents of the OBSERVABLE_TYPE\\012-- -------\\012\\012ALTER TABLE data\\012\\011DROP CONSTRAINT data_obty_fk;\\012\\012ALTER TABLE data_set_types\\012\\011DROP CONSTRAINT obty_pk;\\012\\012ALTER TABLE data_set_types\\012\\011ADD CONSTRAINT dsty_pk PRIMARY KEY (id);\\012\\012ALTER TABLE data\\012\\011ADD CONSTRAINT data_dsty_fk FOREIGN KEY (dsty_id) REFERENCES data_set_types(id);\\012\\012ALTER TABLE data_set_types\\012\\011DROP CONSTRAINT obty_bk_uk;\\012\\012ALTER TABLE data_set_types\\012\\011DROP CONSTRAINT obty_dbin_fk;\\012\\012ALTER TABLE data_set_types\\012\\011ADD CONSTRAINT dsty_bk_uk UNIQUE (code, dbin_id);\\012\\012ALTER TABLE data_set_types\\012\\011ADD CONSTRAINT dsty_dbin_fk FOREIGN KEY (dbin_id) REFERENCES database_instances(id);\\012\\012DROP INDEX data_obty_fk_i;\\012\\012CREATE INDEX data_dsty_fk_i ON data(dsty_id);\\012	\N
+./sourceTest/sql/postgresql/032/.svn/text-base/013=database_version_logs.tsv.svn-base:030	source/sql/postgresql/migration/migration-029-030.sql	SUCCESS	2009-03-23 15:34:44.72	-- -------\\012-- add modification_timestamp field to allow edition with Hibernate\\012-- -------\\012ALTER TABLE data\\012\\011ADD COLUMN modification_timestamp TIME_STAMP DEFAULT CURRENT_TIMESTAMP;\\012ALTER TABLE experiment_types\\012\\011ADD COLUMN modification_timestamp TIME_STAMP DEFAULT CURRENT_TIMESTAMP;\\012ALTER TABLE sample_types\\012\\011ADD COLUMN modification_timestamp TIME_STAMP DEFAULT CURRENT_TIMESTAMP;\\012ALTER TABLE material_types\\012\\011ADD COLUMN modification_timestamp TIME_STAMP DEFAULT CURRENT_TIMESTAMP;\\012ALTER TABLE data_set_types\\012\\011ADD COLUMN modification_timestamp TIME_STAMP DEFAULT CURRENT_TIMESTAMP;\\012ALTER TABLE controlled_vocabularies\\012\\011ADD COLUMN modification_timestamp TIME_STAMP DEFAULT CURRENT_TIMESTAMP;\\012-- -------\\012-- add properties to data sets\\012-- -------\\012CREATE TABLE DATA_SET_PROPERTIES (ID TECH_ID NOT NULL,DS_ID TECH_ID NOT NULL,DSTPT_ID TECH_ID NOT NULL,VALUE GENERIC_VALUE,CVTE_ID TECH_ID, MATE_PROP_ID TECH_ID, PERS_ID_REGISTERER TECH_ID NOT NULL,REGISTRATION_TIMESTAMP TIME_STAMP_DFL NOT NULL DEFAULT CURRENT_TIMESTAMP, MODIFICATION_TIMESTAMP TIME_STAMP DEFAULT CURRENT_TIMESTAMP);\\012CREATE TABLE DATA_SET_TYPE_PROPERTY_TYPES (ID TECH_ID NOT NULL,DSTY_ID TECH_ID NOT NULL,PRTY_ID TECH_ID NOT NULL,IS_MANDATORY BOOLEAN_CHAR NOT NULL DEFAULT 'F',IS_MANAGED_INTERNALLY BOOLEAN_CHAR NOT NULL DEFAULT 'F',PERS_ID_REGISTERER TECH_ID NOT NULL,REGISTRATION_TIMESTAMP TIME_STAMP_DFL NOT NULL DEFAULT CURRENT_TIMESTAMP);\\012\\012CREATE SEQUENCE DATA_SET_PROPERTY_ID_SEQ;\\012CREATE SEQUENCE DSTPT_ID_SEQ;\\012\\012ALTER TABLE DATA_SET_TYPE_PROPERTY_TYPES ADD CONSTRAINT DSTPT_PK PRIMARY KEY(ID);\\012ALTER TABLE DATA_SET_PROPERTIES ADD CONSTRAINT DSPR_PK PRIMARY KEY(ID);\\012\\012ALTER TABLE DATA_SET_TYPE_PROPERTY_TYPES ADD CONSTRAINT DSTPT_BK_UK UNIQUE(DSTY_ID,PRTY_ID);\\012ALTER TABLE DATA_SET_PROPERTIES ADD CONSTRAINT DSPR_BK_UK UNIQUE(DS_ID,DSTPT_ID);\\012\\012\\012ALTER TABLE DATA_SET_TYPE_PROPERTY_TYPES ADD CONSTRAINT DSTPT_DSTY_FK FOREIGN KEY (DSTY_ID) REFERENCES DATA_SET_TYPES(ID);\\012ALTER TABLE DATA_SET_TYPE_PROPERTY_TYPES ADD CONSTRAINT DSTPT_PERS_FK FOREIGN KEY (PERS_ID_REGISTERER) REFERENCES PERSONS(ID);\\012ALTER TABLE DATA_SET_TYPE_PROPERTY_TYPES ADD CONSTRAINT DSTPT_PRTY_FK FOREIGN KEY (PRTY_ID) REFERENCES PROPERTY_TYPES(ID);\\012ALTER TABLE DATA_SET_PROPERTIES ADD CONSTRAINT DSPR_CVTE_FK FOREIGN KEY (CVTE_ID) REFERENCES CONTROLLED_VOCABULARY_TERMS(ID);\\012ALTER TABLE DATA_SET_PROPERTIES ADD CONSTRAINT DSPR_DSTPT_FK FOREIGN KEY (DSTPT_ID) REFERENCES DATA_SET_TYPE_PROPERTY_TYPES(ID) ON DELETE CASCADE;\\012ALTER TABLE DATA_SET_PROPERTIES ADD CONSTRAINT DSPR_DS_FK FOREIGN KEY (DS_ID) REFERENCES DATA(ID);\\012ALTER TABLE DATA_SET_PROPERTIES ADD CONSTRAINT DSPR_PERS_FK FOREIGN KEY (PERS_ID_REGISTERER) REFERENCES PERSONS(ID);\\012ALTER TABLE DATA_SET_PROPERTIES ADD CONSTRAINT DSPR_MAPR_FK FOREIGN KEY (MATE_PROP_ID) REFERENCES MATERIALS(ID);\\012\\012ALTER TABLE DATA_SET_PROPERTIES ADD CONSTRAINT DSPR_CK CHECK \\012\\011((VALUE IS NOT NULL AND CVTE_ID IS NULL AND MATE_PROP_ID IS NULL) OR \\012\\011 (VALUE IS NULL AND CVTE_ID IS NOT NULL AND MATE_PROP_ID IS NULL) OR\\012\\011 (VALUE IS NULL AND CVTE_ID IS NULL AND MATE_PROP_ID IS NOT NULL)\\012\\011);\\012\\012CREATE INDEX DSPR_CVTE_FK_I ON DATA_SET_PROPERTIES (CVTE_ID);\\012CREATE INDEX DSPR_DSTPT_FK_I ON DATA_SET_PROPERTIES (DSTPT_ID);\\012CREATE INDEX DSPR_DS_FK_I ON DATA_SET_PROPERTIES (DS_ID);\\012CREATE INDEX DSPR_PERS_FK_I ON DATA_SET_PROPERTIES (PERS_ID_REGISTERER);\\012CREATE INDEX DSTPT_DSTY_FK_I ON DATA_SET_TYPE_PROPERTY_TYPES (DSTY_ID);\\012CREATE INDEX DSTPT_PERS_FK_I ON DATA_SET_TYPE_PROPERTY_TYPES (PERS_ID_REGISTERER);\\012CREATE INDEX DSTPT_PRTY_FK_I ON DATA_SET_TYPE_PROPERTY_TYPES (PRTY_ID);\\012\\012CREATE OR REPLACE FUNCTION DATA_SET_PROPERTY_WITH_MATERIAL_DATA_TYPE_CHECK() RETURNS trigger AS $$\\012DECLARE\\012   v_type_id  CODE;\\012   v_type_id_prop  CODE;\\012BEGIN\\012   if NEW.mate_prop_id IS NOT NULL then\\012\\011\\011\\011-- find material type id of the property type \\012\\011\\011\\011select pt.maty_prop_id into v_type_id_prop \\012\\011\\011\\011  from data_set_type_property_types dstpt, property_types pt \\012\\011\\011\\011 where NEW.dstpt_id = dstpt.id AND dstpt.prty_id = pt.id;\\012\\011\\011\\012\\011\\011\\011if v_type_id_prop IS NOT NULL then\\012\\011\\011\\011\\011-- find material type id of the material which consists the entity's property value\\012\\011\\011\\011\\011select entity.maty_id into v_type_id \\012\\011\\011\\011\\011  from materials entity\\012\\011\\011\\011\\011 where NEW.mate_prop_id = entity.id;\\012\\011\\011\\011\\011if v_type_id != v_type_id_prop then\\012\\011\\011\\011\\011\\011RAISE EXCEPTION 'Insert/Update of property value referencing material (id: %) failed, as referenced material type is different than expected (id %, expected id: %).', \\012\\011\\011\\011\\011\\011\\011\\011\\011\\011\\011\\011\\011 NEW.mate_prop_id, v_type_id, v_type_id_prop;\\012\\011\\011\\011\\011end if;\\012\\011\\011\\011end if;\\012   end if;\\012   RETURN NEW;\\012END;\\012$$ LANGUAGE 'plpgsql';\\012\\012CREATE TRIGGER DATA_SET_PROPERTY_WITH_MATERIAL_DATA_TYPE_CHECK BEFORE INSERT OR UPDATE ON data_set_properties\\012    FOR EACH ROW EXECUTE PROCEDURE DATA_SET_PROPERTY_WITH_MATERIAL_DATA_TYPE_CHECK();   \\012	\N
+./sourceTest/sql/postgresql/032/.svn/text-base/013=database_version_logs.tsv.svn-base:032	source/sql/postgresql/migration/migration-031-032.sql	SUCCESS	2009-04-09 09:36:36.20	-- -------\\012-- Modify MATERIAL_BATCHES\\012-- -------\\012\\012ALTER TABLE material_batches\\012    DROP COLUMN proc_id;\\012\\012-- -------\\012-- Modify SAMPLES\\012-- -------\\012\\012ALTER TABLE samples\\012    ADD COLUMN expe_id tech_id;\\012\\012ALTER TABLE samples\\012    ADD CONSTRAINT samp_expe_fk FOREIGN KEY (expe_id) REFERENCES experiments(id);\\012\\012CREATE INDEX samp_expe_fk_i ON samples USING btree (expe_id);\\012\\012-- relink samples directly to experiments\\012\\012UPDATE samples\\012SET expe_id = (SELECT e.id FROM experiments e, procedures p, sample_inputs si \\012               WHERE si.samp_id = samples.id AND si.proc_id = p.id AND p.expe_id = e.id AND e.inva_id IS NULL);\\012\\012\\012-- -------\\012-- Modify DATA\\012-- -------\\012\\012ALTER TABLE data\\012    ADD COLUMN expe_id tech_id;\\012\\012ALTER TABLE data\\012    ADD CONSTRAINT data_expe_fk FOREIGN KEY (expe_id) REFERENCES experiments(id);\\012\\012CREATE INDEX data_expe_fk_i ON data USING btree (expe_id);\\012\\012UPDATE data\\012SET expe_id = (SELECT e.id FROM experiments e, procedures p \\012               WHERE data.proc_id_produced_by = p.id AND p.expe_id = e.id);\\012\\012ALTER TABLE data\\012    ALTER COLUMN expe_id SET NOT NULL;\\012\\012ALTER TABLE data\\012    DROP COLUMN proc_id_produced_by;\\012\\012-- -------\\012-- Drop PROCEDURES, PROCEDURE_TYPES, and SAMPLE_INPUTS\\012-- -------\\012\\012DROP TABLE sample_inputs;\\012DROP TABLE procedures;\\012DROP TABLE procedure_types;\\012\\012DROP SEQUENCE procedure_id_seq;\\012DROP SEQUENCE procedure_type_id_seq;\\012\\012-- -------\\012-- Add CODE_SEQ\\012-- -------\\012\\012CREATE SEQUENCE CODE_SEQ;\\012\\012-- -------\\012-- Add new columns to DATA_STORES\\012-- -------\\012\\012ALTER TABLE data_stores\\012    ADD COLUMN remote_url character varying(250),\\012    ADD COLUMN session_token character varying(50),\\012    ADD COLUMN modification_timestamp time_stamp DEFAULT now();\\012\\012UPDATE data_stores\\012SET remote_url = '', session_token='';\\012\\012ALTER TABLE data_stores\\012    ALTER COLUMN remote_url SET NOT NULL,\\012    ALTER COLUMN session_token SET NOT NULL;\\012\\012-- -------\\012-- Drop foreign keys onto DATA_STORES\\012-- -------\\012\\012ALTER TABLE database_instances\\012    DROP COLUMN dast_id;\\012\\012ALTER TABLE groups\\012    DROP COLUMN dast_id;\\012\\012ALTER TABLE projects\\012    DROP COLUMN dast_id;\\012\\012ALTER TABLE experiments\\012    DROP COLUMN dast_id;\\012\\012-- -------\\012-- Add foreign key from DATA onto DATA_STORES\\012-- -------\\012\\012ALTER TABLE data\\012    ADD COLUMN dast_id tech_id;\\012\\012ALTER TABLE data\\012    ADD CONSTRAINT data_dast_fk FOREIGN KEY (dast_id) REFERENCES data_stores(id);\\012\\012UPDATE data\\012SET dast_id = (select id from data_stores where code = 'STANDARD');\\012\\012ALTER TABLE data\\012    ALTER COLUMN dast_id SET NOT NULL;\\012\\012\\012------------------------------------------------------------------------------------\\012--  Purpose:  Replace trigger SAMPLE_CODE_UNIQUENESS_CHECK \\012------------------------------------------------------------------------------------\\012\\012CREATE OR REPLACE FUNCTION SAMPLE_CODE_UNIQUENESS_CHECK() RETURNS trigger AS $$\\012DECLARE\\012   counter  INTEGER;\\012BEGIN\\012    LOCK TABLE samples IN EXCLUSIVE MODE;\\012    IF (NEW.samp_id_part_of is NULL) THEN\\012        IF (NEW.dbin_id is not NULL) THEN\\012            SELECT count(*) into counter FROM samples \\012                where id != NEW.id and code = NEW.code and samp_id_part_of is NULL and dbin_id = NEW.dbin_id;\\012            IF (counter > 0) THEN\\012                RAISE EXCEPTION 'Insert/Update of Sample (Code: %) failed because database instance sample with the same code already exists.', NEW.code;\\012            END IF;\\012        ELSIF (NEW.grou_id is not NULL) THEN\\012            SELECT count(*) into counter FROM samples \\012                where id != NEW.id and code = NEW.code and samp_id_part_of is NULL and grou_id = NEW.grou_id;\\012            IF (counter > 0) THEN\\012                RAISE EXCEPTION 'Insert/Update of Sample (Code: %) failed because group sample with the same code already exists.', NEW.code;\\012            END IF;\\012        END IF;\\012        ELSE\\012        IF (NEW.dbin_id is not NULL) THEN\\012            SELECT count(*) into counter FROM samples \\012                where id != NEW.id and code = NEW.code and samp_id_part_of = NEW.samp_id_part_of and dbin_id = NEW.dbin_id;\\012            IF (counter > 0) THEN\\012                RAISE EXCEPTION 'Insert/Update of Sample (Code: %) failed because database instance sample with the same code and being the part of the same parent already exists.', NEW.code;\\012            END IF;\\012        ELSIF (NEW.grou_id is not NULL) THEN\\012            SELECT count(*) into counter FROM samples \\012                where id != NEW.id and code = NEW.code and samp_id_part_of = NEW.samp_id_part_of and grou_id = NEW.grou_id;\\012            IF (counter > 0) THEN\\012                RAISE EXCEPTION 'Insert/Update of Sample (Code: %) failed because group sample with the same code and being the part of the same parent already exists.', NEW.code;\\012            END IF;\\012        END IF;\\012        END IF;   \\012   RETURN NEW;\\012END;\\012$$ LANGUAGE 'plpgsql';\\012\\012\\012\\012	\N
+./sourceTest/sql/postgresql/032/.svn/text-base/schema-032.sql.svn-base:    LANGUAGE plpgsql;
+./sourceTest/sql/postgresql/032/.svn/text-base/schema-032.sql.svn-base:    LANGUAGE plpgsql;
+./sourceTest/sql/postgresql/032/.svn/text-base/schema-032.sql.svn-base:    LANGUAGE plpgsql;
+./sourceTest/sql/postgresql/032/.svn/text-base/schema-032.sql.svn-base:    LANGUAGE plpgsql;
+./sourceTest/sql/postgresql/032/.svn/text-base/schema-032.sql.svn-base:    LANGUAGE plpgsql;
+./sourceTest/sql/postgresql/032/.svn/text-base/schema-032.sql.svn-base:    LANGUAGE plpgsql;
+./sourceTest/sql/postgresql/032/.svn/text-base/schema-032.sql.svn-base:    LANGUAGE plpgsql;
+./sourceTest/sql/postgresql/032/.svn/text-base/schema-032.sql.svn-base:    LANGUAGE plpgsql;
+./sourceTest/sql/postgresql/032/013=database_version_logs.tsv:027	D:\\User\\felmer\\dev-workspace\\openbis/source/sql/postgresql/027/function-027.sql	SUCCESS	2008-11-05 09:18:00.403	-- Creating Functions\\012\\012------------------------------------------------------------------------------------\\012--  Purpose:  Create function RENAME_SEQUENCE() that is required for renaming the sequences belonging to tables\\012------------------------------------------------------------------------------------\\012CREATE FUNCTION RENAME_SEQUENCE(OLD_NAME VARCHAR, NEW_NAME VARCHAR) RETURNS INTEGER AS $$\\012DECLARE\\012  CURR_SEQ_VAL   INTEGER;\\012BEGIN\\012  SELECT INTO CURR_SEQ_VAL NEXTVAL(OLD_NAME);\\012  EXECUTE 'CREATE SEQUENCE ' || NEW_NAME || ' START WITH ' || CURR_SEQ_VAL;\\012  EXECUTE 'DROP SEQUENCE ' || OLD_NAME;\\012  RETURN CURR_SEQ_VAL;\\012END;\\012$$ LANGUAGE 'plpgsql';\\012\\012\\012------------------------------------------------------------------------------------\\012--  Purpose:  Create trigger CONTROLLED_VOCABULARY_CHECK \\012------------------------------------------------------------------------------------\\012\\012CREATE OR REPLACE FUNCTION CONTROLLED_VOCABULARY_CHECK() RETURNS trigger AS $$\\012DECLARE\\012   v_code  CODE;\\012BEGIN\\012\\012   select code into v_code from data_types where id = NEW.daty_id;\\012\\012   -- Check if the data is of type "CONTROLLEDVOCABULARY"\\012   if v_code = 'CONTROLLEDVOCABULARY' then\\012      if NEW.covo_id IS NULL then\\012         RAISE EXCEPTION 'Insert/Update of Property Type (Code: %) failed, as its Data Type is CONTROLLEDVOCABULARY, but it is not linked to a Controlled Vocabulary.', NEW.code;\\012      end if;\\012   end if;\\012\\012   RETURN NEW;\\012\\012END;\\012$$ LANGUAGE 'plpgsql';\\012\\012CREATE TRIGGER CONTROLLED_VOCABULARY_CHECK BEFORE INSERT OR UPDATE ON PROPERTY_TYPES\\012    FOR EACH ROW EXECUTE PROCEDURE CONTROLLED_VOCABULARY_CHECK();\\012\\012\\012------------------------------------------------------------------------------------\\012--  Purpose:  Create trigger EXTERNAL_DATA_STORAGE_FORMAT_CHECK \\012------------------------------------------------------------------------------------\\012\\012CREATE OR REPLACE FUNCTION EXTERNAL_DATA_STORAGE_FORMAT_CHECK() RETURNS trigger AS $$\\012DECLARE\\012   v_covo_code  CODE;\\012   data_code CODE;\\012BEGIN\\012\\012   select code into v_covo_code from controlled_vocabularies\\012      where is_internal_namespace = true and \\012         id = (select covo_id from controlled_vocabulary_terms where id = NEW.cvte_id_stor_fmt);\\012   -- Check if the data storage format is a term of the controlled vocabulary "STORAGE_FORMAT"\\012   if v_covo_code != 'STORAGE_FORMAT' then\\012      select code into data_code from data where id = NEW.data_id; \\012      RAISE EXCEPTION 'Insert/Update of Data (Code: %) failed, as its Storage Format is %, but is required to be STORAGE_FORMAT.', data_code, v_covo_code;\\012   end if;\\012\\012   RETURN NEW;\\012\\012END;\\012$$ LANGUAGE 'plpgsql';\\012\\012CREATE TRIGGER EXTERNAL_DATA_STORAGE_FORMAT_CHECK BEFORE INSERT OR UPDATE ON EXTERNAL_DATA\\012    FOR EACH ROW EXECUTE PROCEDURE EXTERNAL_DATA_STORAGE_FORMAT_CHECK();\\012\\012------------------------------------------------------------------------------------\\012--  Purpose:  Create trigger SAMPLE_CODE_UNIQUENESS_CHECK \\012------------------------------------------------------------------------------------\\012\\012CREATE OR REPLACE FUNCTION SAMPLE_CODE_UNIQUENESS_CHECK() RETURNS trigger AS $$\\012DECLARE\\012   counter  INTEGER;\\012BEGIN\\012\\011IF (NEW.samp_id_part_of is NULL) THEN\\012\\011\\011IF (NEW.dbin_id is not NULL) THEN\\012\\011\\011\\011SELECT count(*) into counter FROM samples \\012\\011\\011\\011\\011where id != NEW.id and code = NEW.code and samp_id_part_of is NULL and dbin_id = NEW.dbin_id;\\012\\011\\011\\011IF (counter > 0) THEN\\012\\011\\011\\011\\011RAISE EXCEPTION 'Insert/Update of Sample (Code: %) failed because database instance sample with the same code already exists.', NEW.code;\\012\\011\\011\\011END IF;\\012\\011\\011ELSIF (NEW.grou_id is not NULL) THEN\\012\\011\\011\\011SELECT count(*) into counter FROM samples \\012\\011\\011\\011\\011where id != NEW.id and code = NEW.code and samp_id_part_of is NULL and grou_id = NEW.grou_id;\\012\\011\\011\\011IF (counter > 0) THEN\\012\\011\\011\\011\\011RAISE EXCEPTION 'Insert/Update of Sample (Code: %) failed because group sample with the same code already exists.', NEW.code;\\012\\011\\011\\011END IF;\\012\\011\\011END IF;\\012        ELSE\\012\\011\\011IF (NEW.dbin_id is not NULL) THEN\\012\\011\\011\\011SELECT count(*) into counter FROM samples \\012\\011\\011\\011\\011where id != NEW.id and code = NEW.code and samp_id_part_of = NEW.samp_id_part_of and dbin_id = NEW.dbin_id;\\012\\011\\011\\011IF (counter > 0) THEN\\012\\011\\011\\011\\011RAISE EXCEPTION 'Insert/Update of Sample (Code: %) failed because database instance sample with the same code and being the part of the same parent already exists.', NEW.code;\\012\\011\\011\\011END IF;\\012\\011\\011ELSIF (NEW.grou_id is not NULL) THEN\\012\\011\\011\\011SELECT count(*) into counter FROM samples \\012\\011\\011\\011\\011where id != NEW.id and code = NEW.code and samp_id_part_of = NEW.samp_id_part_of and grou_id = NEW.grou_id;\\012\\011\\011\\011IF (counter > 0) THEN\\012\\011\\011\\011\\011RAISE EXCEPTION 'Insert/Update of Sample (Code: %) failed because group sample with the same code and being the part of the same parent already exists.', NEW.code;\\012\\011\\011\\011END IF;\\012\\011\\011END IF;\\012        END IF;   \\012   RETURN NEW;\\012END;\\012$$ LANGUAGE 'plpgsql';\\012\\012CREATE TRIGGER SAMPLE_CODE_UNIQUENESS_CHECK BEFORE INSERT OR UPDATE ON SAMPLES\\012    FOR EACH ROW EXECUTE PROCEDURE SAMPLE_CODE_UNIQUENESS_CHECK();\\012	\N
+./sourceTest/sql/postgresql/032/013=database_version_logs.tsv:028	source/sql/postgresql/migration/migration-027-028.sql	SUCCESS	2008-11-18 13:24:17.508	-- Create EXPERIMENT_ATTACHMENT_CONTENTS.\\012CREATE TABLE EXPERIMENT_ATTACHMENT_CONTENTS (ID TECH_ID NOT NULL,VALUE FILE NOT NULL);\\012CREATE SEQUENCE EXPERIMENT_ATTACHMENT_CONTENT_ID_SEQ;\\012ALTER TABLE EXPERIMENT_ATTACHMENT_CONTENTS ADD CONSTRAINT EXAC_PK PRIMARY KEY(ID);\\012\\012-- Alter EXPERIMENT_ATTACHMENTS by adding the new column which has a NULL constraint.\\012-- The NOT NULL constraint is added later on.\\012ALTER TABLE EXPERIMENT_ATTACHMENTS ADD COLUMN EXAC_ID TECH_ID;\\012\\012-- Does the VALUE migration between EXPERIMENT_ATTACHMENTS to EXPERIMENT_ATTACHMENT_CONTENTS.\\012CREATE OR REPLACE FUNCTION move_exp_att_content() RETURNS integer AS $$\\012DECLARE\\012    rec RECORD;\\012    seq BIGINT;\\012BEGIN\\012  FOR rec IN SELECT id, value FROM EXPERIMENT_ATTACHMENTS LOOP\\012  \\011seq := nextval('EXPERIMENT_ATTACHMENT_CONTENT_ID_SEQ');\\012    INSERT INTO EXPERIMENT_ATTACHMENT_CONTENTS (id, value) VALUES (seq, rec.value);\\012    UPDATE EXPERIMENT_ATTACHMENTS SET exac_id = seq WHERE id = rec.id;\\012  END LOOP;\\012  RETURN 1;\\012END;\\012$$ LANGUAGE 'plpgsql';\\012\\012-- Call the function.\\012SELECT move_exp_att_content();\\012DROP FUNCTION move_exp_att_content();\\012\\012\\012-- Finish EXPERIMENT_ATTACHMENTS changes.\\012ALTER TABLE EXPERIMENT_ATTACHMENTS ADD CONSTRAINT EXAT_CONT_FK FOREIGN KEY (EXAC_ID) REFERENCES EXPERIMENT_ATTACHMENT_CONTENTS(ID);\\012ALTER TABLE EXPERIMENT_ATTACHMENTS DROP COLUMN VALUE;\\012ALTER TABLE EXPERIMENT_ATTACHMENTS ALTER COLUMN EXAC_ID SET NOT NULL;\\012	\N
+./sourceTest/sql/postgresql/032/013=database_version_logs.tsv:029	source/sql/postgresql/migration/migration-028-029.sql	SUCCESS	2009-03-18 10:50:20.105	-- -------\\012-- add modification_timestamp field to allow edition with Hibernate\\012-- -------\\012\\012ALTER TABLE samples\\012\\011ADD COLUMN modification_timestamp TIME_STAMP DEFAULT CURRENT_TIMESTAMP;\\012\\012ALTER TABLE experiments\\012\\011ADD COLUMN modification_timestamp TIME_STAMP DEFAULT CURRENT_TIMESTAMP;\\012\\012ALTER TABLE materials\\012\\011ADD COLUMN modification_timestamp TIME_STAMP DEFAULT CURRENT_TIMESTAMP;\\012\\012ALTER TABLE experiment_properties\\012\\011ADD COLUMN modification_timestamp TIME_STAMP DEFAULT CURRENT_TIMESTAMP;\\012\\012ALTER TABLE material_properties\\012\\011ADD COLUMN modification_timestamp TIME_STAMP DEFAULT CURRENT_TIMESTAMP;\\012\\012ALTER TABLE sample_properties\\012\\011ADD COLUMN modification_timestamp TIME_STAMP DEFAULT CURRENT_TIMESTAMP;\\012\\012-- -------\\012-- add property data type which references materials\\012-- -------\\012\\012ALTER TABLE property_types\\012\\011ADD COLUMN maty_prop_id tech_id;\\012\\012ALTER TABLE property_types\\012\\011ADD CONSTRAINT prty_maty_fk FOREIGN KEY (maty_prop_id) REFERENCES material_types(id);\\012\\012ALTER TABLE experiment_properties\\012\\011ADD COLUMN mate_prop_id tech_id;\\012\\012ALTER TABLE material_properties\\012\\011ADD COLUMN mate_prop_id tech_id;\\012\\012ALTER TABLE sample_properties\\012\\011ADD COLUMN mate_prop_id tech_id;\\012\\012ALTER TABLE experiment_properties\\012\\011ADD CONSTRAINT expr_mapr_fk FOREIGN KEY (mate_prop_id) REFERENCES materials(id);\\012\\012ALTER TABLE material_properties\\012\\011ADD CONSTRAINT mapr_mapr_fk FOREIGN KEY (mate_prop_id) REFERENCES materials(id);\\012\\012ALTER TABLE sample_properties\\012\\011ADD CONSTRAINT sapr_mapr_fk FOREIGN KEY (mate_prop_id) REFERENCES materials(id);\\012\\012insert into data_types\\012(id\\012 ,code\\012 ,description)\\012 values \\012 (nextval('DATA_TYPE_ID_SEQ')\\012 ,'MATERIAL'\\012 ,'Reference to a material'\\012);\\012\\012ALTER TABLE MATERIAL_PROPERTIES DROP CONSTRAINT MAPR_CK;\\012ALTER TABLE MATERIAL_PROPERTIES ADD CONSTRAINT MAPR_CK CHECK \\012\\011((VALUE IS NOT NULL AND CVTE_ID IS NULL AND MATE_PROP_ID IS NULL) OR \\012\\011 (VALUE IS NULL AND CVTE_ID IS NOT NULL AND MATE_PROP_ID IS NULL) OR\\012\\011 (VALUE IS NULL AND CVTE_ID IS NULL AND MATE_PROP_ID IS NOT NULL)\\012\\011);\\012\\012ALTER TABLE EXPERIMENT_PROPERTIES DROP CONSTRAINT EXPR_CK;\\012ALTER TABLE EXPERIMENT_PROPERTIES ADD CONSTRAINT EXPR_CK CHECK \\012\\011((VALUE IS NOT NULL AND CVTE_ID IS NULL AND MATE_PROP_ID IS NULL) OR \\012\\011 (VALUE IS NULL AND CVTE_ID IS NOT NULL AND MATE_PROP_ID IS NULL) OR\\012\\011 (VALUE IS NULL AND CVTE_ID IS NULL AND MATE_PROP_ID IS NOT NULL)\\012\\011);\\012\\012ALTER TABLE SAMPLE_PROPERTIES DROP CONSTRAINT SAPR_CK;\\012ALTER TABLE SAMPLE_PROPERTIES ADD CONSTRAINT SAPR_CK CHECK \\012\\011((VALUE IS NOT NULL AND CVTE_ID IS NULL AND MATE_PROP_ID IS NULL) OR \\012\\011 (VALUE IS NULL AND CVTE_ID IS NOT NULL AND MATE_PROP_ID IS NULL) OR\\012\\011 (VALUE IS NULL AND CVTE_ID IS NULL AND MATE_PROP_ID IS NOT NULL)\\012\\011);\\012\\012------------------------------------------------------------------------------------\\012--  Purpose:  Create trigger MATERIAL/SAMPLE/EXPERIMENT _PROPERTY_WITH_MATERIAL_DATA_TYPE_CHECK\\012--            It checks that if material property value is assigned to the entity,\\012--\\011\\011\\011\\011\\011\\011then the material type is equal to the one described by property type.\\012------------------------------------------------------------------------------------\\012\\012CREATE OR REPLACE FUNCTION MATERIAL_PROPERTY_WITH_MATERIAL_DATA_TYPE_CHECK() RETURNS trigger AS $$\\012DECLARE\\012   v_type_id  CODE;\\012   v_type_id_prop  CODE;\\012BEGIN\\012   if NEW.mate_prop_id IS NOT NULL then\\012\\011\\011\\011-- find material type id of the property type \\012\\011\\011\\011select pt.maty_prop_id into v_type_id_prop \\012\\011\\011\\011  from material_type_property_types etpt, property_types pt \\012\\011\\011\\011 where NEW.mtpt_id = etpt.id AND etpt.prty_id = pt.id;\\012\\011\\011\\012\\011\\011\\011if v_type_id_prop IS NOT NULL then\\012\\011\\011\\011\\011-- find material type id of the material which consists the entity's property value\\012\\011\\011\\011\\011select entity.maty_id into v_type_id \\012\\011\\011\\011\\011  from materials entity\\012\\011\\011\\011\\011 where NEW.mate_prop_id = entity.id;\\012\\011\\011\\011\\011if v_type_id != v_type_id_prop then\\012\\011\\011\\011\\011\\011RAISE EXCEPTION 'Insert/Update of property value referencing material (id: %) failed, as referenced material type is different than expected (id %, expected id: %).', \\012\\011\\011\\011\\011\\011\\011\\011 NEW.mate_prop_id, v_type_id, v_type_id_prop;\\012\\011\\011\\011\\011end if;\\012\\011\\011\\011end if;\\012   end if;\\012   RETURN NEW;\\012END;\\012$$ LANGUAGE 'plpgsql';\\012\\012CREATE TRIGGER MATERIAL_PROPERTY_WITH_MATERIAL_DATA_TYPE_CHECK BEFORE INSERT OR UPDATE ON material_properties\\012    FOR EACH ROW EXECUTE PROCEDURE MATERIAL_PROPERTY_WITH_MATERIAL_DATA_TYPE_CHECK();\\012    \\012CREATE OR REPLACE FUNCTION SAMPLE_PROPERTY_WITH_MATERIAL_DATA_TYPE_CHECK() RETURNS trigger AS $$\\012DECLARE\\012   v_type_id  CODE;\\012   v_type_id_prop  CODE;\\012BEGIN\\012   if NEW.mate_prop_id IS NOT NULL then\\012\\011\\011\\011-- find material type id of the property type \\012\\011\\011\\011select pt.maty_prop_id into v_type_id_prop \\012\\011\\011\\011  from sample_type_property_types etpt, property_types pt \\012\\011\\011\\011 where NEW.stpt_id = etpt.id AND etpt.prty_id = pt.id;\\012\\011\\011\\012\\011\\011\\011if v_type_id_prop IS NOT NULL then\\012\\011\\011\\011\\011-- find material type id of the material which consists the entity's property value\\012\\011\\011\\011\\011select entity.maty_id into v_type_id \\012\\011\\011\\011\\011  from materials entity\\012\\011\\011\\011\\011 where NEW.mate_prop_id = entity.id;\\012\\011\\011\\011\\011if v_type_id != v_type_id_prop then\\012\\011\\011\\011\\011\\011RAISE EXCEPTION 'Insert/Update of property value referencing material (id: %) failed, as referenced material type is different than expected (id %, expected id: %).', \\012\\011\\011\\011\\011\\011\\011\\011\\011\\011\\011\\011\\011 NEW.mate_prop_id, v_type_id, v_type_id_prop;\\012\\011\\011\\011\\011end if;\\012\\011\\011\\011end if;\\012   end if;\\012   RETURN NEW;\\012END;\\012$$ LANGUAGE 'plpgsql';\\012\\012CREATE TRIGGER SAMPLE_PROPERTY_WITH_MATERIAL_DATA_TYPE_CHECK BEFORE INSERT OR UPDATE ON sample_properties\\012    FOR EACH ROW EXECUTE PROCEDURE SAMPLE_PROPERTY_WITH_MATERIAL_DATA_TYPE_CHECK();\\012    \\012CREATE OR REPLACE FUNCTION EXPERIMENT_PROPERTY_WITH_MATERIAL_DATA_TYPE_CHECK() RETURNS trigger AS $$\\012DECLARE\\012   v_type_id  CODE;\\012   v_type_id_prop  CODE;\\012BEGIN\\012   if NEW.mate_prop_id IS NOT NULL then\\012\\011\\011\\011-- find material type id of the property type \\012\\011\\011\\011select pt.maty_prop_id into v_type_id_prop \\012\\011\\011\\011  from experiment_type_property_types etpt, property_types pt \\012\\011\\011\\011 where NEW.etpt_id = etpt.id AND etpt.prty_id = pt.id;\\012\\011\\011\\012\\011\\011\\011if v_type_id_prop IS NOT NULL then\\012\\011\\011\\011\\011-- find material type id of the material which consists the entity's property value\\012\\011\\011\\011\\011select entity.maty_id into v_type_id \\012\\011\\011\\011\\011  from materials entity\\012\\011\\011\\011\\011 where NEW.mate_prop_id = entity.id;\\012\\011\\011\\011\\011if v_type_id != v_type_id_prop then\\012\\011\\011\\011\\011\\011RAISE EXCEPTION 'Insert/Update of property value referencing material (id: %) failed, as referenced material type is different than expected (id %, expected id: %).', \\012\\011\\011\\011\\011\\011\\011\\011\\011\\011\\011\\011\\011 NEW.mate_prop_id, v_type_id, v_type_id_prop;\\012\\011\\011\\011\\011end if;\\012\\011\\011\\011end if;\\012   end if;\\012   RETURN NEW;\\012END;\\012$$ LANGUAGE 'plpgsql';\\012\\012CREATE TRIGGER EXPERIMENT_PROPERTY_WITH_MATERIAL_DATA_TYPE_CHECK BEFORE INSERT OR UPDATE ON experiment_properties\\012    FOR EACH ROW EXECUTE PROCEDURE EXPERIMENT_PROPERTY_WITH_MATERIAL_DATA_TYPE_CHECK();\\012       \\012-- -------\\012-- remove the reminescents of the OBSERVABLE_TYPE\\012-- -------\\012\\012ALTER TABLE data\\012\\011DROP CONSTRAINT data_obty_fk;\\012\\012ALTER TABLE data_set_types\\012\\011DROP CONSTRAINT obty_pk;\\012\\012ALTER TABLE data_set_types\\012\\011ADD CONSTRAINT dsty_pk PRIMARY KEY (id);\\012\\012ALTER TABLE data\\012\\011ADD CONSTRAINT data_dsty_fk FOREIGN KEY (dsty_id) REFERENCES data_set_types(id);\\012\\012ALTER TABLE data_set_types\\012\\011DROP CONSTRAINT obty_bk_uk;\\012\\012ALTER TABLE data_set_types\\012\\011DROP CONSTRAINT obty_dbin_fk;\\012\\012ALTER TABLE data_set_types\\012\\011ADD CONSTRAINT dsty_bk_uk UNIQUE (code, dbin_id);\\012\\012ALTER TABLE data_set_types\\012\\011ADD CONSTRAINT dsty_dbin_fk FOREIGN KEY (dbin_id) REFERENCES database_instances(id);\\012\\012DROP INDEX data_obty_fk_i;\\012\\012CREATE INDEX data_dsty_fk_i ON data(dsty_id);\\012	\N
+./sourceTest/sql/postgresql/032/013=database_version_logs.tsv:030	source/sql/postgresql/migration/migration-029-030.sql	SUCCESS	2009-03-23 15:34:44.72	-- -------\\012-- add modification_timestamp field to allow edition with Hibernate\\012-- -------\\012ALTER TABLE data\\012\\011ADD COLUMN modification_timestamp TIME_STAMP DEFAULT CURRENT_TIMESTAMP;\\012ALTER TABLE experiment_types\\012\\011ADD COLUMN modification_timestamp TIME_STAMP DEFAULT CURRENT_TIMESTAMP;\\012ALTER TABLE sample_types\\012\\011ADD COLUMN modification_timestamp TIME_STAMP DEFAULT CURRENT_TIMESTAMP;\\012ALTER TABLE material_types\\012\\011ADD COLUMN modification_timestamp TIME_STAMP DEFAULT CURRENT_TIMESTAMP;\\012ALTER TABLE data_set_types\\012\\011ADD COLUMN modification_timestamp TIME_STAMP DEFAULT CURRENT_TIMESTAMP;\\012ALTER TABLE controlled_vocabularies\\012\\011ADD COLUMN modification_timestamp TIME_STAMP DEFAULT CURRENT_TIMESTAMP;\\012-- -------\\012-- add properties to data sets\\012-- -------\\012CREATE TABLE DATA_SET_PROPERTIES (ID TECH_ID NOT NULL,DS_ID TECH_ID NOT NULL,DSTPT_ID TECH_ID NOT NULL,VALUE GENERIC_VALUE,CVTE_ID TECH_ID, MATE_PROP_ID TECH_ID, PERS_ID_REGISTERER TECH_ID NOT NULL,REGISTRATION_TIMESTAMP TIME_STAMP_DFL NOT NULL DEFAULT CURRENT_TIMESTAMP, MODIFICATION_TIMESTAMP TIME_STAMP DEFAULT CURRENT_TIMESTAMP);\\012CREATE TABLE DATA_SET_TYPE_PROPERTY_TYPES (ID TECH_ID NOT NULL,DSTY_ID TECH_ID NOT NULL,PRTY_ID TECH_ID NOT NULL,IS_MANDATORY BOOLEAN_CHAR NOT NULL DEFAULT 'F',IS_MANAGED_INTERNALLY BOOLEAN_CHAR NOT NULL DEFAULT 'F',PERS_ID_REGISTERER TECH_ID NOT NULL,REGISTRATION_TIMESTAMP TIME_STAMP_DFL NOT NULL DEFAULT CURRENT_TIMESTAMP);\\012\\012CREATE SEQUENCE DATA_SET_PROPERTY_ID_SEQ;\\012CREATE SEQUENCE DSTPT_ID_SEQ;\\012\\012ALTER TABLE DATA_SET_TYPE_PROPERTY_TYPES ADD CONSTRAINT DSTPT_PK PRIMARY KEY(ID);\\012ALTER TABLE DATA_SET_PROPERTIES ADD CONSTRAINT DSPR_PK PRIMARY KEY(ID);\\012\\012ALTER TABLE DATA_SET_TYPE_PROPERTY_TYPES ADD CONSTRAINT DSTPT_BK_UK UNIQUE(DSTY_ID,PRTY_ID);\\012ALTER TABLE DATA_SET_PROPERTIES ADD CONSTRAINT DSPR_BK_UK UNIQUE(DS_ID,DSTPT_ID);\\012\\012\\012ALTER TABLE DATA_SET_TYPE_PROPERTY_TYPES ADD CONSTRAINT DSTPT_DSTY_FK FOREIGN KEY (DSTY_ID) REFERENCES DATA_SET_TYPES(ID);\\012ALTER TABLE DATA_SET_TYPE_PROPERTY_TYPES ADD CONSTRAINT DSTPT_PERS_FK FOREIGN KEY (PERS_ID_REGISTERER) REFERENCES PERSONS(ID);\\012ALTER TABLE DATA_SET_TYPE_PROPERTY_TYPES ADD CONSTRAINT DSTPT_PRTY_FK FOREIGN KEY (PRTY_ID) REFERENCES PROPERTY_TYPES(ID);\\012ALTER TABLE DATA_SET_PROPERTIES ADD CONSTRAINT DSPR_CVTE_FK FOREIGN KEY (CVTE_ID) REFERENCES CONTROLLED_VOCABULARY_TERMS(ID);\\012ALTER TABLE DATA_SET_PROPERTIES ADD CONSTRAINT DSPR_DSTPT_FK FOREIGN KEY (DSTPT_ID) REFERENCES DATA_SET_TYPE_PROPERTY_TYPES(ID) ON DELETE CASCADE;\\012ALTER TABLE DATA_SET_PROPERTIES ADD CONSTRAINT DSPR_DS_FK FOREIGN KEY (DS_ID) REFERENCES DATA(ID);\\012ALTER TABLE DATA_SET_PROPERTIES ADD CONSTRAINT DSPR_PERS_FK FOREIGN KEY (PERS_ID_REGISTERER) REFERENCES PERSONS(ID);\\012ALTER TABLE DATA_SET_PROPERTIES ADD CONSTRAINT DSPR_MAPR_FK FOREIGN KEY (MATE_PROP_ID) REFERENCES MATERIALS(ID);\\012\\012ALTER TABLE DATA_SET_PROPERTIES ADD CONSTRAINT DSPR_CK CHECK \\012\\011((VALUE IS NOT NULL AND CVTE_ID IS NULL AND MATE_PROP_ID IS NULL) OR \\012\\011 (VALUE IS NULL AND CVTE_ID IS NOT NULL AND MATE_PROP_ID IS NULL) OR\\012\\011 (VALUE IS NULL AND CVTE_ID IS NULL AND MATE_PROP_ID IS NOT NULL)\\012\\011);\\012\\012CREATE INDEX DSPR_CVTE_FK_I ON DATA_SET_PROPERTIES (CVTE_ID);\\012CREATE INDEX DSPR_DSTPT_FK_I ON DATA_SET_PROPERTIES (DSTPT_ID);\\012CREATE INDEX DSPR_DS_FK_I ON DATA_SET_PROPERTIES (DS_ID);\\012CREATE INDEX DSPR_PERS_FK_I ON DATA_SET_PROPERTIES (PERS_ID_REGISTERER);\\012CREATE INDEX DSTPT_DSTY_FK_I ON DATA_SET_TYPE_PROPERTY_TYPES (DSTY_ID);\\012CREATE INDEX DSTPT_PERS_FK_I ON DATA_SET_TYPE_PROPERTY_TYPES (PERS_ID_REGISTERER);\\012CREATE INDEX DSTPT_PRTY_FK_I ON DATA_SET_TYPE_PROPERTY_TYPES (PRTY_ID);\\012\\012CREATE OR REPLACE FUNCTION DATA_SET_PROPERTY_WITH_MATERIAL_DATA_TYPE_CHECK() RETURNS trigger AS $$\\012DECLARE\\012   v_type_id  CODE;\\012   v_type_id_prop  CODE;\\012BEGIN\\012   if NEW.mate_prop_id IS NOT NULL then\\012\\011\\011\\011-- find material type id of the property type \\012\\011\\011\\011select pt.maty_prop_id into v_type_id_prop \\012\\011\\011\\011  from data_set_type_property_types dstpt, property_types pt \\012\\011\\011\\011 where NEW.dstpt_id = dstpt.id AND dstpt.prty_id = pt.id;\\012\\011\\011\\012\\011\\011\\011if v_type_id_prop IS NOT NULL then\\012\\011\\011\\011\\011-- find material type id of the material which consists the entity's property value\\012\\011\\011\\011\\011select entity.maty_id into v_type_id \\012\\011\\011\\011\\011  from materials entity\\012\\011\\011\\011\\011 where NEW.mate_prop_id = entity.id;\\012\\011\\011\\011\\011if v_type_id != v_type_id_prop then\\012\\011\\011\\011\\011\\011RAISE EXCEPTION 'Insert/Update of property value referencing material (id: %) failed, as referenced material type is different than expected (id %, expected id: %).', \\012\\011\\011\\011\\011\\011\\011\\011\\011\\011\\011\\011\\011 NEW.mate_prop_id, v_type_id, v_type_id_prop;\\012\\011\\011\\011\\011end if;\\012\\011\\011\\011end if;\\012   end if;\\012   RETURN NEW;\\012END;\\012$$ LANGUAGE 'plpgsql';\\012\\012CREATE TRIGGER DATA_SET_PROPERTY_WITH_MATERIAL_DATA_TYPE_CHECK BEFORE INSERT OR UPDATE ON data_set_properties\\012    FOR EACH ROW EXECUTE PROCEDURE DATA_SET_PROPERTY_WITH_MATERIAL_DATA_TYPE_CHECK();   \\012	\N
+./sourceTest/sql/postgresql/032/013=database_version_logs.tsv:032	source/sql/postgresql/migration/migration-031-032.sql	SUCCESS	2009-04-09 09:36:36.20	-- -------\\012-- Modify MATERIAL_BATCHES\\012-- -------\\012\\012ALTER TABLE material_batches\\012    DROP COLUMN proc_id;\\012\\012-- -------\\012-- Modify SAMPLES\\012-- -------\\012\\012ALTER TABLE samples\\012    ADD COLUMN expe_id tech_id;\\012\\012ALTER TABLE samples\\012    ADD CONSTRAINT samp_expe_fk FOREIGN KEY (expe_id) REFERENCES experiments(id);\\012\\012CREATE INDEX samp_expe_fk_i ON samples USING btree (expe_id);\\012\\012-- relink samples directly to experiments\\012\\012UPDATE samples\\012SET expe_id = (SELECT e.id FROM experiments e, procedures p, sample_inputs si \\012               WHERE si.samp_id = samples.id AND si.proc_id = p.id AND p.expe_id = e.id AND e.inva_id IS NULL);\\012\\012\\012-- -------\\012-- Modify DATA\\012-- -------\\012\\012ALTER TABLE data\\012    ADD COLUMN expe_id tech_id;\\012\\012ALTER TABLE data\\012    ADD CONSTRAINT data_expe_fk FOREIGN KEY (expe_id) REFERENCES experiments(id);\\012\\012CREATE INDEX data_expe_fk_i ON data USING btree (expe_id);\\012\\012UPDATE data\\012SET expe_id = (SELECT e.id FROM experiments e, procedures p \\012               WHERE data.proc_id_produced_by = p.id AND p.expe_id = e.id);\\012\\012ALTER TABLE data\\012    ALTER COLUMN expe_id SET NOT NULL;\\012\\012ALTER TABLE data\\012    DROP COLUMN proc_id_produced_by;\\012\\012-- -------\\012-- Drop PROCEDURES, PROCEDURE_TYPES, and SAMPLE_INPUTS\\012-- -------\\012\\012DROP TABLE sample_inputs;\\012DROP TABLE procedures;\\012DROP TABLE procedure_types;\\012\\012DROP SEQUENCE procedure_id_seq;\\012DROP SEQUENCE procedure_type_id_seq;\\012\\012-- -------\\012-- Add CODE_SEQ\\012-- -------\\012\\012CREATE SEQUENCE CODE_SEQ;\\012\\012-- -------\\012-- Add new columns to DATA_STORES\\012-- -------\\012\\012ALTER TABLE data_stores\\012    ADD COLUMN remote_url character varying(250),\\012    ADD COLUMN session_token character varying(50),\\012    ADD COLUMN modification_timestamp time_stamp DEFAULT now();\\012\\012UPDATE data_stores\\012SET remote_url = '', session_token='';\\012\\012ALTER TABLE data_stores\\012    ALTER COLUMN remote_url SET NOT NULL,\\012    ALTER COLUMN session_token SET NOT NULL;\\012\\012-- -------\\012-- Drop foreign keys onto DATA_STORES\\012-- -------\\012\\012ALTER TABLE database_instances\\012    DROP COLUMN dast_id;\\012\\012ALTER TABLE groups\\012    DROP COLUMN dast_id;\\012\\012ALTER TABLE projects\\012    DROP COLUMN dast_id;\\012\\012ALTER TABLE experiments\\012    DROP COLUMN dast_id;\\012\\012-- -------\\012-- Add foreign key from DATA onto DATA_STORES\\012-- -------\\012\\012ALTER TABLE data\\012    ADD COLUMN dast_id tech_id;\\012\\012ALTER TABLE data\\012    ADD CONSTRAINT data_dast_fk FOREIGN KEY (dast_id) REFERENCES data_stores(id);\\012\\012UPDATE data\\012SET dast_id = (select id from data_stores where code = 'STANDARD');\\012\\012ALTER TABLE data\\012    ALTER COLUMN dast_id SET NOT NULL;\\012\\012\\012------------------------------------------------------------------------------------\\012--  Purpose:  Replace trigger SAMPLE_CODE_UNIQUENESS_CHECK \\012------------------------------------------------------------------------------------\\012\\012CREATE OR REPLACE FUNCTION SAMPLE_CODE_UNIQUENESS_CHECK() RETURNS trigger AS $$\\012DECLARE\\012   counter  INTEGER;\\012BEGIN\\012    LOCK TABLE samples IN EXCLUSIVE MODE;\\012    IF (NEW.samp_id_part_of is NULL) THEN\\012        IF (NEW.dbin_id is not NULL) THEN\\012            SELECT count(*) into counter FROM samples \\012                where id != NEW.id and code = NEW.code and samp_id_part_of is NULL and dbin_id = NEW.dbin_id;\\012            IF (counter > 0) THEN\\012                RAISE EXCEPTION 'Insert/Update of Sample (Code: %) failed because database instance sample with the same code already exists.', NEW.code;\\012            END IF;\\012        ELSIF (NEW.grou_id is not NULL) THEN\\012            SELECT count(*) into counter FROM samples \\012                where id != NEW.id and code = NEW.code and samp_id_part_of is NULL and grou_id = NEW.grou_id;\\012            IF (counter > 0) THEN\\012                RAISE EXCEPTION 'Insert/Update of Sample (Code: %) failed because group sample with the same code already exists.', NEW.code;\\012            END IF;\\012        END IF;\\012        ELSE\\012        IF (NEW.dbin_id is not NULL) THEN\\012            SELECT count(*) into counter FROM samples \\012                where id != NEW.id and code = NEW.code and samp_id_part_of = NEW.samp_id_part_of and dbin_id = NEW.dbin_id;\\012            IF (counter > 0) THEN\\012                RAISE EXCEPTION 'Insert/Update of Sample (Code: %) failed because database instance sample with the same code and being the part of the same parent already exists.', NEW.code;\\012            END IF;\\012        ELSIF (NEW.grou_id is not NULL) THEN\\012            SELECT count(*) into counter FROM samples \\012                where id != NEW.id and code = NEW.code and samp_id_part_of = NEW.samp_id_part_of and grou_id = NEW.grou_id;\\012            IF (counter > 0) THEN\\012                RAISE EXCEPTION 'Insert/Update of Sample (Code: %) failed because group sample with the same code and being the part of the same parent already exists.', NEW.code;\\012            END IF;\\012        END IF;\\012        END IF;   \\012   RETURN NEW;\\012END;\\012$$ LANGUAGE 'plpgsql';\\012\\012\\012\\012	\N
+./sourceTest/sql/postgresql/032/schema-032.sql:    LANGUAGE plpgsql;
+./sourceTest/sql/postgresql/032/schema-032.sql:    LANGUAGE plpgsql;
+./sourceTest/sql/postgresql/032/schema-032.sql:    LANGUAGE plpgsql;
+./sourceTest/sql/postgresql/032/schema-032.sql:    LANGUAGE plpgsql;
+./sourceTest/sql/postgresql/032/schema-032.sql:    LANGUAGE plpgsql;
+./sourceTest/sql/postgresql/032/schema-032.sql:    LANGUAGE plpgsql;
+./sourceTest/sql/postgresql/032/schema-032.sql:    LANGUAGE plpgsql;
+./sourceTest/sql/postgresql/032/schema-032.sql:    LANGUAGE plpgsql;
+./sourceTest/sql/postgresql/033/.svn/text-base/013=database_version_logs.tsv.svn-base:027	D:\\User\\felmer\\dev-workspace\\openbis/source/sql/postgresql/027/function-027.sql	SUCCESS	2008-11-05 09:18:00.403	-- Creating Functions\\012\\012------------------------------------------------------------------------------------\\012--  Purpose:  Create function RENAME_SEQUENCE() that is required for renaming the sequences belonging to tables\\012------------------------------------------------------------------------------------\\012CREATE FUNCTION RENAME_SEQUENCE(OLD_NAME VARCHAR, NEW_NAME VARCHAR) RETURNS INTEGER AS $$\\012DECLARE\\012  CURR_SEQ_VAL   INTEGER;\\012BEGIN\\012  SELECT INTO CURR_SEQ_VAL NEXTVAL(OLD_NAME);\\012  EXECUTE 'CREATE SEQUENCE ' || NEW_NAME || ' START WITH ' || CURR_SEQ_VAL;\\012  EXECUTE 'DROP SEQUENCE ' || OLD_NAME;\\012  RETURN CURR_SEQ_VAL;\\012END;\\012$$ LANGUAGE 'plpgsql';\\012\\012\\012------------------------------------------------------------------------------------\\012--  Purpose:  Create trigger CONTROLLED_VOCABULARY_CHECK \\012------------------------------------------------------------------------------------\\012\\012CREATE OR REPLACE FUNCTION CONTROLLED_VOCABULARY_CHECK() RETURNS trigger AS $$\\012DECLARE\\012   v_code  CODE;\\012BEGIN\\012\\012   select code into v_code from data_types where id = NEW.daty_id;\\012\\012   -- Check if the data is of type "CONTROLLEDVOCABULARY"\\012   if v_code = 'CONTROLLEDVOCABULARY' then\\012      if NEW.covo_id IS NULL then\\012         RAISE EXCEPTION 'Insert/Update of Property Type (Code: %) failed, as its Data Type is CONTROLLEDVOCABULARY, but it is not linked to a Controlled Vocabulary.', NEW.code;\\012      end if;\\012   end if;\\012\\012   RETURN NEW;\\012\\012END;\\012$$ LANGUAGE 'plpgsql';\\012\\012CREATE TRIGGER CONTROLLED_VOCABULARY_CHECK BEFORE INSERT OR UPDATE ON PROPERTY_TYPES\\012    FOR EACH ROW EXECUTE PROCEDURE CONTROLLED_VOCABULARY_CHECK();\\012\\012\\012------------------------------------------------------------------------------------\\012--  Purpose:  Create trigger EXTERNAL_DATA_STORAGE_FORMAT_CHECK \\012------------------------------------------------------------------------------------\\012\\012CREATE OR REPLACE FUNCTION EXTERNAL_DATA_STORAGE_FORMAT_CHECK() RETURNS trigger AS $$\\012DECLARE\\012   v_covo_code  CODE;\\012   data_code CODE;\\012BEGIN\\012\\012   select code into v_covo_code from controlled_vocabularies\\012      where is_internal_namespace = true and \\012         id = (select covo_id from controlled_vocabulary_terms where id = NEW.cvte_id_stor_fmt);\\012   -- Check if the data storage format is a term of the controlled vocabulary "STORAGE_FORMAT"\\012   if v_covo_code != 'STORAGE_FORMAT' then\\012      select code into data_code from data where id = NEW.data_id; \\012      RAISE EXCEPTION 'Insert/Update of Data (Code: %) failed, as its Storage Format is %, but is required to be STORAGE_FORMAT.', data_code, v_covo_code;\\012   end if;\\012\\012   RETURN NEW;\\012\\012END;\\012$$ LANGUAGE 'plpgsql';\\012\\012CREATE TRIGGER EXTERNAL_DATA_STORAGE_FORMAT_CHECK BEFORE INSERT OR UPDATE ON EXTERNAL_DATA\\012    FOR EACH ROW EXECUTE PROCEDURE EXTERNAL_DATA_STORAGE_FORMAT_CHECK();\\012\\012------------------------------------------------------------------------------------\\012--  Purpose:  Create trigger SAMPLE_CODE_UNIQUENESS_CHECK \\012------------------------------------------------------------------------------------\\012\\012CREATE OR REPLACE FUNCTION SAMPLE_CODE_UNIQUENESS_CHECK() RETURNS trigger AS $$\\012DECLARE\\012   counter  INTEGER;\\012BEGIN\\012\\011IF (NEW.samp_id_part_of is NULL) THEN\\012\\011\\011IF (NEW.dbin_id is not NULL) THEN\\012\\011\\011\\011SELECT count(*) into counter FROM samples \\012\\011\\011\\011\\011where id != NEW.id and code = NEW.code and samp_id_part_of is NULL and dbin_id = NEW.dbin_id;\\012\\011\\011\\011IF (counter > 0) THEN\\012\\011\\011\\011\\011RAISE EXCEPTION 'Insert/Update of Sample (Code: %) failed because database instance sample with the same code already exists.', NEW.code;\\012\\011\\011\\011END IF;\\012\\011\\011ELSIF (NEW.grou_id is not NULL) THEN\\012\\011\\011\\011SELECT count(*) into counter FROM samples \\012\\011\\011\\011\\011where id != NEW.id and code = NEW.code and samp_id_part_of is NULL and grou_id = NEW.grou_id;\\012\\011\\011\\011IF (counter > 0) THEN\\012\\011\\011\\011\\011RAISE EXCEPTION 'Insert/Update of Sample (Code: %) failed because group sample with the same code already exists.', NEW.code;\\012\\011\\011\\011END IF;\\012\\011\\011END IF;\\012        ELSE\\012\\011\\011IF (NEW.dbin_id is not NULL) THEN\\012\\011\\011\\011SELECT count(*) into counter FROM samples \\012\\011\\011\\011\\011where id != NEW.id and code = NEW.code and samp_id_part_of = NEW.samp_id_part_of and dbin_id = NEW.dbin_id;\\012\\011\\011\\011IF (counter > 0) THEN\\012\\011\\011\\011\\011RAISE EXCEPTION 'Insert/Update of Sample (Code: %) failed because database instance sample with the same code and being the part of the same parent already exists.', NEW.code;\\012\\011\\011\\011END IF;\\012\\011\\011ELSIF (NEW.grou_id is not NULL) THEN\\012\\011\\011\\011SELECT count(*) into counter FROM samples \\012\\011\\011\\011\\011where id != NEW.id and code = NEW.code and samp_id_part_of = NEW.samp_id_part_of and grou_id = NEW.grou_id;\\012\\011\\011\\011IF (counter > 0) THEN\\012\\011\\011\\011\\011RAISE EXCEPTION 'Insert/Update of Sample (Code: %) failed because group sample with the same code and being the part of the same parent already exists.', NEW.code;\\012\\011\\011\\011END IF;\\012\\011\\011END IF;\\012        END IF;   \\012   RETURN NEW;\\012END;\\012$$ LANGUAGE 'plpgsql';\\012\\012CREATE TRIGGER SAMPLE_CODE_UNIQUENESS_CHECK BEFORE INSERT OR UPDATE ON SAMPLES\\012    FOR EACH ROW EXECUTE PROCEDURE SAMPLE_CODE_UNIQUENESS_CHECK();\\012	\N
+./sourceTest/sql/postgresql/033/.svn/text-base/013=database_version_logs.tsv.svn-base:028	source/sql/postgresql/migration/migration-027-028.sql	SUCCESS	2008-11-18 13:24:17.508	-- Create EXPERIMENT_ATTACHMENT_CONTENTS.\\012CREATE TABLE EXPERIMENT_ATTACHMENT_CONTENTS (ID TECH_ID NOT NULL,VALUE FILE NOT NULL);\\012CREATE SEQUENCE EXPERIMENT_ATTACHMENT_CONTENT_ID_SEQ;\\012ALTER TABLE EXPERIMENT_ATTACHMENT_CONTENTS ADD CONSTRAINT EXAC_PK PRIMARY KEY(ID);\\012\\012-- Alter EXPERIMENT_ATTACHMENTS by adding the new column which has a NULL constraint.\\012-- The NOT NULL constraint is added later on.\\012ALTER TABLE EXPERIMENT_ATTACHMENTS ADD COLUMN EXAC_ID TECH_ID;\\012\\012-- Does the VALUE migration between EXPERIMENT_ATTACHMENTS to EXPERIMENT_ATTACHMENT_CONTENTS.\\012CREATE OR REPLACE FUNCTION move_exp_att_content() RETURNS integer AS $$\\012DECLARE\\012    rec RECORD;\\012    seq BIGINT;\\012BEGIN\\012  FOR rec IN SELECT id, value FROM EXPERIMENT_ATTACHMENTS LOOP\\012  \\011seq := nextval('EXPERIMENT_ATTACHMENT_CONTENT_ID_SEQ');\\012    INSERT INTO EXPERIMENT_ATTACHMENT_CONTENTS (id, value) VALUES (seq, rec.value);\\012    UPDATE EXPERIMENT_ATTACHMENTS SET exac_id = seq WHERE id = rec.id;\\012  END LOOP;\\012  RETURN 1;\\012END;\\012$$ LANGUAGE 'plpgsql';\\012\\012-- Call the function.\\012SELECT move_exp_att_content();\\012DROP FUNCTION move_exp_att_content();\\012\\012\\012-- Finish EXPERIMENT_ATTACHMENTS changes.\\012ALTER TABLE EXPERIMENT_ATTACHMENTS ADD CONSTRAINT EXAT_CONT_FK FOREIGN KEY (EXAC_ID) REFERENCES EXPERIMENT_ATTACHMENT_CONTENTS(ID);\\012ALTER TABLE EXPERIMENT_ATTACHMENTS DROP COLUMN VALUE;\\012ALTER TABLE EXPERIMENT_ATTACHMENTS ALTER COLUMN EXAC_ID SET NOT NULL;\\012	\N
+./sourceTest/sql/postgresql/033/.svn/text-base/013=database_version_logs.tsv.svn-base:029	source/sql/postgresql/migration/migration-028-029.sql	SUCCESS	2009-03-18 10:50:20.105	-- -------\\012-- add modification_timestamp field to allow edition with Hibernate\\012-- -------\\012\\012ALTER TABLE samples\\012\\011ADD COLUMN modification_timestamp TIME_STAMP DEFAULT CURRENT_TIMESTAMP;\\012\\012ALTER TABLE experiments\\012\\011ADD COLUMN modification_timestamp TIME_STAMP DEFAULT CURRENT_TIMESTAMP;\\012\\012ALTER TABLE materials\\012\\011ADD COLUMN modification_timestamp TIME_STAMP DEFAULT CURRENT_TIMESTAMP;\\012\\012ALTER TABLE experiment_properties\\012\\011ADD COLUMN modification_timestamp TIME_STAMP DEFAULT CURRENT_TIMESTAMP;\\012\\012ALTER TABLE material_properties\\012\\011ADD COLUMN modification_timestamp TIME_STAMP DEFAULT CURRENT_TIMESTAMP;\\012\\012ALTER TABLE sample_properties\\012\\011ADD COLUMN modification_timestamp TIME_STAMP DEFAULT CURRENT_TIMESTAMP;\\012\\012-- -------\\012-- add property data type which references materials\\012-- -------\\012\\012ALTER TABLE property_types\\012\\011ADD COLUMN maty_prop_id tech_id;\\012\\012ALTER TABLE property_types\\012\\011ADD CONSTRAINT prty_maty_fk FOREIGN KEY (maty_prop_id) REFERENCES material_types(id);\\012\\012ALTER TABLE experiment_properties\\012\\011ADD COLUMN mate_prop_id tech_id;\\012\\012ALTER TABLE material_properties\\012\\011ADD COLUMN mate_prop_id tech_id;\\012\\012ALTER TABLE sample_properties\\012\\011ADD COLUMN mate_prop_id tech_id;\\012\\012ALTER TABLE experiment_properties\\012\\011ADD CONSTRAINT expr_mapr_fk FOREIGN KEY (mate_prop_id) REFERENCES materials(id);\\012\\012ALTER TABLE material_properties\\012\\011ADD CONSTRAINT mapr_mapr_fk FOREIGN KEY (mate_prop_id) REFERENCES materials(id);\\012\\012ALTER TABLE sample_properties\\012\\011ADD CONSTRAINT sapr_mapr_fk FOREIGN KEY (mate_prop_id) REFERENCES materials(id);\\012\\012insert into data_types\\012(id\\012 ,code\\012 ,description)\\012 values \\012 (nextval('DATA_TYPE_ID_SEQ')\\012 ,'MATERIAL'\\012 ,'Reference to a material'\\012);\\012\\012ALTER TABLE MATERIAL_PROPERTIES DROP CONSTRAINT MAPR_CK;\\012ALTER TABLE MATERIAL_PROPERTIES ADD CONSTRAINT MAPR_CK CHECK \\012\\011((VALUE IS NOT NULL AND CVTE_ID IS NULL AND MATE_PROP_ID IS NULL) OR \\012\\011 (VALUE IS NULL AND CVTE_ID IS NOT NULL AND MATE_PROP_ID IS NULL) OR\\012\\011 (VALUE IS NULL AND CVTE_ID IS NULL AND MATE_PROP_ID IS NOT NULL)\\012\\011);\\012\\012ALTER TABLE EXPERIMENT_PROPERTIES DROP CONSTRAINT EXPR_CK;\\012ALTER TABLE EXPERIMENT_PROPERTIES ADD CONSTRAINT EXPR_CK CHECK \\012\\011((VALUE IS NOT NULL AND CVTE_ID IS NULL AND MATE_PROP_ID IS NULL) OR \\012\\011 (VALUE IS NULL AND CVTE_ID IS NOT NULL AND MATE_PROP_ID IS NULL) OR\\012\\011 (VALUE IS NULL AND CVTE_ID IS NULL AND MATE_PROP_ID IS NOT NULL)\\012\\011);\\012\\012ALTER TABLE SAMPLE_PROPERTIES DROP CONSTRAINT SAPR_CK;\\012ALTER TABLE SAMPLE_PROPERTIES ADD CONSTRAINT SAPR_CK CHECK \\012\\011((VALUE IS NOT NULL AND CVTE_ID IS NULL AND MATE_PROP_ID IS NULL) OR \\012\\011 (VALUE IS NULL AND CVTE_ID IS NOT NULL AND MATE_PROP_ID IS NULL) OR\\012\\011 (VALUE IS NULL AND CVTE_ID IS NULL AND MATE_PROP_ID IS NOT NULL)\\012\\011);\\012\\012------------------------------------------------------------------------------------\\012--  Purpose:  Create trigger MATERIAL/SAMPLE/EXPERIMENT _PROPERTY_WITH_MATERIAL_DATA_TYPE_CHECK\\012--            It checks that if material property value is assigned to the entity,\\012--\\011\\011\\011\\011\\011\\011then the material type is equal to the one described by property type.\\012------------------------------------------------------------------------------------\\012\\012CREATE OR REPLACE FUNCTION MATERIAL_PROPERTY_WITH_MATERIAL_DATA_TYPE_CHECK() RETURNS trigger AS $$\\012DECLARE\\012   v_type_id  CODE;\\012   v_type_id_prop  CODE;\\012BEGIN\\012   if NEW.mate_prop_id IS NOT NULL then\\012\\011\\011\\011-- find material type id of the property type \\012\\011\\011\\011select pt.maty_prop_id into v_type_id_prop \\012\\011\\011\\011  from material_type_property_types etpt, property_types pt \\012\\011\\011\\011 where NEW.mtpt_id = etpt.id AND etpt.prty_id = pt.id;\\012\\011\\011\\012\\011\\011\\011if v_type_id_prop IS NOT NULL then\\012\\011\\011\\011\\011-- find material type id of the material which consists the entity's property value\\012\\011\\011\\011\\011select entity.maty_id into v_type_id \\012\\011\\011\\011\\011  from materials entity\\012\\011\\011\\011\\011 where NEW.mate_prop_id = entity.id;\\012\\011\\011\\011\\011if v_type_id != v_type_id_prop then\\012\\011\\011\\011\\011\\011RAISE EXCEPTION 'Insert/Update of property value referencing material (id: %) failed, as referenced material type is different than expected (id %, expected id: %).', \\012\\011\\011\\011\\011\\011\\011\\011 NEW.mate_prop_id, v_type_id, v_type_id_prop;\\012\\011\\011\\011\\011end if;\\012\\011\\011\\011end if;\\012   end if;\\012   RETURN NEW;\\012END;\\012$$ LANGUAGE 'plpgsql';\\012\\012CREATE TRIGGER MATERIAL_PROPERTY_WITH_MATERIAL_DATA_TYPE_CHECK BEFORE INSERT OR UPDATE ON material_properties\\012    FOR EACH ROW EXECUTE PROCEDURE MATERIAL_PROPERTY_WITH_MATERIAL_DATA_TYPE_CHECK();\\012    \\012CREATE OR REPLACE FUNCTION SAMPLE_PROPERTY_WITH_MATERIAL_DATA_TYPE_CHECK() RETURNS trigger AS $$\\012DECLARE\\012   v_type_id  CODE;\\012   v_type_id_prop  CODE;\\012BEGIN\\012   if NEW.mate_prop_id IS NOT NULL then\\012\\011\\011\\011-- find material type id of the property type \\012\\011\\011\\011select pt.maty_prop_id into v_type_id_prop \\012\\011\\011\\011  from sample_type_property_types etpt, property_types pt \\012\\011\\011\\011 where NEW.stpt_id = etpt.id AND etpt.prty_id = pt.id;\\012\\011\\011\\012\\011\\011\\011if v_type_id_prop IS NOT NULL then\\012\\011\\011\\011\\011-- find material type id of the material which consists the entity's property value\\012\\011\\011\\011\\011select entity.maty_id into v_type_id \\012\\011\\011\\011\\011  from materials entity\\012\\011\\011\\011\\011 where NEW.mate_prop_id = entity.id;\\012\\011\\011\\011\\011if v_type_id != v_type_id_prop then\\012\\011\\011\\011\\011\\011RAISE EXCEPTION 'Insert/Update of property value referencing material (id: %) failed, as referenced material type is different than expected (id %, expected id: %).', \\012\\011\\011\\011\\011\\011\\011\\011\\011\\011\\011\\011\\011 NEW.mate_prop_id, v_type_id, v_type_id_prop;\\012\\011\\011\\011\\011end if;\\012\\011\\011\\011end if;\\012   end if;\\012   RETURN NEW;\\012END;\\012$$ LANGUAGE 'plpgsql';\\012\\012CREATE TRIGGER SAMPLE_PROPERTY_WITH_MATERIAL_DATA_TYPE_CHECK BEFORE INSERT OR UPDATE ON sample_properties\\012    FOR EACH ROW EXECUTE PROCEDURE SAMPLE_PROPERTY_WITH_MATERIAL_DATA_TYPE_CHECK();\\012    \\012CREATE OR REPLACE FUNCTION EXPERIMENT_PROPERTY_WITH_MATERIAL_DATA_TYPE_CHECK() RETURNS trigger AS $$\\012DECLARE\\012   v_type_id  CODE;\\012   v_type_id_prop  CODE;\\012BEGIN\\012   if NEW.mate_prop_id IS NOT NULL then\\012\\011\\011\\011-- find material type id of the property type \\012\\011\\011\\011select pt.maty_prop_id into v_type_id_prop \\012\\011\\011\\011  from experiment_type_property_types etpt, property_types pt \\012\\011\\011\\011 where NEW.etpt_id = etpt.id AND etpt.prty_id = pt.id;\\012\\011\\011\\012\\011\\011\\011if v_type_id_prop IS NOT NULL then\\012\\011\\011\\011\\011-- find material type id of the material which consists the entity's property value\\012\\011\\011\\011\\011select entity.maty_id into v_type_id \\012\\011\\011\\011\\011  from materials entity\\012\\011\\011\\011\\011 where NEW.mate_prop_id = entity.id;\\012\\011\\011\\011\\011if v_type_id != v_type_id_prop then\\012\\011\\011\\011\\011\\011RAISE EXCEPTION 'Insert/Update of property value referencing material (id: %) failed, as referenced material type is different than expected (id %, expected id: %).', \\012\\011\\011\\011\\011\\011\\011\\011\\011\\011\\011\\011\\011 NEW.mate_prop_id, v_type_id, v_type_id_prop;\\012\\011\\011\\011\\011end if;\\012\\011\\011\\011end if;\\012   end if;\\012   RETURN NEW;\\012END;\\012$$ LANGUAGE 'plpgsql';\\012\\012CREATE TRIGGER EXPERIMENT_PROPERTY_WITH_MATERIAL_DATA_TYPE_CHECK BEFORE INSERT OR UPDATE ON experiment_properties\\012    FOR EACH ROW EXECUTE PROCEDURE EXPERIMENT_PROPERTY_WITH_MATERIAL_DATA_TYPE_CHECK();\\012       \\012-- -------\\012-- remove the reminescents of the OBSERVABLE_TYPE\\012-- -------\\012\\012ALTER TABLE data\\012\\011DROP CONSTRAINT data_obty_fk;\\012\\012ALTER TABLE data_set_types\\012\\011DROP CONSTRAINT obty_pk;\\012\\012ALTER TABLE data_set_types\\012\\011ADD CONSTRAINT dsty_pk PRIMARY KEY (id);\\012\\012ALTER TABLE data\\012\\011ADD CONSTRAINT data_dsty_fk FOREIGN KEY (dsty_id) REFERENCES data_set_types(id);\\012\\012ALTER TABLE data_set_types\\012\\011DROP CONSTRAINT obty_bk_uk;\\012\\012ALTER TABLE data_set_types\\012\\011DROP CONSTRAINT obty_dbin_fk;\\012\\012ALTER TABLE data_set_types\\012\\011ADD CONSTRAINT dsty_bk_uk UNIQUE (code, dbin_id);\\012\\012ALTER TABLE data_set_types\\012\\011ADD CONSTRAINT dsty_dbin_fk FOREIGN KEY (dbin_id) REFERENCES database_instances(id);\\012\\012DROP INDEX data_obty_fk_i;\\012\\012CREATE INDEX data_dsty_fk_i ON data(dsty_id);\\012	\N
+./sourceTest/sql/postgresql/033/.svn/text-base/013=database_version_logs.tsv.svn-base:030	source/sql/postgresql/migration/migration-029-030.sql	SUCCESS	2009-03-23 15:34:44.72	-- -------\\012-- add modification_timestamp field to allow edition with Hibernate\\012-- -------\\012ALTER TABLE data\\012\\011ADD COLUMN modification_timestamp TIME_STAMP DEFAULT CURRENT_TIMESTAMP;\\012ALTER TABLE experiment_types\\012\\011ADD COLUMN modification_timestamp TIME_STAMP DEFAULT CURRENT_TIMESTAMP;\\012ALTER TABLE sample_types\\012\\011ADD COLUMN modification_timestamp TIME_STAMP DEFAULT CURRENT_TIMESTAMP;\\012ALTER TABLE material_types\\012\\011ADD COLUMN modification_timestamp TIME_STAMP DEFAULT CURRENT_TIMESTAMP;\\012ALTER TABLE data_set_types\\012\\011ADD COLUMN modification_timestamp TIME_STAMP DEFAULT CURRENT_TIMESTAMP;\\012ALTER TABLE controlled_vocabularies\\012\\011ADD COLUMN modification_timestamp TIME_STAMP DEFAULT CURRENT_TIMESTAMP;\\012-- -------\\012-- add properties to data sets\\012-- -------\\012CREATE TABLE DATA_SET_PROPERTIES (ID TECH_ID NOT NULL,DS_ID TECH_ID NOT NULL,DSTPT_ID TECH_ID NOT NULL,VALUE GENERIC_VALUE,CVTE_ID TECH_ID, MATE_PROP_ID TECH_ID, PERS_ID_REGISTERER TECH_ID NOT NULL,REGISTRATION_TIMESTAMP TIME_STAMP_DFL NOT NULL DEFAULT CURRENT_TIMESTAMP, MODIFICATION_TIMESTAMP TIME_STAMP DEFAULT CURRENT_TIMESTAMP);\\012CREATE TABLE DATA_SET_TYPE_PROPERTY_TYPES (ID TECH_ID NOT NULL,DSTY_ID TECH_ID NOT NULL,PRTY_ID TECH_ID NOT NULL,IS_MANDATORY BOOLEAN_CHAR NOT NULL DEFAULT 'F',IS_MANAGED_INTERNALLY BOOLEAN_CHAR NOT NULL DEFAULT 'F',PERS_ID_REGISTERER TECH_ID NOT NULL,REGISTRATION_TIMESTAMP TIME_STAMP_DFL NOT NULL DEFAULT CURRENT_TIMESTAMP);\\012\\012CREATE SEQUENCE DATA_SET_PROPERTY_ID_SEQ;\\012CREATE SEQUENCE DSTPT_ID_SEQ;\\012\\012ALTER TABLE DATA_SET_TYPE_PROPERTY_TYPES ADD CONSTRAINT DSTPT_PK PRIMARY KEY(ID);\\012ALTER TABLE DATA_SET_PROPERTIES ADD CONSTRAINT DSPR_PK PRIMARY KEY(ID);\\012\\012ALTER TABLE DATA_SET_TYPE_PROPERTY_TYPES ADD CONSTRAINT DSTPT_BK_UK UNIQUE(DSTY_ID,PRTY_ID);\\012ALTER TABLE DATA_SET_PROPERTIES ADD CONSTRAINT DSPR_BK_UK UNIQUE(DS_ID,DSTPT_ID);\\012\\012\\012ALTER TABLE DATA_SET_TYPE_PROPERTY_TYPES ADD CONSTRAINT DSTPT_DSTY_FK FOREIGN KEY (DSTY_ID) REFERENCES DATA_SET_TYPES(ID);\\012ALTER TABLE DATA_SET_TYPE_PROPERTY_TYPES ADD CONSTRAINT DSTPT_PERS_FK FOREIGN KEY (PERS_ID_REGISTERER) REFERENCES PERSONS(ID);\\012ALTER TABLE DATA_SET_TYPE_PROPERTY_TYPES ADD CONSTRAINT DSTPT_PRTY_FK FOREIGN KEY (PRTY_ID) REFERENCES PROPERTY_TYPES(ID);\\012ALTER TABLE DATA_SET_PROPERTIES ADD CONSTRAINT DSPR_CVTE_FK FOREIGN KEY (CVTE_ID) REFERENCES CONTROLLED_VOCABULARY_TERMS(ID);\\012ALTER TABLE DATA_SET_PROPERTIES ADD CONSTRAINT DSPR_DSTPT_FK FOREIGN KEY (DSTPT_ID) REFERENCES DATA_SET_TYPE_PROPERTY_TYPES(ID) ON DELETE CASCADE;\\012ALTER TABLE DATA_SET_PROPERTIES ADD CONSTRAINT DSPR_DS_FK FOREIGN KEY (DS_ID) REFERENCES DATA(ID);\\012ALTER TABLE DATA_SET_PROPERTIES ADD CONSTRAINT DSPR_PERS_FK FOREIGN KEY (PERS_ID_REGISTERER) REFERENCES PERSONS(ID);\\012ALTER TABLE DATA_SET_PROPERTIES ADD CONSTRAINT DSPR_MAPR_FK FOREIGN KEY (MATE_PROP_ID) REFERENCES MATERIALS(ID);\\012\\012ALTER TABLE DATA_SET_PROPERTIES ADD CONSTRAINT DSPR_CK CHECK \\012\\011((VALUE IS NOT NULL AND CVTE_ID IS NULL AND MATE_PROP_ID IS NULL) OR \\012\\011 (VALUE IS NULL AND CVTE_ID IS NOT NULL AND MATE_PROP_ID IS NULL) OR\\012\\011 (VALUE IS NULL AND CVTE_ID IS NULL AND MATE_PROP_ID IS NOT NULL)\\012\\011);\\012\\012CREATE INDEX DSPR_CVTE_FK_I ON DATA_SET_PROPERTIES (CVTE_ID);\\012CREATE INDEX DSPR_DSTPT_FK_I ON DATA_SET_PROPERTIES (DSTPT_ID);\\012CREATE INDEX DSPR_DS_FK_I ON DATA_SET_PROPERTIES (DS_ID);\\012CREATE INDEX DSPR_PERS_FK_I ON DATA_SET_PROPERTIES (PERS_ID_REGISTERER);\\012CREATE INDEX DSTPT_DSTY_FK_I ON DATA_SET_TYPE_PROPERTY_TYPES (DSTY_ID);\\012CREATE INDEX DSTPT_PERS_FK_I ON DATA_SET_TYPE_PROPERTY_TYPES (PERS_ID_REGISTERER);\\012CREATE INDEX DSTPT_PRTY_FK_I ON DATA_SET_TYPE_PROPERTY_TYPES (PRTY_ID);\\012\\012CREATE OR REPLACE FUNCTION DATA_SET_PROPERTY_WITH_MATERIAL_DATA_TYPE_CHECK() RETURNS trigger AS $$\\012DECLARE\\012   v_type_id  CODE;\\012   v_type_id_prop  CODE;\\012BEGIN\\012   if NEW.mate_prop_id IS NOT NULL then\\012\\011\\011\\011-- find material type id of the property type \\012\\011\\011\\011select pt.maty_prop_id into v_type_id_prop \\012\\011\\011\\011  from data_set_type_property_types dstpt, property_types pt \\012\\011\\011\\011 where NEW.dstpt_id = dstpt.id AND dstpt.prty_id = pt.id;\\012\\011\\011\\012\\011\\011\\011if v_type_id_prop IS NOT NULL then\\012\\011\\011\\011\\011-- find material type id of the material which consists the entity's property value\\012\\011\\011\\011\\011select entity.maty_id into v_type_id \\012\\011\\011\\011\\011  from materials entity\\012\\011\\011\\011\\011 where NEW.mate_prop_id = entity.id;\\012\\011\\011\\011\\011if v_type_id != v_type_id_prop then\\012\\011\\011\\011\\011\\011RAISE EXCEPTION 'Insert/Update of property value referencing material (id: %) failed, as referenced material type is different than expected (id %, expected id: %).', \\012\\011\\011\\011\\011\\011\\011\\011\\011\\011\\011\\011\\011 NEW.mate_prop_id, v_type_id, v_type_id_prop;\\012\\011\\011\\011\\011end if;\\012\\011\\011\\011end if;\\012   end if;\\012   RETURN NEW;\\012END;\\012$$ LANGUAGE 'plpgsql';\\012\\012CREATE TRIGGER DATA_SET_PROPERTY_WITH_MATERIAL_DATA_TYPE_CHECK BEFORE INSERT OR UPDATE ON data_set_properties\\012    FOR EACH ROW EXECUTE PROCEDURE DATA_SET_PROPERTY_WITH_MATERIAL_DATA_TYPE_CHECK();   \\012	\N
+./sourceTest/sql/postgresql/033/.svn/text-base/013=database_version_logs.tsv.svn-base:032	source/sql/postgresql/migration/migration-031-032.sql	SUCCESS	2009-04-09 09:36:36.20	-- -------\\012-- Modify MATERIAL_BATCHES\\012-- -------\\012\\012ALTER TABLE material_batches\\012    DROP COLUMN proc_id;\\012\\012-- -------\\012-- Modify SAMPLES\\012-- -------\\012\\012ALTER TABLE samples\\012    ADD COLUMN expe_id tech_id;\\012\\012ALTER TABLE samples\\012    ADD CONSTRAINT samp_expe_fk FOREIGN KEY (expe_id) REFERENCES experiments(id);\\012\\012CREATE INDEX samp_expe_fk_i ON samples USING btree (expe_id);\\012\\012-- relink samples directly to experiments\\012\\012UPDATE samples\\012SET expe_id = (SELECT e.id FROM experiments e, procedures p, sample_inputs si \\012               WHERE si.samp_id = samples.id AND si.proc_id = p.id AND p.expe_id = e.id AND e.inva_id IS NULL);\\012\\012\\012-- -------\\012-- Modify DATA\\012-- -------\\012\\012ALTER TABLE data\\012    ADD COLUMN expe_id tech_id;\\012\\012ALTER TABLE data\\012    ADD CONSTRAINT data_expe_fk FOREIGN KEY (expe_id) REFERENCES experiments(id);\\012\\012CREATE INDEX data_expe_fk_i ON data USING btree (expe_id);\\012\\012UPDATE data\\012SET expe_id = (SELECT e.id FROM experiments e, procedures p \\012               WHERE data.proc_id_produced_by = p.id AND p.expe_id = e.id);\\012\\012ALTER TABLE data\\012    ALTER COLUMN expe_id SET NOT NULL;\\012\\012ALTER TABLE data\\012    DROP COLUMN proc_id_produced_by;\\012\\012-- -------\\012-- Drop PROCEDURES, PROCEDURE_TYPES, and SAMPLE_INPUTS\\012-- -------\\012\\012DROP TABLE sample_inputs;\\012DROP TABLE procedures;\\012DROP TABLE procedure_types;\\012\\012DROP SEQUENCE procedure_id_seq;\\012DROP SEQUENCE procedure_type_id_seq;\\012\\012-- -------\\012-- Add CODE_SEQ\\012-- -------\\012\\012CREATE SEQUENCE CODE_SEQ;\\012\\012-- -------\\012-- Add new columns to DATA_STORES\\012-- -------\\012\\012ALTER TABLE data_stores\\012    ADD COLUMN remote_url character varying(250),\\012    ADD COLUMN session_token character varying(50),\\012    ADD COLUMN modification_timestamp time_stamp DEFAULT now();\\012\\012UPDATE data_stores\\012SET remote_url = '', session_token='';\\012\\012ALTER TABLE data_stores\\012    ALTER COLUMN remote_url SET NOT NULL,\\012    ALTER COLUMN session_token SET NOT NULL;\\012\\012-- -------\\012-- Drop foreign keys onto DATA_STORES\\012-- -------\\012\\012ALTER TABLE database_instances\\012    DROP COLUMN dast_id;\\012\\012ALTER TABLE groups\\012    DROP COLUMN dast_id;\\012\\012ALTER TABLE projects\\012    DROP COLUMN dast_id;\\012\\012ALTER TABLE experiments\\012    DROP COLUMN dast_id;\\012\\012-- -------\\012-- Add foreign key from DATA onto DATA_STORES\\012-- -------\\012\\012ALTER TABLE data\\012    ADD COLUMN dast_id tech_id;\\012\\012ALTER TABLE data\\012    ADD CONSTRAINT data_dast_fk FOREIGN KEY (dast_id) REFERENCES data_stores(id);\\012\\012UPDATE data\\012SET dast_id = (select id from data_stores where code = 'STANDARD');\\012\\012ALTER TABLE data\\012    ALTER COLUMN dast_id SET NOT NULL;\\012\\012\\012------------------------------------------------------------------------------------\\012--  Purpose:  Replace trigger SAMPLE_CODE_UNIQUENESS_CHECK \\012------------------------------------------------------------------------------------\\012\\012CREATE OR REPLACE FUNCTION SAMPLE_CODE_UNIQUENESS_CHECK() RETURNS trigger AS $$\\012DECLARE\\012   counter  INTEGER;\\012BEGIN\\012    LOCK TABLE samples IN EXCLUSIVE MODE;\\012    IF (NEW.samp_id_part_of is NULL) THEN\\012        IF (NEW.dbin_id is not NULL) THEN\\012            SELECT count(*) into counter FROM samples \\012                where id != NEW.id and code = NEW.code and samp_id_part_of is NULL and dbin_id = NEW.dbin_id;\\012            IF (counter > 0) THEN\\012                RAISE EXCEPTION 'Insert/Update of Sample (Code: %) failed because database instance sample with the same code already exists.', NEW.code;\\012            END IF;\\012        ELSIF (NEW.grou_id is not NULL) THEN\\012            SELECT count(*) into counter FROM samples \\012                where id != NEW.id and code = NEW.code and samp_id_part_of is NULL and grou_id = NEW.grou_id;\\012            IF (counter > 0) THEN\\012                RAISE EXCEPTION 'Insert/Update of Sample (Code: %) failed because group sample with the same code already exists.', NEW.code;\\012            END IF;\\012        END IF;\\012        ELSE\\012        IF (NEW.dbin_id is not NULL) THEN\\012            SELECT count(*) into counter FROM samples \\012                where id != NEW.id and code = NEW.code and samp_id_part_of = NEW.samp_id_part_of and dbin_id = NEW.dbin_id;\\012            IF (counter > 0) THEN\\012                RAISE EXCEPTION 'Insert/Update of Sample (Code: %) failed because database instance sample with the same code and being the part of the same parent already exists.', NEW.code;\\012            END IF;\\012        ELSIF (NEW.grou_id is not NULL) THEN\\012            SELECT count(*) into counter FROM samples \\012                where id != NEW.id and code = NEW.code and samp_id_part_of = NEW.samp_id_part_of and grou_id = NEW.grou_id;\\012            IF (counter > 0) THEN\\012                RAISE EXCEPTION 'Insert/Update of Sample (Code: %) failed because group sample with the same code and being the part of the same parent already exists.', NEW.code;\\012            END IF;\\012        END IF;\\012        END IF;   \\012   RETURN NEW;\\012END;\\012$$ LANGUAGE 'plpgsql';\\012\\012\\012\\012	\N
+./sourceTest/sql/postgresql/033/.svn/text-base/schema-033.sql.svn-base:    LANGUAGE plpgsql;
+./sourceTest/sql/postgresql/033/.svn/text-base/schema-033.sql.svn-base:    LANGUAGE plpgsql;
+./sourceTest/sql/postgresql/033/.svn/text-base/schema-033.sql.svn-base:    LANGUAGE plpgsql;
+./sourceTest/sql/postgresql/033/.svn/text-base/schema-033.sql.svn-base:    LANGUAGE plpgsql;
+./sourceTest/sql/postgresql/033/.svn/text-base/schema-033.sql.svn-base:    LANGUAGE plpgsql;
+./sourceTest/sql/postgresql/033/.svn/text-base/schema-033.sql.svn-base:    LANGUAGE plpgsql;
+./sourceTest/sql/postgresql/033/.svn/text-base/schema-033.sql.svn-base:    LANGUAGE plpgsql;
+./sourceTest/sql/postgresql/033/.svn/text-base/schema-033.sql.svn-base:    LANGUAGE plpgsql;
+./sourceTest/sql/postgresql/033/013=database_version_logs.tsv:027	D:\\User\\felmer\\dev-workspace\\openbis/source/sql/postgresql/027/function-027.sql	SUCCESS	2008-11-05 09:18:00.403	-- Creating Functions\\012\\012------------------------------------------------------------------------------------\\012--  Purpose:  Create function RENAME_SEQUENCE() that is required for renaming the sequences belonging to tables\\012------------------------------------------------------------------------------------\\012CREATE FUNCTION RENAME_SEQUENCE(OLD_NAME VARCHAR, NEW_NAME VARCHAR) RETURNS INTEGER AS $$\\012DECLARE\\012  CURR_SEQ_VAL   INTEGER;\\012BEGIN\\012  SELECT INTO CURR_SEQ_VAL NEXTVAL(OLD_NAME);\\012  EXECUTE 'CREATE SEQUENCE ' || NEW_NAME || ' START WITH ' || CURR_SEQ_VAL;\\012  EXECUTE 'DROP SEQUENCE ' || OLD_NAME;\\012  RETURN CURR_SEQ_VAL;\\012END;\\012$$ LANGUAGE 'plpgsql';\\012\\012\\012------------------------------------------------------------------------------------\\012--  Purpose:  Create trigger CONTROLLED_VOCABULARY_CHECK \\012------------------------------------------------------------------------------------\\012\\012CREATE OR REPLACE FUNCTION CONTROLLED_VOCABULARY_CHECK() RETURNS trigger AS $$\\012DECLARE\\012   v_code  CODE;\\012BEGIN\\012\\012   select code into v_code from data_types where id = NEW.daty_id;\\012\\012   -- Check if the data is of type "CONTROLLEDVOCABULARY"\\012   if v_code = 'CONTROLLEDVOCABULARY' then\\012      if NEW.covo_id IS NULL then\\012         RAISE EXCEPTION 'Insert/Update of Property Type (Code: %) failed, as its Data Type is CONTROLLEDVOCABULARY, but it is not linked to a Controlled Vocabulary.', NEW.code;\\012      end if;\\012   end if;\\012\\012   RETURN NEW;\\012\\012END;\\012$$ LANGUAGE 'plpgsql';\\012\\012CREATE TRIGGER CONTROLLED_VOCABULARY_CHECK BEFORE INSERT OR UPDATE ON PROPERTY_TYPES\\012    FOR EACH ROW EXECUTE PROCEDURE CONTROLLED_VOCABULARY_CHECK();\\012\\012\\012------------------------------------------------------------------------------------\\012--  Purpose:  Create trigger EXTERNAL_DATA_STORAGE_FORMAT_CHECK \\012------------------------------------------------------------------------------------\\012\\012CREATE OR REPLACE FUNCTION EXTERNAL_DATA_STORAGE_FORMAT_CHECK() RETURNS trigger AS $$\\012DECLARE\\012   v_covo_code  CODE;\\012   data_code CODE;\\012BEGIN\\012\\012   select code into v_covo_code from controlled_vocabularies\\012      where is_internal_namespace = true and \\012         id = (select covo_id from controlled_vocabulary_terms where id = NEW.cvte_id_stor_fmt);\\012   -- Check if the data storage format is a term of the controlled vocabulary "STORAGE_FORMAT"\\012   if v_covo_code != 'STORAGE_FORMAT' then\\012      select code into data_code from data where id = NEW.data_id; \\012      RAISE EXCEPTION 'Insert/Update of Data (Code: %) failed, as its Storage Format is %, but is required to be STORAGE_FORMAT.', data_code, v_covo_code;\\012   end if;\\012\\012   RETURN NEW;\\012\\012END;\\012$$ LANGUAGE 'plpgsql';\\012\\012CREATE TRIGGER EXTERNAL_DATA_STORAGE_FORMAT_CHECK BEFORE INSERT OR UPDATE ON EXTERNAL_DATA\\012    FOR EACH ROW EXECUTE PROCEDURE EXTERNAL_DATA_STORAGE_FORMAT_CHECK();\\012\\012------------------------------------------------------------------------------------\\012--  Purpose:  Create trigger SAMPLE_CODE_UNIQUENESS_CHECK \\012------------------------------------------------------------------------------------\\012\\012CREATE OR REPLACE FUNCTION SAMPLE_CODE_UNIQUENESS_CHECK() RETURNS trigger AS $$\\012DECLARE\\012   counter  INTEGER;\\012BEGIN\\012\\011IF (NEW.samp_id_part_of is NULL) THEN\\012\\011\\011IF (NEW.dbin_id is not NULL) THEN\\012\\011\\011\\011SELECT count(*) into counter FROM samples \\012\\011\\011\\011\\011where id != NEW.id and code = NEW.code and samp_id_part_of is NULL and dbin_id = NEW.dbin_id;\\012\\011\\011\\011IF (counter > 0) THEN\\012\\011\\011\\011\\011RAISE EXCEPTION 'Insert/Update of Sample (Code: %) failed because database instance sample with the same code already exists.', NEW.code;\\012\\011\\011\\011END IF;\\012\\011\\011ELSIF (NEW.grou_id is not NULL) THEN\\012\\011\\011\\011SELECT count(*) into counter FROM samples \\012\\011\\011\\011\\011where id != NEW.id and code = NEW.code and samp_id_part_of is NULL and grou_id = NEW.grou_id;\\012\\011\\011\\011IF (counter > 0) THEN\\012\\011\\011\\011\\011RAISE EXCEPTION 'Insert/Update of Sample (Code: %) failed because group sample with the same code already exists.', NEW.code;\\012\\011\\011\\011END IF;\\012\\011\\011END IF;\\012        ELSE\\012\\011\\011IF (NEW.dbin_id is not NULL) THEN\\012\\011\\011\\011SELECT count(*) into counter FROM samples \\012\\011\\011\\011\\011where id != NEW.id and code = NEW.code and samp_id_part_of = NEW.samp_id_part_of and dbin_id = NEW.dbin_id;\\012\\011\\011\\011IF (counter > 0) THEN\\012\\011\\011\\011\\011RAISE EXCEPTION 'Insert/Update of Sample (Code: %) failed because database instance sample with the same code and being the part of the same parent already exists.', NEW.code;\\012\\011\\011\\011END IF;\\012\\011\\011ELSIF (NEW.grou_id is not NULL) THEN\\012\\011\\011\\011SELECT count(*) into counter FROM samples \\012\\011\\011\\011\\011where id != NEW.id and code = NEW.code and samp_id_part_of = NEW.samp_id_part_of and grou_id = NEW.grou_id;\\012\\011\\011\\011IF (counter > 0) THEN\\012\\011\\011\\011\\011RAISE EXCEPTION 'Insert/Update of Sample (Code: %) failed because group sample with the same code and being the part of the same parent already exists.', NEW.code;\\012\\011\\011\\011END IF;\\012\\011\\011END IF;\\012        END IF;   \\012   RETURN NEW;\\012END;\\012$$ LANGUAGE 'plpgsql';\\012\\012CREATE TRIGGER SAMPLE_CODE_UNIQUENESS_CHECK BEFORE INSERT OR UPDATE ON SAMPLES\\012    FOR EACH ROW EXECUTE PROCEDURE SAMPLE_CODE_UNIQUENESS_CHECK();\\012	\N
+./sourceTest/sql/postgresql/033/013=database_version_logs.tsv:028	source/sql/postgresql/migration/migration-027-028.sql	SUCCESS	2008-11-18 13:24:17.508	-- Create EXPERIMENT_ATTACHMENT_CONTENTS.\\012CREATE TABLE EXPERIMENT_ATTACHMENT_CONTENTS (ID TECH_ID NOT NULL,VALUE FILE NOT NULL);\\012CREATE SEQUENCE EXPERIMENT_ATTACHMENT_CONTENT_ID_SEQ;\\012ALTER TABLE EXPERIMENT_ATTACHMENT_CONTENTS ADD CONSTRAINT EXAC_PK PRIMARY KEY(ID);\\012\\012-- Alter EXPERIMENT_ATTACHMENTS by adding the new column which has a NULL constraint.\\012-- The NOT NULL constraint is added later on.\\012ALTER TABLE EXPERIMENT_ATTACHMENTS ADD COLUMN EXAC_ID TECH_ID;\\012\\012-- Does the VALUE migration between EXPERIMENT_ATTACHMENTS to EXPERIMENT_ATTACHMENT_CONTENTS.\\012CREATE OR REPLACE FUNCTION move_exp_att_content() RETURNS integer AS $$\\012DECLARE\\012    rec RECORD;\\012    seq BIGINT;\\012BEGIN\\012  FOR rec IN SELECT id, value FROM EXPERIMENT_ATTACHMENTS LOOP\\012  \\011seq := nextval('EXPERIMENT_ATTACHMENT_CONTENT_ID_SEQ');\\012    INSERT INTO EXPERIMENT_ATTACHMENT_CONTENTS (id, value) VALUES (seq, rec.value);\\012    UPDATE EXPERIMENT_ATTACHMENTS SET exac_id = seq WHERE id = rec.id;\\012  END LOOP;\\012  RETURN 1;\\012END;\\012$$ LANGUAGE 'plpgsql';\\012\\012-- Call the function.\\012SELECT move_exp_att_content();\\012DROP FUNCTION move_exp_att_content();\\012\\012\\012-- Finish EXPERIMENT_ATTACHMENTS changes.\\012ALTER TABLE EXPERIMENT_ATTACHMENTS ADD CONSTRAINT EXAT_CONT_FK FOREIGN KEY (EXAC_ID) REFERENCES EXPERIMENT_ATTACHMENT_CONTENTS(ID);\\012ALTER TABLE EXPERIMENT_ATTACHMENTS DROP COLUMN VALUE;\\012ALTER TABLE EXPERIMENT_ATTACHMENTS ALTER COLUMN EXAC_ID SET NOT NULL;\\012	\N
+./sourceTest/sql/postgresql/033/013=database_version_logs.tsv:029	source/sql/postgresql/migration/migration-028-029.sql	SUCCESS	2009-03-18 10:50:20.105	-- -------\\012-- add modification_timestamp field to allow edition with Hibernate\\012-- -------\\012\\012ALTER TABLE samples\\012\\011ADD COLUMN modification_timestamp TIME_STAMP DEFAULT CURRENT_TIMESTAMP;\\012\\012ALTER TABLE experiments\\012\\011ADD COLUMN modification_timestamp TIME_STAMP DEFAULT CURRENT_TIMESTAMP;\\012\\012ALTER TABLE materials\\012\\011ADD COLUMN modification_timestamp TIME_STAMP DEFAULT CURRENT_TIMESTAMP;\\012\\012ALTER TABLE experiment_properties\\012\\011ADD COLUMN modification_timestamp TIME_STAMP DEFAULT CURRENT_TIMESTAMP;\\012\\012ALTER TABLE material_properties\\012\\011ADD COLUMN modification_timestamp TIME_STAMP DEFAULT CURRENT_TIMESTAMP;\\012\\012ALTER TABLE sample_properties\\012\\011ADD COLUMN modification_timestamp TIME_STAMP DEFAULT CURRENT_TIMESTAMP;\\012\\012-- -------\\012-- add property data type which references materials\\012-- -------\\012\\012ALTER TABLE property_types\\012\\011ADD COLUMN maty_prop_id tech_id;\\012\\012ALTER TABLE property_types\\012\\011ADD CONSTRAINT prty_maty_fk FOREIGN KEY (maty_prop_id) REFERENCES material_types(id);\\012\\012ALTER TABLE experiment_properties\\012\\011ADD COLUMN mate_prop_id tech_id;\\012\\012ALTER TABLE material_properties\\012\\011ADD COLUMN mate_prop_id tech_id;\\012\\012ALTER TABLE sample_properties\\012\\011ADD COLUMN mate_prop_id tech_id;\\012\\012ALTER TABLE experiment_properties\\012\\011ADD CONSTRAINT expr_mapr_fk FOREIGN KEY (mate_prop_id) REFERENCES materials(id);\\012\\012ALTER TABLE material_properties\\012\\011ADD CONSTRAINT mapr_mapr_fk FOREIGN KEY (mate_prop_id) REFERENCES materials(id);\\012\\012ALTER TABLE sample_properties\\012\\011ADD CONSTRAINT sapr_mapr_fk FOREIGN KEY (mate_prop_id) REFERENCES materials(id);\\012\\012insert into data_types\\012(id\\012 ,code\\012 ,description)\\012 values \\012 (nextval('DATA_TYPE_ID_SEQ')\\012 ,'MATERIAL'\\012 ,'Reference to a material'\\012);\\012\\012ALTER TABLE MATERIAL_PROPERTIES DROP CONSTRAINT MAPR_CK;\\012ALTER TABLE MATERIAL_PROPERTIES ADD CONSTRAINT MAPR_CK CHECK \\012\\011((VALUE IS NOT NULL AND CVTE_ID IS NULL AND MATE_PROP_ID IS NULL) OR \\012\\011 (VALUE IS NULL AND CVTE_ID IS NOT NULL AND MATE_PROP_ID IS NULL) OR\\012\\011 (VALUE IS NULL AND CVTE_ID IS NULL AND MATE_PROP_ID IS NOT NULL)\\012\\011);\\012\\012ALTER TABLE EXPERIMENT_PROPERTIES DROP CONSTRAINT EXPR_CK;\\012ALTER TABLE EXPERIMENT_PROPERTIES ADD CONSTRAINT EXPR_CK CHECK \\012\\011((VALUE IS NOT NULL AND CVTE_ID IS NULL AND MATE_PROP_ID IS NULL) OR \\012\\011 (VALUE IS NULL AND CVTE_ID IS NOT NULL AND MATE_PROP_ID IS NULL) OR\\012\\011 (VALUE IS NULL AND CVTE_ID IS NULL AND MATE_PROP_ID IS NOT NULL)\\012\\011);\\012\\012ALTER TABLE SAMPLE_PROPERTIES DROP CONSTRAINT SAPR_CK;\\012ALTER TABLE SAMPLE_PROPERTIES ADD CONSTRAINT SAPR_CK CHECK \\012\\011((VALUE IS NOT NULL AND CVTE_ID IS NULL AND MATE_PROP_ID IS NULL) OR \\012\\011 (VALUE IS NULL AND CVTE_ID IS NOT NULL AND MATE_PROP_ID IS NULL) OR\\012\\011 (VALUE IS NULL AND CVTE_ID IS NULL AND MATE_PROP_ID IS NOT NULL)\\012\\011);\\012\\012------------------------------------------------------------------------------------\\012--  Purpose:  Create trigger MATERIAL/SAMPLE/EXPERIMENT _PROPERTY_WITH_MATERIAL_DATA_TYPE_CHECK\\012--            It checks that if material property value is assigned to the entity,\\012--\\011\\011\\011\\011\\011\\011then the material type is equal to the one described by property type.\\012------------------------------------------------------------------------------------\\012\\012CREATE OR REPLACE FUNCTION MATERIAL_PROPERTY_WITH_MATERIAL_DATA_TYPE_CHECK() RETURNS trigger AS $$\\012DECLARE\\012   v_type_id  CODE;\\012   v_type_id_prop  CODE;\\012BEGIN\\012   if NEW.mate_prop_id IS NOT NULL then\\012\\011\\011\\011-- find material type id of the property type \\012\\011\\011\\011select pt.maty_prop_id into v_type_id_prop \\012\\011\\011\\011  from material_type_property_types etpt, property_types pt \\012\\011\\011\\011 where NEW.mtpt_id = etpt.id AND etpt.prty_id = pt.id;\\012\\011\\011\\012\\011\\011\\011if v_type_id_prop IS NOT NULL then\\012\\011\\011\\011\\011-- find material type id of the material which consists the entity's property value\\012\\011\\011\\011\\011select entity.maty_id into v_type_id \\012\\011\\011\\011\\011  from materials entity\\012\\011\\011\\011\\011 where NEW.mate_prop_id = entity.id;\\012\\011\\011\\011\\011if v_type_id != v_type_id_prop then\\012\\011\\011\\011\\011\\011RAISE EXCEPTION 'Insert/Update of property value referencing material (id: %) failed, as referenced material type is different than expected (id %, expected id: %).', \\012\\011\\011\\011\\011\\011\\011\\011 NEW.mate_prop_id, v_type_id, v_type_id_prop;\\012\\011\\011\\011\\011end if;\\012\\011\\011\\011end if;\\012   end if;\\012   RETURN NEW;\\012END;\\012$$ LANGUAGE 'plpgsql';\\012\\012CREATE TRIGGER MATERIAL_PROPERTY_WITH_MATERIAL_DATA_TYPE_CHECK BEFORE INSERT OR UPDATE ON material_properties\\012    FOR EACH ROW EXECUTE PROCEDURE MATERIAL_PROPERTY_WITH_MATERIAL_DATA_TYPE_CHECK();\\012    \\012CREATE OR REPLACE FUNCTION SAMPLE_PROPERTY_WITH_MATERIAL_DATA_TYPE_CHECK() RETURNS trigger AS $$\\012DECLARE\\012   v_type_id  CODE;\\012   v_type_id_prop  CODE;\\012BEGIN\\012   if NEW.mate_prop_id IS NOT NULL then\\012\\011\\011\\011-- find material type id of the property type \\012\\011\\011\\011select pt.maty_prop_id into v_type_id_prop \\012\\011\\011\\011  from sample_type_property_types etpt, property_types pt \\012\\011\\011\\011 where NEW.stpt_id = etpt.id AND etpt.prty_id = pt.id;\\012\\011\\011\\012\\011\\011\\011if v_type_id_prop IS NOT NULL then\\012\\011\\011\\011\\011-- find material type id of the material which consists the entity's property value\\012\\011\\011\\011\\011select entity.maty_id into v_type_id \\012\\011\\011\\011\\011  from materials entity\\012\\011\\011\\011\\011 where NEW.mate_prop_id = entity.id;\\012\\011\\011\\011\\011if v_type_id != v_type_id_prop then\\012\\011\\011\\011\\011\\011RAISE EXCEPTION 'Insert/Update of property value referencing material (id: %) failed, as referenced material type is different than expected (id %, expected id: %).', \\012\\011\\011\\011\\011\\011\\011\\011\\011\\011\\011\\011\\011 NEW.mate_prop_id, v_type_id, v_type_id_prop;\\012\\011\\011\\011\\011end if;\\012\\011\\011\\011end if;\\012   end if;\\012   RETURN NEW;\\012END;\\012$$ LANGUAGE 'plpgsql';\\012\\012CREATE TRIGGER SAMPLE_PROPERTY_WITH_MATERIAL_DATA_TYPE_CHECK BEFORE INSERT OR UPDATE ON sample_properties\\012    FOR EACH ROW EXECUTE PROCEDURE SAMPLE_PROPERTY_WITH_MATERIAL_DATA_TYPE_CHECK();\\012    \\012CREATE OR REPLACE FUNCTION EXPERIMENT_PROPERTY_WITH_MATERIAL_DATA_TYPE_CHECK() RETURNS trigger AS $$\\012DECLARE\\012   v_type_id  CODE;\\012   v_type_id_prop  CODE;\\012BEGIN\\012   if NEW.mate_prop_id IS NOT NULL then\\012\\011\\011\\011-- find material type id of the property type \\012\\011\\011\\011select pt.maty_prop_id into v_type_id_prop \\012\\011\\011\\011  from experiment_type_property_types etpt, property_types pt \\012\\011\\011\\011 where NEW.etpt_id = etpt.id AND etpt.prty_id = pt.id;\\012\\011\\011\\012\\011\\011\\011if v_type_id_prop IS NOT NULL then\\012\\011\\011\\011\\011-- find material type id of the material which consists the entity's property value\\012\\011\\011\\011\\011select entity.maty_id into v_type_id \\012\\011\\011\\011\\011  from materials entity\\012\\011\\011\\011\\011 where NEW.mate_prop_id = entity.id;\\012\\011\\011\\011\\011if v_type_id != v_type_id_prop then\\012\\011\\011\\011\\011\\011RAISE EXCEPTION 'Insert/Update of property value referencing material (id: %) failed, as referenced material type is different than expected (id %, expected id: %).', \\012\\011\\011\\011\\011\\011\\011\\011\\011\\011\\011\\011\\011 NEW.mate_prop_id, v_type_id, v_type_id_prop;\\012\\011\\011\\011\\011end if;\\012\\011\\011\\011end if;\\012   end if;\\012   RETURN NEW;\\012END;\\012$$ LANGUAGE 'plpgsql';\\012\\012CREATE TRIGGER EXPERIMENT_PROPERTY_WITH_MATERIAL_DATA_TYPE_CHECK BEFORE INSERT OR UPDATE ON experiment_properties\\012    FOR EACH ROW EXECUTE PROCEDURE EXPERIMENT_PROPERTY_WITH_MATERIAL_DATA_TYPE_CHECK();\\012       \\012-- -------\\012-- remove the reminescents of the OBSERVABLE_TYPE\\012-- -------\\012\\012ALTER TABLE data\\012\\011DROP CONSTRAINT data_obty_fk;\\012\\012ALTER TABLE data_set_types\\012\\011DROP CONSTRAINT obty_pk;\\012\\012ALTER TABLE data_set_types\\012\\011ADD CONSTRAINT dsty_pk PRIMARY KEY (id);\\012\\012ALTER TABLE data\\012\\011ADD CONSTRAINT data_dsty_fk FOREIGN KEY (dsty_id) REFERENCES data_set_types(id);\\012\\012ALTER TABLE data_set_types\\012\\011DROP CONSTRAINT obty_bk_uk;\\012\\012ALTER TABLE data_set_types\\012\\011DROP CONSTRAINT obty_dbin_fk;\\012\\012ALTER TABLE data_set_types\\012\\011ADD CONSTRAINT dsty_bk_uk UNIQUE (code, dbin_id);\\012\\012ALTER TABLE data_set_types\\012\\011ADD CONSTRAINT dsty_dbin_fk FOREIGN KEY (dbin_id) REFERENCES database_instances(id);\\012\\012DROP INDEX data_obty_fk_i;\\012\\012CREATE INDEX data_dsty_fk_i ON data(dsty_id);\\012	\N
+./sourceTest/sql/postgresql/033/013=database_version_logs.tsv:030	source/sql/postgresql/migration/migration-029-030.sql	SUCCESS	2009-03-23 15:34:44.72	-- -------\\012-- add modification_timestamp field to allow edition with Hibernate\\012-- -------\\012ALTER TABLE data\\012\\011ADD COLUMN modification_timestamp TIME_STAMP DEFAULT CURRENT_TIMESTAMP;\\012ALTER TABLE experiment_types\\012\\011ADD COLUMN modification_timestamp TIME_STAMP DEFAULT CURRENT_TIMESTAMP;\\012ALTER TABLE sample_types\\012\\011ADD COLUMN modification_timestamp TIME_STAMP DEFAULT CURRENT_TIMESTAMP;\\012ALTER TABLE material_types\\012\\011ADD COLUMN modification_timestamp TIME_STAMP DEFAULT CURRENT_TIMESTAMP;\\012ALTER TABLE data_set_types\\012\\011ADD COLUMN modification_timestamp TIME_STAMP DEFAULT CURRENT_TIMESTAMP;\\012ALTER TABLE controlled_vocabularies\\012\\011ADD COLUMN modification_timestamp TIME_STAMP DEFAULT CURRENT_TIMESTAMP;\\012-- -------\\012-- add properties to data sets\\012-- -------\\012CREATE TABLE DATA_SET_PROPERTIES (ID TECH_ID NOT NULL,DS_ID TECH_ID NOT NULL,DSTPT_ID TECH_ID NOT NULL,VALUE GENERIC_VALUE,CVTE_ID TECH_ID, MATE_PROP_ID TECH_ID, PERS_ID_REGISTERER TECH_ID NOT NULL,REGISTRATION_TIMESTAMP TIME_STAMP_DFL NOT NULL DEFAULT CURRENT_TIMESTAMP, MODIFICATION_TIMESTAMP TIME_STAMP DEFAULT CURRENT_TIMESTAMP);\\012CREATE TABLE DATA_SET_TYPE_PROPERTY_TYPES (ID TECH_ID NOT NULL,DSTY_ID TECH_ID NOT NULL,PRTY_ID TECH_ID NOT NULL,IS_MANDATORY BOOLEAN_CHAR NOT NULL DEFAULT 'F',IS_MANAGED_INTERNALLY BOOLEAN_CHAR NOT NULL DEFAULT 'F',PERS_ID_REGISTERER TECH_ID NOT NULL,REGISTRATION_TIMESTAMP TIME_STAMP_DFL NOT NULL DEFAULT CURRENT_TIMESTAMP);\\012\\012CREATE SEQUENCE DATA_SET_PROPERTY_ID_SEQ;\\012CREATE SEQUENCE DSTPT_ID_SEQ;\\012\\012ALTER TABLE DATA_SET_TYPE_PROPERTY_TYPES ADD CONSTRAINT DSTPT_PK PRIMARY KEY(ID);\\012ALTER TABLE DATA_SET_PROPERTIES ADD CONSTRAINT DSPR_PK PRIMARY KEY(ID);\\012\\012ALTER TABLE DATA_SET_TYPE_PROPERTY_TYPES ADD CONSTRAINT DSTPT_BK_UK UNIQUE(DSTY_ID,PRTY_ID);\\012ALTER TABLE DATA_SET_PROPERTIES ADD CONSTRAINT DSPR_BK_UK UNIQUE(DS_ID,DSTPT_ID);\\012\\012\\012ALTER TABLE DATA_SET_TYPE_PROPERTY_TYPES ADD CONSTRAINT DSTPT_DSTY_FK FOREIGN KEY (DSTY_ID) REFERENCES DATA_SET_TYPES(ID);\\012ALTER TABLE DATA_SET_TYPE_PROPERTY_TYPES ADD CONSTRAINT DSTPT_PERS_FK FOREIGN KEY (PERS_ID_REGISTERER) REFERENCES PERSONS(ID);\\012ALTER TABLE DATA_SET_TYPE_PROPERTY_TYPES ADD CONSTRAINT DSTPT_PRTY_FK FOREIGN KEY (PRTY_ID) REFERENCES PROPERTY_TYPES(ID);\\012ALTER TABLE DATA_SET_PROPERTIES ADD CONSTRAINT DSPR_CVTE_FK FOREIGN KEY (CVTE_ID) REFERENCES CONTROLLED_VOCABULARY_TERMS(ID);\\012ALTER TABLE DATA_SET_PROPERTIES ADD CONSTRAINT DSPR_DSTPT_FK FOREIGN KEY (DSTPT_ID) REFERENCES DATA_SET_TYPE_PROPERTY_TYPES(ID) ON DELETE CASCADE;\\012ALTER TABLE DATA_SET_PROPERTIES ADD CONSTRAINT DSPR_DS_FK FOREIGN KEY (DS_ID) REFERENCES DATA(ID);\\012ALTER TABLE DATA_SET_PROPERTIES ADD CONSTRAINT DSPR_PERS_FK FOREIGN KEY (PERS_ID_REGISTERER) REFERENCES PERSONS(ID);\\012ALTER TABLE DATA_SET_PROPERTIES ADD CONSTRAINT DSPR_MAPR_FK FOREIGN KEY (MATE_PROP_ID) REFERENCES MATERIALS(ID);\\012\\012ALTER TABLE DATA_SET_PROPERTIES ADD CONSTRAINT DSPR_CK CHECK \\012\\011((VALUE IS NOT NULL AND CVTE_ID IS NULL AND MATE_PROP_ID IS NULL) OR \\012\\011 (VALUE IS NULL AND CVTE_ID IS NOT NULL AND MATE_PROP_ID IS NULL) OR\\012\\011 (VALUE IS NULL AND CVTE_ID IS NULL AND MATE_PROP_ID IS NOT NULL)\\012\\011);\\012\\012CREATE INDEX DSPR_CVTE_FK_I ON DATA_SET_PROPERTIES (CVTE_ID);\\012CREATE INDEX DSPR_DSTPT_FK_I ON DATA_SET_PROPERTIES (DSTPT_ID);\\012CREATE INDEX DSPR_DS_FK_I ON DATA_SET_PROPERTIES (DS_ID);\\012CREATE INDEX DSPR_PERS_FK_I ON DATA_SET_PROPERTIES (PERS_ID_REGISTERER);\\012CREATE INDEX DSTPT_DSTY_FK_I ON DATA_SET_TYPE_PROPERTY_TYPES (DSTY_ID);\\012CREATE INDEX DSTPT_PERS_FK_I ON DATA_SET_TYPE_PROPERTY_TYPES (PERS_ID_REGISTERER);\\012CREATE INDEX DSTPT_PRTY_FK_I ON DATA_SET_TYPE_PROPERTY_TYPES (PRTY_ID);\\012\\012CREATE OR REPLACE FUNCTION DATA_SET_PROPERTY_WITH_MATERIAL_DATA_TYPE_CHECK() RETURNS trigger AS $$\\012DECLARE\\012   v_type_id  CODE;\\012   v_type_id_prop  CODE;\\012BEGIN\\012   if NEW.mate_prop_id IS NOT NULL then\\012\\011\\011\\011-- find material type id of the property type \\012\\011\\011\\011select pt.maty_prop_id into v_type_id_prop \\012\\011\\011\\011  from data_set_type_property_types dstpt, property_types pt \\012\\011\\011\\011 where NEW.dstpt_id = dstpt.id AND dstpt.prty_id = pt.id;\\012\\011\\011\\012\\011\\011\\011if v_type_id_prop IS NOT NULL then\\012\\011\\011\\011\\011-- find material type id of the material which consists the entity's property value\\012\\011\\011\\011\\011select entity.maty_id into v_type_id \\012\\011\\011\\011\\011  from materials entity\\012\\011\\011\\011\\011 where NEW.mate_prop_id = entity.id;\\012\\011\\011\\011\\011if v_type_id != v_type_id_prop then\\012\\011\\011\\011\\011\\011RAISE EXCEPTION 'Insert/Update of property value referencing material (id: %) failed, as referenced material type is different than expected (id %, expected id: %).', \\012\\011\\011\\011\\011\\011\\011\\011\\011\\011\\011\\011\\011 NEW.mate_prop_id, v_type_id, v_type_id_prop;\\012\\011\\011\\011\\011end if;\\012\\011\\011\\011end if;\\012   end if;\\012   RETURN NEW;\\012END;\\012$$ LANGUAGE 'plpgsql';\\012\\012CREATE TRIGGER DATA_SET_PROPERTY_WITH_MATERIAL_DATA_TYPE_CHECK BEFORE INSERT OR UPDATE ON data_set_properties\\012    FOR EACH ROW EXECUTE PROCEDURE DATA_SET_PROPERTY_WITH_MATERIAL_DATA_TYPE_CHECK();   \\012	\N
+./sourceTest/sql/postgresql/033/013=database_version_logs.tsv:032	source/sql/postgresql/migration/migration-031-032.sql	SUCCESS	2009-04-09 09:36:36.20	-- -------\\012-- Modify MATERIAL_BATCHES\\012-- -------\\012\\012ALTER TABLE material_batches\\012    DROP COLUMN proc_id;\\012\\012-- -------\\012-- Modify SAMPLES\\012-- -------\\012\\012ALTER TABLE samples\\012    ADD COLUMN expe_id tech_id;\\012\\012ALTER TABLE samples\\012    ADD CONSTRAINT samp_expe_fk FOREIGN KEY (expe_id) REFERENCES experiments(id);\\012\\012CREATE INDEX samp_expe_fk_i ON samples USING btree (expe_id);\\012\\012-- relink samples directly to experiments\\012\\012UPDATE samples\\012SET expe_id = (SELECT e.id FROM experiments e, procedures p, sample_inputs si \\012               WHERE si.samp_id = samples.id AND si.proc_id = p.id AND p.expe_id = e.id AND e.inva_id IS NULL);\\012\\012\\012-- -------\\012-- Modify DATA\\012-- -------\\012\\012ALTER TABLE data\\012    ADD COLUMN expe_id tech_id;\\012\\012ALTER TABLE data\\012    ADD CONSTRAINT data_expe_fk FOREIGN KEY (expe_id) REFERENCES experiments(id);\\012\\012CREATE INDEX data_expe_fk_i ON data USING btree (expe_id);\\012\\012UPDATE data\\012SET expe_id = (SELECT e.id FROM experiments e, procedures p \\012               WHERE data.proc_id_produced_by = p.id AND p.expe_id = e.id);\\012\\012ALTER TABLE data\\012    ALTER COLUMN expe_id SET NOT NULL;\\012\\012ALTER TABLE data\\012    DROP COLUMN proc_id_produced_by;\\012\\012-- -------\\012-- Drop PROCEDURES, PROCEDURE_TYPES, and SAMPLE_INPUTS\\012-- -------\\012\\012DROP TABLE sample_inputs;\\012DROP TABLE procedures;\\012DROP TABLE procedure_types;\\012\\012DROP SEQUENCE procedure_id_seq;\\012DROP SEQUENCE procedure_type_id_seq;\\012\\012-- -------\\012-- Add CODE_SEQ\\012-- -------\\012\\012CREATE SEQUENCE CODE_SEQ;\\012\\012-- -------\\012-- Add new columns to DATA_STORES\\012-- -------\\012\\012ALTER TABLE data_stores\\012    ADD COLUMN remote_url character varying(250),\\012    ADD COLUMN session_token character varying(50),\\012    ADD COLUMN modification_timestamp time_stamp DEFAULT now();\\012\\012UPDATE data_stores\\012SET remote_url = '', session_token='';\\012\\012ALTER TABLE data_stores\\012    ALTER COLUMN remote_url SET NOT NULL,\\012    ALTER COLUMN session_token SET NOT NULL;\\012\\012-- -------\\012-- Drop foreign keys onto DATA_STORES\\012-- -------\\012\\012ALTER TABLE database_instances\\012    DROP COLUMN dast_id;\\012\\012ALTER TABLE groups\\012    DROP COLUMN dast_id;\\012\\012ALTER TABLE projects\\012    DROP COLUMN dast_id;\\012\\012ALTER TABLE experiments\\012    DROP COLUMN dast_id;\\012\\012-- -------\\012-- Add foreign key from DATA onto DATA_STORES\\012-- -------\\012\\012ALTER TABLE data\\012    ADD COLUMN dast_id tech_id;\\012\\012ALTER TABLE data\\012    ADD CONSTRAINT data_dast_fk FOREIGN KEY (dast_id) REFERENCES data_stores(id);\\012\\012UPDATE data\\012SET dast_id = (select id from data_stores where code = 'STANDARD');\\012\\012ALTER TABLE data\\012    ALTER COLUMN dast_id SET NOT NULL;\\012\\012\\012------------------------------------------------------------------------------------\\012--  Purpose:  Replace trigger SAMPLE_CODE_UNIQUENESS_CHECK \\012------------------------------------------------------------------------------------\\012\\012CREATE OR REPLACE FUNCTION SAMPLE_CODE_UNIQUENESS_CHECK() RETURNS trigger AS $$\\012DECLARE\\012   counter  INTEGER;\\012BEGIN\\012    LOCK TABLE samples IN EXCLUSIVE MODE;\\012    IF (NEW.samp_id_part_of is NULL) THEN\\012        IF (NEW.dbin_id is not NULL) THEN\\012            SELECT count(*) into counter FROM samples \\012                where id != NEW.id and code = NEW.code and samp_id_part_of is NULL and dbin_id = NEW.dbin_id;\\012            IF (counter > 0) THEN\\012                RAISE EXCEPTION 'Insert/Update of Sample (Code: %) failed because database instance sample with the same code already exists.', NEW.code;\\012            END IF;\\012        ELSIF (NEW.grou_id is not NULL) THEN\\012            SELECT count(*) into counter FROM samples \\012                where id != NEW.id and code = NEW.code and samp_id_part_of is NULL and grou_id = NEW.grou_id;\\012            IF (counter > 0) THEN\\012                RAISE EXCEPTION 'Insert/Update of Sample (Code: %) failed because group sample with the same code already exists.', NEW.code;\\012            END IF;\\012        END IF;\\012        ELSE\\012        IF (NEW.dbin_id is not NULL) THEN\\012            SELECT count(*) into counter FROM samples \\012                where id != NEW.id and code = NEW.code and samp_id_part_of = NEW.samp_id_part_of and dbin_id = NEW.dbin_id;\\012            IF (counter > 0) THEN\\012                RAISE EXCEPTION 'Insert/Update of Sample (Code: %) failed because database instance sample with the same code and being the part of the same parent already exists.', NEW.code;\\012            END IF;\\012        ELSIF (NEW.grou_id is not NULL) THEN\\012            SELECT count(*) into counter FROM samples \\012                where id != NEW.id and code = NEW.code and samp_id_part_of = NEW.samp_id_part_of and grou_id = NEW.grou_id;\\012            IF (counter > 0) THEN\\012                RAISE EXCEPTION 'Insert/Update of Sample (Code: %) failed because group sample with the same code and being the part of the same parent already exists.', NEW.code;\\012            END IF;\\012        END IF;\\012        END IF;   \\012   RETURN NEW;\\012END;\\012$$ LANGUAGE 'plpgsql';\\012\\012\\012\\012	\N
+./sourceTest/sql/postgresql/033/schema-033.sql:    LANGUAGE plpgsql;
+./sourceTest/sql/postgresql/033/schema-033.sql:    LANGUAGE plpgsql;
+./sourceTest/sql/postgresql/033/schema-033.sql:    LANGUAGE plpgsql;
+./sourceTest/sql/postgresql/033/schema-033.sql:    LANGUAGE plpgsql;
+./sourceTest/sql/postgresql/033/schema-033.sql:    LANGUAGE plpgsql;
+./sourceTest/sql/postgresql/033/schema-033.sql:    LANGUAGE plpgsql;
+./sourceTest/sql/postgresql/033/schema-033.sql:    LANGUAGE plpgsql;
+./sourceTest/sql/postgresql/033/schema-033.sql:    LANGUAGE plpgsql;
+./sourceTest/sql/postgresql/034/.svn/text-base/013=database_version_logs.tsv.svn-base:027	D:\\User\\felmer\\dev-workspace\\openbis/source/sql/postgresql/027/function-027.sql	SUCCESS	2008-11-05 09:18:00.403	-- Creating Functions\\012\\012------------------------------------------------------------------------------------\\012--  Purpose:  Create function RENAME_SEQUENCE() that is required for renaming the sequences belonging to tables\\012------------------------------------------------------------------------------------\\012CREATE FUNCTION RENAME_SEQUENCE(OLD_NAME VARCHAR, NEW_NAME VARCHAR) RETURNS INTEGER AS $$\\012DECLARE\\012  CURR_SEQ_VAL   INTEGER;\\012BEGIN\\012  SELECT INTO CURR_SEQ_VAL NEXTVAL(OLD_NAME);\\012  EXECUTE 'CREATE SEQUENCE ' || NEW_NAME || ' START WITH ' || CURR_SEQ_VAL;\\012  EXECUTE 'DROP SEQUENCE ' || OLD_NAME;\\012  RETURN CURR_SEQ_VAL;\\012END;\\012$$ LANGUAGE 'plpgsql';\\012\\012\\012------------------------------------------------------------------------------------\\012--  Purpose:  Create trigger CONTROLLED_VOCABULARY_CHECK \\012------------------------------------------------------------------------------------\\012\\012CREATE OR REPLACE FUNCTION CONTROLLED_VOCABULARY_CHECK() RETURNS trigger AS $$\\012DECLARE\\012   v_code  CODE;\\012BEGIN\\012\\012   select code into v_code from data_types where id = NEW.daty_id;\\012\\012   -- Check if the data is of type "CONTROLLEDVOCABULARY"\\012   if v_code = 'CONTROLLEDVOCABULARY' then\\012      if NEW.covo_id IS NULL then\\012         RAISE EXCEPTION 'Insert/Update of Property Type (Code: %) failed, as its Data Type is CONTROLLEDVOCABULARY, but it is not linked to a Controlled Vocabulary.', NEW.code;\\012      end if;\\012   end if;\\012\\012   RETURN NEW;\\012\\012END;\\012$$ LANGUAGE 'plpgsql';\\012\\012CREATE TRIGGER CONTROLLED_VOCABULARY_CHECK BEFORE INSERT OR UPDATE ON PROPERTY_TYPES\\012    FOR EACH ROW EXECUTE PROCEDURE CONTROLLED_VOCABULARY_CHECK();\\012\\012\\012------------------------------------------------------------------------------------\\012--  Purpose:  Create trigger EXTERNAL_DATA_STORAGE_FORMAT_CHECK \\012------------------------------------------------------------------------------------\\012\\012CREATE OR REPLACE FUNCTION EXTERNAL_DATA_STORAGE_FORMAT_CHECK() RETURNS trigger AS $$\\012DECLARE\\012   v_covo_code  CODE;\\012   data_code CODE;\\012BEGIN\\012\\012   select code into v_covo_code from controlled_vocabularies\\012      where is_internal_namespace = true and \\012         id = (select covo_id from controlled_vocabulary_terms where id = NEW.cvte_id_stor_fmt);\\012   -- Check if the data storage format is a term of the controlled vocabulary "STORAGE_FORMAT"\\012   if v_covo_code != 'STORAGE_FORMAT' then\\012      select code into data_code from data where id = NEW.data_id; \\012      RAISE EXCEPTION 'Insert/Update of Data (Code: %) failed, as its Storage Format is %, but is required to be STORAGE_FORMAT.', data_code, v_covo_code;\\012   end if;\\012\\012   RETURN NEW;\\012\\012END;\\012$$ LANGUAGE 'plpgsql';\\012\\012CREATE TRIGGER EXTERNAL_DATA_STORAGE_FORMAT_CHECK BEFORE INSERT OR UPDATE ON EXTERNAL_DATA\\012    FOR EACH ROW EXECUTE PROCEDURE EXTERNAL_DATA_STORAGE_FORMAT_CHECK();\\012\\012------------------------------------------------------------------------------------\\012--  Purpose:  Create trigger SAMPLE_CODE_UNIQUENESS_CHECK \\012------------------------------------------------------------------------------------\\012\\012CREATE OR REPLACE FUNCTION SAMPLE_CODE_UNIQUENESS_CHECK() RETURNS trigger AS $$\\012DECLARE\\012   counter  INTEGER;\\012BEGIN\\012\\011IF (NEW.samp_id_part_of is NULL) THEN\\012\\011\\011IF (NEW.dbin_id is not NULL) THEN\\012\\011\\011\\011SELECT count(*) into counter FROM samples \\012\\011\\011\\011\\011where id != NEW.id and code = NEW.code and samp_id_part_of is NULL and dbin_id = NEW.dbin_id;\\012\\011\\011\\011IF (counter > 0) THEN\\012\\011\\011\\011\\011RAISE EXCEPTION 'Insert/Update of Sample (Code: %) failed because database instance sample with the same code already exists.', NEW.code;\\012\\011\\011\\011END IF;\\012\\011\\011ELSIF (NEW.grou_id is not NULL) THEN\\012\\011\\011\\011SELECT count(*) into counter FROM samples \\012\\011\\011\\011\\011where id != NEW.id and code = NEW.code and samp_id_part_of is NULL and grou_id = NEW.grou_id;\\012\\011\\011\\011IF (counter > 0) THEN\\012\\011\\011\\011\\011RAISE EXCEPTION 'Insert/Update of Sample (Code: %) failed because group sample with the same code already exists.', NEW.code;\\012\\011\\011\\011END IF;\\012\\011\\011END IF;\\012        ELSE\\012\\011\\011IF (NEW.dbin_id is not NULL) THEN\\012\\011\\011\\011SELECT count(*) into counter FROM samples \\012\\011\\011\\011\\011where id != NEW.id and code = NEW.code and samp_id_part_of = NEW.samp_id_part_of and dbin_id = NEW.dbin_id;\\012\\011\\011\\011IF (counter > 0) THEN\\012\\011\\011\\011\\011RAISE EXCEPTION 'Insert/Update of Sample (Code: %) failed because database instance sample with the same code and being the part of the same parent already exists.', NEW.code;\\012\\011\\011\\011END IF;\\012\\011\\011ELSIF (NEW.grou_id is not NULL) THEN\\012\\011\\011\\011SELECT count(*) into counter FROM samples \\012\\011\\011\\011\\011where id != NEW.id and code = NEW.code and samp_id_part_of = NEW.samp_id_part_of and grou_id = NEW.grou_id;\\012\\011\\011\\011IF (counter > 0) THEN\\012\\011\\011\\011\\011RAISE EXCEPTION 'Insert/Update of Sample (Code: %) failed because group sample with the same code and being the part of the same parent already exists.', NEW.code;\\012\\011\\011\\011END IF;\\012\\011\\011END IF;\\012        END IF;   \\012   RETURN NEW;\\012END;\\012$$ LANGUAGE 'plpgsql';\\012\\012CREATE TRIGGER SAMPLE_CODE_UNIQUENESS_CHECK BEFORE INSERT OR UPDATE ON SAMPLES\\012    FOR EACH ROW EXECUTE PROCEDURE SAMPLE_CODE_UNIQUENESS_CHECK();\\012	\N
+./sourceTest/sql/postgresql/034/.svn/text-base/013=database_version_logs.tsv.svn-base:028	source/sql/postgresql/migration/migration-027-028.sql	SUCCESS	2008-11-18 13:24:17.508	-- Create EXPERIMENT_ATTACHMENT_CONTENTS.\\012CREATE TABLE EXPERIMENT_ATTACHMENT_CONTENTS (ID TECH_ID NOT NULL,VALUE FILE NOT NULL);\\012CREATE SEQUENCE EXPERIMENT_ATTACHMENT_CONTENT_ID_SEQ;\\012ALTER TABLE EXPERIMENT_ATTACHMENT_CONTENTS ADD CONSTRAINT EXAC_PK PRIMARY KEY(ID);\\012\\012-- Alter EXPERIMENT_ATTACHMENTS by adding the new column which has a NULL constraint.\\012-- The NOT NULL constraint is added later on.\\012ALTER TABLE EXPERIMENT_ATTACHMENTS ADD COLUMN EXAC_ID TECH_ID;\\012\\012-- Does the VALUE migration between EXPERIMENT_ATTACHMENTS to EXPERIMENT_ATTACHMENT_CONTENTS.\\012CREATE OR REPLACE FUNCTION move_exp_att_content() RETURNS integer AS $$\\012DECLARE\\012    rec RECORD;\\012    seq BIGINT;\\012BEGIN\\012  FOR rec IN SELECT id, value FROM EXPERIMENT_ATTACHMENTS LOOP\\012  \\011seq := nextval('EXPERIMENT_ATTACHMENT_CONTENT_ID_SEQ');\\012    INSERT INTO EXPERIMENT_ATTACHMENT_CONTENTS (id, value) VALUES (seq, rec.value);\\012    UPDATE EXPERIMENT_ATTACHMENTS SET exac_id = seq WHERE id = rec.id;\\012  END LOOP;\\012  RETURN 1;\\012END;\\012$$ LANGUAGE 'plpgsql';\\012\\012-- Call the function.\\012SELECT move_exp_att_content();\\012DROP FUNCTION move_exp_att_content();\\012\\012\\012-- Finish EXPERIMENT_ATTACHMENTS changes.\\012ALTER TABLE EXPERIMENT_ATTACHMENTS ADD CONSTRAINT EXAT_CONT_FK FOREIGN KEY (EXAC_ID) REFERENCES EXPERIMENT_ATTACHMENT_CONTENTS(ID);\\012ALTER TABLE EXPERIMENT_ATTACHMENTS DROP COLUMN VALUE;\\012ALTER TABLE EXPERIMENT_ATTACHMENTS ALTER COLUMN EXAC_ID SET NOT NULL;\\012	\N
+./sourceTest/sql/postgresql/034/.svn/text-base/013=database_version_logs.tsv.svn-base:029	source/sql/postgresql/migration/migration-028-029.sql	SUCCESS	2009-03-18 10:50:20.105	-- -------\\012-- add modification_timestamp field to allow edition with Hibernate\\012-- -------\\012\\012ALTER TABLE samples\\012\\011ADD COLUMN modification_timestamp TIME_STAMP DEFAULT CURRENT_TIMESTAMP;\\012\\012ALTER TABLE experiments\\012\\011ADD COLUMN modification_timestamp TIME_STAMP DEFAULT CURRENT_TIMESTAMP;\\012\\012ALTER TABLE materials\\012\\011ADD COLUMN modification_timestamp TIME_STAMP DEFAULT CURRENT_TIMESTAMP;\\012\\012ALTER TABLE experiment_properties\\012\\011ADD COLUMN modification_timestamp TIME_STAMP DEFAULT CURRENT_TIMESTAMP;\\012\\012ALTER TABLE material_properties\\012\\011ADD COLUMN modification_timestamp TIME_STAMP DEFAULT CURRENT_TIMESTAMP;\\012\\012ALTER TABLE sample_properties\\012\\011ADD COLUMN modification_timestamp TIME_STAMP DEFAULT CURRENT_TIMESTAMP;\\012\\012-- -------\\012-- add property data type which references materials\\012-- -------\\012\\012ALTER TABLE property_types\\012\\011ADD COLUMN maty_prop_id tech_id;\\012\\012ALTER TABLE property_types\\012\\011ADD CONSTRAINT prty_maty_fk FOREIGN KEY (maty_prop_id) REFERENCES material_types(id);\\012\\012ALTER TABLE experiment_properties\\012\\011ADD COLUMN mate_prop_id tech_id;\\012\\012ALTER TABLE material_properties\\012\\011ADD COLUMN mate_prop_id tech_id;\\012\\012ALTER TABLE sample_properties\\012\\011ADD COLUMN mate_prop_id tech_id;\\012\\012ALTER TABLE experiment_properties\\012\\011ADD CONSTRAINT expr_mapr_fk FOREIGN KEY (mate_prop_id) REFERENCES materials(id);\\012\\012ALTER TABLE material_properties\\012\\011ADD CONSTRAINT mapr_mapr_fk FOREIGN KEY (mate_prop_id) REFERENCES materials(id);\\012\\012ALTER TABLE sample_properties\\012\\011ADD CONSTRAINT sapr_mapr_fk FOREIGN KEY (mate_prop_id) REFERENCES materials(id);\\012\\012insert into data_types\\012(id\\012 ,code\\012 ,description)\\012 values \\012 (nextval('DATA_TYPE_ID_SEQ')\\012 ,'MATERIAL'\\012 ,'Reference to a material'\\012);\\012\\012ALTER TABLE MATERIAL_PROPERTIES DROP CONSTRAINT MAPR_CK;\\012ALTER TABLE MATERIAL_PROPERTIES ADD CONSTRAINT MAPR_CK CHECK \\012\\011((VALUE IS NOT NULL AND CVTE_ID IS NULL AND MATE_PROP_ID IS NULL) OR \\012\\011 (VALUE IS NULL AND CVTE_ID IS NOT NULL AND MATE_PROP_ID IS NULL) OR\\012\\011 (VALUE IS NULL AND CVTE_ID IS NULL AND MATE_PROP_ID IS NOT NULL)\\012\\011);\\012\\012ALTER TABLE EXPERIMENT_PROPERTIES DROP CONSTRAINT EXPR_CK;\\012ALTER TABLE EXPERIMENT_PROPERTIES ADD CONSTRAINT EXPR_CK CHECK \\012\\011((VALUE IS NOT NULL AND CVTE_ID IS NULL AND MATE_PROP_ID IS NULL) OR \\012\\011 (VALUE IS NULL AND CVTE_ID IS NOT NULL AND MATE_PROP_ID IS NULL) OR\\012\\011 (VALUE IS NULL AND CVTE_ID IS NULL AND MATE_PROP_ID IS NOT NULL)\\012\\011);\\012\\012ALTER TABLE SAMPLE_PROPERTIES DROP CONSTRAINT SAPR_CK;\\012ALTER TABLE SAMPLE_PROPERTIES ADD CONSTRAINT SAPR_CK CHECK \\012\\011((VALUE IS NOT NULL AND CVTE_ID IS NULL AND MATE_PROP_ID IS NULL) OR \\012\\011 (VALUE IS NULL AND CVTE_ID IS NOT NULL AND MATE_PROP_ID IS NULL) OR\\012\\011 (VALUE IS NULL AND CVTE_ID IS NULL AND MATE_PROP_ID IS NOT NULL)\\012\\011);\\012\\012------------------------------------------------------------------------------------\\012--  Purpose:  Create trigger MATERIAL/SAMPLE/EXPERIMENT _PROPERTY_WITH_MATERIAL_DATA_TYPE_CHECK\\012--            It checks that if material property value is assigned to the entity,\\012--\\011\\011\\011\\011\\011\\011then the material type is equal to the one described by property type.\\012------------------------------------------------------------------------------------\\012\\012CREATE OR REPLACE FUNCTION MATERIAL_PROPERTY_WITH_MATERIAL_DATA_TYPE_CHECK() RETURNS trigger AS $$\\012DECLARE\\012   v_type_id  CODE;\\012   v_type_id_prop  CODE;\\012BEGIN\\012   if NEW.mate_prop_id IS NOT NULL then\\012\\011\\011\\011-- find material type id of the property type \\012\\011\\011\\011select pt.maty_prop_id into v_type_id_prop \\012\\011\\011\\011  from material_type_property_types etpt, property_types pt \\012\\011\\011\\011 where NEW.mtpt_id = etpt.id AND etpt.prty_id = pt.id;\\012\\011\\011\\012\\011\\011\\011if v_type_id_prop IS NOT NULL then\\012\\011\\011\\011\\011-- find material type id of the material which consists the entity's property value\\012\\011\\011\\011\\011select entity.maty_id into v_type_id \\012\\011\\011\\011\\011  from materials entity\\012\\011\\011\\011\\011 where NEW.mate_prop_id = entity.id;\\012\\011\\011\\011\\011if v_type_id != v_type_id_prop then\\012\\011\\011\\011\\011\\011RAISE EXCEPTION 'Insert/Update of property value referencing material (id: %) failed, as referenced material type is different than expected (id %, expected id: %).', \\012\\011\\011\\011\\011\\011\\011\\011 NEW.mate_prop_id, v_type_id, v_type_id_prop;\\012\\011\\011\\011\\011end if;\\012\\011\\011\\011end if;\\012   end if;\\012   RETURN NEW;\\012END;\\012$$ LANGUAGE 'plpgsql';\\012\\012CREATE TRIGGER MATERIAL_PROPERTY_WITH_MATERIAL_DATA_TYPE_CHECK BEFORE INSERT OR UPDATE ON material_properties\\012    FOR EACH ROW EXECUTE PROCEDURE MATERIAL_PROPERTY_WITH_MATERIAL_DATA_TYPE_CHECK();\\012    \\012CREATE OR REPLACE FUNCTION SAMPLE_PROPERTY_WITH_MATERIAL_DATA_TYPE_CHECK() RETURNS trigger AS $$\\012DECLARE\\012   v_type_id  CODE;\\012   v_type_id_prop  CODE;\\012BEGIN\\012   if NEW.mate_prop_id IS NOT NULL then\\012\\011\\011\\011-- find material type id of the property type \\012\\011\\011\\011select pt.maty_prop_id into v_type_id_prop \\012\\011\\011\\011  from sample_type_property_types etpt, property_types pt \\012\\011\\011\\011 where NEW.stpt_id = etpt.id AND etpt.prty_id = pt.id;\\012\\011\\011\\012\\011\\011\\011if v_type_id_prop IS NOT NULL then\\012\\011\\011\\011\\011-- find material type id of the material which consists the entity's property value\\012\\011\\011\\011\\011select entity.maty_id into v_type_id \\012\\011\\011\\011\\011  from materials entity\\012\\011\\011\\011\\011 where NEW.mate_prop_id = entity.id;\\012\\011\\011\\011\\011if v_type_id != v_type_id_prop then\\012\\011\\011\\011\\011\\011RAISE EXCEPTION 'Insert/Update of property value referencing material (id: %) failed, as referenced material type is different than expected (id %, expected id: %).', \\012\\011\\011\\011\\011\\011\\011\\011\\011\\011\\011\\011\\011 NEW.mate_prop_id, v_type_id, v_type_id_prop;\\012\\011\\011\\011\\011end if;\\012\\011\\011\\011end if;\\012   end if;\\012   RETURN NEW;\\012END;\\012$$ LANGUAGE 'plpgsql';\\012\\012CREATE TRIGGER SAMPLE_PROPERTY_WITH_MATERIAL_DATA_TYPE_CHECK BEFORE INSERT OR UPDATE ON sample_properties\\012    FOR EACH ROW EXECUTE PROCEDURE SAMPLE_PROPERTY_WITH_MATERIAL_DATA_TYPE_CHECK();\\012    \\012CREATE OR REPLACE FUNCTION EXPERIMENT_PROPERTY_WITH_MATERIAL_DATA_TYPE_CHECK() RETURNS trigger AS $$\\012DECLARE\\012   v_type_id  CODE;\\012   v_type_id_prop  CODE;\\012BEGIN\\012   if NEW.mate_prop_id IS NOT NULL then\\012\\011\\011\\011-- find material type id of the property type \\012\\011\\011\\011select pt.maty_prop_id into v_type_id_prop \\012\\011\\011\\011  from experiment_type_property_types etpt, property_types pt \\012\\011\\011\\011 where NEW.etpt_id = etpt.id AND etpt.prty_id = pt.id;\\012\\011\\011\\012\\011\\011\\011if v_type_id_prop IS NOT NULL then\\012\\011\\011\\011\\011-- find material type id of the material which consists the entity's property value\\012\\011\\011\\011\\011select entity.maty_id into v_type_id \\012\\011\\011\\011\\011  from materials entity\\012\\011\\011\\011\\011 where NEW.mate_prop_id = entity.id;\\012\\011\\011\\011\\011if v_type_id != v_type_id_prop then\\012\\011\\011\\011\\011\\011RAISE EXCEPTION 'Insert/Update of property value referencing material (id: %) failed, as referenced material type is different than expected (id %, expected id: %).', \\012\\011\\011\\011\\011\\011\\011\\011\\011\\011\\011\\011\\011 NEW.mate_prop_id, v_type_id, v_type_id_prop;\\012\\011\\011\\011\\011end if;\\012\\011\\011\\011end if;\\012   end if;\\012   RETURN NEW;\\012END;\\012$$ LANGUAGE 'plpgsql';\\012\\012CREATE TRIGGER EXPERIMENT_PROPERTY_WITH_MATERIAL_DATA_TYPE_CHECK BEFORE INSERT OR UPDATE ON experiment_properties\\012    FOR EACH ROW EXECUTE PROCEDURE EXPERIMENT_PROPERTY_WITH_MATERIAL_DATA_TYPE_CHECK();\\012       \\012-- -------\\012-- remove the reminescents of the OBSERVABLE_TYPE\\012-- -------\\012\\012ALTER TABLE data\\012\\011DROP CONSTRAINT data_obty_fk;\\012\\012ALTER TABLE data_set_types\\012\\011DROP CONSTRAINT obty_pk;\\012\\012ALTER TABLE data_set_types\\012\\011ADD CONSTRAINT dsty_pk PRIMARY KEY (id);\\012\\012ALTER TABLE data\\012\\011ADD CONSTRAINT data_dsty_fk FOREIGN KEY (dsty_id) REFERENCES data_set_types(id);\\012\\012ALTER TABLE data_set_types\\012\\011DROP CONSTRAINT obty_bk_uk;\\012\\012ALTER TABLE data_set_types\\012\\011DROP CONSTRAINT obty_dbin_fk;\\012\\012ALTER TABLE data_set_types\\012\\011ADD CONSTRAINT dsty_bk_uk UNIQUE (code, dbin_id);\\012\\012ALTER TABLE data_set_types\\012\\011ADD CONSTRAINT dsty_dbin_fk FOREIGN KEY (dbin_id) REFERENCES database_instances(id);\\012\\012DROP INDEX data_obty_fk_i;\\012\\012CREATE INDEX data_dsty_fk_i ON data(dsty_id);\\012	\N
+./sourceTest/sql/postgresql/034/.svn/text-base/013=database_version_logs.tsv.svn-base:030	source/sql/postgresql/migration/migration-029-030.sql	SUCCESS	2009-03-23 15:34:44.72	-- -------\\012-- add modification_timestamp field to allow edition with Hibernate\\012-- -------\\012ALTER TABLE data\\012\\011ADD COLUMN modification_timestamp TIME_STAMP DEFAULT CURRENT_TIMESTAMP;\\012ALTER TABLE experiment_types\\012\\011ADD COLUMN modification_timestamp TIME_STAMP DEFAULT CURRENT_TIMESTAMP;\\012ALTER TABLE sample_types\\012\\011ADD COLUMN modification_timestamp TIME_STAMP DEFAULT CURRENT_TIMESTAMP;\\012ALTER TABLE material_types\\012\\011ADD COLUMN modification_timestamp TIME_STAMP DEFAULT CURRENT_TIMESTAMP;\\012ALTER TABLE data_set_types\\012\\011ADD COLUMN modification_timestamp TIME_STAMP DEFAULT CURRENT_TIMESTAMP;\\012ALTER TABLE controlled_vocabularies\\012\\011ADD COLUMN modification_timestamp TIME_STAMP DEFAULT CURRENT_TIMESTAMP;\\012-- -------\\012-- add properties to data sets\\012-- -------\\012CREATE TABLE DATA_SET_PROPERTIES (ID TECH_ID NOT NULL,DS_ID TECH_ID NOT NULL,DSTPT_ID TECH_ID NOT NULL,VALUE GENERIC_VALUE,CVTE_ID TECH_ID, MATE_PROP_ID TECH_ID, PERS_ID_REGISTERER TECH_ID NOT NULL,REGISTRATION_TIMESTAMP TIME_STAMP_DFL NOT NULL DEFAULT CURRENT_TIMESTAMP, MODIFICATION_TIMESTAMP TIME_STAMP DEFAULT CURRENT_TIMESTAMP);\\012CREATE TABLE DATA_SET_TYPE_PROPERTY_TYPES (ID TECH_ID NOT NULL,DSTY_ID TECH_ID NOT NULL,PRTY_ID TECH_ID NOT NULL,IS_MANDATORY BOOLEAN_CHAR NOT NULL DEFAULT 'F',IS_MANAGED_INTERNALLY BOOLEAN_CHAR NOT NULL DEFAULT 'F',PERS_ID_REGISTERER TECH_ID NOT NULL,REGISTRATION_TIMESTAMP TIME_STAMP_DFL NOT NULL DEFAULT CURRENT_TIMESTAMP);\\012\\012CREATE SEQUENCE DATA_SET_PROPERTY_ID_SEQ;\\012CREATE SEQUENCE DSTPT_ID_SEQ;\\012\\012ALTER TABLE DATA_SET_TYPE_PROPERTY_TYPES ADD CONSTRAINT DSTPT_PK PRIMARY KEY(ID);\\012ALTER TABLE DATA_SET_PROPERTIES ADD CONSTRAINT DSPR_PK PRIMARY KEY(ID);\\012\\012ALTER TABLE DATA_SET_TYPE_PROPERTY_TYPES ADD CONSTRAINT DSTPT_BK_UK UNIQUE(DSTY_ID,PRTY_ID);\\012ALTER TABLE DATA_SET_PROPERTIES ADD CONSTRAINT DSPR_BK_UK UNIQUE(DS_ID,DSTPT_ID);\\012\\012\\012ALTER TABLE DATA_SET_TYPE_PROPERTY_TYPES ADD CONSTRAINT DSTPT_DSTY_FK FOREIGN KEY (DSTY_ID) REFERENCES DATA_SET_TYPES(ID);\\012ALTER TABLE DATA_SET_TYPE_PROPERTY_TYPES ADD CONSTRAINT DSTPT_PERS_FK FOREIGN KEY (PERS_ID_REGISTERER) REFERENCES PERSONS(ID);\\012ALTER TABLE DATA_SET_TYPE_PROPERTY_TYPES ADD CONSTRAINT DSTPT_PRTY_FK FOREIGN KEY (PRTY_ID) REFERENCES PROPERTY_TYPES(ID);\\012ALTER TABLE DATA_SET_PROPERTIES ADD CONSTRAINT DSPR_CVTE_FK FOREIGN KEY (CVTE_ID) REFERENCES CONTROLLED_VOCABULARY_TERMS(ID);\\012ALTER TABLE DATA_SET_PROPERTIES ADD CONSTRAINT DSPR_DSTPT_FK FOREIGN KEY (DSTPT_ID) REFERENCES DATA_SET_TYPE_PROPERTY_TYPES(ID) ON DELETE CASCADE;\\012ALTER TABLE DATA_SET_PROPERTIES ADD CONSTRAINT DSPR_DS_FK FOREIGN KEY (DS_ID) REFERENCES DATA(ID);\\012ALTER TABLE DATA_SET_PROPERTIES ADD CONSTRAINT DSPR_PERS_FK FOREIGN KEY (PERS_ID_REGISTERER) REFERENCES PERSONS(ID);\\012ALTER TABLE DATA_SET_PROPERTIES ADD CONSTRAINT DSPR_MAPR_FK FOREIGN KEY (MATE_PROP_ID) REFERENCES MATERIALS(ID);\\012\\012ALTER TABLE DATA_SET_PROPERTIES ADD CONSTRAINT DSPR_CK CHECK \\012\\011((VALUE IS NOT NULL AND CVTE_ID IS NULL AND MATE_PROP_ID IS NULL) OR \\012\\011 (VALUE IS NULL AND CVTE_ID IS NOT NULL AND MATE_PROP_ID IS NULL) OR\\012\\011 (VALUE IS NULL AND CVTE_ID IS NULL AND MATE_PROP_ID IS NOT NULL)\\012\\011);\\012\\012CREATE INDEX DSPR_CVTE_FK_I ON DATA_SET_PROPERTIES (CVTE_ID);\\012CREATE INDEX DSPR_DSTPT_FK_I ON DATA_SET_PROPERTIES (DSTPT_ID);\\012CREATE INDEX DSPR_DS_FK_I ON DATA_SET_PROPERTIES (DS_ID);\\012CREATE INDEX DSPR_PERS_FK_I ON DATA_SET_PROPERTIES (PERS_ID_REGISTERER);\\012CREATE INDEX DSTPT_DSTY_FK_I ON DATA_SET_TYPE_PROPERTY_TYPES (DSTY_ID);\\012CREATE INDEX DSTPT_PERS_FK_I ON DATA_SET_TYPE_PROPERTY_TYPES (PERS_ID_REGISTERER);\\012CREATE INDEX DSTPT_PRTY_FK_I ON DATA_SET_TYPE_PROPERTY_TYPES (PRTY_ID);\\012\\012CREATE OR REPLACE FUNCTION DATA_SET_PROPERTY_WITH_MATERIAL_DATA_TYPE_CHECK() RETURNS trigger AS $$\\012DECLARE\\012   v_type_id  CODE;\\012   v_type_id_prop  CODE;\\012BEGIN\\012   if NEW.mate_prop_id IS NOT NULL then\\012\\011\\011\\011-- find material type id of the property type \\012\\011\\011\\011select pt.maty_prop_id into v_type_id_prop \\012\\011\\011\\011  from data_set_type_property_types dstpt, property_types pt \\012\\011\\011\\011 where NEW.dstpt_id = dstpt.id AND dstpt.prty_id = pt.id;\\012\\011\\011\\012\\011\\011\\011if v_type_id_prop IS NOT NULL then\\012\\011\\011\\011\\011-- find material type id of the material which consists the entity's property value\\012\\011\\011\\011\\011select entity.maty_id into v_type_id \\012\\011\\011\\011\\011  from materials entity\\012\\011\\011\\011\\011 where NEW.mate_prop_id = entity.id;\\012\\011\\011\\011\\011if v_type_id != v_type_id_prop then\\012\\011\\011\\011\\011\\011RAISE EXCEPTION 'Insert/Update of property value referencing material (id: %) failed, as referenced material type is different than expected (id %, expected id: %).', \\012\\011\\011\\011\\011\\011\\011\\011\\011\\011\\011\\011\\011 NEW.mate_prop_id, v_type_id, v_type_id_prop;\\012\\011\\011\\011\\011end if;\\012\\011\\011\\011end if;\\012   end if;\\012   RETURN NEW;\\012END;\\012$$ LANGUAGE 'plpgsql';\\012\\012CREATE TRIGGER DATA_SET_PROPERTY_WITH_MATERIAL_DATA_TYPE_CHECK BEFORE INSERT OR UPDATE ON data_set_properties\\012    FOR EACH ROW EXECUTE PROCEDURE DATA_SET_PROPERTY_WITH_MATERIAL_DATA_TYPE_CHECK();   \\012	\N
+./sourceTest/sql/postgresql/034/.svn/text-base/013=database_version_logs.tsv.svn-base:032	source/sql/postgresql/migration/migration-031-032.sql	SUCCESS	2009-04-09 09:36:36.20	-- -------\\012-- Modify MATERIAL_BATCHES\\012-- -------\\012\\012ALTER TABLE material_batches\\012    DROP COLUMN proc_id;\\012\\012-- -------\\012-- Modify SAMPLES\\012-- -------\\012\\012ALTER TABLE samples\\012    ADD COLUMN expe_id tech_id;\\012\\012ALTER TABLE samples\\012    ADD CONSTRAINT samp_expe_fk FOREIGN KEY (expe_id) REFERENCES experiments(id);\\012\\012CREATE INDEX samp_expe_fk_i ON samples USING btree (expe_id);\\012\\012-- relink samples directly to experiments\\012\\012UPDATE samples\\012SET expe_id = (SELECT e.id FROM experiments e, procedures p, sample_inputs si \\012               WHERE si.samp_id = samples.id AND si.proc_id = p.id AND p.expe_id = e.id AND e.inva_id IS NULL);\\012\\012\\012-- -------\\012-- Modify DATA\\012-- -------\\012\\012ALTER TABLE data\\012    ADD COLUMN expe_id tech_id;\\012\\012ALTER TABLE data\\012    ADD CONSTRAINT data_expe_fk FOREIGN KEY (expe_id) REFERENCES experiments(id);\\012\\012CREATE INDEX data_expe_fk_i ON data USING btree (expe_id);\\012\\012UPDATE data\\012SET expe_id = (SELECT e.id FROM experiments e, procedures p \\012               WHERE data.proc_id_produced_by = p.id AND p.expe_id = e.id);\\012\\012ALTER TABLE data\\012    ALTER COLUMN expe_id SET NOT NULL;\\012\\012ALTER TABLE data\\012    DROP COLUMN proc_id_produced_by;\\012\\012-- -------\\012-- Drop PROCEDURES, PROCEDURE_TYPES, and SAMPLE_INPUTS\\012-- -------\\012\\012DROP TABLE sample_inputs;\\012DROP TABLE procedures;\\012DROP TABLE procedure_types;\\012\\012DROP SEQUENCE procedure_id_seq;\\012DROP SEQUENCE procedure_type_id_seq;\\012\\012-- -------\\012-- Add CODE_SEQ\\012-- -------\\012\\012CREATE SEQUENCE CODE_SEQ;\\012\\012-- -------\\012-- Add new columns to DATA_STORES\\012-- -------\\012\\012ALTER TABLE data_stores\\012    ADD COLUMN remote_url character varying(250),\\012    ADD COLUMN session_token character varying(50),\\012    ADD COLUMN modification_timestamp time_stamp DEFAULT now();\\012\\012UPDATE data_stores\\012SET remote_url = '', session_token='';\\012\\012ALTER TABLE data_stores\\012    ALTER COLUMN remote_url SET NOT NULL,\\012    ALTER COLUMN session_token SET NOT NULL;\\012\\012-- -------\\012-- Drop foreign keys onto DATA_STORES\\012-- -------\\012\\012ALTER TABLE database_instances\\012    DROP COLUMN dast_id;\\012\\012ALTER TABLE groups\\012    DROP COLUMN dast_id;\\012\\012ALTER TABLE projects\\012    DROP COLUMN dast_id;\\012\\012ALTER TABLE experiments\\012    DROP COLUMN dast_id;\\012\\012-- -------\\012-- Add foreign key from DATA onto DATA_STORES\\012-- -------\\012\\012ALTER TABLE data\\012    ADD COLUMN dast_id tech_id;\\012\\012ALTER TABLE data\\012    ADD CONSTRAINT data_dast_fk FOREIGN KEY (dast_id) REFERENCES data_stores(id);\\012\\012UPDATE data\\012SET dast_id = (select id from data_stores where code = 'STANDARD');\\012\\012ALTER TABLE data\\012    ALTER COLUMN dast_id SET NOT NULL;\\012\\012\\012------------------------------------------------------------------------------------\\012--  Purpose:  Replace trigger SAMPLE_CODE_UNIQUENESS_CHECK \\012------------------------------------------------------------------------------------\\012\\012CREATE OR REPLACE FUNCTION SAMPLE_CODE_UNIQUENESS_CHECK() RETURNS trigger AS $$\\012DECLARE\\012   counter  INTEGER;\\012BEGIN\\012    LOCK TABLE samples IN EXCLUSIVE MODE;\\012    IF (NEW.samp_id_part_of is NULL) THEN\\012        IF (NEW.dbin_id is not NULL) THEN\\012            SELECT count(*) into counter FROM samples \\012                where id != NEW.id and code = NEW.code and samp_id_part_of is NULL and dbin_id = NEW.dbin_id;\\012            IF (counter > 0) THEN\\012                RAISE EXCEPTION 'Insert/Update of Sample (Code: %) failed because database instance sample with the same code already exists.', NEW.code;\\012            END IF;\\012        ELSIF (NEW.grou_id is not NULL) THEN\\012            SELECT count(*) into counter FROM samples \\012                where id != NEW.id and code = NEW.code and samp_id_part_of is NULL and grou_id = NEW.grou_id;\\012            IF (counter > 0) THEN\\012                RAISE EXCEPTION 'Insert/Update of Sample (Code: %) failed because group sample with the same code already exists.', NEW.code;\\012            END IF;\\012        END IF;\\012        ELSE\\012        IF (NEW.dbin_id is not NULL) THEN\\012            SELECT count(*) into counter FROM samples \\012                where id != NEW.id and code = NEW.code and samp_id_part_of = NEW.samp_id_part_of and dbin_id = NEW.dbin_id;\\012            IF (counter > 0) THEN\\012                RAISE EXCEPTION 'Insert/Update of Sample (Code: %) failed because database instance sample with the same code and being the part of the same parent already exists.', NEW.code;\\012            END IF;\\012        ELSIF (NEW.grou_id is not NULL) THEN\\012            SELECT count(*) into counter FROM samples \\012                where id != NEW.id and code = NEW.code and samp_id_part_of = NEW.samp_id_part_of and grou_id = NEW.grou_id;\\012            IF (counter > 0) THEN\\012                RAISE EXCEPTION 'Insert/Update of Sample (Code: %) failed because group sample with the same code and being the part of the same parent already exists.', NEW.code;\\012            END IF;\\012        END IF;\\012        END IF;   \\012   RETURN NEW;\\012END;\\012$$ LANGUAGE 'plpgsql';\\012\\012\\012\\012	\N
+./sourceTest/sql/postgresql/034/.svn/text-base/013=database_version_logs.tsv.svn-base:034	source/sql/postgresql/migration/migration-033-034.sql	SUCCESS	2009-05-26 08:32:49.935	------------------------------------------------------------------------------------\\012-- Create sequence for generating permanent identifiers starting with nextval of existing dataset sequence.\\012------------------------------------------------------------------------------------\\012CREATE FUNCTION CREATE_SEQUENCE(EXISTING_SEQUENCE VARCHAR, NEW_SEQUENCE VARCHAR) RETURNS VOID AS $$\\012DECLARE\\012  CURR_SEQ_VAL   INTEGER;\\012BEGIN\\012  SELECT INTO CURR_SEQ_VAL NEXTVAL(EXISTING_SEQUENCE);\\012  EXECUTE 'CREATE SEQUENCE ' || NEW_SEQUENCE || ' START WITH ' || CURR_SEQ_VAL;\\012  RETURN;\\012END;\\012$$ LANGUAGE 'plpgsql';\\012\\012SELECT CREATE_SEQUENCE('DATA_ID_SEQ', 'PERM_ID_SEQ');\\012DROP FUNCTION CREATE_SEQUENCE(VARCHAR, VARCHAR);\\012\\012------------------------------------------------------------------------------------\\012-- Add perm_id columns to samples and experiments.\\012------------------------------------------------------------------------------------\\012ALTER TABLE SAMPLES ADD COLUMN PERM_ID CODE;\\012ALTER TABLE EXPERIMENTS ADD COLUMN PERM_ID CODE;\\012\\012UPDATE SAMPLES SET PERM_ID = to_char(registration_timestamp,'YYYYMMDDHHSSMS') || '-' || NEXTVAL('PERM_ID_SEQ');\\012UPDATE EXPERIMENTS SET PERM_ID = to_char(registration_timestamp,'YYYYMMDDHHSSMS') || '-' || NEXTVAL('PERM_ID_SEQ');\\012ALTER TABLE SAMPLES ALTER COLUMN PERM_ID SET NOT NULL;\\012ALTER TABLE EXPERIMENTS ALTER COLUMN PERM_ID SET NOT NULL;\\012ALTER TABLE SAMPLES ADD CONSTRAINT SAMP_PI_UK UNIQUE(PERM_ID);\\012ALTER TABLE EXPERIMENTS ADD CONSTRAINT EXPE_PI_UK UNIQUE(PERM_ID);\\012\\012\\012------------------------------------------------------------------------------------\\012-- Add column is_chosen_from_list to controlled_vocabularies.\\012------------------------------------------------------------------------------------\\012ALTER TABLE controlled_vocabularies ADD COLUMN is_chosen_from_list BOOLEAN_CHAR NOT NULL DEFAULT TRUE;\\012ALTER TABLE controlled_vocabularies ADD COLUMN source_uri CHARACTER VARYING(250);\\012------------------------------------------------------------------------------------\\012-- Modify Data table - remove arc connection between Sample and Data table, use a flag instead\\012------------------------------------------------------------------------------------\\012\\012-- add new columns\\012\\012ALTER TABLE data\\012    ADD COLUMN is_derived boolean_char;\\012ALTER TABLE data\\012    ADD COLUMN samp_id tech_id;\\012\\012-- update values in new columns\\012\\012UPDATE data\\012    SET is_derived = (samp_id_derived_from IS NOT NULL); \\012UPDATE data\\012    SET samp_id = samp_id_derived_from \\012    WHERE is_derived = 'TRUE';\\012UPDATE data\\012    SET samp_id = samp_id_acquired_from \\012    WHERE is_derived = 'FALSE';\\012\\012-- add constraints and indexes to new columns\\012\\012ALTER TABLE data\\012    ALTER COLUMN is_derived SET NOT NULL;\\012ALTER TABLE data\\012    ALTER COLUMN samp_id SET NOT NULL;   \\012ALTER TABLE data\\012    ADD CONSTRAINT data_samp_fk FOREIGN KEY (samp_id) REFERENCES samples (id);\\012CREATE INDEX data_samp_fk_i ON data USING btree (samp_id);\\012\\012-- remove old columns\\012\\012ALTER TABLE data\\012    DROP COLUMN samp_id_acquired_from;\\012ALTER TABLE data\\012    DROP COLUMN samp_id_derived_from;\\012    \\012------------------------------------------------------------------------------------\\012-- Granting SELECT privilege to group openbis_readonly\\012------------------------------------------------------------------------------------\\012\\012GRANT SELECT ON SEQUENCE attachment_content_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE attachment_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE code_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE controlled_vocabulary_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE cvte_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE data_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE data_set_property_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE data_set_relationship_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE data_set_type_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE data_store_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE data_type_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE database_instance_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE dstpt_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE etpt_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE event_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE experiment_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE experiment_property_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE experiment_type_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE file_format_type_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE group_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE invalidation_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE locator_type_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE material_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE material_property_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE material_type_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE mtpt_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE perm_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE person_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE project_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE property_type_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE role_assignment_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE sample_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE sample_property_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE sample_type_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE stpt_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE attachment_contents TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE attachments TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE controlled_vocabularies TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE controlled_vocabulary_terms TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE data TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE data_set_properties TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE data_set_relationships TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE data_set_type_property_types TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE data_set_types TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE data_stores TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE data_types TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE database_instances TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE database_version_logs TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE events TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE experiment_properties TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE experiment_type_property_types TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE experiment_types TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE experiments TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE external_data TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE file_format_types TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE groups TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE invalidations TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE locator_types TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE material_properties TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE material_type_property_types TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE material_types TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE materials TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE persons TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE projects TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE property_types TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE role_assignments TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE sample_properties TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE sample_type_property_types TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE sample_types TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE samples TO GROUP OPENBIS_READONLY;\\012\\012------------------------------------------------------------------------------------\\012-- Delete MATERIAL_BATCHES table\\012------------------------------------------------------------------------------------\\012\\012-- WARNING: Potential data lost!!!\\012-- WARNING: Potential data lost!!!\\012-- WARNING: Potential data lost!!!\\012\\012DROP TABLE SAMPLE_MATERIAL_BATCHES;\\012DROP TABLE MATERIAL_BATCHES;\\012DROP SEQUENCE MATERIAL_BATCH_ID_SEQ;\\012\\012------------------------------------------------------------------------------------\\012-- Delete MATE_ID_INHIBITOR_OF from table MATERIALS\\012------------------------------------------------------------------------------------\\012\\012-- WARNING: Potential data lost!!!\\012-- WARNING: Potential data lost!!!\\012-- WARNING: Potential data lost!!!\\012\\012ALTER TABLE MATERIALS DROP COLUMN MATE_ID_INHIBITOR_OF;\\012	\N
+./sourceTest/sql/postgresql/034/.svn/text-base/schema-034.sql.svn-base:    LANGUAGE plpgsql;
+./sourceTest/sql/postgresql/034/.svn/text-base/schema-034.sql.svn-base:    LANGUAGE plpgsql;
+./sourceTest/sql/postgresql/034/.svn/text-base/schema-034.sql.svn-base:    LANGUAGE plpgsql;
+./sourceTest/sql/postgresql/034/.svn/text-base/schema-034.sql.svn-base:    LANGUAGE plpgsql;
+./sourceTest/sql/postgresql/034/.svn/text-base/schema-034.sql.svn-base:    LANGUAGE plpgsql;
+./sourceTest/sql/postgresql/034/.svn/text-base/schema-034.sql.svn-base:    LANGUAGE plpgsql;
+./sourceTest/sql/postgresql/034/.svn/text-base/schema-034.sql.svn-base:    LANGUAGE plpgsql;
+./sourceTest/sql/postgresql/034/.svn/text-base/schema-034.sql.svn-base:    LANGUAGE plpgsql;
+./sourceTest/sql/postgresql/034/013=database_version_logs.tsv:027	D:\\User\\felmer\\dev-workspace\\openbis/source/sql/postgresql/027/function-027.sql	SUCCESS	2008-11-05 09:18:00.403	-- Creating Functions\\012\\012------------------------------------------------------------------------------------\\012--  Purpose:  Create function RENAME_SEQUENCE() that is required for renaming the sequences belonging to tables\\012------------------------------------------------------------------------------------\\012CREATE FUNCTION RENAME_SEQUENCE(OLD_NAME VARCHAR, NEW_NAME VARCHAR) RETURNS INTEGER AS $$\\012DECLARE\\012  CURR_SEQ_VAL   INTEGER;\\012BEGIN\\012  SELECT INTO CURR_SEQ_VAL NEXTVAL(OLD_NAME);\\012  EXECUTE 'CREATE SEQUENCE ' || NEW_NAME || ' START WITH ' || CURR_SEQ_VAL;\\012  EXECUTE 'DROP SEQUENCE ' || OLD_NAME;\\012  RETURN CURR_SEQ_VAL;\\012END;\\012$$ LANGUAGE 'plpgsql';\\012\\012\\012------------------------------------------------------------------------------------\\012--  Purpose:  Create trigger CONTROLLED_VOCABULARY_CHECK \\012------------------------------------------------------------------------------------\\012\\012CREATE OR REPLACE FUNCTION CONTROLLED_VOCABULARY_CHECK() RETURNS trigger AS $$\\012DECLARE\\012   v_code  CODE;\\012BEGIN\\012\\012   select code into v_code from data_types where id = NEW.daty_id;\\012\\012   -- Check if the data is of type "CONTROLLEDVOCABULARY"\\012   if v_code = 'CONTROLLEDVOCABULARY' then\\012      if NEW.covo_id IS NULL then\\012         RAISE EXCEPTION 'Insert/Update of Property Type (Code: %) failed, as its Data Type is CONTROLLEDVOCABULARY, but it is not linked to a Controlled Vocabulary.', NEW.code;\\012      end if;\\012   end if;\\012\\012   RETURN NEW;\\012\\012END;\\012$$ LANGUAGE 'plpgsql';\\012\\012CREATE TRIGGER CONTROLLED_VOCABULARY_CHECK BEFORE INSERT OR UPDATE ON PROPERTY_TYPES\\012    FOR EACH ROW EXECUTE PROCEDURE CONTROLLED_VOCABULARY_CHECK();\\012\\012\\012------------------------------------------------------------------------------------\\012--  Purpose:  Create trigger EXTERNAL_DATA_STORAGE_FORMAT_CHECK \\012------------------------------------------------------------------------------------\\012\\012CREATE OR REPLACE FUNCTION EXTERNAL_DATA_STORAGE_FORMAT_CHECK() RETURNS trigger AS $$\\012DECLARE\\012   v_covo_code  CODE;\\012   data_code CODE;\\012BEGIN\\012\\012   select code into v_covo_code from controlled_vocabularies\\012      where is_internal_namespace = true and \\012         id = (select covo_id from controlled_vocabulary_terms where id = NEW.cvte_id_stor_fmt);\\012   -- Check if the data storage format is a term of the controlled vocabulary "STORAGE_FORMAT"\\012   if v_covo_code != 'STORAGE_FORMAT' then\\012      select code into data_code from data where id = NEW.data_id; \\012      RAISE EXCEPTION 'Insert/Update of Data (Code: %) failed, as its Storage Format is %, but is required to be STORAGE_FORMAT.', data_code, v_covo_code;\\012   end if;\\012\\012   RETURN NEW;\\012\\012END;\\012$$ LANGUAGE 'plpgsql';\\012\\012CREATE TRIGGER EXTERNAL_DATA_STORAGE_FORMAT_CHECK BEFORE INSERT OR UPDATE ON EXTERNAL_DATA\\012    FOR EACH ROW EXECUTE PROCEDURE EXTERNAL_DATA_STORAGE_FORMAT_CHECK();\\012\\012------------------------------------------------------------------------------------\\012--  Purpose:  Create trigger SAMPLE_CODE_UNIQUENESS_CHECK \\012------------------------------------------------------------------------------------\\012\\012CREATE OR REPLACE FUNCTION SAMPLE_CODE_UNIQUENESS_CHECK() RETURNS trigger AS $$\\012DECLARE\\012   counter  INTEGER;\\012BEGIN\\012\\011IF (NEW.samp_id_part_of is NULL) THEN\\012\\011\\011IF (NEW.dbin_id is not NULL) THEN\\012\\011\\011\\011SELECT count(*) into counter FROM samples \\012\\011\\011\\011\\011where id != NEW.id and code = NEW.code and samp_id_part_of is NULL and dbin_id = NEW.dbin_id;\\012\\011\\011\\011IF (counter > 0) THEN\\012\\011\\011\\011\\011RAISE EXCEPTION 'Insert/Update of Sample (Code: %) failed because database instance sample with the same code already exists.', NEW.code;\\012\\011\\011\\011END IF;\\012\\011\\011ELSIF (NEW.grou_id is not NULL) THEN\\012\\011\\011\\011SELECT count(*) into counter FROM samples \\012\\011\\011\\011\\011where id != NEW.id and code = NEW.code and samp_id_part_of is NULL and grou_id = NEW.grou_id;\\012\\011\\011\\011IF (counter > 0) THEN\\012\\011\\011\\011\\011RAISE EXCEPTION 'Insert/Update of Sample (Code: %) failed because group sample with the same code already exists.', NEW.code;\\012\\011\\011\\011END IF;\\012\\011\\011END IF;\\012        ELSE\\012\\011\\011IF (NEW.dbin_id is not NULL) THEN\\012\\011\\011\\011SELECT count(*) into counter FROM samples \\012\\011\\011\\011\\011where id != NEW.id and code = NEW.code and samp_id_part_of = NEW.samp_id_part_of and dbin_id = NEW.dbin_id;\\012\\011\\011\\011IF (counter > 0) THEN\\012\\011\\011\\011\\011RAISE EXCEPTION 'Insert/Update of Sample (Code: %) failed because database instance sample with the same code and being the part of the same parent already exists.', NEW.code;\\012\\011\\011\\011END IF;\\012\\011\\011ELSIF (NEW.grou_id is not NULL) THEN\\012\\011\\011\\011SELECT count(*) into counter FROM samples \\012\\011\\011\\011\\011where id != NEW.id and code = NEW.code and samp_id_part_of = NEW.samp_id_part_of and grou_id = NEW.grou_id;\\012\\011\\011\\011IF (counter > 0) THEN\\012\\011\\011\\011\\011RAISE EXCEPTION 'Insert/Update of Sample (Code: %) failed because group sample with the same code and being the part of the same parent already exists.', NEW.code;\\012\\011\\011\\011END IF;\\012\\011\\011END IF;\\012        END IF;   \\012   RETURN NEW;\\012END;\\012$$ LANGUAGE 'plpgsql';\\012\\012CREATE TRIGGER SAMPLE_CODE_UNIQUENESS_CHECK BEFORE INSERT OR UPDATE ON SAMPLES\\012    FOR EACH ROW EXECUTE PROCEDURE SAMPLE_CODE_UNIQUENESS_CHECK();\\012	\N
+./sourceTest/sql/postgresql/034/013=database_version_logs.tsv:028	source/sql/postgresql/migration/migration-027-028.sql	SUCCESS	2008-11-18 13:24:17.508	-- Create EXPERIMENT_ATTACHMENT_CONTENTS.\\012CREATE TABLE EXPERIMENT_ATTACHMENT_CONTENTS (ID TECH_ID NOT NULL,VALUE FILE NOT NULL);\\012CREATE SEQUENCE EXPERIMENT_ATTACHMENT_CONTENT_ID_SEQ;\\012ALTER TABLE EXPERIMENT_ATTACHMENT_CONTENTS ADD CONSTRAINT EXAC_PK PRIMARY KEY(ID);\\012\\012-- Alter EXPERIMENT_ATTACHMENTS by adding the new column which has a NULL constraint.\\012-- The NOT NULL constraint is added later on.\\012ALTER TABLE EXPERIMENT_ATTACHMENTS ADD COLUMN EXAC_ID TECH_ID;\\012\\012-- Does the VALUE migration between EXPERIMENT_ATTACHMENTS to EXPERIMENT_ATTACHMENT_CONTENTS.\\012CREATE OR REPLACE FUNCTION move_exp_att_content() RETURNS integer AS $$\\012DECLARE\\012    rec RECORD;\\012    seq BIGINT;\\012BEGIN\\012  FOR rec IN SELECT id, value FROM EXPERIMENT_ATTACHMENTS LOOP\\012  \\011seq := nextval('EXPERIMENT_ATTACHMENT_CONTENT_ID_SEQ');\\012    INSERT INTO EXPERIMENT_ATTACHMENT_CONTENTS (id, value) VALUES (seq, rec.value);\\012    UPDATE EXPERIMENT_ATTACHMENTS SET exac_id = seq WHERE id = rec.id;\\012  END LOOP;\\012  RETURN 1;\\012END;\\012$$ LANGUAGE 'plpgsql';\\012\\012-- Call the function.\\012SELECT move_exp_att_content();\\012DROP FUNCTION move_exp_att_content();\\012\\012\\012-- Finish EXPERIMENT_ATTACHMENTS changes.\\012ALTER TABLE EXPERIMENT_ATTACHMENTS ADD CONSTRAINT EXAT_CONT_FK FOREIGN KEY (EXAC_ID) REFERENCES EXPERIMENT_ATTACHMENT_CONTENTS(ID);\\012ALTER TABLE EXPERIMENT_ATTACHMENTS DROP COLUMN VALUE;\\012ALTER TABLE EXPERIMENT_ATTACHMENTS ALTER COLUMN EXAC_ID SET NOT NULL;\\012	\N
+./sourceTest/sql/postgresql/034/013=database_version_logs.tsv:029	source/sql/postgresql/migration/migration-028-029.sql	SUCCESS	2009-03-18 10:50:20.105	-- -------\\012-- add modification_timestamp field to allow edition with Hibernate\\012-- -------\\012\\012ALTER TABLE samples\\012\\011ADD COLUMN modification_timestamp TIME_STAMP DEFAULT CURRENT_TIMESTAMP;\\012\\012ALTER TABLE experiments\\012\\011ADD COLUMN modification_timestamp TIME_STAMP DEFAULT CURRENT_TIMESTAMP;\\012\\012ALTER TABLE materials\\012\\011ADD COLUMN modification_timestamp TIME_STAMP DEFAULT CURRENT_TIMESTAMP;\\012\\012ALTER TABLE experiment_properties\\012\\011ADD COLUMN modification_timestamp TIME_STAMP DEFAULT CURRENT_TIMESTAMP;\\012\\012ALTER TABLE material_properties\\012\\011ADD COLUMN modification_timestamp TIME_STAMP DEFAULT CURRENT_TIMESTAMP;\\012\\012ALTER TABLE sample_properties\\012\\011ADD COLUMN modification_timestamp TIME_STAMP DEFAULT CURRENT_TIMESTAMP;\\012\\012-- -------\\012-- add property data type which references materials\\012-- -------\\012\\012ALTER TABLE property_types\\012\\011ADD COLUMN maty_prop_id tech_id;\\012\\012ALTER TABLE property_types\\012\\011ADD CONSTRAINT prty_maty_fk FOREIGN KEY (maty_prop_id) REFERENCES material_types(id);\\012\\012ALTER TABLE experiment_properties\\012\\011ADD COLUMN mate_prop_id tech_id;\\012\\012ALTER TABLE material_properties\\012\\011ADD COLUMN mate_prop_id tech_id;\\012\\012ALTER TABLE sample_properties\\012\\011ADD COLUMN mate_prop_id tech_id;\\012\\012ALTER TABLE experiment_properties\\012\\011ADD CONSTRAINT expr_mapr_fk FOREIGN KEY (mate_prop_id) REFERENCES materials(id);\\012\\012ALTER TABLE material_properties\\012\\011ADD CONSTRAINT mapr_mapr_fk FOREIGN KEY (mate_prop_id) REFERENCES materials(id);\\012\\012ALTER TABLE sample_properties\\012\\011ADD CONSTRAINT sapr_mapr_fk FOREIGN KEY (mate_prop_id) REFERENCES materials(id);\\012\\012insert into data_types\\012(id\\012 ,code\\012 ,description)\\012 values \\012 (nextval('DATA_TYPE_ID_SEQ')\\012 ,'MATERIAL'\\012 ,'Reference to a material'\\012);\\012\\012ALTER TABLE MATERIAL_PROPERTIES DROP CONSTRAINT MAPR_CK;\\012ALTER TABLE MATERIAL_PROPERTIES ADD CONSTRAINT MAPR_CK CHECK \\012\\011((VALUE IS NOT NULL AND CVTE_ID IS NULL AND MATE_PROP_ID IS NULL) OR \\012\\011 (VALUE IS NULL AND CVTE_ID IS NOT NULL AND MATE_PROP_ID IS NULL) OR\\012\\011 (VALUE IS NULL AND CVTE_ID IS NULL AND MATE_PROP_ID IS NOT NULL)\\012\\011);\\012\\012ALTER TABLE EXPERIMENT_PROPERTIES DROP CONSTRAINT EXPR_CK;\\012ALTER TABLE EXPERIMENT_PROPERTIES ADD CONSTRAINT EXPR_CK CHECK \\012\\011((VALUE IS NOT NULL AND CVTE_ID IS NULL AND MATE_PROP_ID IS NULL) OR \\012\\011 (VALUE IS NULL AND CVTE_ID IS NOT NULL AND MATE_PROP_ID IS NULL) OR\\012\\011 (VALUE IS NULL AND CVTE_ID IS NULL AND MATE_PROP_ID IS NOT NULL)\\012\\011);\\012\\012ALTER TABLE SAMPLE_PROPERTIES DROP CONSTRAINT SAPR_CK;\\012ALTER TABLE SAMPLE_PROPERTIES ADD CONSTRAINT SAPR_CK CHECK \\012\\011((VALUE IS NOT NULL AND CVTE_ID IS NULL AND MATE_PROP_ID IS NULL) OR \\012\\011 (VALUE IS NULL AND CVTE_ID IS NOT NULL AND MATE_PROP_ID IS NULL) OR\\012\\011 (VALUE IS NULL AND CVTE_ID IS NULL AND MATE_PROP_ID IS NOT NULL)\\012\\011);\\012\\012------------------------------------------------------------------------------------\\012--  Purpose:  Create trigger MATERIAL/SAMPLE/EXPERIMENT _PROPERTY_WITH_MATERIAL_DATA_TYPE_CHECK\\012--            It checks that if material property value is assigned to the entity,\\012--\\011\\011\\011\\011\\011\\011then the material type is equal to the one described by property type.\\012------------------------------------------------------------------------------------\\012\\012CREATE OR REPLACE FUNCTION MATERIAL_PROPERTY_WITH_MATERIAL_DATA_TYPE_CHECK() RETURNS trigger AS $$\\012DECLARE\\012   v_type_id  CODE;\\012   v_type_id_prop  CODE;\\012BEGIN\\012   if NEW.mate_prop_id IS NOT NULL then\\012\\011\\011\\011-- find material type id of the property type \\012\\011\\011\\011select pt.maty_prop_id into v_type_id_prop \\012\\011\\011\\011  from material_type_property_types etpt, property_types pt \\012\\011\\011\\011 where NEW.mtpt_id = etpt.id AND etpt.prty_id = pt.id;\\012\\011\\011\\012\\011\\011\\011if v_type_id_prop IS NOT NULL then\\012\\011\\011\\011\\011-- find material type id of the material which consists the entity's property value\\012\\011\\011\\011\\011select entity.maty_id into v_type_id \\012\\011\\011\\011\\011  from materials entity\\012\\011\\011\\011\\011 where NEW.mate_prop_id = entity.id;\\012\\011\\011\\011\\011if v_type_id != v_type_id_prop then\\012\\011\\011\\011\\011\\011RAISE EXCEPTION 'Insert/Update of property value referencing material (id: %) failed, as referenced material type is different than expected (id %, expected id: %).', \\012\\011\\011\\011\\011\\011\\011\\011 NEW.mate_prop_id, v_type_id, v_type_id_prop;\\012\\011\\011\\011\\011end if;\\012\\011\\011\\011end if;\\012   end if;\\012   RETURN NEW;\\012END;\\012$$ LANGUAGE 'plpgsql';\\012\\012CREATE TRIGGER MATERIAL_PROPERTY_WITH_MATERIAL_DATA_TYPE_CHECK BEFORE INSERT OR UPDATE ON material_properties\\012    FOR EACH ROW EXECUTE PROCEDURE MATERIAL_PROPERTY_WITH_MATERIAL_DATA_TYPE_CHECK();\\012    \\012CREATE OR REPLACE FUNCTION SAMPLE_PROPERTY_WITH_MATERIAL_DATA_TYPE_CHECK() RETURNS trigger AS $$\\012DECLARE\\012   v_type_id  CODE;\\012   v_type_id_prop  CODE;\\012BEGIN\\012   if NEW.mate_prop_id IS NOT NULL then\\012\\011\\011\\011-- find material type id of the property type \\012\\011\\011\\011select pt.maty_prop_id into v_type_id_prop \\012\\011\\011\\011  from sample_type_property_types etpt, property_types pt \\012\\011\\011\\011 where NEW.stpt_id = etpt.id AND etpt.prty_id = pt.id;\\012\\011\\011\\012\\011\\011\\011if v_type_id_prop IS NOT NULL then\\012\\011\\011\\011\\011-- find material type id of the material which consists the entity's property value\\012\\011\\011\\011\\011select entity.maty_id into v_type_id \\012\\011\\011\\011\\011  from materials entity\\012\\011\\011\\011\\011 where NEW.mate_prop_id = entity.id;\\012\\011\\011\\011\\011if v_type_id != v_type_id_prop then\\012\\011\\011\\011\\011\\011RAISE EXCEPTION 'Insert/Update of property value referencing material (id: %) failed, as referenced material type is different than expected (id %, expected id: %).', \\012\\011\\011\\011\\011\\011\\011\\011\\011\\011\\011\\011\\011 NEW.mate_prop_id, v_type_id, v_type_id_prop;\\012\\011\\011\\011\\011end if;\\012\\011\\011\\011end if;\\012   end if;\\012   RETURN NEW;\\012END;\\012$$ LANGUAGE 'plpgsql';\\012\\012CREATE TRIGGER SAMPLE_PROPERTY_WITH_MATERIAL_DATA_TYPE_CHECK BEFORE INSERT OR UPDATE ON sample_properties\\012    FOR EACH ROW EXECUTE PROCEDURE SAMPLE_PROPERTY_WITH_MATERIAL_DATA_TYPE_CHECK();\\012    \\012CREATE OR REPLACE FUNCTION EXPERIMENT_PROPERTY_WITH_MATERIAL_DATA_TYPE_CHECK() RETURNS trigger AS $$\\012DECLARE\\012   v_type_id  CODE;\\012   v_type_id_prop  CODE;\\012BEGIN\\012   if NEW.mate_prop_id IS NOT NULL then\\012\\011\\011\\011-- find material type id of the property type \\012\\011\\011\\011select pt.maty_prop_id into v_type_id_prop \\012\\011\\011\\011  from experiment_type_property_types etpt, property_types pt \\012\\011\\011\\011 where NEW.etpt_id = etpt.id AND etpt.prty_id = pt.id;\\012\\011\\011\\012\\011\\011\\011if v_type_id_prop IS NOT NULL then\\012\\011\\011\\011\\011-- find material type id of the material which consists the entity's property value\\012\\011\\011\\011\\011select entity.maty_id into v_type_id \\012\\011\\011\\011\\011  from materials entity\\012\\011\\011\\011\\011 where NEW.mate_prop_id = entity.id;\\012\\011\\011\\011\\011if v_type_id != v_type_id_prop then\\012\\011\\011\\011\\011\\011RAISE EXCEPTION 'Insert/Update of property value referencing material (id: %) failed, as referenced material type is different than expected (id %, expected id: %).', \\012\\011\\011\\011\\011\\011\\011\\011\\011\\011\\011\\011\\011 NEW.mate_prop_id, v_type_id, v_type_id_prop;\\012\\011\\011\\011\\011end if;\\012\\011\\011\\011end if;\\012   end if;\\012   RETURN NEW;\\012END;\\012$$ LANGUAGE 'plpgsql';\\012\\012CREATE TRIGGER EXPERIMENT_PROPERTY_WITH_MATERIAL_DATA_TYPE_CHECK BEFORE INSERT OR UPDATE ON experiment_properties\\012    FOR EACH ROW EXECUTE PROCEDURE EXPERIMENT_PROPERTY_WITH_MATERIAL_DATA_TYPE_CHECK();\\012       \\012-- -------\\012-- remove the reminescents of the OBSERVABLE_TYPE\\012-- -------\\012\\012ALTER TABLE data\\012\\011DROP CONSTRAINT data_obty_fk;\\012\\012ALTER TABLE data_set_types\\012\\011DROP CONSTRAINT obty_pk;\\012\\012ALTER TABLE data_set_types\\012\\011ADD CONSTRAINT dsty_pk PRIMARY KEY (id);\\012\\012ALTER TABLE data\\012\\011ADD CONSTRAINT data_dsty_fk FOREIGN KEY (dsty_id) REFERENCES data_set_types(id);\\012\\012ALTER TABLE data_set_types\\012\\011DROP CONSTRAINT obty_bk_uk;\\012\\012ALTER TABLE data_set_types\\012\\011DROP CONSTRAINT obty_dbin_fk;\\012\\012ALTER TABLE data_set_types\\012\\011ADD CONSTRAINT dsty_bk_uk UNIQUE (code, dbin_id);\\012\\012ALTER TABLE data_set_types\\012\\011ADD CONSTRAINT dsty_dbin_fk FOREIGN KEY (dbin_id) REFERENCES database_instances(id);\\012\\012DROP INDEX data_obty_fk_i;\\012\\012CREATE INDEX data_dsty_fk_i ON data(dsty_id);\\012	\N
+./sourceTest/sql/postgresql/034/013=database_version_logs.tsv:030	source/sql/postgresql/migration/migration-029-030.sql	SUCCESS	2009-03-23 15:34:44.72	-- -------\\012-- add modification_timestamp field to allow edition with Hibernate\\012-- -------\\012ALTER TABLE data\\012\\011ADD COLUMN modification_timestamp TIME_STAMP DEFAULT CURRENT_TIMESTAMP;\\012ALTER TABLE experiment_types\\012\\011ADD COLUMN modification_timestamp TIME_STAMP DEFAULT CURRENT_TIMESTAMP;\\012ALTER TABLE sample_types\\012\\011ADD COLUMN modification_timestamp TIME_STAMP DEFAULT CURRENT_TIMESTAMP;\\012ALTER TABLE material_types\\012\\011ADD COLUMN modification_timestamp TIME_STAMP DEFAULT CURRENT_TIMESTAMP;\\012ALTER TABLE data_set_types\\012\\011ADD COLUMN modification_timestamp TIME_STAMP DEFAULT CURRENT_TIMESTAMP;\\012ALTER TABLE controlled_vocabularies\\012\\011ADD COLUMN modification_timestamp TIME_STAMP DEFAULT CURRENT_TIMESTAMP;\\012-- -------\\012-- add properties to data sets\\012-- -------\\012CREATE TABLE DATA_SET_PROPERTIES (ID TECH_ID NOT NULL,DS_ID TECH_ID NOT NULL,DSTPT_ID TECH_ID NOT NULL,VALUE GENERIC_VALUE,CVTE_ID TECH_ID, MATE_PROP_ID TECH_ID, PERS_ID_REGISTERER TECH_ID NOT NULL,REGISTRATION_TIMESTAMP TIME_STAMP_DFL NOT NULL DEFAULT CURRENT_TIMESTAMP, MODIFICATION_TIMESTAMP TIME_STAMP DEFAULT CURRENT_TIMESTAMP);\\012CREATE TABLE DATA_SET_TYPE_PROPERTY_TYPES (ID TECH_ID NOT NULL,DSTY_ID TECH_ID NOT NULL,PRTY_ID TECH_ID NOT NULL,IS_MANDATORY BOOLEAN_CHAR NOT NULL DEFAULT 'F',IS_MANAGED_INTERNALLY BOOLEAN_CHAR NOT NULL DEFAULT 'F',PERS_ID_REGISTERER TECH_ID NOT NULL,REGISTRATION_TIMESTAMP TIME_STAMP_DFL NOT NULL DEFAULT CURRENT_TIMESTAMP);\\012\\012CREATE SEQUENCE DATA_SET_PROPERTY_ID_SEQ;\\012CREATE SEQUENCE DSTPT_ID_SEQ;\\012\\012ALTER TABLE DATA_SET_TYPE_PROPERTY_TYPES ADD CONSTRAINT DSTPT_PK PRIMARY KEY(ID);\\012ALTER TABLE DATA_SET_PROPERTIES ADD CONSTRAINT DSPR_PK PRIMARY KEY(ID);\\012\\012ALTER TABLE DATA_SET_TYPE_PROPERTY_TYPES ADD CONSTRAINT DSTPT_BK_UK UNIQUE(DSTY_ID,PRTY_ID);\\012ALTER TABLE DATA_SET_PROPERTIES ADD CONSTRAINT DSPR_BK_UK UNIQUE(DS_ID,DSTPT_ID);\\012\\012\\012ALTER TABLE DATA_SET_TYPE_PROPERTY_TYPES ADD CONSTRAINT DSTPT_DSTY_FK FOREIGN KEY (DSTY_ID) REFERENCES DATA_SET_TYPES(ID);\\012ALTER TABLE DATA_SET_TYPE_PROPERTY_TYPES ADD CONSTRAINT DSTPT_PERS_FK FOREIGN KEY (PERS_ID_REGISTERER) REFERENCES PERSONS(ID);\\012ALTER TABLE DATA_SET_TYPE_PROPERTY_TYPES ADD CONSTRAINT DSTPT_PRTY_FK FOREIGN KEY (PRTY_ID) REFERENCES PROPERTY_TYPES(ID);\\012ALTER TABLE DATA_SET_PROPERTIES ADD CONSTRAINT DSPR_CVTE_FK FOREIGN KEY (CVTE_ID) REFERENCES CONTROLLED_VOCABULARY_TERMS(ID);\\012ALTER TABLE DATA_SET_PROPERTIES ADD CONSTRAINT DSPR_DSTPT_FK FOREIGN KEY (DSTPT_ID) REFERENCES DATA_SET_TYPE_PROPERTY_TYPES(ID) ON DELETE CASCADE;\\012ALTER TABLE DATA_SET_PROPERTIES ADD CONSTRAINT DSPR_DS_FK FOREIGN KEY (DS_ID) REFERENCES DATA(ID);\\012ALTER TABLE DATA_SET_PROPERTIES ADD CONSTRAINT DSPR_PERS_FK FOREIGN KEY (PERS_ID_REGISTERER) REFERENCES PERSONS(ID);\\012ALTER TABLE DATA_SET_PROPERTIES ADD CONSTRAINT DSPR_MAPR_FK FOREIGN KEY (MATE_PROP_ID) REFERENCES MATERIALS(ID);\\012\\012ALTER TABLE DATA_SET_PROPERTIES ADD CONSTRAINT DSPR_CK CHECK \\012\\011((VALUE IS NOT NULL AND CVTE_ID IS NULL AND MATE_PROP_ID IS NULL) OR \\012\\011 (VALUE IS NULL AND CVTE_ID IS NOT NULL AND MATE_PROP_ID IS NULL) OR\\012\\011 (VALUE IS NULL AND CVTE_ID IS NULL AND MATE_PROP_ID IS NOT NULL)\\012\\011);\\012\\012CREATE INDEX DSPR_CVTE_FK_I ON DATA_SET_PROPERTIES (CVTE_ID);\\012CREATE INDEX DSPR_DSTPT_FK_I ON DATA_SET_PROPERTIES (DSTPT_ID);\\012CREATE INDEX DSPR_DS_FK_I ON DATA_SET_PROPERTIES (DS_ID);\\012CREATE INDEX DSPR_PERS_FK_I ON DATA_SET_PROPERTIES (PERS_ID_REGISTERER);\\012CREATE INDEX DSTPT_DSTY_FK_I ON DATA_SET_TYPE_PROPERTY_TYPES (DSTY_ID);\\012CREATE INDEX DSTPT_PERS_FK_I ON DATA_SET_TYPE_PROPERTY_TYPES (PERS_ID_REGISTERER);\\012CREATE INDEX DSTPT_PRTY_FK_I ON DATA_SET_TYPE_PROPERTY_TYPES (PRTY_ID);\\012\\012CREATE OR REPLACE FUNCTION DATA_SET_PROPERTY_WITH_MATERIAL_DATA_TYPE_CHECK() RETURNS trigger AS $$\\012DECLARE\\012   v_type_id  CODE;\\012   v_type_id_prop  CODE;\\012BEGIN\\012   if NEW.mate_prop_id IS NOT NULL then\\012\\011\\011\\011-- find material type id of the property type \\012\\011\\011\\011select pt.maty_prop_id into v_type_id_prop \\012\\011\\011\\011  from data_set_type_property_types dstpt, property_types pt \\012\\011\\011\\011 where NEW.dstpt_id = dstpt.id AND dstpt.prty_id = pt.id;\\012\\011\\011\\012\\011\\011\\011if v_type_id_prop IS NOT NULL then\\012\\011\\011\\011\\011-- find material type id of the material which consists the entity's property value\\012\\011\\011\\011\\011select entity.maty_id into v_type_id \\012\\011\\011\\011\\011  from materials entity\\012\\011\\011\\011\\011 where NEW.mate_prop_id = entity.id;\\012\\011\\011\\011\\011if v_type_id != v_type_id_prop then\\012\\011\\011\\011\\011\\011RAISE EXCEPTION 'Insert/Update of property value referencing material (id: %) failed, as referenced material type is different than expected (id %, expected id: %).', \\012\\011\\011\\011\\011\\011\\011\\011\\011\\011\\011\\011\\011 NEW.mate_prop_id, v_type_id, v_type_id_prop;\\012\\011\\011\\011\\011end if;\\012\\011\\011\\011end if;\\012   end if;\\012   RETURN NEW;\\012END;\\012$$ LANGUAGE 'plpgsql';\\012\\012CREATE TRIGGER DATA_SET_PROPERTY_WITH_MATERIAL_DATA_TYPE_CHECK BEFORE INSERT OR UPDATE ON data_set_properties\\012    FOR EACH ROW EXECUTE PROCEDURE DATA_SET_PROPERTY_WITH_MATERIAL_DATA_TYPE_CHECK();   \\012	\N
+./sourceTest/sql/postgresql/034/013=database_version_logs.tsv:032	source/sql/postgresql/migration/migration-031-032.sql	SUCCESS	2009-04-09 09:36:36.20	-- -------\\012-- Modify MATERIAL_BATCHES\\012-- -------\\012\\012ALTER TABLE material_batches\\012    DROP COLUMN proc_id;\\012\\012-- -------\\012-- Modify SAMPLES\\012-- -------\\012\\012ALTER TABLE samples\\012    ADD COLUMN expe_id tech_id;\\012\\012ALTER TABLE samples\\012    ADD CONSTRAINT samp_expe_fk FOREIGN KEY (expe_id) REFERENCES experiments(id);\\012\\012CREATE INDEX samp_expe_fk_i ON samples USING btree (expe_id);\\012\\012-- relink samples directly to experiments\\012\\012UPDATE samples\\012SET expe_id = (SELECT e.id FROM experiments e, procedures p, sample_inputs si \\012               WHERE si.samp_id = samples.id AND si.proc_id = p.id AND p.expe_id = e.id AND e.inva_id IS NULL);\\012\\012\\012-- -------\\012-- Modify DATA\\012-- -------\\012\\012ALTER TABLE data\\012    ADD COLUMN expe_id tech_id;\\012\\012ALTER TABLE data\\012    ADD CONSTRAINT data_expe_fk FOREIGN KEY (expe_id) REFERENCES experiments(id);\\012\\012CREATE INDEX data_expe_fk_i ON data USING btree (expe_id);\\012\\012UPDATE data\\012SET expe_id = (SELECT e.id FROM experiments e, procedures p \\012               WHERE data.proc_id_produced_by = p.id AND p.expe_id = e.id);\\012\\012ALTER TABLE data\\012    ALTER COLUMN expe_id SET NOT NULL;\\012\\012ALTER TABLE data\\012    DROP COLUMN proc_id_produced_by;\\012\\012-- -------\\012-- Drop PROCEDURES, PROCEDURE_TYPES, and SAMPLE_INPUTS\\012-- -------\\012\\012DROP TABLE sample_inputs;\\012DROP TABLE procedures;\\012DROP TABLE procedure_types;\\012\\012DROP SEQUENCE procedure_id_seq;\\012DROP SEQUENCE procedure_type_id_seq;\\012\\012-- -------\\012-- Add CODE_SEQ\\012-- -------\\012\\012CREATE SEQUENCE CODE_SEQ;\\012\\012-- -------\\012-- Add new columns to DATA_STORES\\012-- -------\\012\\012ALTER TABLE data_stores\\012    ADD COLUMN remote_url character varying(250),\\012    ADD COLUMN session_token character varying(50),\\012    ADD COLUMN modification_timestamp time_stamp DEFAULT now();\\012\\012UPDATE data_stores\\012SET remote_url = '', session_token='';\\012\\012ALTER TABLE data_stores\\012    ALTER COLUMN remote_url SET NOT NULL,\\012    ALTER COLUMN session_token SET NOT NULL;\\012\\012-- -------\\012-- Drop foreign keys onto DATA_STORES\\012-- -------\\012\\012ALTER TABLE database_instances\\012    DROP COLUMN dast_id;\\012\\012ALTER TABLE groups\\012    DROP COLUMN dast_id;\\012\\012ALTER TABLE projects\\012    DROP COLUMN dast_id;\\012\\012ALTER TABLE experiments\\012    DROP COLUMN dast_id;\\012\\012-- -------\\012-- Add foreign key from DATA onto DATA_STORES\\012-- -------\\012\\012ALTER TABLE data\\012    ADD COLUMN dast_id tech_id;\\012\\012ALTER TABLE data\\012    ADD CONSTRAINT data_dast_fk FOREIGN KEY (dast_id) REFERENCES data_stores(id);\\012\\012UPDATE data\\012SET dast_id = (select id from data_stores where code = 'STANDARD');\\012\\012ALTER TABLE data\\012    ALTER COLUMN dast_id SET NOT NULL;\\012\\012\\012------------------------------------------------------------------------------------\\012--  Purpose:  Replace trigger SAMPLE_CODE_UNIQUENESS_CHECK \\012------------------------------------------------------------------------------------\\012\\012CREATE OR REPLACE FUNCTION SAMPLE_CODE_UNIQUENESS_CHECK() RETURNS trigger AS $$\\012DECLARE\\012   counter  INTEGER;\\012BEGIN\\012    LOCK TABLE samples IN EXCLUSIVE MODE;\\012    IF (NEW.samp_id_part_of is NULL) THEN\\012        IF (NEW.dbin_id is not NULL) THEN\\012            SELECT count(*) into counter FROM samples \\012                where id != NEW.id and code = NEW.code and samp_id_part_of is NULL and dbin_id = NEW.dbin_id;\\012            IF (counter > 0) THEN\\012                RAISE EXCEPTION 'Insert/Update of Sample (Code: %) failed because database instance sample with the same code already exists.', NEW.code;\\012            END IF;\\012        ELSIF (NEW.grou_id is not NULL) THEN\\012            SELECT count(*) into counter FROM samples \\012                where id != NEW.id and code = NEW.code and samp_id_part_of is NULL and grou_id = NEW.grou_id;\\012            IF (counter > 0) THEN\\012                RAISE EXCEPTION 'Insert/Update of Sample (Code: %) failed because group sample with the same code already exists.', NEW.code;\\012            END IF;\\012        END IF;\\012        ELSE\\012        IF (NEW.dbin_id is not NULL) THEN\\012            SELECT count(*) into counter FROM samples \\012                where id != NEW.id and code = NEW.code and samp_id_part_of = NEW.samp_id_part_of and dbin_id = NEW.dbin_id;\\012            IF (counter > 0) THEN\\012                RAISE EXCEPTION 'Insert/Update of Sample (Code: %) failed because database instance sample with the same code and being the part of the same parent already exists.', NEW.code;\\012            END IF;\\012        ELSIF (NEW.grou_id is not NULL) THEN\\012            SELECT count(*) into counter FROM samples \\012                where id != NEW.id and code = NEW.code and samp_id_part_of = NEW.samp_id_part_of and grou_id = NEW.grou_id;\\012            IF (counter > 0) THEN\\012                RAISE EXCEPTION 'Insert/Update of Sample (Code: %) failed because group sample with the same code and being the part of the same parent already exists.', NEW.code;\\012            END IF;\\012        END IF;\\012        END IF;   \\012   RETURN NEW;\\012END;\\012$$ LANGUAGE 'plpgsql';\\012\\012\\012\\012	\N
+./sourceTest/sql/postgresql/034/013=database_version_logs.tsv:034	source/sql/postgresql/migration/migration-033-034.sql	SUCCESS	2009-05-26 08:32:49.935	------------------------------------------------------------------------------------\\012-- Create sequence for generating permanent identifiers starting with nextval of existing dataset sequence.\\012------------------------------------------------------------------------------------\\012CREATE FUNCTION CREATE_SEQUENCE(EXISTING_SEQUENCE VARCHAR, NEW_SEQUENCE VARCHAR) RETURNS VOID AS $$\\012DECLARE\\012  CURR_SEQ_VAL   INTEGER;\\012BEGIN\\012  SELECT INTO CURR_SEQ_VAL NEXTVAL(EXISTING_SEQUENCE);\\012  EXECUTE 'CREATE SEQUENCE ' || NEW_SEQUENCE || ' START WITH ' || CURR_SEQ_VAL;\\012  RETURN;\\012END;\\012$$ LANGUAGE 'plpgsql';\\012\\012SELECT CREATE_SEQUENCE('DATA_ID_SEQ', 'PERM_ID_SEQ');\\012DROP FUNCTION CREATE_SEQUENCE(VARCHAR, VARCHAR);\\012\\012------------------------------------------------------------------------------------\\012-- Add perm_id columns to samples and experiments.\\012------------------------------------------------------------------------------------\\012ALTER TABLE SAMPLES ADD COLUMN PERM_ID CODE;\\012ALTER TABLE EXPERIMENTS ADD COLUMN PERM_ID CODE;\\012\\012UPDATE SAMPLES SET PERM_ID = to_char(registration_timestamp,'YYYYMMDDHHSSMS') || '-' || NEXTVAL('PERM_ID_SEQ');\\012UPDATE EXPERIMENTS SET PERM_ID = to_char(registration_timestamp,'YYYYMMDDHHSSMS') || '-' || NEXTVAL('PERM_ID_SEQ');\\012ALTER TABLE SAMPLES ALTER COLUMN PERM_ID SET NOT NULL;\\012ALTER TABLE EXPERIMENTS ALTER COLUMN PERM_ID SET NOT NULL;\\012ALTER TABLE SAMPLES ADD CONSTRAINT SAMP_PI_UK UNIQUE(PERM_ID);\\012ALTER TABLE EXPERIMENTS ADD CONSTRAINT EXPE_PI_UK UNIQUE(PERM_ID);\\012\\012\\012------------------------------------------------------------------------------------\\012-- Add column is_chosen_from_list to controlled_vocabularies.\\012------------------------------------------------------------------------------------\\012ALTER TABLE controlled_vocabularies ADD COLUMN is_chosen_from_list BOOLEAN_CHAR NOT NULL DEFAULT TRUE;\\012ALTER TABLE controlled_vocabularies ADD COLUMN source_uri CHARACTER VARYING(250);\\012------------------------------------------------------------------------------------\\012-- Modify Data table - remove arc connection between Sample and Data table, use a flag instead\\012------------------------------------------------------------------------------------\\012\\012-- add new columns\\012\\012ALTER TABLE data\\012    ADD COLUMN is_derived boolean_char;\\012ALTER TABLE data\\012    ADD COLUMN samp_id tech_id;\\012\\012-- update values in new columns\\012\\012UPDATE data\\012    SET is_derived = (samp_id_derived_from IS NOT NULL); \\012UPDATE data\\012    SET samp_id = samp_id_derived_from \\012    WHERE is_derived = 'TRUE';\\012UPDATE data\\012    SET samp_id = samp_id_acquired_from \\012    WHERE is_derived = 'FALSE';\\012\\012-- add constraints and indexes to new columns\\012\\012ALTER TABLE data\\012    ALTER COLUMN is_derived SET NOT NULL;\\012ALTER TABLE data\\012    ALTER COLUMN samp_id SET NOT NULL;   \\012ALTER TABLE data\\012    ADD CONSTRAINT data_samp_fk FOREIGN KEY (samp_id) REFERENCES samples (id);\\012CREATE INDEX data_samp_fk_i ON data USING btree (samp_id);\\012\\012-- remove old columns\\012\\012ALTER TABLE data\\012    DROP COLUMN samp_id_acquired_from;\\012ALTER TABLE data\\012    DROP COLUMN samp_id_derived_from;\\012    \\012------------------------------------------------------------------------------------\\012-- Granting SELECT privilege to group openbis_readonly\\012------------------------------------------------------------------------------------\\012\\012GRANT SELECT ON SEQUENCE attachment_content_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE attachment_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE code_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE controlled_vocabulary_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE cvte_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE data_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE data_set_property_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE data_set_relationship_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE data_set_type_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE data_store_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE data_type_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE database_instance_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE dstpt_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE etpt_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE event_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE experiment_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE experiment_property_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE experiment_type_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE file_format_type_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE group_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE invalidation_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE locator_type_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE material_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE material_property_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE material_type_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE mtpt_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE perm_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE person_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE project_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE property_type_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE role_assignment_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE sample_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE sample_property_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE sample_type_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE stpt_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE attachment_contents TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE attachments TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE controlled_vocabularies TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE controlled_vocabulary_terms TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE data TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE data_set_properties TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE data_set_relationships TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE data_set_type_property_types TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE data_set_types TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE data_stores TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE data_types TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE database_instances TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE database_version_logs TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE events TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE experiment_properties TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE experiment_type_property_types TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE experiment_types TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE experiments TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE external_data TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE file_format_types TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE groups TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE invalidations TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE locator_types TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE material_properties TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE material_type_property_types TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE material_types TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE materials TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE persons TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE projects TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE property_types TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE role_assignments TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE sample_properties TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE sample_type_property_types TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE sample_types TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE samples TO GROUP OPENBIS_READONLY;\\012\\012------------------------------------------------------------------------------------\\012-- Delete MATERIAL_BATCHES table\\012------------------------------------------------------------------------------------\\012\\012-- WARNING: Potential data lost!!!\\012-- WARNING: Potential data lost!!!\\012-- WARNING: Potential data lost!!!\\012\\012DROP TABLE SAMPLE_MATERIAL_BATCHES;\\012DROP TABLE MATERIAL_BATCHES;\\012DROP SEQUENCE MATERIAL_BATCH_ID_SEQ;\\012\\012------------------------------------------------------------------------------------\\012-- Delete MATE_ID_INHIBITOR_OF from table MATERIALS\\012------------------------------------------------------------------------------------\\012\\012-- WARNING: Potential data lost!!!\\012-- WARNING: Potential data lost!!!\\012-- WARNING: Potential data lost!!!\\012\\012ALTER TABLE MATERIALS DROP COLUMN MATE_ID_INHIBITOR_OF;\\012	\N
+./sourceTest/sql/postgresql/034/schema-034.sql:    LANGUAGE plpgsql;
+./sourceTest/sql/postgresql/034/schema-034.sql:    LANGUAGE plpgsql;
+./sourceTest/sql/postgresql/034/schema-034.sql:    LANGUAGE plpgsql;
+./sourceTest/sql/postgresql/034/schema-034.sql:    LANGUAGE plpgsql;
+./sourceTest/sql/postgresql/034/schema-034.sql:    LANGUAGE plpgsql;
+./sourceTest/sql/postgresql/034/schema-034.sql:    LANGUAGE plpgsql;
+./sourceTest/sql/postgresql/034/schema-034.sql:    LANGUAGE plpgsql;
+./sourceTest/sql/postgresql/034/schema-034.sql:    LANGUAGE plpgsql;
+./sourceTest/sql/postgresql/035/.svn/text-base/013=database_version_logs.tsv.svn-base:027	D:\\User\\felmer\\dev-workspace\\openbis/source/sql/postgresql/027/function-027.sql	SUCCESS	2008-11-05 09:18:00.403	-- Creating Functions\\012\\012------------------------------------------------------------------------------------\\012--  Purpose:  Create function RENAME_SEQUENCE() that is required for renaming the sequences belonging to tables\\012------------------------------------------------------------------------------------\\012CREATE FUNCTION RENAME_SEQUENCE(OLD_NAME VARCHAR, NEW_NAME VARCHAR) RETURNS INTEGER AS $$\\012DECLARE\\012  CURR_SEQ_VAL   INTEGER;\\012BEGIN\\012  SELECT INTO CURR_SEQ_VAL NEXTVAL(OLD_NAME);\\012  EXECUTE 'CREATE SEQUENCE ' || NEW_NAME || ' START WITH ' || CURR_SEQ_VAL;\\012  EXECUTE 'DROP SEQUENCE ' || OLD_NAME;\\012  RETURN CURR_SEQ_VAL;\\012END;\\012$$ LANGUAGE 'plpgsql';\\012\\012\\012------------------------------------------------------------------------------------\\012--  Purpose:  Create trigger CONTROLLED_VOCABULARY_CHECK \\012------------------------------------------------------------------------------------\\012\\012CREATE OR REPLACE FUNCTION CONTROLLED_VOCABULARY_CHECK() RETURNS trigger AS $$\\012DECLARE\\012   v_code  CODE;\\012BEGIN\\012\\012   select code into v_code from data_types where id = NEW.daty_id;\\012\\012   -- Check if the data is of type "CONTROLLEDVOCABULARY"\\012   if v_code = 'CONTROLLEDVOCABULARY' then\\012      if NEW.covo_id IS NULL then\\012         RAISE EXCEPTION 'Insert/Update of Property Type (Code: %) failed, as its Data Type is CONTROLLEDVOCABULARY, but it is not linked to a Controlled Vocabulary.', NEW.code;\\012      end if;\\012   end if;\\012\\012   RETURN NEW;\\012\\012END;\\012$$ LANGUAGE 'plpgsql';\\012\\012CREATE TRIGGER CONTROLLED_VOCABULARY_CHECK BEFORE INSERT OR UPDATE ON PROPERTY_TYPES\\012    FOR EACH ROW EXECUTE PROCEDURE CONTROLLED_VOCABULARY_CHECK();\\012\\012\\012------------------------------------------------------------------------------------\\012--  Purpose:  Create trigger EXTERNAL_DATA_STORAGE_FORMAT_CHECK \\012------------------------------------------------------------------------------------\\012\\012CREATE OR REPLACE FUNCTION EXTERNAL_DATA_STORAGE_FORMAT_CHECK() RETURNS trigger AS $$\\012DECLARE\\012   v_covo_code  CODE;\\012   data_code CODE;\\012BEGIN\\012\\012   select code into v_covo_code from controlled_vocabularies\\012      where is_internal_namespace = true and \\012         id = (select covo_id from controlled_vocabulary_terms where id = NEW.cvte_id_stor_fmt);\\012   -- Check if the data storage format is a term of the controlled vocabulary "STORAGE_FORMAT"\\012   if v_covo_code != 'STORAGE_FORMAT' then\\012      select code into data_code from data where id = NEW.data_id; \\012      RAISE EXCEPTION 'Insert/Update of Data (Code: %) failed, as its Storage Format is %, but is required to be STORAGE_FORMAT.', data_code, v_covo_code;\\012   end if;\\012\\012   RETURN NEW;\\012\\012END;\\012$$ LANGUAGE 'plpgsql';\\012\\012CREATE TRIGGER EXTERNAL_DATA_STORAGE_FORMAT_CHECK BEFORE INSERT OR UPDATE ON EXTERNAL_DATA\\012    FOR EACH ROW EXECUTE PROCEDURE EXTERNAL_DATA_STORAGE_FORMAT_CHECK();\\012\\012------------------------------------------------------------------------------------\\012--  Purpose:  Create trigger SAMPLE_CODE_UNIQUENESS_CHECK \\012------------------------------------------------------------------------------------\\012\\012CREATE OR REPLACE FUNCTION SAMPLE_CODE_UNIQUENESS_CHECK() RETURNS trigger AS $$\\012DECLARE\\012   counter  INTEGER;\\012BEGIN\\012\\011IF (NEW.samp_id_part_of is NULL) THEN\\012\\011\\011IF (NEW.dbin_id is not NULL) THEN\\012\\011\\011\\011SELECT count(*) into counter FROM samples \\012\\011\\011\\011\\011where id != NEW.id and code = NEW.code and samp_id_part_of is NULL and dbin_id = NEW.dbin_id;\\012\\011\\011\\011IF (counter > 0) THEN\\012\\011\\011\\011\\011RAISE EXCEPTION 'Insert/Update of Sample (Code: %) failed because database instance sample with the same code already exists.', NEW.code;\\012\\011\\011\\011END IF;\\012\\011\\011ELSIF (NEW.grou_id is not NULL) THEN\\012\\011\\011\\011SELECT count(*) into counter FROM samples \\012\\011\\011\\011\\011where id != NEW.id and code = NEW.code and samp_id_part_of is NULL and grou_id = NEW.grou_id;\\012\\011\\011\\011IF (counter > 0) THEN\\012\\011\\011\\011\\011RAISE EXCEPTION 'Insert/Update of Sample (Code: %) failed because group sample with the same code already exists.', NEW.code;\\012\\011\\011\\011END IF;\\012\\011\\011END IF;\\012        ELSE\\012\\011\\011IF (NEW.dbin_id is not NULL) THEN\\012\\011\\011\\011SELECT count(*) into counter FROM samples \\012\\011\\011\\011\\011where id != NEW.id and code = NEW.code and samp_id_part_of = NEW.samp_id_part_of and dbin_id = NEW.dbin_id;\\012\\011\\011\\011IF (counter > 0) THEN\\012\\011\\011\\011\\011RAISE EXCEPTION 'Insert/Update of Sample (Code: %) failed because database instance sample with the same code and being the part of the same parent already exists.', NEW.code;\\012\\011\\011\\011END IF;\\012\\011\\011ELSIF (NEW.grou_id is not NULL) THEN\\012\\011\\011\\011SELECT count(*) into counter FROM samples \\012\\011\\011\\011\\011where id != NEW.id and code = NEW.code and samp_id_part_of = NEW.samp_id_part_of and grou_id = NEW.grou_id;\\012\\011\\011\\011IF (counter > 0) THEN\\012\\011\\011\\011\\011RAISE EXCEPTION 'Insert/Update of Sample (Code: %) failed because group sample with the same code and being the part of the same parent already exists.', NEW.code;\\012\\011\\011\\011END IF;\\012\\011\\011END IF;\\012        END IF;   \\012   RETURN NEW;\\012END;\\012$$ LANGUAGE 'plpgsql';\\012\\012CREATE TRIGGER SAMPLE_CODE_UNIQUENESS_CHECK BEFORE INSERT OR UPDATE ON SAMPLES\\012    FOR EACH ROW EXECUTE PROCEDURE SAMPLE_CODE_UNIQUENESS_CHECK();\\012	\N
+./sourceTest/sql/postgresql/035/.svn/text-base/013=database_version_logs.tsv.svn-base:028	source/sql/postgresql/migration/migration-027-028.sql	SUCCESS	2008-11-18 13:24:17.508	-- Create EXPERIMENT_ATTACHMENT_CONTENTS.\\012CREATE TABLE EXPERIMENT_ATTACHMENT_CONTENTS (ID TECH_ID NOT NULL,VALUE FILE NOT NULL);\\012CREATE SEQUENCE EXPERIMENT_ATTACHMENT_CONTENT_ID_SEQ;\\012ALTER TABLE EXPERIMENT_ATTACHMENT_CONTENTS ADD CONSTRAINT EXAC_PK PRIMARY KEY(ID);\\012\\012-- Alter EXPERIMENT_ATTACHMENTS by adding the new column which has a NULL constraint.\\012-- The NOT NULL constraint is added later on.\\012ALTER TABLE EXPERIMENT_ATTACHMENTS ADD COLUMN EXAC_ID TECH_ID;\\012\\012-- Does the VALUE migration between EXPERIMENT_ATTACHMENTS to EXPERIMENT_ATTACHMENT_CONTENTS.\\012CREATE OR REPLACE FUNCTION move_exp_att_content() RETURNS integer AS $$\\012DECLARE\\012    rec RECORD;\\012    seq BIGINT;\\012BEGIN\\012  FOR rec IN SELECT id, value FROM EXPERIMENT_ATTACHMENTS LOOP\\012  \\011seq := nextval('EXPERIMENT_ATTACHMENT_CONTENT_ID_SEQ');\\012    INSERT INTO EXPERIMENT_ATTACHMENT_CONTENTS (id, value) VALUES (seq, rec.value);\\012    UPDATE EXPERIMENT_ATTACHMENTS SET exac_id = seq WHERE id = rec.id;\\012  END LOOP;\\012  RETURN 1;\\012END;\\012$$ LANGUAGE 'plpgsql';\\012\\012-- Call the function.\\012SELECT move_exp_att_content();\\012DROP FUNCTION move_exp_att_content();\\012\\012\\012-- Finish EXPERIMENT_ATTACHMENTS changes.\\012ALTER TABLE EXPERIMENT_ATTACHMENTS ADD CONSTRAINT EXAT_CONT_FK FOREIGN KEY (EXAC_ID) REFERENCES EXPERIMENT_ATTACHMENT_CONTENTS(ID);\\012ALTER TABLE EXPERIMENT_ATTACHMENTS DROP COLUMN VALUE;\\012ALTER TABLE EXPERIMENT_ATTACHMENTS ALTER COLUMN EXAC_ID SET NOT NULL;\\012	\N
+./sourceTest/sql/postgresql/035/.svn/text-base/013=database_version_logs.tsv.svn-base:029	source/sql/postgresql/migration/migration-028-029.sql	SUCCESS	2009-03-18 10:50:20.105	-- -------\\012-- add modification_timestamp field to allow edition with Hibernate\\012-- -------\\012\\012ALTER TABLE samples\\012\\011ADD COLUMN modification_timestamp TIME_STAMP DEFAULT CURRENT_TIMESTAMP;\\012\\012ALTER TABLE experiments\\012\\011ADD COLUMN modification_timestamp TIME_STAMP DEFAULT CURRENT_TIMESTAMP;\\012\\012ALTER TABLE materials\\012\\011ADD COLUMN modification_timestamp TIME_STAMP DEFAULT CURRENT_TIMESTAMP;\\012\\012ALTER TABLE experiment_properties\\012\\011ADD COLUMN modification_timestamp TIME_STAMP DEFAULT CURRENT_TIMESTAMP;\\012\\012ALTER TABLE material_properties\\012\\011ADD COLUMN modification_timestamp TIME_STAMP DEFAULT CURRENT_TIMESTAMP;\\012\\012ALTER TABLE sample_properties\\012\\011ADD COLUMN modification_timestamp TIME_STAMP DEFAULT CURRENT_TIMESTAMP;\\012\\012-- -------\\012-- add property data type which references materials\\012-- -------\\012\\012ALTER TABLE property_types\\012\\011ADD COLUMN maty_prop_id tech_id;\\012\\012ALTER TABLE property_types\\012\\011ADD CONSTRAINT prty_maty_fk FOREIGN KEY (maty_prop_id) REFERENCES material_types(id);\\012\\012ALTER TABLE experiment_properties\\012\\011ADD COLUMN mate_prop_id tech_id;\\012\\012ALTER TABLE material_properties\\012\\011ADD COLUMN mate_prop_id tech_id;\\012\\012ALTER TABLE sample_properties\\012\\011ADD COLUMN mate_prop_id tech_id;\\012\\012ALTER TABLE experiment_properties\\012\\011ADD CONSTRAINT expr_mapr_fk FOREIGN KEY (mate_prop_id) REFERENCES materials(id);\\012\\012ALTER TABLE material_properties\\012\\011ADD CONSTRAINT mapr_mapr_fk FOREIGN KEY (mate_prop_id) REFERENCES materials(id);\\012\\012ALTER TABLE sample_properties\\012\\011ADD CONSTRAINT sapr_mapr_fk FOREIGN KEY (mate_prop_id) REFERENCES materials(id);\\012\\012insert into data_types\\012(id\\012 ,code\\012 ,description)\\012 values \\012 (nextval('DATA_TYPE_ID_SEQ')\\012 ,'MATERIAL'\\012 ,'Reference to a material'\\012);\\012\\012ALTER TABLE MATERIAL_PROPERTIES DROP CONSTRAINT MAPR_CK;\\012ALTER TABLE MATERIAL_PROPERTIES ADD CONSTRAINT MAPR_CK CHECK \\012\\011((VALUE IS NOT NULL AND CVTE_ID IS NULL AND MATE_PROP_ID IS NULL) OR \\012\\011 (VALUE IS NULL AND CVTE_ID IS NOT NULL AND MATE_PROP_ID IS NULL) OR\\012\\011 (VALUE IS NULL AND CVTE_ID IS NULL AND MATE_PROP_ID IS NOT NULL)\\012\\011);\\012\\012ALTER TABLE EXPERIMENT_PROPERTIES DROP CONSTRAINT EXPR_CK;\\012ALTER TABLE EXPERIMENT_PROPERTIES ADD CONSTRAINT EXPR_CK CHECK \\012\\011((VALUE IS NOT NULL AND CVTE_ID IS NULL AND MATE_PROP_ID IS NULL) OR \\012\\011 (VALUE IS NULL AND CVTE_ID IS NOT NULL AND MATE_PROP_ID IS NULL) OR\\012\\011 (VALUE IS NULL AND CVTE_ID IS NULL AND MATE_PROP_ID IS NOT NULL)\\012\\011);\\012\\012ALTER TABLE SAMPLE_PROPERTIES DROP CONSTRAINT SAPR_CK;\\012ALTER TABLE SAMPLE_PROPERTIES ADD CONSTRAINT SAPR_CK CHECK \\012\\011((VALUE IS NOT NULL AND CVTE_ID IS NULL AND MATE_PROP_ID IS NULL) OR \\012\\011 (VALUE IS NULL AND CVTE_ID IS NOT NULL AND MATE_PROP_ID IS NULL) OR\\012\\011 (VALUE IS NULL AND CVTE_ID IS NULL AND MATE_PROP_ID IS NOT NULL)\\012\\011);\\012\\012------------------------------------------------------------------------------------\\012--  Purpose:  Create trigger MATERIAL/SAMPLE/EXPERIMENT _PROPERTY_WITH_MATERIAL_DATA_TYPE_CHECK\\012--            It checks that if material property value is assigned to the entity,\\012--\\011\\011\\011\\011\\011\\011then the material type is equal to the one described by property type.\\012------------------------------------------------------------------------------------\\012\\012CREATE OR REPLACE FUNCTION MATERIAL_PROPERTY_WITH_MATERIAL_DATA_TYPE_CHECK() RETURNS trigger AS $$\\012DECLARE\\012   v_type_id  CODE;\\012   v_type_id_prop  CODE;\\012BEGIN\\012   if NEW.mate_prop_id IS NOT NULL then\\012\\011\\011\\011-- find material type id of the property type \\012\\011\\011\\011select pt.maty_prop_id into v_type_id_prop \\012\\011\\011\\011  from material_type_property_types etpt, property_types pt \\012\\011\\011\\011 where NEW.mtpt_id = etpt.id AND etpt.prty_id = pt.id;\\012\\011\\011\\012\\011\\011\\011if v_type_id_prop IS NOT NULL then\\012\\011\\011\\011\\011-- find material type id of the material which consists the entity's property value\\012\\011\\011\\011\\011select entity.maty_id into v_type_id \\012\\011\\011\\011\\011  from materials entity\\012\\011\\011\\011\\011 where NEW.mate_prop_id = entity.id;\\012\\011\\011\\011\\011if v_type_id != v_type_id_prop then\\012\\011\\011\\011\\011\\011RAISE EXCEPTION 'Insert/Update of property value referencing material (id: %) failed, as referenced material type is different than expected (id %, expected id: %).', \\012\\011\\011\\011\\011\\011\\011\\011 NEW.mate_prop_id, v_type_id, v_type_id_prop;\\012\\011\\011\\011\\011end if;\\012\\011\\011\\011end if;\\012   end if;\\012   RETURN NEW;\\012END;\\012$$ LANGUAGE 'plpgsql';\\012\\012CREATE TRIGGER MATERIAL_PROPERTY_WITH_MATERIAL_DATA_TYPE_CHECK BEFORE INSERT OR UPDATE ON material_properties\\012    FOR EACH ROW EXECUTE PROCEDURE MATERIAL_PROPERTY_WITH_MATERIAL_DATA_TYPE_CHECK();\\012    \\012CREATE OR REPLACE FUNCTION SAMPLE_PROPERTY_WITH_MATERIAL_DATA_TYPE_CHECK() RETURNS trigger AS $$\\012DECLARE\\012   v_type_id  CODE;\\012   v_type_id_prop  CODE;\\012BEGIN\\012   if NEW.mate_prop_id IS NOT NULL then\\012\\011\\011\\011-- find material type id of the property type \\012\\011\\011\\011select pt.maty_prop_id into v_type_id_prop \\012\\011\\011\\011  from sample_type_property_types etpt, property_types pt \\012\\011\\011\\011 where NEW.stpt_id = etpt.id AND etpt.prty_id = pt.id;\\012\\011\\011\\012\\011\\011\\011if v_type_id_prop IS NOT NULL then\\012\\011\\011\\011\\011-- find material type id of the material which consists the entity's property value\\012\\011\\011\\011\\011select entity.maty_id into v_type_id \\012\\011\\011\\011\\011  from materials entity\\012\\011\\011\\011\\011 where NEW.mate_prop_id = entity.id;\\012\\011\\011\\011\\011if v_type_id != v_type_id_prop then\\012\\011\\011\\011\\011\\011RAISE EXCEPTION 'Insert/Update of property value referencing material (id: %) failed, as referenced material type is different than expected (id %, expected id: %).', \\012\\011\\011\\011\\011\\011\\011\\011\\011\\011\\011\\011\\011 NEW.mate_prop_id, v_type_id, v_type_id_prop;\\012\\011\\011\\011\\011end if;\\012\\011\\011\\011end if;\\012   end if;\\012   RETURN NEW;\\012END;\\012$$ LANGUAGE 'plpgsql';\\012\\012CREATE TRIGGER SAMPLE_PROPERTY_WITH_MATERIAL_DATA_TYPE_CHECK BEFORE INSERT OR UPDATE ON sample_properties\\012    FOR EACH ROW EXECUTE PROCEDURE SAMPLE_PROPERTY_WITH_MATERIAL_DATA_TYPE_CHECK();\\012    \\012CREATE OR REPLACE FUNCTION EXPERIMENT_PROPERTY_WITH_MATERIAL_DATA_TYPE_CHECK() RETURNS trigger AS $$\\012DECLARE\\012   v_type_id  CODE;\\012   v_type_id_prop  CODE;\\012BEGIN\\012   if NEW.mate_prop_id IS NOT NULL then\\012\\011\\011\\011-- find material type id of the property type \\012\\011\\011\\011select pt.maty_prop_id into v_type_id_prop \\012\\011\\011\\011  from experiment_type_property_types etpt, property_types pt \\012\\011\\011\\011 where NEW.etpt_id = etpt.id AND etpt.prty_id = pt.id;\\012\\011\\011\\012\\011\\011\\011if v_type_id_prop IS NOT NULL then\\012\\011\\011\\011\\011-- find material type id of the material which consists the entity's property value\\012\\011\\011\\011\\011select entity.maty_id into v_type_id \\012\\011\\011\\011\\011  from materials entity\\012\\011\\011\\011\\011 where NEW.mate_prop_id = entity.id;\\012\\011\\011\\011\\011if v_type_id != v_type_id_prop then\\012\\011\\011\\011\\011\\011RAISE EXCEPTION 'Insert/Update of property value referencing material (id: %) failed, as referenced material type is different than expected (id %, expected id: %).', \\012\\011\\011\\011\\011\\011\\011\\011\\011\\011\\011\\011\\011 NEW.mate_prop_id, v_type_id, v_type_id_prop;\\012\\011\\011\\011\\011end if;\\012\\011\\011\\011end if;\\012   end if;\\012   RETURN NEW;\\012END;\\012$$ LANGUAGE 'plpgsql';\\012\\012CREATE TRIGGER EXPERIMENT_PROPERTY_WITH_MATERIAL_DATA_TYPE_CHECK BEFORE INSERT OR UPDATE ON experiment_properties\\012    FOR EACH ROW EXECUTE PROCEDURE EXPERIMENT_PROPERTY_WITH_MATERIAL_DATA_TYPE_CHECK();\\012       \\012-- -------\\012-- remove the reminescents of the OBSERVABLE_TYPE\\012-- -------\\012\\012ALTER TABLE data\\012\\011DROP CONSTRAINT data_obty_fk;\\012\\012ALTER TABLE data_set_types\\012\\011DROP CONSTRAINT obty_pk;\\012\\012ALTER TABLE data_set_types\\012\\011ADD CONSTRAINT dsty_pk PRIMARY KEY (id);\\012\\012ALTER TABLE data\\012\\011ADD CONSTRAINT data_dsty_fk FOREIGN KEY (dsty_id) REFERENCES data_set_types(id);\\012\\012ALTER TABLE data_set_types\\012\\011DROP CONSTRAINT obty_bk_uk;\\012\\012ALTER TABLE data_set_types\\012\\011DROP CONSTRAINT obty_dbin_fk;\\012\\012ALTER TABLE data_set_types\\012\\011ADD CONSTRAINT dsty_bk_uk UNIQUE (code, dbin_id);\\012\\012ALTER TABLE data_set_types\\012\\011ADD CONSTRAINT dsty_dbin_fk FOREIGN KEY (dbin_id) REFERENCES database_instances(id);\\012\\012DROP INDEX data_obty_fk_i;\\012\\012CREATE INDEX data_dsty_fk_i ON data(dsty_id);\\012	\N
+./sourceTest/sql/postgresql/035/.svn/text-base/013=database_version_logs.tsv.svn-base:030	source/sql/postgresql/migration/migration-029-030.sql	SUCCESS	2009-03-23 15:34:44.72	-- -------\\012-- add modification_timestamp field to allow edition with Hibernate\\012-- -------\\012ALTER TABLE data\\012\\011ADD COLUMN modification_timestamp TIME_STAMP DEFAULT CURRENT_TIMESTAMP;\\012ALTER TABLE experiment_types\\012\\011ADD COLUMN modification_timestamp TIME_STAMP DEFAULT CURRENT_TIMESTAMP;\\012ALTER TABLE sample_types\\012\\011ADD COLUMN modification_timestamp TIME_STAMP DEFAULT CURRENT_TIMESTAMP;\\012ALTER TABLE material_types\\012\\011ADD COLUMN modification_timestamp TIME_STAMP DEFAULT CURRENT_TIMESTAMP;\\012ALTER TABLE data_set_types\\012\\011ADD COLUMN modification_timestamp TIME_STAMP DEFAULT CURRENT_TIMESTAMP;\\012ALTER TABLE controlled_vocabularies\\012\\011ADD COLUMN modification_timestamp TIME_STAMP DEFAULT CURRENT_TIMESTAMP;\\012-- -------\\012-- add properties to data sets\\012-- -------\\012CREATE TABLE DATA_SET_PROPERTIES (ID TECH_ID NOT NULL,DS_ID TECH_ID NOT NULL,DSTPT_ID TECH_ID NOT NULL,VALUE GENERIC_VALUE,CVTE_ID TECH_ID, MATE_PROP_ID TECH_ID, PERS_ID_REGISTERER TECH_ID NOT NULL,REGISTRATION_TIMESTAMP TIME_STAMP_DFL NOT NULL DEFAULT CURRENT_TIMESTAMP, MODIFICATION_TIMESTAMP TIME_STAMP DEFAULT CURRENT_TIMESTAMP);\\012CREATE TABLE DATA_SET_TYPE_PROPERTY_TYPES (ID TECH_ID NOT NULL,DSTY_ID TECH_ID NOT NULL,PRTY_ID TECH_ID NOT NULL,IS_MANDATORY BOOLEAN_CHAR NOT NULL DEFAULT 'F',IS_MANAGED_INTERNALLY BOOLEAN_CHAR NOT NULL DEFAULT 'F',PERS_ID_REGISTERER TECH_ID NOT NULL,REGISTRATION_TIMESTAMP TIME_STAMP_DFL NOT NULL DEFAULT CURRENT_TIMESTAMP);\\012\\012CREATE SEQUENCE DATA_SET_PROPERTY_ID_SEQ;\\012CREATE SEQUENCE DSTPT_ID_SEQ;\\012\\012ALTER TABLE DATA_SET_TYPE_PROPERTY_TYPES ADD CONSTRAINT DSTPT_PK PRIMARY KEY(ID);\\012ALTER TABLE DATA_SET_PROPERTIES ADD CONSTRAINT DSPR_PK PRIMARY KEY(ID);\\012\\012ALTER TABLE DATA_SET_TYPE_PROPERTY_TYPES ADD CONSTRAINT DSTPT_BK_UK UNIQUE(DSTY_ID,PRTY_ID);\\012ALTER TABLE DATA_SET_PROPERTIES ADD CONSTRAINT DSPR_BK_UK UNIQUE(DS_ID,DSTPT_ID);\\012\\012\\012ALTER TABLE DATA_SET_TYPE_PROPERTY_TYPES ADD CONSTRAINT DSTPT_DSTY_FK FOREIGN KEY (DSTY_ID) REFERENCES DATA_SET_TYPES(ID);\\012ALTER TABLE DATA_SET_TYPE_PROPERTY_TYPES ADD CONSTRAINT DSTPT_PERS_FK FOREIGN KEY (PERS_ID_REGISTERER) REFERENCES PERSONS(ID);\\012ALTER TABLE DATA_SET_TYPE_PROPERTY_TYPES ADD CONSTRAINT DSTPT_PRTY_FK FOREIGN KEY (PRTY_ID) REFERENCES PROPERTY_TYPES(ID);\\012ALTER TABLE DATA_SET_PROPERTIES ADD CONSTRAINT DSPR_CVTE_FK FOREIGN KEY (CVTE_ID) REFERENCES CONTROLLED_VOCABULARY_TERMS(ID);\\012ALTER TABLE DATA_SET_PROPERTIES ADD CONSTRAINT DSPR_DSTPT_FK FOREIGN KEY (DSTPT_ID) REFERENCES DATA_SET_TYPE_PROPERTY_TYPES(ID) ON DELETE CASCADE;\\012ALTER TABLE DATA_SET_PROPERTIES ADD CONSTRAINT DSPR_DS_FK FOREIGN KEY (DS_ID) REFERENCES DATA(ID);\\012ALTER TABLE DATA_SET_PROPERTIES ADD CONSTRAINT DSPR_PERS_FK FOREIGN KEY (PERS_ID_REGISTERER) REFERENCES PERSONS(ID);\\012ALTER TABLE DATA_SET_PROPERTIES ADD CONSTRAINT DSPR_MAPR_FK FOREIGN KEY (MATE_PROP_ID) REFERENCES MATERIALS(ID);\\012\\012ALTER TABLE DATA_SET_PROPERTIES ADD CONSTRAINT DSPR_CK CHECK \\012\\011((VALUE IS NOT NULL AND CVTE_ID IS NULL AND MATE_PROP_ID IS NULL) OR \\012\\011 (VALUE IS NULL AND CVTE_ID IS NOT NULL AND MATE_PROP_ID IS NULL) OR\\012\\011 (VALUE IS NULL AND CVTE_ID IS NULL AND MATE_PROP_ID IS NOT NULL)\\012\\011);\\012\\012CREATE INDEX DSPR_CVTE_FK_I ON DATA_SET_PROPERTIES (CVTE_ID);\\012CREATE INDEX DSPR_DSTPT_FK_I ON DATA_SET_PROPERTIES (DSTPT_ID);\\012CREATE INDEX DSPR_DS_FK_I ON DATA_SET_PROPERTIES (DS_ID);\\012CREATE INDEX DSPR_PERS_FK_I ON DATA_SET_PROPERTIES (PERS_ID_REGISTERER);\\012CREATE INDEX DSTPT_DSTY_FK_I ON DATA_SET_TYPE_PROPERTY_TYPES (DSTY_ID);\\012CREATE INDEX DSTPT_PERS_FK_I ON DATA_SET_TYPE_PROPERTY_TYPES (PERS_ID_REGISTERER);\\012CREATE INDEX DSTPT_PRTY_FK_I ON DATA_SET_TYPE_PROPERTY_TYPES (PRTY_ID);\\012\\012CREATE OR REPLACE FUNCTION DATA_SET_PROPERTY_WITH_MATERIAL_DATA_TYPE_CHECK() RETURNS trigger AS $$\\012DECLARE\\012   v_type_id  CODE;\\012   v_type_id_prop  CODE;\\012BEGIN\\012   if NEW.mate_prop_id IS NOT NULL then\\012\\011\\011\\011-- find material type id of the property type \\012\\011\\011\\011select pt.maty_prop_id into v_type_id_prop \\012\\011\\011\\011  from data_set_type_property_types dstpt, property_types pt \\012\\011\\011\\011 where NEW.dstpt_id = dstpt.id AND dstpt.prty_id = pt.id;\\012\\011\\011\\012\\011\\011\\011if v_type_id_prop IS NOT NULL then\\012\\011\\011\\011\\011-- find material type id of the material which consists the entity's property value\\012\\011\\011\\011\\011select entity.maty_id into v_type_id \\012\\011\\011\\011\\011  from materials entity\\012\\011\\011\\011\\011 where NEW.mate_prop_id = entity.id;\\012\\011\\011\\011\\011if v_type_id != v_type_id_prop then\\012\\011\\011\\011\\011\\011RAISE EXCEPTION 'Insert/Update of property value referencing material (id: %) failed, as referenced material type is different than expected (id %, expected id: %).', \\012\\011\\011\\011\\011\\011\\011\\011\\011\\011\\011\\011\\011 NEW.mate_prop_id, v_type_id, v_type_id_prop;\\012\\011\\011\\011\\011end if;\\012\\011\\011\\011end if;\\012   end if;\\012   RETURN NEW;\\012END;\\012$$ LANGUAGE 'plpgsql';\\012\\012CREATE TRIGGER DATA_SET_PROPERTY_WITH_MATERIAL_DATA_TYPE_CHECK BEFORE INSERT OR UPDATE ON data_set_properties\\012    FOR EACH ROW EXECUTE PROCEDURE DATA_SET_PROPERTY_WITH_MATERIAL_DATA_TYPE_CHECK();   \\012	\N
+./sourceTest/sql/postgresql/035/.svn/text-base/013=database_version_logs.tsv.svn-base:032	source/sql/postgresql/migration/migration-031-032.sql	SUCCESS	2009-04-09 09:36:36.20	-- -------\\012-- Modify MATERIAL_BATCHES\\012-- -------\\012\\012ALTER TABLE material_batches\\012    DROP COLUMN proc_id;\\012\\012-- -------\\012-- Modify SAMPLES\\012-- -------\\012\\012ALTER TABLE samples\\012    ADD COLUMN expe_id tech_id;\\012\\012ALTER TABLE samples\\012    ADD CONSTRAINT samp_expe_fk FOREIGN KEY (expe_id) REFERENCES experiments(id);\\012\\012CREATE INDEX samp_expe_fk_i ON samples USING btree (expe_id);\\012\\012-- relink samples directly to experiments\\012\\012UPDATE samples\\012SET expe_id = (SELECT e.id FROM experiments e, procedures p, sample_inputs si \\012               WHERE si.samp_id = samples.id AND si.proc_id = p.id AND p.expe_id = e.id AND e.inva_id IS NULL);\\012\\012\\012-- -------\\012-- Modify DATA\\012-- -------\\012\\012ALTER TABLE data\\012    ADD COLUMN expe_id tech_id;\\012\\012ALTER TABLE data\\012    ADD CONSTRAINT data_expe_fk FOREIGN KEY (expe_id) REFERENCES experiments(id);\\012\\012CREATE INDEX data_expe_fk_i ON data USING btree (expe_id);\\012\\012UPDATE data\\012SET expe_id = (SELECT e.id FROM experiments e, procedures p \\012               WHERE data.proc_id_produced_by = p.id AND p.expe_id = e.id);\\012\\012ALTER TABLE data\\012    ALTER COLUMN expe_id SET NOT NULL;\\012\\012ALTER TABLE data\\012    DROP COLUMN proc_id_produced_by;\\012\\012-- -------\\012-- Drop PROCEDURES, PROCEDURE_TYPES, and SAMPLE_INPUTS\\012-- -------\\012\\012DROP TABLE sample_inputs;\\012DROP TABLE procedures;\\012DROP TABLE procedure_types;\\012\\012DROP SEQUENCE procedure_id_seq;\\012DROP SEQUENCE procedure_type_id_seq;\\012\\012-- -------\\012-- Add CODE_SEQ\\012-- -------\\012\\012CREATE SEQUENCE CODE_SEQ;\\012\\012-- -------\\012-- Add new columns to DATA_STORES\\012-- -------\\012\\012ALTER TABLE data_stores\\012    ADD COLUMN remote_url character varying(250),\\012    ADD COLUMN session_token character varying(50),\\012    ADD COLUMN modification_timestamp time_stamp DEFAULT now();\\012\\012UPDATE data_stores\\012SET remote_url = '', session_token='';\\012\\012ALTER TABLE data_stores\\012    ALTER COLUMN remote_url SET NOT NULL,\\012    ALTER COLUMN session_token SET NOT NULL;\\012\\012-- -------\\012-- Drop foreign keys onto DATA_STORES\\012-- -------\\012\\012ALTER TABLE database_instances\\012    DROP COLUMN dast_id;\\012\\012ALTER TABLE groups\\012    DROP COLUMN dast_id;\\012\\012ALTER TABLE projects\\012    DROP COLUMN dast_id;\\012\\012ALTER TABLE experiments\\012    DROP COLUMN dast_id;\\012\\012-- -------\\012-- Add foreign key from DATA onto DATA_STORES\\012-- -------\\012\\012ALTER TABLE data\\012    ADD COLUMN dast_id tech_id;\\012\\012ALTER TABLE data\\012    ADD CONSTRAINT data_dast_fk FOREIGN KEY (dast_id) REFERENCES data_stores(id);\\012\\012UPDATE data\\012SET dast_id = (select id from data_stores where code = 'STANDARD');\\012\\012ALTER TABLE data\\012    ALTER COLUMN dast_id SET NOT NULL;\\012\\012\\012------------------------------------------------------------------------------------\\012--  Purpose:  Replace trigger SAMPLE_CODE_UNIQUENESS_CHECK \\012------------------------------------------------------------------------------------\\012\\012CREATE OR REPLACE FUNCTION SAMPLE_CODE_UNIQUENESS_CHECK() RETURNS trigger AS $$\\012DECLARE\\012   counter  INTEGER;\\012BEGIN\\012    LOCK TABLE samples IN EXCLUSIVE MODE;\\012    IF (NEW.samp_id_part_of is NULL) THEN\\012        IF (NEW.dbin_id is not NULL) THEN\\012            SELECT count(*) into counter FROM samples \\012                where id != NEW.id and code = NEW.code and samp_id_part_of is NULL and dbin_id = NEW.dbin_id;\\012            IF (counter > 0) THEN\\012                RAISE EXCEPTION 'Insert/Update of Sample (Code: %) failed because database instance sample with the same code already exists.', NEW.code;\\012            END IF;\\012        ELSIF (NEW.grou_id is not NULL) THEN\\012            SELECT count(*) into counter FROM samples \\012                where id != NEW.id and code = NEW.code and samp_id_part_of is NULL and grou_id = NEW.grou_id;\\012            IF (counter > 0) THEN\\012                RAISE EXCEPTION 'Insert/Update of Sample (Code: %) failed because group sample with the same code already exists.', NEW.code;\\012            END IF;\\012        END IF;\\012        ELSE\\012        IF (NEW.dbin_id is not NULL) THEN\\012            SELECT count(*) into counter FROM samples \\012                where id != NEW.id and code = NEW.code and samp_id_part_of = NEW.samp_id_part_of and dbin_id = NEW.dbin_id;\\012            IF (counter > 0) THEN\\012                RAISE EXCEPTION 'Insert/Update of Sample (Code: %) failed because database instance sample with the same code and being the part of the same parent already exists.', NEW.code;\\012            END IF;\\012        ELSIF (NEW.grou_id is not NULL) THEN\\012            SELECT count(*) into counter FROM samples \\012                where id != NEW.id and code = NEW.code and samp_id_part_of = NEW.samp_id_part_of and grou_id = NEW.grou_id;\\012            IF (counter > 0) THEN\\012                RAISE EXCEPTION 'Insert/Update of Sample (Code: %) failed because group sample with the same code and being the part of the same parent already exists.', NEW.code;\\012            END IF;\\012        END IF;\\012        END IF;   \\012   RETURN NEW;\\012END;\\012$$ LANGUAGE 'plpgsql';\\012\\012\\012\\012	\N
+./sourceTest/sql/postgresql/035/.svn/text-base/013=database_version_logs.tsv.svn-base:034	source/sql/postgresql/migration/migration-033-034.sql	SUCCESS	2009-05-26 08:32:49.935	------------------------------------------------------------------------------------\\012-- Create sequence for generating permanent identifiers starting with nextval of existing dataset sequence.\\012------------------------------------------------------------------------------------\\012CREATE FUNCTION CREATE_SEQUENCE(EXISTING_SEQUENCE VARCHAR, NEW_SEQUENCE VARCHAR) RETURNS VOID AS $$\\012DECLARE\\012  CURR_SEQ_VAL   INTEGER;\\012BEGIN\\012  SELECT INTO CURR_SEQ_VAL NEXTVAL(EXISTING_SEQUENCE);\\012  EXECUTE 'CREATE SEQUENCE ' || NEW_SEQUENCE || ' START WITH ' || CURR_SEQ_VAL;\\012  RETURN;\\012END;\\012$$ LANGUAGE 'plpgsql';\\012\\012SELECT CREATE_SEQUENCE('DATA_ID_SEQ', 'PERM_ID_SEQ');\\012DROP FUNCTION CREATE_SEQUENCE(VARCHAR, VARCHAR);\\012\\012------------------------------------------------------------------------------------\\012-- Add perm_id columns to samples and experiments.\\012------------------------------------------------------------------------------------\\012ALTER TABLE SAMPLES ADD COLUMN PERM_ID CODE;\\012ALTER TABLE EXPERIMENTS ADD COLUMN PERM_ID CODE;\\012\\012UPDATE SAMPLES SET PERM_ID = to_char(registration_timestamp,'YYYYMMDDHHSSMS') || '-' || NEXTVAL('PERM_ID_SEQ');\\012UPDATE EXPERIMENTS SET PERM_ID = to_char(registration_timestamp,'YYYYMMDDHHSSMS') || '-' || NEXTVAL('PERM_ID_SEQ');\\012ALTER TABLE SAMPLES ALTER COLUMN PERM_ID SET NOT NULL;\\012ALTER TABLE EXPERIMENTS ALTER COLUMN PERM_ID SET NOT NULL;\\012ALTER TABLE SAMPLES ADD CONSTRAINT SAMP_PI_UK UNIQUE(PERM_ID);\\012ALTER TABLE EXPERIMENTS ADD CONSTRAINT EXPE_PI_UK UNIQUE(PERM_ID);\\012\\012\\012------------------------------------------------------------------------------------\\012-- Add column is_chosen_from_list to controlled_vocabularies.\\012------------------------------------------------------------------------------------\\012ALTER TABLE controlled_vocabularies ADD COLUMN is_chosen_from_list BOOLEAN_CHAR NOT NULL DEFAULT TRUE;\\012ALTER TABLE controlled_vocabularies ADD COLUMN source_uri CHARACTER VARYING(250);\\012------------------------------------------------------------------------------------\\012-- Modify Data table - remove arc connection between Sample and Data table, use a flag instead\\012------------------------------------------------------------------------------------\\012\\012-- add new columns\\012\\012ALTER TABLE data\\012    ADD COLUMN is_derived boolean_char;\\012ALTER TABLE data\\012    ADD COLUMN samp_id tech_id;\\012\\012-- update values in new columns\\012\\012UPDATE data\\012    SET is_derived = (samp_id_derived_from IS NOT NULL); \\012UPDATE data\\012    SET samp_id = samp_id_derived_from \\012    WHERE is_derived = 'TRUE';\\012UPDATE data\\012    SET samp_id = samp_id_acquired_from \\012    WHERE is_derived = 'FALSE';\\012\\012-- add constraints and indexes to new columns\\012\\012ALTER TABLE data\\012    ALTER COLUMN is_derived SET NOT NULL;\\012ALTER TABLE data\\012    ALTER COLUMN samp_id SET NOT NULL;   \\012ALTER TABLE data\\012    ADD CONSTRAINT data_samp_fk FOREIGN KEY (samp_id) REFERENCES samples (id);\\012CREATE INDEX data_samp_fk_i ON data USING btree (samp_id);\\012\\012-- remove old columns\\012\\012ALTER TABLE data\\012    DROP COLUMN samp_id_acquired_from;\\012ALTER TABLE data\\012    DROP COLUMN samp_id_derived_from;\\012    \\012------------------------------------------------------------------------------------\\012-- Granting SELECT privilege to group openbis_readonly\\012------------------------------------------------------------------------------------\\012\\012GRANT SELECT ON SEQUENCE attachment_content_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE attachment_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE code_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE controlled_vocabulary_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE cvte_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE data_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE data_set_property_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE data_set_relationship_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE data_set_type_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE data_store_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE data_type_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE database_instance_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE dstpt_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE etpt_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE event_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE experiment_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE experiment_property_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE experiment_type_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE file_format_type_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE group_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE invalidation_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE locator_type_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE material_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE material_property_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE material_type_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE mtpt_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE perm_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE person_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE project_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE property_type_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE role_assignment_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE sample_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE sample_property_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE sample_type_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE stpt_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE attachment_contents TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE attachments TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE controlled_vocabularies TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE controlled_vocabulary_terms TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE data TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE data_set_properties TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE data_set_relationships TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE data_set_type_property_types TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE data_set_types TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE data_stores TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE data_types TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE database_instances TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE database_version_logs TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE events TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE experiment_properties TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE experiment_type_property_types TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE experiment_types TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE experiments TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE external_data TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE file_format_types TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE groups TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE invalidations TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE locator_types TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE material_properties TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE material_type_property_types TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE material_types TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE materials TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE persons TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE projects TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE property_types TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE role_assignments TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE sample_properties TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE sample_type_property_types TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE sample_types TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE samples TO GROUP OPENBIS_READONLY;\\012\\012------------------------------------------------------------------------------------\\012-- Delete MATERIAL_BATCHES table\\012------------------------------------------------------------------------------------\\012\\012-- WARNING: Potential data lost!!!\\012-- WARNING: Potential data lost!!!\\012-- WARNING: Potential data lost!!!\\012\\012DROP TABLE SAMPLE_MATERIAL_BATCHES;\\012DROP TABLE MATERIAL_BATCHES;\\012DROP SEQUENCE MATERIAL_BATCH_ID_SEQ;\\012\\012------------------------------------------------------------------------------------\\012-- Delete MATE_ID_INHIBITOR_OF from table MATERIALS\\012------------------------------------------------------------------------------------\\012\\012-- WARNING: Potential data lost!!!\\012-- WARNING: Potential data lost!!!\\012-- WARNING: Potential data lost!!!\\012\\012ALTER TABLE MATERIALS DROP COLUMN MATE_ID_INHIBITOR_OF;\\012	\N
+./sourceTest/sql/postgresql/035/.svn/text-base/schema-035.sql.svn-base:    LANGUAGE plpgsql;
+./sourceTest/sql/postgresql/035/.svn/text-base/schema-035.sql.svn-base:    LANGUAGE plpgsql;
+./sourceTest/sql/postgresql/035/.svn/text-base/schema-035.sql.svn-base:    LANGUAGE plpgsql;
+./sourceTest/sql/postgresql/035/.svn/text-base/schema-035.sql.svn-base:    LANGUAGE plpgsql;
+./sourceTest/sql/postgresql/035/.svn/text-base/schema-035.sql.svn-base:    LANGUAGE plpgsql;
+./sourceTest/sql/postgresql/035/.svn/text-base/schema-035.sql.svn-base:    LANGUAGE plpgsql;
+./sourceTest/sql/postgresql/035/.svn/text-base/schema-035.sql.svn-base:    LANGUAGE plpgsql;
+./sourceTest/sql/postgresql/035/.svn/text-base/schema-035.sql.svn-base:    LANGUAGE plpgsql;
+./sourceTest/sql/postgresql/035/013=database_version_logs.tsv:027	D:\\User\\felmer\\dev-workspace\\openbis/source/sql/postgresql/027/function-027.sql	SUCCESS	2008-11-05 09:18:00.403	-- Creating Functions\\012\\012------------------------------------------------------------------------------------\\012--  Purpose:  Create function RENAME_SEQUENCE() that is required for renaming the sequences belonging to tables\\012------------------------------------------------------------------------------------\\012CREATE FUNCTION RENAME_SEQUENCE(OLD_NAME VARCHAR, NEW_NAME VARCHAR) RETURNS INTEGER AS $$\\012DECLARE\\012  CURR_SEQ_VAL   INTEGER;\\012BEGIN\\012  SELECT INTO CURR_SEQ_VAL NEXTVAL(OLD_NAME);\\012  EXECUTE 'CREATE SEQUENCE ' || NEW_NAME || ' START WITH ' || CURR_SEQ_VAL;\\012  EXECUTE 'DROP SEQUENCE ' || OLD_NAME;\\012  RETURN CURR_SEQ_VAL;\\012END;\\012$$ LANGUAGE 'plpgsql';\\012\\012\\012------------------------------------------------------------------------------------\\012--  Purpose:  Create trigger CONTROLLED_VOCABULARY_CHECK \\012------------------------------------------------------------------------------------\\012\\012CREATE OR REPLACE FUNCTION CONTROLLED_VOCABULARY_CHECK() RETURNS trigger AS $$\\012DECLARE\\012   v_code  CODE;\\012BEGIN\\012\\012   select code into v_code from data_types where id = NEW.daty_id;\\012\\012   -- Check if the data is of type "CONTROLLEDVOCABULARY"\\012   if v_code = 'CONTROLLEDVOCABULARY' then\\012      if NEW.covo_id IS NULL then\\012         RAISE EXCEPTION 'Insert/Update of Property Type (Code: %) failed, as its Data Type is CONTROLLEDVOCABULARY, but it is not linked to a Controlled Vocabulary.', NEW.code;\\012      end if;\\012   end if;\\012\\012   RETURN NEW;\\012\\012END;\\012$$ LANGUAGE 'plpgsql';\\012\\012CREATE TRIGGER CONTROLLED_VOCABULARY_CHECK BEFORE INSERT OR UPDATE ON PROPERTY_TYPES\\012    FOR EACH ROW EXECUTE PROCEDURE CONTROLLED_VOCABULARY_CHECK();\\012\\012\\012------------------------------------------------------------------------------------\\012--  Purpose:  Create trigger EXTERNAL_DATA_STORAGE_FORMAT_CHECK \\012------------------------------------------------------------------------------------\\012\\012CREATE OR REPLACE FUNCTION EXTERNAL_DATA_STORAGE_FORMAT_CHECK() RETURNS trigger AS $$\\012DECLARE\\012   v_covo_code  CODE;\\012   data_code CODE;\\012BEGIN\\012\\012   select code into v_covo_code from controlled_vocabularies\\012      where is_internal_namespace = true and \\012         id = (select covo_id from controlled_vocabulary_terms where id = NEW.cvte_id_stor_fmt);\\012   -- Check if the data storage format is a term of the controlled vocabulary "STORAGE_FORMAT"\\012   if v_covo_code != 'STORAGE_FORMAT' then\\012      select code into data_code from data where id = NEW.data_id; \\012      RAISE EXCEPTION 'Insert/Update of Data (Code: %) failed, as its Storage Format is %, but is required to be STORAGE_FORMAT.', data_code, v_covo_code;\\012   end if;\\012\\012   RETURN NEW;\\012\\012END;\\012$$ LANGUAGE 'plpgsql';\\012\\012CREATE TRIGGER EXTERNAL_DATA_STORAGE_FORMAT_CHECK BEFORE INSERT OR UPDATE ON EXTERNAL_DATA\\012    FOR EACH ROW EXECUTE PROCEDURE EXTERNAL_DATA_STORAGE_FORMAT_CHECK();\\012\\012------------------------------------------------------------------------------------\\012--  Purpose:  Create trigger SAMPLE_CODE_UNIQUENESS_CHECK \\012------------------------------------------------------------------------------------\\012\\012CREATE OR REPLACE FUNCTION SAMPLE_CODE_UNIQUENESS_CHECK() RETURNS trigger AS $$\\012DECLARE\\012   counter  INTEGER;\\012BEGIN\\012\\011IF (NEW.samp_id_part_of is NULL) THEN\\012\\011\\011IF (NEW.dbin_id is not NULL) THEN\\012\\011\\011\\011SELECT count(*) into counter FROM samples \\012\\011\\011\\011\\011where id != NEW.id and code = NEW.code and samp_id_part_of is NULL and dbin_id = NEW.dbin_id;\\012\\011\\011\\011IF (counter > 0) THEN\\012\\011\\011\\011\\011RAISE EXCEPTION 'Insert/Update of Sample (Code: %) failed because database instance sample with the same code already exists.', NEW.code;\\012\\011\\011\\011END IF;\\012\\011\\011ELSIF (NEW.grou_id is not NULL) THEN\\012\\011\\011\\011SELECT count(*) into counter FROM samples \\012\\011\\011\\011\\011where id != NEW.id and code = NEW.code and samp_id_part_of is NULL and grou_id = NEW.grou_id;\\012\\011\\011\\011IF (counter > 0) THEN\\012\\011\\011\\011\\011RAISE EXCEPTION 'Insert/Update of Sample (Code: %) failed because group sample with the same code already exists.', NEW.code;\\012\\011\\011\\011END IF;\\012\\011\\011END IF;\\012        ELSE\\012\\011\\011IF (NEW.dbin_id is not NULL) THEN\\012\\011\\011\\011SELECT count(*) into counter FROM samples \\012\\011\\011\\011\\011where id != NEW.id and code = NEW.code and samp_id_part_of = NEW.samp_id_part_of and dbin_id = NEW.dbin_id;\\012\\011\\011\\011IF (counter > 0) THEN\\012\\011\\011\\011\\011RAISE EXCEPTION 'Insert/Update of Sample (Code: %) failed because database instance sample with the same code and being the part of the same parent already exists.', NEW.code;\\012\\011\\011\\011END IF;\\012\\011\\011ELSIF (NEW.grou_id is not NULL) THEN\\012\\011\\011\\011SELECT count(*) into counter FROM samples \\012\\011\\011\\011\\011where id != NEW.id and code = NEW.code and samp_id_part_of = NEW.samp_id_part_of and grou_id = NEW.grou_id;\\012\\011\\011\\011IF (counter > 0) THEN\\012\\011\\011\\011\\011RAISE EXCEPTION 'Insert/Update of Sample (Code: %) failed because group sample with the same code and being the part of the same parent already exists.', NEW.code;\\012\\011\\011\\011END IF;\\012\\011\\011END IF;\\012        END IF;   \\012   RETURN NEW;\\012END;\\012$$ LANGUAGE 'plpgsql';\\012\\012CREATE TRIGGER SAMPLE_CODE_UNIQUENESS_CHECK BEFORE INSERT OR UPDATE ON SAMPLES\\012    FOR EACH ROW EXECUTE PROCEDURE SAMPLE_CODE_UNIQUENESS_CHECK();\\012	\N
+./sourceTest/sql/postgresql/035/013=database_version_logs.tsv:028	source/sql/postgresql/migration/migration-027-028.sql	SUCCESS	2008-11-18 13:24:17.508	-- Create EXPERIMENT_ATTACHMENT_CONTENTS.\\012CREATE TABLE EXPERIMENT_ATTACHMENT_CONTENTS (ID TECH_ID NOT NULL,VALUE FILE NOT NULL);\\012CREATE SEQUENCE EXPERIMENT_ATTACHMENT_CONTENT_ID_SEQ;\\012ALTER TABLE EXPERIMENT_ATTACHMENT_CONTENTS ADD CONSTRAINT EXAC_PK PRIMARY KEY(ID);\\012\\012-- Alter EXPERIMENT_ATTACHMENTS by adding the new column which has a NULL constraint.\\012-- The NOT NULL constraint is added later on.\\012ALTER TABLE EXPERIMENT_ATTACHMENTS ADD COLUMN EXAC_ID TECH_ID;\\012\\012-- Does the VALUE migration between EXPERIMENT_ATTACHMENTS to EXPERIMENT_ATTACHMENT_CONTENTS.\\012CREATE OR REPLACE FUNCTION move_exp_att_content() RETURNS integer AS $$\\012DECLARE\\012    rec RECORD;\\012    seq BIGINT;\\012BEGIN\\012  FOR rec IN SELECT id, value FROM EXPERIMENT_ATTACHMENTS LOOP\\012  \\011seq := nextval('EXPERIMENT_ATTACHMENT_CONTENT_ID_SEQ');\\012    INSERT INTO EXPERIMENT_ATTACHMENT_CONTENTS (id, value) VALUES (seq, rec.value);\\012    UPDATE EXPERIMENT_ATTACHMENTS SET exac_id = seq WHERE id = rec.id;\\012  END LOOP;\\012  RETURN 1;\\012END;\\012$$ LANGUAGE 'plpgsql';\\012\\012-- Call the function.\\012SELECT move_exp_att_content();\\012DROP FUNCTION move_exp_att_content();\\012\\012\\012-- Finish EXPERIMENT_ATTACHMENTS changes.\\012ALTER TABLE EXPERIMENT_ATTACHMENTS ADD CONSTRAINT EXAT_CONT_FK FOREIGN KEY (EXAC_ID) REFERENCES EXPERIMENT_ATTACHMENT_CONTENTS(ID);\\012ALTER TABLE EXPERIMENT_ATTACHMENTS DROP COLUMN VALUE;\\012ALTER TABLE EXPERIMENT_ATTACHMENTS ALTER COLUMN EXAC_ID SET NOT NULL;\\012	\N
+./sourceTest/sql/postgresql/035/013=database_version_logs.tsv:029	source/sql/postgresql/migration/migration-028-029.sql	SUCCESS	2009-03-18 10:50:20.105	-- -------\\012-- add modification_timestamp field to allow edition with Hibernate\\012-- -------\\012\\012ALTER TABLE samples\\012\\011ADD COLUMN modification_timestamp TIME_STAMP DEFAULT CURRENT_TIMESTAMP;\\012\\012ALTER TABLE experiments\\012\\011ADD COLUMN modification_timestamp TIME_STAMP DEFAULT CURRENT_TIMESTAMP;\\012\\012ALTER TABLE materials\\012\\011ADD COLUMN modification_timestamp TIME_STAMP DEFAULT CURRENT_TIMESTAMP;\\012\\012ALTER TABLE experiment_properties\\012\\011ADD COLUMN modification_timestamp TIME_STAMP DEFAULT CURRENT_TIMESTAMP;\\012\\012ALTER TABLE material_properties\\012\\011ADD COLUMN modification_timestamp TIME_STAMP DEFAULT CURRENT_TIMESTAMP;\\012\\012ALTER TABLE sample_properties\\012\\011ADD COLUMN modification_timestamp TIME_STAMP DEFAULT CURRENT_TIMESTAMP;\\012\\012-- -------\\012-- add property data type which references materials\\012-- -------\\012\\012ALTER TABLE property_types\\012\\011ADD COLUMN maty_prop_id tech_id;\\012\\012ALTER TABLE property_types\\012\\011ADD CONSTRAINT prty_maty_fk FOREIGN KEY (maty_prop_id) REFERENCES material_types(id);\\012\\012ALTER TABLE experiment_properties\\012\\011ADD COLUMN mate_prop_id tech_id;\\012\\012ALTER TABLE material_properties\\012\\011ADD COLUMN mate_prop_id tech_id;\\012\\012ALTER TABLE sample_properties\\012\\011ADD COLUMN mate_prop_id tech_id;\\012\\012ALTER TABLE experiment_properties\\012\\011ADD CONSTRAINT expr_mapr_fk FOREIGN KEY (mate_prop_id) REFERENCES materials(id);\\012\\012ALTER TABLE material_properties\\012\\011ADD CONSTRAINT mapr_mapr_fk FOREIGN KEY (mate_prop_id) REFERENCES materials(id);\\012\\012ALTER TABLE sample_properties\\012\\011ADD CONSTRAINT sapr_mapr_fk FOREIGN KEY (mate_prop_id) REFERENCES materials(id);\\012\\012insert into data_types\\012(id\\012 ,code\\012 ,description)\\012 values \\012 (nextval('DATA_TYPE_ID_SEQ')\\012 ,'MATERIAL'\\012 ,'Reference to a material'\\012);\\012\\012ALTER TABLE MATERIAL_PROPERTIES DROP CONSTRAINT MAPR_CK;\\012ALTER TABLE MATERIAL_PROPERTIES ADD CONSTRAINT MAPR_CK CHECK \\012\\011((VALUE IS NOT NULL AND CVTE_ID IS NULL AND MATE_PROP_ID IS NULL) OR \\012\\011 (VALUE IS NULL AND CVTE_ID IS NOT NULL AND MATE_PROP_ID IS NULL) OR\\012\\011 (VALUE IS NULL AND CVTE_ID IS NULL AND MATE_PROP_ID IS NOT NULL)\\012\\011);\\012\\012ALTER TABLE EXPERIMENT_PROPERTIES DROP CONSTRAINT EXPR_CK;\\012ALTER TABLE EXPERIMENT_PROPERTIES ADD CONSTRAINT EXPR_CK CHECK \\012\\011((VALUE IS NOT NULL AND CVTE_ID IS NULL AND MATE_PROP_ID IS NULL) OR \\012\\011 (VALUE IS NULL AND CVTE_ID IS NOT NULL AND MATE_PROP_ID IS NULL) OR\\012\\011 (VALUE IS NULL AND CVTE_ID IS NULL AND MATE_PROP_ID IS NOT NULL)\\012\\011);\\012\\012ALTER TABLE SAMPLE_PROPERTIES DROP CONSTRAINT SAPR_CK;\\012ALTER TABLE SAMPLE_PROPERTIES ADD CONSTRAINT SAPR_CK CHECK \\012\\011((VALUE IS NOT NULL AND CVTE_ID IS NULL AND MATE_PROP_ID IS NULL) OR \\012\\011 (VALUE IS NULL AND CVTE_ID IS NOT NULL AND MATE_PROP_ID IS NULL) OR\\012\\011 (VALUE IS NULL AND CVTE_ID IS NULL AND MATE_PROP_ID IS NOT NULL)\\012\\011);\\012\\012------------------------------------------------------------------------------------\\012--  Purpose:  Create trigger MATERIAL/SAMPLE/EXPERIMENT _PROPERTY_WITH_MATERIAL_DATA_TYPE_CHECK\\012--            It checks that if material property value is assigned to the entity,\\012--\\011\\011\\011\\011\\011\\011then the material type is equal to the one described by property type.\\012------------------------------------------------------------------------------------\\012\\012CREATE OR REPLACE FUNCTION MATERIAL_PROPERTY_WITH_MATERIAL_DATA_TYPE_CHECK() RETURNS trigger AS $$\\012DECLARE\\012   v_type_id  CODE;\\012   v_type_id_prop  CODE;\\012BEGIN\\012   if NEW.mate_prop_id IS NOT NULL then\\012\\011\\011\\011-- find material type id of the property type \\012\\011\\011\\011select pt.maty_prop_id into v_type_id_prop \\012\\011\\011\\011  from material_type_property_types etpt, property_types pt \\012\\011\\011\\011 where NEW.mtpt_id = etpt.id AND etpt.prty_id = pt.id;\\012\\011\\011\\012\\011\\011\\011if v_type_id_prop IS NOT NULL then\\012\\011\\011\\011\\011-- find material type id of the material which consists the entity's property value\\012\\011\\011\\011\\011select entity.maty_id into v_type_id \\012\\011\\011\\011\\011  from materials entity\\012\\011\\011\\011\\011 where NEW.mate_prop_id = entity.id;\\012\\011\\011\\011\\011if v_type_id != v_type_id_prop then\\012\\011\\011\\011\\011\\011RAISE EXCEPTION 'Insert/Update of property value referencing material (id: %) failed, as referenced material type is different than expected (id %, expected id: %).', \\012\\011\\011\\011\\011\\011\\011\\011 NEW.mate_prop_id, v_type_id, v_type_id_prop;\\012\\011\\011\\011\\011end if;\\012\\011\\011\\011end if;\\012   end if;\\012   RETURN NEW;\\012END;\\012$$ LANGUAGE 'plpgsql';\\012\\012CREATE TRIGGER MATERIAL_PROPERTY_WITH_MATERIAL_DATA_TYPE_CHECK BEFORE INSERT OR UPDATE ON material_properties\\012    FOR EACH ROW EXECUTE PROCEDURE MATERIAL_PROPERTY_WITH_MATERIAL_DATA_TYPE_CHECK();\\012    \\012CREATE OR REPLACE FUNCTION SAMPLE_PROPERTY_WITH_MATERIAL_DATA_TYPE_CHECK() RETURNS trigger AS $$\\012DECLARE\\012   v_type_id  CODE;\\012   v_type_id_prop  CODE;\\012BEGIN\\012   if NEW.mate_prop_id IS NOT NULL then\\012\\011\\011\\011-- find material type id of the property type \\012\\011\\011\\011select pt.maty_prop_id into v_type_id_prop \\012\\011\\011\\011  from sample_type_property_types etpt, property_types pt \\012\\011\\011\\011 where NEW.stpt_id = etpt.id AND etpt.prty_id = pt.id;\\012\\011\\011\\012\\011\\011\\011if v_type_id_prop IS NOT NULL then\\012\\011\\011\\011\\011-- find material type id of the material which consists the entity's property value\\012\\011\\011\\011\\011select entity.maty_id into v_type_id \\012\\011\\011\\011\\011  from materials entity\\012\\011\\011\\011\\011 where NEW.mate_prop_id = entity.id;\\012\\011\\011\\011\\011if v_type_id != v_type_id_prop then\\012\\011\\011\\011\\011\\011RAISE EXCEPTION 'Insert/Update of property value referencing material (id: %) failed, as referenced material type is different than expected (id %, expected id: %).', \\012\\011\\011\\011\\011\\011\\011\\011\\011\\011\\011\\011\\011 NEW.mate_prop_id, v_type_id, v_type_id_prop;\\012\\011\\011\\011\\011end if;\\012\\011\\011\\011end if;\\012   end if;\\012   RETURN NEW;\\012END;\\012$$ LANGUAGE 'plpgsql';\\012\\012CREATE TRIGGER SAMPLE_PROPERTY_WITH_MATERIAL_DATA_TYPE_CHECK BEFORE INSERT OR UPDATE ON sample_properties\\012    FOR EACH ROW EXECUTE PROCEDURE SAMPLE_PROPERTY_WITH_MATERIAL_DATA_TYPE_CHECK();\\012    \\012CREATE OR REPLACE FUNCTION EXPERIMENT_PROPERTY_WITH_MATERIAL_DATA_TYPE_CHECK() RETURNS trigger AS $$\\012DECLARE\\012   v_type_id  CODE;\\012   v_type_id_prop  CODE;\\012BEGIN\\012   if NEW.mate_prop_id IS NOT NULL then\\012\\011\\011\\011-- find material type id of the property type \\012\\011\\011\\011select pt.maty_prop_id into v_type_id_prop \\012\\011\\011\\011  from experiment_type_property_types etpt, property_types pt \\012\\011\\011\\011 where NEW.etpt_id = etpt.id AND etpt.prty_id = pt.id;\\012\\011\\011\\012\\011\\011\\011if v_type_id_prop IS NOT NULL then\\012\\011\\011\\011\\011-- find material type id of the material which consists the entity's property value\\012\\011\\011\\011\\011select entity.maty_id into v_type_id \\012\\011\\011\\011\\011  from materials entity\\012\\011\\011\\011\\011 where NEW.mate_prop_id = entity.id;\\012\\011\\011\\011\\011if v_type_id != v_type_id_prop then\\012\\011\\011\\011\\011\\011RAISE EXCEPTION 'Insert/Update of property value referencing material (id: %) failed, as referenced material type is different than expected (id %, expected id: %).', \\012\\011\\011\\011\\011\\011\\011\\011\\011\\011\\011\\011\\011 NEW.mate_prop_id, v_type_id, v_type_id_prop;\\012\\011\\011\\011\\011end if;\\012\\011\\011\\011end if;\\012   end if;\\012   RETURN NEW;\\012END;\\012$$ LANGUAGE 'plpgsql';\\012\\012CREATE TRIGGER EXPERIMENT_PROPERTY_WITH_MATERIAL_DATA_TYPE_CHECK BEFORE INSERT OR UPDATE ON experiment_properties\\012    FOR EACH ROW EXECUTE PROCEDURE EXPERIMENT_PROPERTY_WITH_MATERIAL_DATA_TYPE_CHECK();\\012       \\012-- -------\\012-- remove the reminescents of the OBSERVABLE_TYPE\\012-- -------\\012\\012ALTER TABLE data\\012\\011DROP CONSTRAINT data_obty_fk;\\012\\012ALTER TABLE data_set_types\\012\\011DROP CONSTRAINT obty_pk;\\012\\012ALTER TABLE data_set_types\\012\\011ADD CONSTRAINT dsty_pk PRIMARY KEY (id);\\012\\012ALTER TABLE data\\012\\011ADD CONSTRAINT data_dsty_fk FOREIGN KEY (dsty_id) REFERENCES data_set_types(id);\\012\\012ALTER TABLE data_set_types\\012\\011DROP CONSTRAINT obty_bk_uk;\\012\\012ALTER TABLE data_set_types\\012\\011DROP CONSTRAINT obty_dbin_fk;\\012\\012ALTER TABLE data_set_types\\012\\011ADD CONSTRAINT dsty_bk_uk UNIQUE (code, dbin_id);\\012\\012ALTER TABLE data_set_types\\012\\011ADD CONSTRAINT dsty_dbin_fk FOREIGN KEY (dbin_id) REFERENCES database_instances(id);\\012\\012DROP INDEX data_obty_fk_i;\\012\\012CREATE INDEX data_dsty_fk_i ON data(dsty_id);\\012	\N
+./sourceTest/sql/postgresql/035/013=database_version_logs.tsv:030	source/sql/postgresql/migration/migration-029-030.sql	SUCCESS	2009-03-23 15:34:44.72	-- -------\\012-- add modification_timestamp field to allow edition with Hibernate\\012-- -------\\012ALTER TABLE data\\012\\011ADD COLUMN modification_timestamp TIME_STAMP DEFAULT CURRENT_TIMESTAMP;\\012ALTER TABLE experiment_types\\012\\011ADD COLUMN modification_timestamp TIME_STAMP DEFAULT CURRENT_TIMESTAMP;\\012ALTER TABLE sample_types\\012\\011ADD COLUMN modification_timestamp TIME_STAMP DEFAULT CURRENT_TIMESTAMP;\\012ALTER TABLE material_types\\012\\011ADD COLUMN modification_timestamp TIME_STAMP DEFAULT CURRENT_TIMESTAMP;\\012ALTER TABLE data_set_types\\012\\011ADD COLUMN modification_timestamp TIME_STAMP DEFAULT CURRENT_TIMESTAMP;\\012ALTER TABLE controlled_vocabularies\\012\\011ADD COLUMN modification_timestamp TIME_STAMP DEFAULT CURRENT_TIMESTAMP;\\012-- -------\\012-- add properties to data sets\\012-- -------\\012CREATE TABLE DATA_SET_PROPERTIES (ID TECH_ID NOT NULL,DS_ID TECH_ID NOT NULL,DSTPT_ID TECH_ID NOT NULL,VALUE GENERIC_VALUE,CVTE_ID TECH_ID, MATE_PROP_ID TECH_ID, PERS_ID_REGISTERER TECH_ID NOT NULL,REGISTRATION_TIMESTAMP TIME_STAMP_DFL NOT NULL DEFAULT CURRENT_TIMESTAMP, MODIFICATION_TIMESTAMP TIME_STAMP DEFAULT CURRENT_TIMESTAMP);\\012CREATE TABLE DATA_SET_TYPE_PROPERTY_TYPES (ID TECH_ID NOT NULL,DSTY_ID TECH_ID NOT NULL,PRTY_ID TECH_ID NOT NULL,IS_MANDATORY BOOLEAN_CHAR NOT NULL DEFAULT 'F',IS_MANAGED_INTERNALLY BOOLEAN_CHAR NOT NULL DEFAULT 'F',PERS_ID_REGISTERER TECH_ID NOT NULL,REGISTRATION_TIMESTAMP TIME_STAMP_DFL NOT NULL DEFAULT CURRENT_TIMESTAMP);\\012\\012CREATE SEQUENCE DATA_SET_PROPERTY_ID_SEQ;\\012CREATE SEQUENCE DSTPT_ID_SEQ;\\012\\012ALTER TABLE DATA_SET_TYPE_PROPERTY_TYPES ADD CONSTRAINT DSTPT_PK PRIMARY KEY(ID);\\012ALTER TABLE DATA_SET_PROPERTIES ADD CONSTRAINT DSPR_PK PRIMARY KEY(ID);\\012\\012ALTER TABLE DATA_SET_TYPE_PROPERTY_TYPES ADD CONSTRAINT DSTPT_BK_UK UNIQUE(DSTY_ID,PRTY_ID);\\012ALTER TABLE DATA_SET_PROPERTIES ADD CONSTRAINT DSPR_BK_UK UNIQUE(DS_ID,DSTPT_ID);\\012\\012\\012ALTER TABLE DATA_SET_TYPE_PROPERTY_TYPES ADD CONSTRAINT DSTPT_DSTY_FK FOREIGN KEY (DSTY_ID) REFERENCES DATA_SET_TYPES(ID);\\012ALTER TABLE DATA_SET_TYPE_PROPERTY_TYPES ADD CONSTRAINT DSTPT_PERS_FK FOREIGN KEY (PERS_ID_REGISTERER) REFERENCES PERSONS(ID);\\012ALTER TABLE DATA_SET_TYPE_PROPERTY_TYPES ADD CONSTRAINT DSTPT_PRTY_FK FOREIGN KEY (PRTY_ID) REFERENCES PROPERTY_TYPES(ID);\\012ALTER TABLE DATA_SET_PROPERTIES ADD CONSTRAINT DSPR_CVTE_FK FOREIGN KEY (CVTE_ID) REFERENCES CONTROLLED_VOCABULARY_TERMS(ID);\\012ALTER TABLE DATA_SET_PROPERTIES ADD CONSTRAINT DSPR_DSTPT_FK FOREIGN KEY (DSTPT_ID) REFERENCES DATA_SET_TYPE_PROPERTY_TYPES(ID) ON DELETE CASCADE;\\012ALTER TABLE DATA_SET_PROPERTIES ADD CONSTRAINT DSPR_DS_FK FOREIGN KEY (DS_ID) REFERENCES DATA(ID);\\012ALTER TABLE DATA_SET_PROPERTIES ADD CONSTRAINT DSPR_PERS_FK FOREIGN KEY (PERS_ID_REGISTERER) REFERENCES PERSONS(ID);\\012ALTER TABLE DATA_SET_PROPERTIES ADD CONSTRAINT DSPR_MAPR_FK FOREIGN KEY (MATE_PROP_ID) REFERENCES MATERIALS(ID);\\012\\012ALTER TABLE DATA_SET_PROPERTIES ADD CONSTRAINT DSPR_CK CHECK \\012\\011((VALUE IS NOT NULL AND CVTE_ID IS NULL AND MATE_PROP_ID IS NULL) OR \\012\\011 (VALUE IS NULL AND CVTE_ID IS NOT NULL AND MATE_PROP_ID IS NULL) OR\\012\\011 (VALUE IS NULL AND CVTE_ID IS NULL AND MATE_PROP_ID IS NOT NULL)\\012\\011);\\012\\012CREATE INDEX DSPR_CVTE_FK_I ON DATA_SET_PROPERTIES (CVTE_ID);\\012CREATE INDEX DSPR_DSTPT_FK_I ON DATA_SET_PROPERTIES (DSTPT_ID);\\012CREATE INDEX DSPR_DS_FK_I ON DATA_SET_PROPERTIES (DS_ID);\\012CREATE INDEX DSPR_PERS_FK_I ON DATA_SET_PROPERTIES (PERS_ID_REGISTERER);\\012CREATE INDEX DSTPT_DSTY_FK_I ON DATA_SET_TYPE_PROPERTY_TYPES (DSTY_ID);\\012CREATE INDEX DSTPT_PERS_FK_I ON DATA_SET_TYPE_PROPERTY_TYPES (PERS_ID_REGISTERER);\\012CREATE INDEX DSTPT_PRTY_FK_I ON DATA_SET_TYPE_PROPERTY_TYPES (PRTY_ID);\\012\\012CREATE OR REPLACE FUNCTION DATA_SET_PROPERTY_WITH_MATERIAL_DATA_TYPE_CHECK() RETURNS trigger AS $$\\012DECLARE\\012   v_type_id  CODE;\\012   v_type_id_prop  CODE;\\012BEGIN\\012   if NEW.mate_prop_id IS NOT NULL then\\012\\011\\011\\011-- find material type id of the property type \\012\\011\\011\\011select pt.maty_prop_id into v_type_id_prop \\012\\011\\011\\011  from data_set_type_property_types dstpt, property_types pt \\012\\011\\011\\011 where NEW.dstpt_id = dstpt.id AND dstpt.prty_id = pt.id;\\012\\011\\011\\012\\011\\011\\011if v_type_id_prop IS NOT NULL then\\012\\011\\011\\011\\011-- find material type id of the material which consists the entity's property value\\012\\011\\011\\011\\011select entity.maty_id into v_type_id \\012\\011\\011\\011\\011  from materials entity\\012\\011\\011\\011\\011 where NEW.mate_prop_id = entity.id;\\012\\011\\011\\011\\011if v_type_id != v_type_id_prop then\\012\\011\\011\\011\\011\\011RAISE EXCEPTION 'Insert/Update of property value referencing material (id: %) failed, as referenced material type is different than expected (id %, expected id: %).', \\012\\011\\011\\011\\011\\011\\011\\011\\011\\011\\011\\011\\011 NEW.mate_prop_id, v_type_id, v_type_id_prop;\\012\\011\\011\\011\\011end if;\\012\\011\\011\\011end if;\\012   end if;\\012   RETURN NEW;\\012END;\\012$$ LANGUAGE 'plpgsql';\\012\\012CREATE TRIGGER DATA_SET_PROPERTY_WITH_MATERIAL_DATA_TYPE_CHECK BEFORE INSERT OR UPDATE ON data_set_properties\\012    FOR EACH ROW EXECUTE PROCEDURE DATA_SET_PROPERTY_WITH_MATERIAL_DATA_TYPE_CHECK();   \\012	\N
+./sourceTest/sql/postgresql/035/013=database_version_logs.tsv:032	source/sql/postgresql/migration/migration-031-032.sql	SUCCESS	2009-04-09 09:36:36.20	-- -------\\012-- Modify MATERIAL_BATCHES\\012-- -------\\012\\012ALTER TABLE material_batches\\012    DROP COLUMN proc_id;\\012\\012-- -------\\012-- Modify SAMPLES\\012-- -------\\012\\012ALTER TABLE samples\\012    ADD COLUMN expe_id tech_id;\\012\\012ALTER TABLE samples\\012    ADD CONSTRAINT samp_expe_fk FOREIGN KEY (expe_id) REFERENCES experiments(id);\\012\\012CREATE INDEX samp_expe_fk_i ON samples USING btree (expe_id);\\012\\012-- relink samples directly to experiments\\012\\012UPDATE samples\\012SET expe_id = (SELECT e.id FROM experiments e, procedures p, sample_inputs si \\012               WHERE si.samp_id = samples.id AND si.proc_id = p.id AND p.expe_id = e.id AND e.inva_id IS NULL);\\012\\012\\012-- -------\\012-- Modify DATA\\012-- -------\\012\\012ALTER TABLE data\\012    ADD COLUMN expe_id tech_id;\\012\\012ALTER TABLE data\\012    ADD CONSTRAINT data_expe_fk FOREIGN KEY (expe_id) REFERENCES experiments(id);\\012\\012CREATE INDEX data_expe_fk_i ON data USING btree (expe_id);\\012\\012UPDATE data\\012SET expe_id = (SELECT e.id FROM experiments e, procedures p \\012               WHERE data.proc_id_produced_by = p.id AND p.expe_id = e.id);\\012\\012ALTER TABLE data\\012    ALTER COLUMN expe_id SET NOT NULL;\\012\\012ALTER TABLE data\\012    DROP COLUMN proc_id_produced_by;\\012\\012-- -------\\012-- Drop PROCEDURES, PROCEDURE_TYPES, and SAMPLE_INPUTS\\012-- -------\\012\\012DROP TABLE sample_inputs;\\012DROP TABLE procedures;\\012DROP TABLE procedure_types;\\012\\012DROP SEQUENCE procedure_id_seq;\\012DROP SEQUENCE procedure_type_id_seq;\\012\\012-- -------\\012-- Add CODE_SEQ\\012-- -------\\012\\012CREATE SEQUENCE CODE_SEQ;\\012\\012-- -------\\012-- Add new columns to DATA_STORES\\012-- -------\\012\\012ALTER TABLE data_stores\\012    ADD COLUMN remote_url character varying(250),\\012    ADD COLUMN session_token character varying(50),\\012    ADD COLUMN modification_timestamp time_stamp DEFAULT now();\\012\\012UPDATE data_stores\\012SET remote_url = '', session_token='';\\012\\012ALTER TABLE data_stores\\012    ALTER COLUMN remote_url SET NOT NULL,\\012    ALTER COLUMN session_token SET NOT NULL;\\012\\012-- -------\\012-- Drop foreign keys onto DATA_STORES\\012-- -------\\012\\012ALTER TABLE database_instances\\012    DROP COLUMN dast_id;\\012\\012ALTER TABLE groups\\012    DROP COLUMN dast_id;\\012\\012ALTER TABLE projects\\012    DROP COLUMN dast_id;\\012\\012ALTER TABLE experiments\\012    DROP COLUMN dast_id;\\012\\012-- -------\\012-- Add foreign key from DATA onto DATA_STORES\\012-- -------\\012\\012ALTER TABLE data\\012    ADD COLUMN dast_id tech_id;\\012\\012ALTER TABLE data\\012    ADD CONSTRAINT data_dast_fk FOREIGN KEY (dast_id) REFERENCES data_stores(id);\\012\\012UPDATE data\\012SET dast_id = (select id from data_stores where code = 'STANDARD');\\012\\012ALTER TABLE data\\012    ALTER COLUMN dast_id SET NOT NULL;\\012\\012\\012------------------------------------------------------------------------------------\\012--  Purpose:  Replace trigger SAMPLE_CODE_UNIQUENESS_CHECK \\012------------------------------------------------------------------------------------\\012\\012CREATE OR REPLACE FUNCTION SAMPLE_CODE_UNIQUENESS_CHECK() RETURNS trigger AS $$\\012DECLARE\\012   counter  INTEGER;\\012BEGIN\\012    LOCK TABLE samples IN EXCLUSIVE MODE;\\012    IF (NEW.samp_id_part_of is NULL) THEN\\012        IF (NEW.dbin_id is not NULL) THEN\\012            SELECT count(*) into counter FROM samples \\012                where id != NEW.id and code = NEW.code and samp_id_part_of is NULL and dbin_id = NEW.dbin_id;\\012            IF (counter > 0) THEN\\012                RAISE EXCEPTION 'Insert/Update of Sample (Code: %) failed because database instance sample with the same code already exists.', NEW.code;\\012            END IF;\\012        ELSIF (NEW.grou_id is not NULL) THEN\\012            SELECT count(*) into counter FROM samples \\012                where id != NEW.id and code = NEW.code and samp_id_part_of is NULL and grou_id = NEW.grou_id;\\012            IF (counter > 0) THEN\\012                RAISE EXCEPTION 'Insert/Update of Sample (Code: %) failed because group sample with the same code already exists.', NEW.code;\\012            END IF;\\012        END IF;\\012        ELSE\\012        IF (NEW.dbin_id is not NULL) THEN\\012            SELECT count(*) into counter FROM samples \\012                where id != NEW.id and code = NEW.code and samp_id_part_of = NEW.samp_id_part_of and dbin_id = NEW.dbin_id;\\012            IF (counter > 0) THEN\\012                RAISE EXCEPTION 'Insert/Update of Sample (Code: %) failed because database instance sample with the same code and being the part of the same parent already exists.', NEW.code;\\012            END IF;\\012        ELSIF (NEW.grou_id is not NULL) THEN\\012            SELECT count(*) into counter FROM samples \\012                where id != NEW.id and code = NEW.code and samp_id_part_of = NEW.samp_id_part_of and grou_id = NEW.grou_id;\\012            IF (counter > 0) THEN\\012                RAISE EXCEPTION 'Insert/Update of Sample (Code: %) failed because group sample with the same code and being the part of the same parent already exists.', NEW.code;\\012            END IF;\\012        END IF;\\012        END IF;   \\012   RETURN NEW;\\012END;\\012$$ LANGUAGE 'plpgsql';\\012\\012\\012\\012	\N
+./sourceTest/sql/postgresql/035/013=database_version_logs.tsv:034	source/sql/postgresql/migration/migration-033-034.sql	SUCCESS	2009-05-26 08:32:49.935	------------------------------------------------------------------------------------\\012-- Create sequence for generating permanent identifiers starting with nextval of existing dataset sequence.\\012------------------------------------------------------------------------------------\\012CREATE FUNCTION CREATE_SEQUENCE(EXISTING_SEQUENCE VARCHAR, NEW_SEQUENCE VARCHAR) RETURNS VOID AS $$\\012DECLARE\\012  CURR_SEQ_VAL   INTEGER;\\012BEGIN\\012  SELECT INTO CURR_SEQ_VAL NEXTVAL(EXISTING_SEQUENCE);\\012  EXECUTE 'CREATE SEQUENCE ' || NEW_SEQUENCE || ' START WITH ' || CURR_SEQ_VAL;\\012  RETURN;\\012END;\\012$$ LANGUAGE 'plpgsql';\\012\\012SELECT CREATE_SEQUENCE('DATA_ID_SEQ', 'PERM_ID_SEQ');\\012DROP FUNCTION CREATE_SEQUENCE(VARCHAR, VARCHAR);\\012\\012------------------------------------------------------------------------------------\\012-- Add perm_id columns to samples and experiments.\\012------------------------------------------------------------------------------------\\012ALTER TABLE SAMPLES ADD COLUMN PERM_ID CODE;\\012ALTER TABLE EXPERIMENTS ADD COLUMN PERM_ID CODE;\\012\\012UPDATE SAMPLES SET PERM_ID = to_char(registration_timestamp,'YYYYMMDDHHSSMS') || '-' || NEXTVAL('PERM_ID_SEQ');\\012UPDATE EXPERIMENTS SET PERM_ID = to_char(registration_timestamp,'YYYYMMDDHHSSMS') || '-' || NEXTVAL('PERM_ID_SEQ');\\012ALTER TABLE SAMPLES ALTER COLUMN PERM_ID SET NOT NULL;\\012ALTER TABLE EXPERIMENTS ALTER COLUMN PERM_ID SET NOT NULL;\\012ALTER TABLE SAMPLES ADD CONSTRAINT SAMP_PI_UK UNIQUE(PERM_ID);\\012ALTER TABLE EXPERIMENTS ADD CONSTRAINT EXPE_PI_UK UNIQUE(PERM_ID);\\012\\012\\012------------------------------------------------------------------------------------\\012-- Add column is_chosen_from_list to controlled_vocabularies.\\012------------------------------------------------------------------------------------\\012ALTER TABLE controlled_vocabularies ADD COLUMN is_chosen_from_list BOOLEAN_CHAR NOT NULL DEFAULT TRUE;\\012ALTER TABLE controlled_vocabularies ADD COLUMN source_uri CHARACTER VARYING(250);\\012------------------------------------------------------------------------------------\\012-- Modify Data table - remove arc connection between Sample and Data table, use a flag instead\\012------------------------------------------------------------------------------------\\012\\012-- add new columns\\012\\012ALTER TABLE data\\012    ADD COLUMN is_derived boolean_char;\\012ALTER TABLE data\\012    ADD COLUMN samp_id tech_id;\\012\\012-- update values in new columns\\012\\012UPDATE data\\012    SET is_derived = (samp_id_derived_from IS NOT NULL); \\012UPDATE data\\012    SET samp_id = samp_id_derived_from \\012    WHERE is_derived = 'TRUE';\\012UPDATE data\\012    SET samp_id = samp_id_acquired_from \\012    WHERE is_derived = 'FALSE';\\012\\012-- add constraints and indexes to new columns\\012\\012ALTER TABLE data\\012    ALTER COLUMN is_derived SET NOT NULL;\\012ALTER TABLE data\\012    ALTER COLUMN samp_id SET NOT NULL;   \\012ALTER TABLE data\\012    ADD CONSTRAINT data_samp_fk FOREIGN KEY (samp_id) REFERENCES samples (id);\\012CREATE INDEX data_samp_fk_i ON data USING btree (samp_id);\\012\\012-- remove old columns\\012\\012ALTER TABLE data\\012    DROP COLUMN samp_id_acquired_from;\\012ALTER TABLE data\\012    DROP COLUMN samp_id_derived_from;\\012    \\012------------------------------------------------------------------------------------\\012-- Granting SELECT privilege to group openbis_readonly\\012------------------------------------------------------------------------------------\\012\\012GRANT SELECT ON SEQUENCE attachment_content_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE attachment_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE code_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE controlled_vocabulary_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE cvte_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE data_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE data_set_property_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE data_set_relationship_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE data_set_type_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE data_store_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE data_type_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE database_instance_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE dstpt_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE etpt_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE event_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE experiment_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE experiment_property_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE experiment_type_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE file_format_type_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE group_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE invalidation_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE locator_type_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE material_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE material_property_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE material_type_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE mtpt_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE perm_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE person_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE project_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE property_type_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE role_assignment_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE sample_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE sample_property_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE sample_type_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE stpt_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE attachment_contents TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE attachments TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE controlled_vocabularies TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE controlled_vocabulary_terms TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE data TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE data_set_properties TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE data_set_relationships TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE data_set_type_property_types TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE data_set_types TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE data_stores TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE data_types TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE database_instances TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE database_version_logs TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE events TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE experiment_properties TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE experiment_type_property_types TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE experiment_types TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE experiments TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE external_data TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE file_format_types TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE groups TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE invalidations TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE locator_types TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE material_properties TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE material_type_property_types TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE material_types TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE materials TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE persons TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE projects TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE property_types TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE role_assignments TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE sample_properties TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE sample_type_property_types TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE sample_types TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE samples TO GROUP OPENBIS_READONLY;\\012\\012------------------------------------------------------------------------------------\\012-- Delete MATERIAL_BATCHES table\\012------------------------------------------------------------------------------------\\012\\012-- WARNING: Potential data lost!!!\\012-- WARNING: Potential data lost!!!\\012-- WARNING: Potential data lost!!!\\012\\012DROP TABLE SAMPLE_MATERIAL_BATCHES;\\012DROP TABLE MATERIAL_BATCHES;\\012DROP SEQUENCE MATERIAL_BATCH_ID_SEQ;\\012\\012------------------------------------------------------------------------------------\\012-- Delete MATE_ID_INHIBITOR_OF from table MATERIALS\\012------------------------------------------------------------------------------------\\012\\012-- WARNING: Potential data lost!!!\\012-- WARNING: Potential data lost!!!\\012-- WARNING: Potential data lost!!!\\012\\012ALTER TABLE MATERIALS DROP COLUMN MATE_ID_INHIBITOR_OF;\\012	\N
+./sourceTest/sql/postgresql/035/schema-035.sql:    LANGUAGE plpgsql;
+./sourceTest/sql/postgresql/035/schema-035.sql:    LANGUAGE plpgsql;
+./sourceTest/sql/postgresql/035/schema-035.sql:    LANGUAGE plpgsql;
+./sourceTest/sql/postgresql/035/schema-035.sql:    LANGUAGE plpgsql;
+./sourceTest/sql/postgresql/035/schema-035.sql:    LANGUAGE plpgsql;
+./sourceTest/sql/postgresql/035/schema-035.sql:    LANGUAGE plpgsql;
+./sourceTest/sql/postgresql/035/schema-035.sql:    LANGUAGE plpgsql;
+./sourceTest/sql/postgresql/035/schema-035.sql:    LANGUAGE plpgsql;
+./sourceTest/sql/postgresql/036/.svn/text-base/013=database_version_logs.tsv.svn-base:027	D:\\User\\felmer\\dev-workspace\\openbis/source/sql/postgresql/027/function-027.sql	SUCCESS	2008-11-05 09:18:00.403	-- Creating Functions\\012\\012------------------------------------------------------------------------------------\\012--  Purpose:  Create function RENAME_SEQUENCE() that is required for renaming the sequences belonging to tables\\012------------------------------------------------------------------------------------\\012CREATE FUNCTION RENAME_SEQUENCE(OLD_NAME VARCHAR, NEW_NAME VARCHAR) RETURNS INTEGER AS $$\\012DECLARE\\012  CURR_SEQ_VAL   INTEGER;\\012BEGIN\\012  SELECT INTO CURR_SEQ_VAL NEXTVAL(OLD_NAME);\\012  EXECUTE 'CREATE SEQUENCE ' || NEW_NAME || ' START WITH ' || CURR_SEQ_VAL;\\012  EXECUTE 'DROP SEQUENCE ' || OLD_NAME;\\012  RETURN CURR_SEQ_VAL;\\012END;\\012$$ LANGUAGE 'plpgsql';\\012\\012\\012------------------------------------------------------------------------------------\\012--  Purpose:  Create trigger CONTROLLED_VOCABULARY_CHECK \\012------------------------------------------------------------------------------------\\012\\012CREATE OR REPLACE FUNCTION CONTROLLED_VOCABULARY_CHECK() RETURNS trigger AS $$\\012DECLARE\\012   v_code  CODE;\\012BEGIN\\012\\012   select code into v_code from data_types where id = NEW.daty_id;\\012\\012   -- Check if the data is of type "CONTROLLEDVOCABULARY"\\012   if v_code = 'CONTROLLEDVOCABULARY' then\\012      if NEW.covo_id IS NULL then\\012         RAISE EXCEPTION 'Insert/Update of Property Type (Code: %) failed, as its Data Type is CONTROLLEDVOCABULARY, but it is not linked to a Controlled Vocabulary.', NEW.code;\\012      end if;\\012   end if;\\012\\012   RETURN NEW;\\012\\012END;\\012$$ LANGUAGE 'plpgsql';\\012\\012CREATE TRIGGER CONTROLLED_VOCABULARY_CHECK BEFORE INSERT OR UPDATE ON PROPERTY_TYPES\\012    FOR EACH ROW EXECUTE PROCEDURE CONTROLLED_VOCABULARY_CHECK();\\012\\012\\012------------------------------------------------------------------------------------\\012--  Purpose:  Create trigger EXTERNAL_DATA_STORAGE_FORMAT_CHECK \\012------------------------------------------------------------------------------------\\012\\012CREATE OR REPLACE FUNCTION EXTERNAL_DATA_STORAGE_FORMAT_CHECK() RETURNS trigger AS $$\\012DECLARE\\012   v_covo_code  CODE;\\012   data_code CODE;\\012BEGIN\\012\\012   select code into v_covo_code from controlled_vocabularies\\012      where is_internal_namespace = true and \\012         id = (select covo_id from controlled_vocabulary_terms where id = NEW.cvte_id_stor_fmt);\\012   -- Check if the data storage format is a term of the controlled vocabulary "STORAGE_FORMAT"\\012   if v_covo_code != 'STORAGE_FORMAT' then\\012      select code into data_code from data where id = NEW.data_id; \\012      RAISE EXCEPTION 'Insert/Update of Data (Code: %) failed, as its Storage Format is %, but is required to be STORAGE_FORMAT.', data_code, v_covo_code;\\012   end if;\\012\\012   RETURN NEW;\\012\\012END;\\012$$ LANGUAGE 'plpgsql';\\012\\012CREATE TRIGGER EXTERNAL_DATA_STORAGE_FORMAT_CHECK BEFORE INSERT OR UPDATE ON EXTERNAL_DATA\\012    FOR EACH ROW EXECUTE PROCEDURE EXTERNAL_DATA_STORAGE_FORMAT_CHECK();\\012\\012------------------------------------------------------------------------------------\\012--  Purpose:  Create trigger SAMPLE_CODE_UNIQUENESS_CHECK \\012------------------------------------------------------------------------------------\\012\\012CREATE OR REPLACE FUNCTION SAMPLE_CODE_UNIQUENESS_CHECK() RETURNS trigger AS $$\\012DECLARE\\012   counter  INTEGER;\\012BEGIN\\012\\011IF (NEW.samp_id_part_of is NULL) THEN\\012\\011\\011IF (NEW.dbin_id is not NULL) THEN\\012\\011\\011\\011SELECT count(*) into counter FROM samples \\012\\011\\011\\011\\011where id != NEW.id and code = NEW.code and samp_id_part_of is NULL and dbin_id = NEW.dbin_id;\\012\\011\\011\\011IF (counter > 0) THEN\\012\\011\\011\\011\\011RAISE EXCEPTION 'Insert/Update of Sample (Code: %) failed because database instance sample with the same code already exists.', NEW.code;\\012\\011\\011\\011END IF;\\012\\011\\011ELSIF (NEW.grou_id is not NULL) THEN\\012\\011\\011\\011SELECT count(*) into counter FROM samples \\012\\011\\011\\011\\011where id != NEW.id and code = NEW.code and samp_id_part_of is NULL and grou_id = NEW.grou_id;\\012\\011\\011\\011IF (counter > 0) THEN\\012\\011\\011\\011\\011RAISE EXCEPTION 'Insert/Update of Sample (Code: %) failed because group sample with the same code already exists.', NEW.code;\\012\\011\\011\\011END IF;\\012\\011\\011END IF;\\012        ELSE\\012\\011\\011IF (NEW.dbin_id is not NULL) THEN\\012\\011\\011\\011SELECT count(*) into counter FROM samples \\012\\011\\011\\011\\011where id != NEW.id and code = NEW.code and samp_id_part_of = NEW.samp_id_part_of and dbin_id = NEW.dbin_id;\\012\\011\\011\\011IF (counter > 0) THEN\\012\\011\\011\\011\\011RAISE EXCEPTION 'Insert/Update of Sample (Code: %) failed because database instance sample with the same code and being the part of the same parent already exists.', NEW.code;\\012\\011\\011\\011END IF;\\012\\011\\011ELSIF (NEW.grou_id is not NULL) THEN\\012\\011\\011\\011SELECT count(*) into counter FROM samples \\012\\011\\011\\011\\011where id != NEW.id and code = NEW.code and samp_id_part_of = NEW.samp_id_part_of and grou_id = NEW.grou_id;\\012\\011\\011\\011IF (counter > 0) THEN\\012\\011\\011\\011\\011RAISE EXCEPTION 'Insert/Update of Sample (Code: %) failed because group sample with the same code and being the part of the same parent already exists.', NEW.code;\\012\\011\\011\\011END IF;\\012\\011\\011END IF;\\012        END IF;   \\012   RETURN NEW;\\012END;\\012$$ LANGUAGE 'plpgsql';\\012\\012CREATE TRIGGER SAMPLE_CODE_UNIQUENESS_CHECK BEFORE INSERT OR UPDATE ON SAMPLES\\012    FOR EACH ROW EXECUTE PROCEDURE SAMPLE_CODE_UNIQUENESS_CHECK();\\012	\N
+./sourceTest/sql/postgresql/036/.svn/text-base/013=database_version_logs.tsv.svn-base:028	source/sql/postgresql/migration/migration-027-028.sql	SUCCESS	2008-11-18 13:24:17.508	-- Create EXPERIMENT_ATTACHMENT_CONTENTS.\\012CREATE TABLE EXPERIMENT_ATTACHMENT_CONTENTS (ID TECH_ID NOT NULL,VALUE FILE NOT NULL);\\012CREATE SEQUENCE EXPERIMENT_ATTACHMENT_CONTENT_ID_SEQ;\\012ALTER TABLE EXPERIMENT_ATTACHMENT_CONTENTS ADD CONSTRAINT EXAC_PK PRIMARY KEY(ID);\\012\\012-- Alter EXPERIMENT_ATTACHMENTS by adding the new column which has a NULL constraint.\\012-- The NOT NULL constraint is added later on.\\012ALTER TABLE EXPERIMENT_ATTACHMENTS ADD COLUMN EXAC_ID TECH_ID;\\012\\012-- Does the VALUE migration between EXPERIMENT_ATTACHMENTS to EXPERIMENT_ATTACHMENT_CONTENTS.\\012CREATE OR REPLACE FUNCTION move_exp_att_content() RETURNS integer AS $$\\012DECLARE\\012    rec RECORD;\\012    seq BIGINT;\\012BEGIN\\012  FOR rec IN SELECT id, value FROM EXPERIMENT_ATTACHMENTS LOOP\\012  \\011seq := nextval('EXPERIMENT_ATTACHMENT_CONTENT_ID_SEQ');\\012    INSERT INTO EXPERIMENT_ATTACHMENT_CONTENTS (id, value) VALUES (seq, rec.value);\\012    UPDATE EXPERIMENT_ATTACHMENTS SET exac_id = seq WHERE id = rec.id;\\012  END LOOP;\\012  RETURN 1;\\012END;\\012$$ LANGUAGE 'plpgsql';\\012\\012-- Call the function.\\012SELECT move_exp_att_content();\\012DROP FUNCTION move_exp_att_content();\\012\\012\\012-- Finish EXPERIMENT_ATTACHMENTS changes.\\012ALTER TABLE EXPERIMENT_ATTACHMENTS ADD CONSTRAINT EXAT_CONT_FK FOREIGN KEY (EXAC_ID) REFERENCES EXPERIMENT_ATTACHMENT_CONTENTS(ID);\\012ALTER TABLE EXPERIMENT_ATTACHMENTS DROP COLUMN VALUE;\\012ALTER TABLE EXPERIMENT_ATTACHMENTS ALTER COLUMN EXAC_ID SET NOT NULL;\\012	\N
+./sourceTest/sql/postgresql/036/.svn/text-base/013=database_version_logs.tsv.svn-base:029	source/sql/postgresql/migration/migration-028-029.sql	SUCCESS	2009-03-18 10:50:20.105	-- -------\\012-- add modification_timestamp field to allow edition with Hibernate\\012-- -------\\012\\012ALTER TABLE samples\\012\\011ADD COLUMN modification_timestamp TIME_STAMP DEFAULT CURRENT_TIMESTAMP;\\012\\012ALTER TABLE experiments\\012\\011ADD COLUMN modification_timestamp TIME_STAMP DEFAULT CURRENT_TIMESTAMP;\\012\\012ALTER TABLE materials\\012\\011ADD COLUMN modification_timestamp TIME_STAMP DEFAULT CURRENT_TIMESTAMP;\\012\\012ALTER TABLE experiment_properties\\012\\011ADD COLUMN modification_timestamp TIME_STAMP DEFAULT CURRENT_TIMESTAMP;\\012\\012ALTER TABLE material_properties\\012\\011ADD COLUMN modification_timestamp TIME_STAMP DEFAULT CURRENT_TIMESTAMP;\\012\\012ALTER TABLE sample_properties\\012\\011ADD COLUMN modification_timestamp TIME_STAMP DEFAULT CURRENT_TIMESTAMP;\\012\\012-- -------\\012-- add property data type which references materials\\012-- -------\\012\\012ALTER TABLE property_types\\012\\011ADD COLUMN maty_prop_id tech_id;\\012\\012ALTER TABLE property_types\\012\\011ADD CONSTRAINT prty_maty_fk FOREIGN KEY (maty_prop_id) REFERENCES material_types(id);\\012\\012ALTER TABLE experiment_properties\\012\\011ADD COLUMN mate_prop_id tech_id;\\012\\012ALTER TABLE material_properties\\012\\011ADD COLUMN mate_prop_id tech_id;\\012\\012ALTER TABLE sample_properties\\012\\011ADD COLUMN mate_prop_id tech_id;\\012\\012ALTER TABLE experiment_properties\\012\\011ADD CONSTRAINT expr_mapr_fk FOREIGN KEY (mate_prop_id) REFERENCES materials(id);\\012\\012ALTER TABLE material_properties\\012\\011ADD CONSTRAINT mapr_mapr_fk FOREIGN KEY (mate_prop_id) REFERENCES materials(id);\\012\\012ALTER TABLE sample_properties\\012\\011ADD CONSTRAINT sapr_mapr_fk FOREIGN KEY (mate_prop_id) REFERENCES materials(id);\\012\\012insert into data_types\\012(id\\012 ,code\\012 ,description)\\012 values \\012 (nextval('DATA_TYPE_ID_SEQ')\\012 ,'MATERIAL'\\012 ,'Reference to a material'\\012);\\012\\012ALTER TABLE MATERIAL_PROPERTIES DROP CONSTRAINT MAPR_CK;\\012ALTER TABLE MATERIAL_PROPERTIES ADD CONSTRAINT MAPR_CK CHECK \\012\\011((VALUE IS NOT NULL AND CVTE_ID IS NULL AND MATE_PROP_ID IS NULL) OR \\012\\011 (VALUE IS NULL AND CVTE_ID IS NOT NULL AND MATE_PROP_ID IS NULL) OR\\012\\011 (VALUE IS NULL AND CVTE_ID IS NULL AND MATE_PROP_ID IS NOT NULL)\\012\\011);\\012\\012ALTER TABLE EXPERIMENT_PROPERTIES DROP CONSTRAINT EXPR_CK;\\012ALTER TABLE EXPERIMENT_PROPERTIES ADD CONSTRAINT EXPR_CK CHECK \\012\\011((VALUE IS NOT NULL AND CVTE_ID IS NULL AND MATE_PROP_ID IS NULL) OR \\012\\011 (VALUE IS NULL AND CVTE_ID IS NOT NULL AND MATE_PROP_ID IS NULL) OR\\012\\011 (VALUE IS NULL AND CVTE_ID IS NULL AND MATE_PROP_ID IS NOT NULL)\\012\\011);\\012\\012ALTER TABLE SAMPLE_PROPERTIES DROP CONSTRAINT SAPR_CK;\\012ALTER TABLE SAMPLE_PROPERTIES ADD CONSTRAINT SAPR_CK CHECK \\012\\011((VALUE IS NOT NULL AND CVTE_ID IS NULL AND MATE_PROP_ID IS NULL) OR \\012\\011 (VALUE IS NULL AND CVTE_ID IS NOT NULL AND MATE_PROP_ID IS NULL) OR\\012\\011 (VALUE IS NULL AND CVTE_ID IS NULL AND MATE_PROP_ID IS NOT NULL)\\012\\011);\\012\\012------------------------------------------------------------------------------------\\012--  Purpose:  Create trigger MATERIAL/SAMPLE/EXPERIMENT _PROPERTY_WITH_MATERIAL_DATA_TYPE_CHECK\\012--            It checks that if material property value is assigned to the entity,\\012--\\011\\011\\011\\011\\011\\011then the material type is equal to the one described by property type.\\012------------------------------------------------------------------------------------\\012\\012CREATE OR REPLACE FUNCTION MATERIAL_PROPERTY_WITH_MATERIAL_DATA_TYPE_CHECK() RETURNS trigger AS $$\\012DECLARE\\012   v_type_id  CODE;\\012   v_type_id_prop  CODE;\\012BEGIN\\012   if NEW.mate_prop_id IS NOT NULL then\\012\\011\\011\\011-- find material type id of the property type \\012\\011\\011\\011select pt.maty_prop_id into v_type_id_prop \\012\\011\\011\\011  from material_type_property_types etpt, property_types pt \\012\\011\\011\\011 where NEW.mtpt_id = etpt.id AND etpt.prty_id = pt.id;\\012\\011\\011\\012\\011\\011\\011if v_type_id_prop IS NOT NULL then\\012\\011\\011\\011\\011-- find material type id of the material which consists the entity's property value\\012\\011\\011\\011\\011select entity.maty_id into v_type_id \\012\\011\\011\\011\\011  from materials entity\\012\\011\\011\\011\\011 where NEW.mate_prop_id = entity.id;\\012\\011\\011\\011\\011if v_type_id != v_type_id_prop then\\012\\011\\011\\011\\011\\011RAISE EXCEPTION 'Insert/Update of property value referencing material (id: %) failed, as referenced material type is different than expected (id %, expected id: %).', \\012\\011\\011\\011\\011\\011\\011\\011 NEW.mate_prop_id, v_type_id, v_type_id_prop;\\012\\011\\011\\011\\011end if;\\012\\011\\011\\011end if;\\012   end if;\\012   RETURN NEW;\\012END;\\012$$ LANGUAGE 'plpgsql';\\012\\012CREATE TRIGGER MATERIAL_PROPERTY_WITH_MATERIAL_DATA_TYPE_CHECK BEFORE INSERT OR UPDATE ON material_properties\\012    FOR EACH ROW EXECUTE PROCEDURE MATERIAL_PROPERTY_WITH_MATERIAL_DATA_TYPE_CHECK();\\012    \\012CREATE OR REPLACE FUNCTION SAMPLE_PROPERTY_WITH_MATERIAL_DATA_TYPE_CHECK() RETURNS trigger AS $$\\012DECLARE\\012   v_type_id  CODE;\\012   v_type_id_prop  CODE;\\012BEGIN\\012   if NEW.mate_prop_id IS NOT NULL then\\012\\011\\011\\011-- find material type id of the property type \\012\\011\\011\\011select pt.maty_prop_id into v_type_id_prop \\012\\011\\011\\011  from sample_type_property_types etpt, property_types pt \\012\\011\\011\\011 where NEW.stpt_id = etpt.id AND etpt.prty_id = pt.id;\\012\\011\\011\\012\\011\\011\\011if v_type_id_prop IS NOT NULL then\\012\\011\\011\\011\\011-- find material type id of the material which consists the entity's property value\\012\\011\\011\\011\\011select entity.maty_id into v_type_id \\012\\011\\011\\011\\011  from materials entity\\012\\011\\011\\011\\011 where NEW.mate_prop_id = entity.id;\\012\\011\\011\\011\\011if v_type_id != v_type_id_prop then\\012\\011\\011\\011\\011\\011RAISE EXCEPTION 'Insert/Update of property value referencing material (id: %) failed, as referenced material type is different than expected (id %, expected id: %).', \\012\\011\\011\\011\\011\\011\\011\\011\\011\\011\\011\\011\\011 NEW.mate_prop_id, v_type_id, v_type_id_prop;\\012\\011\\011\\011\\011end if;\\012\\011\\011\\011end if;\\012   end if;\\012   RETURN NEW;\\012END;\\012$$ LANGUAGE 'plpgsql';\\012\\012CREATE TRIGGER SAMPLE_PROPERTY_WITH_MATERIAL_DATA_TYPE_CHECK BEFORE INSERT OR UPDATE ON sample_properties\\012    FOR EACH ROW EXECUTE PROCEDURE SAMPLE_PROPERTY_WITH_MATERIAL_DATA_TYPE_CHECK();\\012    \\012CREATE OR REPLACE FUNCTION EXPERIMENT_PROPERTY_WITH_MATERIAL_DATA_TYPE_CHECK() RETURNS trigger AS $$\\012DECLARE\\012   v_type_id  CODE;\\012   v_type_id_prop  CODE;\\012BEGIN\\012   if NEW.mate_prop_id IS NOT NULL then\\012\\011\\011\\011-- find material type id of the property type \\012\\011\\011\\011select pt.maty_prop_id into v_type_id_prop \\012\\011\\011\\011  from experiment_type_property_types etpt, property_types pt \\012\\011\\011\\011 where NEW.etpt_id = etpt.id AND etpt.prty_id = pt.id;\\012\\011\\011\\012\\011\\011\\011if v_type_id_prop IS NOT NULL then\\012\\011\\011\\011\\011-- find material type id of the material which consists the entity's property value\\012\\011\\011\\011\\011select entity.maty_id into v_type_id \\012\\011\\011\\011\\011  from materials entity\\012\\011\\011\\011\\011 where NEW.mate_prop_id = entity.id;\\012\\011\\011\\011\\011if v_type_id != v_type_id_prop then\\012\\011\\011\\011\\011\\011RAISE EXCEPTION 'Insert/Update of property value referencing material (id: %) failed, as referenced material type is different than expected (id %, expected id: %).', \\012\\011\\011\\011\\011\\011\\011\\011\\011\\011\\011\\011\\011 NEW.mate_prop_id, v_type_id, v_type_id_prop;\\012\\011\\011\\011\\011end if;\\012\\011\\011\\011end if;\\012   end if;\\012   RETURN NEW;\\012END;\\012$$ LANGUAGE 'plpgsql';\\012\\012CREATE TRIGGER EXPERIMENT_PROPERTY_WITH_MATERIAL_DATA_TYPE_CHECK BEFORE INSERT OR UPDATE ON experiment_properties\\012    FOR EACH ROW EXECUTE PROCEDURE EXPERIMENT_PROPERTY_WITH_MATERIAL_DATA_TYPE_CHECK();\\012       \\012-- -------\\012-- remove the reminescents of the OBSERVABLE_TYPE\\012-- -------\\012\\012ALTER TABLE data\\012\\011DROP CONSTRAINT data_obty_fk;\\012\\012ALTER TABLE data_set_types\\012\\011DROP CONSTRAINT obty_pk;\\012\\012ALTER TABLE data_set_types\\012\\011ADD CONSTRAINT dsty_pk PRIMARY KEY (id);\\012\\012ALTER TABLE data\\012\\011ADD CONSTRAINT data_dsty_fk FOREIGN KEY (dsty_id) REFERENCES data_set_types(id);\\012\\012ALTER TABLE data_set_types\\012\\011DROP CONSTRAINT obty_bk_uk;\\012\\012ALTER TABLE data_set_types\\012\\011DROP CONSTRAINT obty_dbin_fk;\\012\\012ALTER TABLE data_set_types\\012\\011ADD CONSTRAINT dsty_bk_uk UNIQUE (code, dbin_id);\\012\\012ALTER TABLE data_set_types\\012\\011ADD CONSTRAINT dsty_dbin_fk FOREIGN KEY (dbin_id) REFERENCES database_instances(id);\\012\\012DROP INDEX data_obty_fk_i;\\012\\012CREATE INDEX data_dsty_fk_i ON data(dsty_id);\\012	\N
+./sourceTest/sql/postgresql/036/.svn/text-base/013=database_version_logs.tsv.svn-base:030	source/sql/postgresql/migration/migration-029-030.sql	SUCCESS	2009-03-23 15:34:44.72	-- -------\\012-- add modification_timestamp field to allow edition with Hibernate\\012-- -------\\012ALTER TABLE data\\012\\011ADD COLUMN modification_timestamp TIME_STAMP DEFAULT CURRENT_TIMESTAMP;\\012ALTER TABLE experiment_types\\012\\011ADD COLUMN modification_timestamp TIME_STAMP DEFAULT CURRENT_TIMESTAMP;\\012ALTER TABLE sample_types\\012\\011ADD COLUMN modification_timestamp TIME_STAMP DEFAULT CURRENT_TIMESTAMP;\\012ALTER TABLE material_types\\012\\011ADD COLUMN modification_timestamp TIME_STAMP DEFAULT CURRENT_TIMESTAMP;\\012ALTER TABLE data_set_types\\012\\011ADD COLUMN modification_timestamp TIME_STAMP DEFAULT CURRENT_TIMESTAMP;\\012ALTER TABLE controlled_vocabularies\\012\\011ADD COLUMN modification_timestamp TIME_STAMP DEFAULT CURRENT_TIMESTAMP;\\012-- -------\\012-- add properties to data sets\\012-- -------\\012CREATE TABLE DATA_SET_PROPERTIES (ID TECH_ID NOT NULL,DS_ID TECH_ID NOT NULL,DSTPT_ID TECH_ID NOT NULL,VALUE GENERIC_VALUE,CVTE_ID TECH_ID, MATE_PROP_ID TECH_ID, PERS_ID_REGISTERER TECH_ID NOT NULL,REGISTRATION_TIMESTAMP TIME_STAMP_DFL NOT NULL DEFAULT CURRENT_TIMESTAMP, MODIFICATION_TIMESTAMP TIME_STAMP DEFAULT CURRENT_TIMESTAMP);\\012CREATE TABLE DATA_SET_TYPE_PROPERTY_TYPES (ID TECH_ID NOT NULL,DSTY_ID TECH_ID NOT NULL,PRTY_ID TECH_ID NOT NULL,IS_MANDATORY BOOLEAN_CHAR NOT NULL DEFAULT 'F',IS_MANAGED_INTERNALLY BOOLEAN_CHAR NOT NULL DEFAULT 'F',PERS_ID_REGISTERER TECH_ID NOT NULL,REGISTRATION_TIMESTAMP TIME_STAMP_DFL NOT NULL DEFAULT CURRENT_TIMESTAMP);\\012\\012CREATE SEQUENCE DATA_SET_PROPERTY_ID_SEQ;\\012CREATE SEQUENCE DSTPT_ID_SEQ;\\012\\012ALTER TABLE DATA_SET_TYPE_PROPERTY_TYPES ADD CONSTRAINT DSTPT_PK PRIMARY KEY(ID);\\012ALTER TABLE DATA_SET_PROPERTIES ADD CONSTRAINT DSPR_PK PRIMARY KEY(ID);\\012\\012ALTER TABLE DATA_SET_TYPE_PROPERTY_TYPES ADD CONSTRAINT DSTPT_BK_UK UNIQUE(DSTY_ID,PRTY_ID);\\012ALTER TABLE DATA_SET_PROPERTIES ADD CONSTRAINT DSPR_BK_UK UNIQUE(DS_ID,DSTPT_ID);\\012\\012\\012ALTER TABLE DATA_SET_TYPE_PROPERTY_TYPES ADD CONSTRAINT DSTPT_DSTY_FK FOREIGN KEY (DSTY_ID) REFERENCES DATA_SET_TYPES(ID);\\012ALTER TABLE DATA_SET_TYPE_PROPERTY_TYPES ADD CONSTRAINT DSTPT_PERS_FK FOREIGN KEY (PERS_ID_REGISTERER) REFERENCES PERSONS(ID);\\012ALTER TABLE DATA_SET_TYPE_PROPERTY_TYPES ADD CONSTRAINT DSTPT_PRTY_FK FOREIGN KEY (PRTY_ID) REFERENCES PROPERTY_TYPES(ID);\\012ALTER TABLE DATA_SET_PROPERTIES ADD CONSTRAINT DSPR_CVTE_FK FOREIGN KEY (CVTE_ID) REFERENCES CONTROLLED_VOCABULARY_TERMS(ID);\\012ALTER TABLE DATA_SET_PROPERTIES ADD CONSTRAINT DSPR_DSTPT_FK FOREIGN KEY (DSTPT_ID) REFERENCES DATA_SET_TYPE_PROPERTY_TYPES(ID) ON DELETE CASCADE;\\012ALTER TABLE DATA_SET_PROPERTIES ADD CONSTRAINT DSPR_DS_FK FOREIGN KEY (DS_ID) REFERENCES DATA(ID);\\012ALTER TABLE DATA_SET_PROPERTIES ADD CONSTRAINT DSPR_PERS_FK FOREIGN KEY (PERS_ID_REGISTERER) REFERENCES PERSONS(ID);\\012ALTER TABLE DATA_SET_PROPERTIES ADD CONSTRAINT DSPR_MAPR_FK FOREIGN KEY (MATE_PROP_ID) REFERENCES MATERIALS(ID);\\012\\012ALTER TABLE DATA_SET_PROPERTIES ADD CONSTRAINT DSPR_CK CHECK \\012\\011((VALUE IS NOT NULL AND CVTE_ID IS NULL AND MATE_PROP_ID IS NULL) OR \\012\\011 (VALUE IS NULL AND CVTE_ID IS NOT NULL AND MATE_PROP_ID IS NULL) OR\\012\\011 (VALUE IS NULL AND CVTE_ID IS NULL AND MATE_PROP_ID IS NOT NULL)\\012\\011);\\012\\012CREATE INDEX DSPR_CVTE_FK_I ON DATA_SET_PROPERTIES (CVTE_ID);\\012CREATE INDEX DSPR_DSTPT_FK_I ON DATA_SET_PROPERTIES (DSTPT_ID);\\012CREATE INDEX DSPR_DS_FK_I ON DATA_SET_PROPERTIES (DS_ID);\\012CREATE INDEX DSPR_PERS_FK_I ON DATA_SET_PROPERTIES (PERS_ID_REGISTERER);\\012CREATE INDEX DSTPT_DSTY_FK_I ON DATA_SET_TYPE_PROPERTY_TYPES (DSTY_ID);\\012CREATE INDEX DSTPT_PERS_FK_I ON DATA_SET_TYPE_PROPERTY_TYPES (PERS_ID_REGISTERER);\\012CREATE INDEX DSTPT_PRTY_FK_I ON DATA_SET_TYPE_PROPERTY_TYPES (PRTY_ID);\\012\\012CREATE OR REPLACE FUNCTION DATA_SET_PROPERTY_WITH_MATERIAL_DATA_TYPE_CHECK() RETURNS trigger AS $$\\012DECLARE\\012   v_type_id  CODE;\\012   v_type_id_prop  CODE;\\012BEGIN\\012   if NEW.mate_prop_id IS NOT NULL then\\012\\011\\011\\011-- find material type id of the property type \\012\\011\\011\\011select pt.maty_prop_id into v_type_id_prop \\012\\011\\011\\011  from data_set_type_property_types dstpt, property_types pt \\012\\011\\011\\011 where NEW.dstpt_id = dstpt.id AND dstpt.prty_id = pt.id;\\012\\011\\011\\012\\011\\011\\011if v_type_id_prop IS NOT NULL then\\012\\011\\011\\011\\011-- find material type id of the material which consists the entity's property value\\012\\011\\011\\011\\011select entity.maty_id into v_type_id \\012\\011\\011\\011\\011  from materials entity\\012\\011\\011\\011\\011 where NEW.mate_prop_id = entity.id;\\012\\011\\011\\011\\011if v_type_id != v_type_id_prop then\\012\\011\\011\\011\\011\\011RAISE EXCEPTION 'Insert/Update of property value referencing material (id: %) failed, as referenced material type is different than expected (id %, expected id: %).', \\012\\011\\011\\011\\011\\011\\011\\011\\011\\011\\011\\011\\011 NEW.mate_prop_id, v_type_id, v_type_id_prop;\\012\\011\\011\\011\\011end if;\\012\\011\\011\\011end if;\\012   end if;\\012   RETURN NEW;\\012END;\\012$$ LANGUAGE 'plpgsql';\\012\\012CREATE TRIGGER DATA_SET_PROPERTY_WITH_MATERIAL_DATA_TYPE_CHECK BEFORE INSERT OR UPDATE ON data_set_properties\\012    FOR EACH ROW EXECUTE PROCEDURE DATA_SET_PROPERTY_WITH_MATERIAL_DATA_TYPE_CHECK();   \\012	\N
+./sourceTest/sql/postgresql/036/.svn/text-base/013=database_version_logs.tsv.svn-base:032	source/sql/postgresql/migration/migration-031-032.sql	SUCCESS	2009-04-09 09:36:36.20	-- -------\\012-- Modify MATERIAL_BATCHES\\012-- -------\\012\\012ALTER TABLE material_batches\\012    DROP COLUMN proc_id;\\012\\012-- -------\\012-- Modify SAMPLES\\012-- -------\\012\\012ALTER TABLE samples\\012    ADD COLUMN expe_id tech_id;\\012\\012ALTER TABLE samples\\012    ADD CONSTRAINT samp_expe_fk FOREIGN KEY (expe_id) REFERENCES experiments(id);\\012\\012CREATE INDEX samp_expe_fk_i ON samples USING btree (expe_id);\\012\\012-- relink samples directly to experiments\\012\\012UPDATE samples\\012SET expe_id = (SELECT e.id FROM experiments e, procedures p, sample_inputs si \\012               WHERE si.samp_id = samples.id AND si.proc_id = p.id AND p.expe_id = e.id AND e.inva_id IS NULL);\\012\\012\\012-- -------\\012-- Modify DATA\\012-- -------\\012\\012ALTER TABLE data\\012    ADD COLUMN expe_id tech_id;\\012\\012ALTER TABLE data\\012    ADD CONSTRAINT data_expe_fk FOREIGN KEY (expe_id) REFERENCES experiments(id);\\012\\012CREATE INDEX data_expe_fk_i ON data USING btree (expe_id);\\012\\012UPDATE data\\012SET expe_id = (SELECT e.id FROM experiments e, procedures p \\012               WHERE data.proc_id_produced_by = p.id AND p.expe_id = e.id);\\012\\012ALTER TABLE data\\012    ALTER COLUMN expe_id SET NOT NULL;\\012\\012ALTER TABLE data\\012    DROP COLUMN proc_id_produced_by;\\012\\012-- -------\\012-- Drop PROCEDURES, PROCEDURE_TYPES, and SAMPLE_INPUTS\\012-- -------\\012\\012DROP TABLE sample_inputs;\\012DROP TABLE procedures;\\012DROP TABLE procedure_types;\\012\\012DROP SEQUENCE procedure_id_seq;\\012DROP SEQUENCE procedure_type_id_seq;\\012\\012-- -------\\012-- Add CODE_SEQ\\012-- -------\\012\\012CREATE SEQUENCE CODE_SEQ;\\012\\012-- -------\\012-- Add new columns to DATA_STORES\\012-- -------\\012\\012ALTER TABLE data_stores\\012    ADD COLUMN remote_url character varying(250),\\012    ADD COLUMN session_token character varying(50),\\012    ADD COLUMN modification_timestamp time_stamp DEFAULT now();\\012\\012UPDATE data_stores\\012SET remote_url = '', session_token='';\\012\\012ALTER TABLE data_stores\\012    ALTER COLUMN remote_url SET NOT NULL,\\012    ALTER COLUMN session_token SET NOT NULL;\\012\\012-- -------\\012-- Drop foreign keys onto DATA_STORES\\012-- -------\\012\\012ALTER TABLE database_instances\\012    DROP COLUMN dast_id;\\012\\012ALTER TABLE groups\\012    DROP COLUMN dast_id;\\012\\012ALTER TABLE projects\\012    DROP COLUMN dast_id;\\012\\012ALTER TABLE experiments\\012    DROP COLUMN dast_id;\\012\\012-- -------\\012-- Add foreign key from DATA onto DATA_STORES\\012-- -------\\012\\012ALTER TABLE data\\012    ADD COLUMN dast_id tech_id;\\012\\012ALTER TABLE data\\012    ADD CONSTRAINT data_dast_fk FOREIGN KEY (dast_id) REFERENCES data_stores(id);\\012\\012UPDATE data\\012SET dast_id = (select id from data_stores where code = 'STANDARD');\\012\\012ALTER TABLE data\\012    ALTER COLUMN dast_id SET NOT NULL;\\012\\012\\012------------------------------------------------------------------------------------\\012--  Purpose:  Replace trigger SAMPLE_CODE_UNIQUENESS_CHECK \\012------------------------------------------------------------------------------------\\012\\012CREATE OR REPLACE FUNCTION SAMPLE_CODE_UNIQUENESS_CHECK() RETURNS trigger AS $$\\012DECLARE\\012   counter  INTEGER;\\012BEGIN\\012    LOCK TABLE samples IN EXCLUSIVE MODE;\\012    IF (NEW.samp_id_part_of is NULL) THEN\\012        IF (NEW.dbin_id is not NULL) THEN\\012            SELECT count(*) into counter FROM samples \\012                where id != NEW.id and code = NEW.code and samp_id_part_of is NULL and dbin_id = NEW.dbin_id;\\012            IF (counter > 0) THEN\\012                RAISE EXCEPTION 'Insert/Update of Sample (Code: %) failed because database instance sample with the same code already exists.', NEW.code;\\012            END IF;\\012        ELSIF (NEW.grou_id is not NULL) THEN\\012            SELECT count(*) into counter FROM samples \\012                where id != NEW.id and code = NEW.code and samp_id_part_of is NULL and grou_id = NEW.grou_id;\\012            IF (counter > 0) THEN\\012                RAISE EXCEPTION 'Insert/Update of Sample (Code: %) failed because group sample with the same code already exists.', NEW.code;\\012            END IF;\\012        END IF;\\012        ELSE\\012        IF (NEW.dbin_id is not NULL) THEN\\012            SELECT count(*) into counter FROM samples \\012                where id != NEW.id and code = NEW.code and samp_id_part_of = NEW.samp_id_part_of and dbin_id = NEW.dbin_id;\\012            IF (counter > 0) THEN\\012                RAISE EXCEPTION 'Insert/Update of Sample (Code: %) failed because database instance sample with the same code and being the part of the same parent already exists.', NEW.code;\\012            END IF;\\012        ELSIF (NEW.grou_id is not NULL) THEN\\012            SELECT count(*) into counter FROM samples \\012                where id != NEW.id and code = NEW.code and samp_id_part_of = NEW.samp_id_part_of and grou_id = NEW.grou_id;\\012            IF (counter > 0) THEN\\012                RAISE EXCEPTION 'Insert/Update of Sample (Code: %) failed because group sample with the same code and being the part of the same parent already exists.', NEW.code;\\012            END IF;\\012        END IF;\\012        END IF;   \\012   RETURN NEW;\\012END;\\012$$ LANGUAGE 'plpgsql';\\012\\012\\012\\012	\N
+./sourceTest/sql/postgresql/036/.svn/text-base/013=database_version_logs.tsv.svn-base:034	source/sql/postgresql/migration/migration-033-034.sql	SUCCESS	2009-05-26 08:32:49.935	------------------------------------------------------------------------------------\\012-- Create sequence for generating permanent identifiers starting with nextval of existing dataset sequence.\\012------------------------------------------------------------------------------------\\012CREATE FUNCTION CREATE_SEQUENCE(EXISTING_SEQUENCE VARCHAR, NEW_SEQUENCE VARCHAR) RETURNS VOID AS $$\\012DECLARE\\012  CURR_SEQ_VAL   INTEGER;\\012BEGIN\\012  SELECT INTO CURR_SEQ_VAL NEXTVAL(EXISTING_SEQUENCE);\\012  EXECUTE 'CREATE SEQUENCE ' || NEW_SEQUENCE || ' START WITH ' || CURR_SEQ_VAL;\\012  RETURN;\\012END;\\012$$ LANGUAGE 'plpgsql';\\012\\012SELECT CREATE_SEQUENCE('DATA_ID_SEQ', 'PERM_ID_SEQ');\\012DROP FUNCTION CREATE_SEQUENCE(VARCHAR, VARCHAR);\\012\\012------------------------------------------------------------------------------------\\012-- Add perm_id columns to samples and experiments.\\012------------------------------------------------------------------------------------\\012ALTER TABLE SAMPLES ADD COLUMN PERM_ID CODE;\\012ALTER TABLE EXPERIMENTS ADD COLUMN PERM_ID CODE;\\012\\012UPDATE SAMPLES SET PERM_ID = to_char(registration_timestamp,'YYYYMMDDHHSSMS') || '-' || NEXTVAL('PERM_ID_SEQ');\\012UPDATE EXPERIMENTS SET PERM_ID = to_char(registration_timestamp,'YYYYMMDDHHSSMS') || '-' || NEXTVAL('PERM_ID_SEQ');\\012ALTER TABLE SAMPLES ALTER COLUMN PERM_ID SET NOT NULL;\\012ALTER TABLE EXPERIMENTS ALTER COLUMN PERM_ID SET NOT NULL;\\012ALTER TABLE SAMPLES ADD CONSTRAINT SAMP_PI_UK UNIQUE(PERM_ID);\\012ALTER TABLE EXPERIMENTS ADD CONSTRAINT EXPE_PI_UK UNIQUE(PERM_ID);\\012\\012\\012------------------------------------------------------------------------------------\\012-- Add column is_chosen_from_list to controlled_vocabularies.\\012------------------------------------------------------------------------------------\\012ALTER TABLE controlled_vocabularies ADD COLUMN is_chosen_from_list BOOLEAN_CHAR NOT NULL DEFAULT TRUE;\\012ALTER TABLE controlled_vocabularies ADD COLUMN source_uri CHARACTER VARYING(250);\\012------------------------------------------------------------------------------------\\012-- Modify Data table - remove arc connection between Sample and Data table, use a flag instead\\012------------------------------------------------------------------------------------\\012\\012-- add new columns\\012\\012ALTER TABLE data\\012    ADD COLUMN is_derived boolean_char;\\012ALTER TABLE data\\012    ADD COLUMN samp_id tech_id;\\012\\012-- update values in new columns\\012\\012UPDATE data\\012    SET is_derived = (samp_id_derived_from IS NOT NULL); \\012UPDATE data\\012    SET samp_id = samp_id_derived_from \\012    WHERE is_derived = 'TRUE';\\012UPDATE data\\012    SET samp_id = samp_id_acquired_from \\012    WHERE is_derived = 'FALSE';\\012\\012-- add constraints and indexes to new columns\\012\\012ALTER TABLE data\\012    ALTER COLUMN is_derived SET NOT NULL;\\012ALTER TABLE data\\012    ALTER COLUMN samp_id SET NOT NULL;   \\012ALTER TABLE data\\012    ADD CONSTRAINT data_samp_fk FOREIGN KEY (samp_id) REFERENCES samples (id);\\012CREATE INDEX data_samp_fk_i ON data USING btree (samp_id);\\012\\012-- remove old columns\\012\\012ALTER TABLE data\\012    DROP COLUMN samp_id_acquired_from;\\012ALTER TABLE data\\012    DROP COLUMN samp_id_derived_from;\\012    \\012------------------------------------------------------------------------------------\\012-- Granting SELECT privilege to group openbis_readonly\\012------------------------------------------------------------------------------------\\012\\012GRANT SELECT ON SEQUENCE attachment_content_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE attachment_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE code_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE controlled_vocabulary_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE cvte_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE data_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE data_set_property_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE data_set_relationship_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE data_set_type_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE data_store_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE data_type_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE database_instance_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE dstpt_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE etpt_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE event_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE experiment_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE experiment_property_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE experiment_type_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE file_format_type_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE group_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE invalidation_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE locator_type_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE material_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE material_property_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE material_type_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE mtpt_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE perm_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE person_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE project_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE property_type_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE role_assignment_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE sample_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE sample_property_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE sample_type_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE stpt_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE attachment_contents TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE attachments TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE controlled_vocabularies TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE controlled_vocabulary_terms TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE data TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE data_set_properties TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE data_set_relationships TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE data_set_type_property_types TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE data_set_types TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE data_stores TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE data_types TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE database_instances TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE database_version_logs TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE events TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE experiment_properties TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE experiment_type_property_types TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE experiment_types TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE experiments TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE external_data TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE file_format_types TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE groups TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE invalidations TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE locator_types TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE material_properties TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE material_type_property_types TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE material_types TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE materials TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE persons TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE projects TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE property_types TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE role_assignments TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE sample_properties TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE sample_type_property_types TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE sample_types TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE samples TO GROUP OPENBIS_READONLY;\\012\\012------------------------------------------------------------------------------------\\012-- Delete MATERIAL_BATCHES table\\012------------------------------------------------------------------------------------\\012\\012-- WARNING: Potential data lost!!!\\012-- WARNING: Potential data lost!!!\\012-- WARNING: Potential data lost!!!\\012\\012DROP TABLE SAMPLE_MATERIAL_BATCHES;\\012DROP TABLE MATERIAL_BATCHES;\\012DROP SEQUENCE MATERIAL_BATCH_ID_SEQ;\\012\\012------------------------------------------------------------------------------------\\012-- Delete MATE_ID_INHIBITOR_OF from table MATERIALS\\012------------------------------------------------------------------------------------\\012\\012-- WARNING: Potential data lost!!!\\012-- WARNING: Potential data lost!!!\\012-- WARNING: Potential data lost!!!\\012\\012ALTER TABLE MATERIALS DROP COLUMN MATE_ID_INHIBITOR_OF;\\012	\N
+./sourceTest/sql/postgresql/036/.svn/text-base/schema-036.sql.svn-base:    LANGUAGE plpgsql;
+./sourceTest/sql/postgresql/036/.svn/text-base/schema-036.sql.svn-base:    LANGUAGE plpgsql;
+./sourceTest/sql/postgresql/036/.svn/text-base/schema-036.sql.svn-base:    LANGUAGE plpgsql;
+./sourceTest/sql/postgresql/036/.svn/text-base/schema-036.sql.svn-base:    LANGUAGE plpgsql;
+./sourceTest/sql/postgresql/036/.svn/text-base/schema-036.sql.svn-base:    LANGUAGE plpgsql;
+./sourceTest/sql/postgresql/036/.svn/text-base/schema-036.sql.svn-base:    LANGUAGE plpgsql;
+./sourceTest/sql/postgresql/036/.svn/text-base/schema-036.sql.svn-base:    LANGUAGE plpgsql;
+./sourceTest/sql/postgresql/036/.svn/text-base/schema-036.sql.svn-base:    LANGUAGE plpgsql;
+./sourceTest/sql/postgresql/036/013=database_version_logs.tsv:027	D:\\User\\felmer\\dev-workspace\\openbis/source/sql/postgresql/027/function-027.sql	SUCCESS	2008-11-05 09:18:00.403	-- Creating Functions\\012\\012------------------------------------------------------------------------------------\\012--  Purpose:  Create function RENAME_SEQUENCE() that is required for renaming the sequences belonging to tables\\012------------------------------------------------------------------------------------\\012CREATE FUNCTION RENAME_SEQUENCE(OLD_NAME VARCHAR, NEW_NAME VARCHAR) RETURNS INTEGER AS $$\\012DECLARE\\012  CURR_SEQ_VAL   INTEGER;\\012BEGIN\\012  SELECT INTO CURR_SEQ_VAL NEXTVAL(OLD_NAME);\\012  EXECUTE 'CREATE SEQUENCE ' || NEW_NAME || ' START WITH ' || CURR_SEQ_VAL;\\012  EXECUTE 'DROP SEQUENCE ' || OLD_NAME;\\012  RETURN CURR_SEQ_VAL;\\012END;\\012$$ LANGUAGE 'plpgsql';\\012\\012\\012------------------------------------------------------------------------------------\\012--  Purpose:  Create trigger CONTROLLED_VOCABULARY_CHECK \\012------------------------------------------------------------------------------------\\012\\012CREATE OR REPLACE FUNCTION CONTROLLED_VOCABULARY_CHECK() RETURNS trigger AS $$\\012DECLARE\\012   v_code  CODE;\\012BEGIN\\012\\012   select code into v_code from data_types where id = NEW.daty_id;\\012\\012   -- Check if the data is of type "CONTROLLEDVOCABULARY"\\012   if v_code = 'CONTROLLEDVOCABULARY' then\\012      if NEW.covo_id IS NULL then\\012         RAISE EXCEPTION 'Insert/Update of Property Type (Code: %) failed, as its Data Type is CONTROLLEDVOCABULARY, but it is not linked to a Controlled Vocabulary.', NEW.code;\\012      end if;\\012   end if;\\012\\012   RETURN NEW;\\012\\012END;\\012$$ LANGUAGE 'plpgsql';\\012\\012CREATE TRIGGER CONTROLLED_VOCABULARY_CHECK BEFORE INSERT OR UPDATE ON PROPERTY_TYPES\\012    FOR EACH ROW EXECUTE PROCEDURE CONTROLLED_VOCABULARY_CHECK();\\012\\012\\012------------------------------------------------------------------------------------\\012--  Purpose:  Create trigger EXTERNAL_DATA_STORAGE_FORMAT_CHECK \\012------------------------------------------------------------------------------------\\012\\012CREATE OR REPLACE FUNCTION EXTERNAL_DATA_STORAGE_FORMAT_CHECK() RETURNS trigger AS $$\\012DECLARE\\012   v_covo_code  CODE;\\012   data_code CODE;\\012BEGIN\\012\\012   select code into v_covo_code from controlled_vocabularies\\012      where is_internal_namespace = true and \\012         id = (select covo_id from controlled_vocabulary_terms where id = NEW.cvte_id_stor_fmt);\\012   -- Check if the data storage format is a term of the controlled vocabulary "STORAGE_FORMAT"\\012   if v_covo_code != 'STORAGE_FORMAT' then\\012      select code into data_code from data where id = NEW.data_id; \\012      RAISE EXCEPTION 'Insert/Update of Data (Code: %) failed, as its Storage Format is %, but is required to be STORAGE_FORMAT.', data_code, v_covo_code;\\012   end if;\\012\\012   RETURN NEW;\\012\\012END;\\012$$ LANGUAGE 'plpgsql';\\012\\012CREATE TRIGGER EXTERNAL_DATA_STORAGE_FORMAT_CHECK BEFORE INSERT OR UPDATE ON EXTERNAL_DATA\\012    FOR EACH ROW EXECUTE PROCEDURE EXTERNAL_DATA_STORAGE_FORMAT_CHECK();\\012\\012------------------------------------------------------------------------------------\\012--  Purpose:  Create trigger SAMPLE_CODE_UNIQUENESS_CHECK \\012------------------------------------------------------------------------------------\\012\\012CREATE OR REPLACE FUNCTION SAMPLE_CODE_UNIQUENESS_CHECK() RETURNS trigger AS $$\\012DECLARE\\012   counter  INTEGER;\\012BEGIN\\012\\011IF (NEW.samp_id_part_of is NULL) THEN\\012\\011\\011IF (NEW.dbin_id is not NULL) THEN\\012\\011\\011\\011SELECT count(*) into counter FROM samples \\012\\011\\011\\011\\011where id != NEW.id and code = NEW.code and samp_id_part_of is NULL and dbin_id = NEW.dbin_id;\\012\\011\\011\\011IF (counter > 0) THEN\\012\\011\\011\\011\\011RAISE EXCEPTION 'Insert/Update of Sample (Code: %) failed because database instance sample with the same code already exists.', NEW.code;\\012\\011\\011\\011END IF;\\012\\011\\011ELSIF (NEW.grou_id is not NULL) THEN\\012\\011\\011\\011SELECT count(*) into counter FROM samples \\012\\011\\011\\011\\011where id != NEW.id and code = NEW.code and samp_id_part_of is NULL and grou_id = NEW.grou_id;\\012\\011\\011\\011IF (counter > 0) THEN\\012\\011\\011\\011\\011RAISE EXCEPTION 'Insert/Update of Sample (Code: %) failed because group sample with the same code already exists.', NEW.code;\\012\\011\\011\\011END IF;\\012\\011\\011END IF;\\012        ELSE\\012\\011\\011IF (NEW.dbin_id is not NULL) THEN\\012\\011\\011\\011SELECT count(*) into counter FROM samples \\012\\011\\011\\011\\011where id != NEW.id and code = NEW.code and samp_id_part_of = NEW.samp_id_part_of and dbin_id = NEW.dbin_id;\\012\\011\\011\\011IF (counter > 0) THEN\\012\\011\\011\\011\\011RAISE EXCEPTION 'Insert/Update of Sample (Code: %) failed because database instance sample with the same code and being the part of the same parent already exists.', NEW.code;\\012\\011\\011\\011END IF;\\012\\011\\011ELSIF (NEW.grou_id is not NULL) THEN\\012\\011\\011\\011SELECT count(*) into counter FROM samples \\012\\011\\011\\011\\011where id != NEW.id and code = NEW.code and samp_id_part_of = NEW.samp_id_part_of and grou_id = NEW.grou_id;\\012\\011\\011\\011IF (counter > 0) THEN\\012\\011\\011\\011\\011RAISE EXCEPTION 'Insert/Update of Sample (Code: %) failed because group sample with the same code and being the part of the same parent already exists.', NEW.code;\\012\\011\\011\\011END IF;\\012\\011\\011END IF;\\012        END IF;   \\012   RETURN NEW;\\012END;\\012$$ LANGUAGE 'plpgsql';\\012\\012CREATE TRIGGER SAMPLE_CODE_UNIQUENESS_CHECK BEFORE INSERT OR UPDATE ON SAMPLES\\012    FOR EACH ROW EXECUTE PROCEDURE SAMPLE_CODE_UNIQUENESS_CHECK();\\012	\N
+./sourceTest/sql/postgresql/036/013=database_version_logs.tsv:028	source/sql/postgresql/migration/migration-027-028.sql	SUCCESS	2008-11-18 13:24:17.508	-- Create EXPERIMENT_ATTACHMENT_CONTENTS.\\012CREATE TABLE EXPERIMENT_ATTACHMENT_CONTENTS (ID TECH_ID NOT NULL,VALUE FILE NOT NULL);\\012CREATE SEQUENCE EXPERIMENT_ATTACHMENT_CONTENT_ID_SEQ;\\012ALTER TABLE EXPERIMENT_ATTACHMENT_CONTENTS ADD CONSTRAINT EXAC_PK PRIMARY KEY(ID);\\012\\012-- Alter EXPERIMENT_ATTACHMENTS by adding the new column which has a NULL constraint.\\012-- The NOT NULL constraint is added later on.\\012ALTER TABLE EXPERIMENT_ATTACHMENTS ADD COLUMN EXAC_ID TECH_ID;\\012\\012-- Does the VALUE migration between EXPERIMENT_ATTACHMENTS to EXPERIMENT_ATTACHMENT_CONTENTS.\\012CREATE OR REPLACE FUNCTION move_exp_att_content() RETURNS integer AS $$\\012DECLARE\\012    rec RECORD;\\012    seq BIGINT;\\012BEGIN\\012  FOR rec IN SELECT id, value FROM EXPERIMENT_ATTACHMENTS LOOP\\012  \\011seq := nextval('EXPERIMENT_ATTACHMENT_CONTENT_ID_SEQ');\\012    INSERT INTO EXPERIMENT_ATTACHMENT_CONTENTS (id, value) VALUES (seq, rec.value);\\012    UPDATE EXPERIMENT_ATTACHMENTS SET exac_id = seq WHERE id = rec.id;\\012  END LOOP;\\012  RETURN 1;\\012END;\\012$$ LANGUAGE 'plpgsql';\\012\\012-- Call the function.\\012SELECT move_exp_att_content();\\012DROP FUNCTION move_exp_att_content();\\012\\012\\012-- Finish EXPERIMENT_ATTACHMENTS changes.\\012ALTER TABLE EXPERIMENT_ATTACHMENTS ADD CONSTRAINT EXAT_CONT_FK FOREIGN KEY (EXAC_ID) REFERENCES EXPERIMENT_ATTACHMENT_CONTENTS(ID);\\012ALTER TABLE EXPERIMENT_ATTACHMENTS DROP COLUMN VALUE;\\012ALTER TABLE EXPERIMENT_ATTACHMENTS ALTER COLUMN EXAC_ID SET NOT NULL;\\012	\N
+./sourceTest/sql/postgresql/036/013=database_version_logs.tsv:029	source/sql/postgresql/migration/migration-028-029.sql	SUCCESS	2009-03-18 10:50:20.105	-- -------\\012-- add modification_timestamp field to allow edition with Hibernate\\012-- -------\\012\\012ALTER TABLE samples\\012\\011ADD COLUMN modification_timestamp TIME_STAMP DEFAULT CURRENT_TIMESTAMP;\\012\\012ALTER TABLE experiments\\012\\011ADD COLUMN modification_timestamp TIME_STAMP DEFAULT CURRENT_TIMESTAMP;\\012\\012ALTER TABLE materials\\012\\011ADD COLUMN modification_timestamp TIME_STAMP DEFAULT CURRENT_TIMESTAMP;\\012\\012ALTER TABLE experiment_properties\\012\\011ADD COLUMN modification_timestamp TIME_STAMP DEFAULT CURRENT_TIMESTAMP;\\012\\012ALTER TABLE material_properties\\012\\011ADD COLUMN modification_timestamp TIME_STAMP DEFAULT CURRENT_TIMESTAMP;\\012\\012ALTER TABLE sample_properties\\012\\011ADD COLUMN modification_timestamp TIME_STAMP DEFAULT CURRENT_TIMESTAMP;\\012\\012-- -------\\012-- add property data type which references materials\\012-- -------\\012\\012ALTER TABLE property_types\\012\\011ADD COLUMN maty_prop_id tech_id;\\012\\012ALTER TABLE property_types\\012\\011ADD CONSTRAINT prty_maty_fk FOREIGN KEY (maty_prop_id) REFERENCES material_types(id);\\012\\012ALTER TABLE experiment_properties\\012\\011ADD COLUMN mate_prop_id tech_id;\\012\\012ALTER TABLE material_properties\\012\\011ADD COLUMN mate_prop_id tech_id;\\012\\012ALTER TABLE sample_properties\\012\\011ADD COLUMN mate_prop_id tech_id;\\012\\012ALTER TABLE experiment_properties\\012\\011ADD CONSTRAINT expr_mapr_fk FOREIGN KEY (mate_prop_id) REFERENCES materials(id);\\012\\012ALTER TABLE material_properties\\012\\011ADD CONSTRAINT mapr_mapr_fk FOREIGN KEY (mate_prop_id) REFERENCES materials(id);\\012\\012ALTER TABLE sample_properties\\012\\011ADD CONSTRAINT sapr_mapr_fk FOREIGN KEY (mate_prop_id) REFERENCES materials(id);\\012\\012insert into data_types\\012(id\\012 ,code\\012 ,description)\\012 values \\012 (nextval('DATA_TYPE_ID_SEQ')\\012 ,'MATERIAL'\\012 ,'Reference to a material'\\012);\\012\\012ALTER TABLE MATERIAL_PROPERTIES DROP CONSTRAINT MAPR_CK;\\012ALTER TABLE MATERIAL_PROPERTIES ADD CONSTRAINT MAPR_CK CHECK \\012\\011((VALUE IS NOT NULL AND CVTE_ID IS NULL AND MATE_PROP_ID IS NULL) OR \\012\\011 (VALUE IS NULL AND CVTE_ID IS NOT NULL AND MATE_PROP_ID IS NULL) OR\\012\\011 (VALUE IS NULL AND CVTE_ID IS NULL AND MATE_PROP_ID IS NOT NULL)\\012\\011);\\012\\012ALTER TABLE EXPERIMENT_PROPERTIES DROP CONSTRAINT EXPR_CK;\\012ALTER TABLE EXPERIMENT_PROPERTIES ADD CONSTRAINT EXPR_CK CHECK \\012\\011((VALUE IS NOT NULL AND CVTE_ID IS NULL AND MATE_PROP_ID IS NULL) OR \\012\\011 (VALUE IS NULL AND CVTE_ID IS NOT NULL AND MATE_PROP_ID IS NULL) OR\\012\\011 (VALUE IS NULL AND CVTE_ID IS NULL AND MATE_PROP_ID IS NOT NULL)\\012\\011);\\012\\012ALTER TABLE SAMPLE_PROPERTIES DROP CONSTRAINT SAPR_CK;\\012ALTER TABLE SAMPLE_PROPERTIES ADD CONSTRAINT SAPR_CK CHECK \\012\\011((VALUE IS NOT NULL AND CVTE_ID IS NULL AND MATE_PROP_ID IS NULL) OR \\012\\011 (VALUE IS NULL AND CVTE_ID IS NOT NULL AND MATE_PROP_ID IS NULL) OR\\012\\011 (VALUE IS NULL AND CVTE_ID IS NULL AND MATE_PROP_ID IS NOT NULL)\\012\\011);\\012\\012------------------------------------------------------------------------------------\\012--  Purpose:  Create trigger MATERIAL/SAMPLE/EXPERIMENT _PROPERTY_WITH_MATERIAL_DATA_TYPE_CHECK\\012--            It checks that if material property value is assigned to the entity,\\012--\\011\\011\\011\\011\\011\\011then the material type is equal to the one described by property type.\\012------------------------------------------------------------------------------------\\012\\012CREATE OR REPLACE FUNCTION MATERIAL_PROPERTY_WITH_MATERIAL_DATA_TYPE_CHECK() RETURNS trigger AS $$\\012DECLARE\\012   v_type_id  CODE;\\012   v_type_id_prop  CODE;\\012BEGIN\\012   if NEW.mate_prop_id IS NOT NULL then\\012\\011\\011\\011-- find material type id of the property type \\012\\011\\011\\011select pt.maty_prop_id into v_type_id_prop \\012\\011\\011\\011  from material_type_property_types etpt, property_types pt \\012\\011\\011\\011 where NEW.mtpt_id = etpt.id AND etpt.prty_id = pt.id;\\012\\011\\011\\012\\011\\011\\011if v_type_id_prop IS NOT NULL then\\012\\011\\011\\011\\011-- find material type id of the material which consists the entity's property value\\012\\011\\011\\011\\011select entity.maty_id into v_type_id \\012\\011\\011\\011\\011  from materials entity\\012\\011\\011\\011\\011 where NEW.mate_prop_id = entity.id;\\012\\011\\011\\011\\011if v_type_id != v_type_id_prop then\\012\\011\\011\\011\\011\\011RAISE EXCEPTION 'Insert/Update of property value referencing material (id: %) failed, as referenced material type is different than expected (id %, expected id: %).', \\012\\011\\011\\011\\011\\011\\011\\011 NEW.mate_prop_id, v_type_id, v_type_id_prop;\\012\\011\\011\\011\\011end if;\\012\\011\\011\\011end if;\\012   end if;\\012   RETURN NEW;\\012END;\\012$$ LANGUAGE 'plpgsql';\\012\\012CREATE TRIGGER MATERIAL_PROPERTY_WITH_MATERIAL_DATA_TYPE_CHECK BEFORE INSERT OR UPDATE ON material_properties\\012    FOR EACH ROW EXECUTE PROCEDURE MATERIAL_PROPERTY_WITH_MATERIAL_DATA_TYPE_CHECK();\\012    \\012CREATE OR REPLACE FUNCTION SAMPLE_PROPERTY_WITH_MATERIAL_DATA_TYPE_CHECK() RETURNS trigger AS $$\\012DECLARE\\012   v_type_id  CODE;\\012   v_type_id_prop  CODE;\\012BEGIN\\012   if NEW.mate_prop_id IS NOT NULL then\\012\\011\\011\\011-- find material type id of the property type \\012\\011\\011\\011select pt.maty_prop_id into v_type_id_prop \\012\\011\\011\\011  from sample_type_property_types etpt, property_types pt \\012\\011\\011\\011 where NEW.stpt_id = etpt.id AND etpt.prty_id = pt.id;\\012\\011\\011\\012\\011\\011\\011if v_type_id_prop IS NOT NULL then\\012\\011\\011\\011\\011-- find material type id of the material which consists the entity's property value\\012\\011\\011\\011\\011select entity.maty_id into v_type_id \\012\\011\\011\\011\\011  from materials entity\\012\\011\\011\\011\\011 where NEW.mate_prop_id = entity.id;\\012\\011\\011\\011\\011if v_type_id != v_type_id_prop then\\012\\011\\011\\011\\011\\011RAISE EXCEPTION 'Insert/Update of property value referencing material (id: %) failed, as referenced material type is different than expected (id %, expected id: %).', \\012\\011\\011\\011\\011\\011\\011\\011\\011\\011\\011\\011\\011 NEW.mate_prop_id, v_type_id, v_type_id_prop;\\012\\011\\011\\011\\011end if;\\012\\011\\011\\011end if;\\012   end if;\\012   RETURN NEW;\\012END;\\012$$ LANGUAGE 'plpgsql';\\012\\012CREATE TRIGGER SAMPLE_PROPERTY_WITH_MATERIAL_DATA_TYPE_CHECK BEFORE INSERT OR UPDATE ON sample_properties\\012    FOR EACH ROW EXECUTE PROCEDURE SAMPLE_PROPERTY_WITH_MATERIAL_DATA_TYPE_CHECK();\\012    \\012CREATE OR REPLACE FUNCTION EXPERIMENT_PROPERTY_WITH_MATERIAL_DATA_TYPE_CHECK() RETURNS trigger AS $$\\012DECLARE\\012   v_type_id  CODE;\\012   v_type_id_prop  CODE;\\012BEGIN\\012   if NEW.mate_prop_id IS NOT NULL then\\012\\011\\011\\011-- find material type id of the property type \\012\\011\\011\\011select pt.maty_prop_id into v_type_id_prop \\012\\011\\011\\011  from experiment_type_property_types etpt, property_types pt \\012\\011\\011\\011 where NEW.etpt_id = etpt.id AND etpt.prty_id = pt.id;\\012\\011\\011\\012\\011\\011\\011if v_type_id_prop IS NOT NULL then\\012\\011\\011\\011\\011-- find material type id of the material which consists the entity's property value\\012\\011\\011\\011\\011select entity.maty_id into v_type_id \\012\\011\\011\\011\\011  from materials entity\\012\\011\\011\\011\\011 where NEW.mate_prop_id = entity.id;\\012\\011\\011\\011\\011if v_type_id != v_type_id_prop then\\012\\011\\011\\011\\011\\011RAISE EXCEPTION 'Insert/Update of property value referencing material (id: %) failed, as referenced material type is different than expected (id %, expected id: %).', \\012\\011\\011\\011\\011\\011\\011\\011\\011\\011\\011\\011\\011 NEW.mate_prop_id, v_type_id, v_type_id_prop;\\012\\011\\011\\011\\011end if;\\012\\011\\011\\011end if;\\012   end if;\\012   RETURN NEW;\\012END;\\012$$ LANGUAGE 'plpgsql';\\012\\012CREATE TRIGGER EXPERIMENT_PROPERTY_WITH_MATERIAL_DATA_TYPE_CHECK BEFORE INSERT OR UPDATE ON experiment_properties\\012    FOR EACH ROW EXECUTE PROCEDURE EXPERIMENT_PROPERTY_WITH_MATERIAL_DATA_TYPE_CHECK();\\012       \\012-- -------\\012-- remove the reminescents of the OBSERVABLE_TYPE\\012-- -------\\012\\012ALTER TABLE data\\012\\011DROP CONSTRAINT data_obty_fk;\\012\\012ALTER TABLE data_set_types\\012\\011DROP CONSTRAINT obty_pk;\\012\\012ALTER TABLE data_set_types\\012\\011ADD CONSTRAINT dsty_pk PRIMARY KEY (id);\\012\\012ALTER TABLE data\\012\\011ADD CONSTRAINT data_dsty_fk FOREIGN KEY (dsty_id) REFERENCES data_set_types(id);\\012\\012ALTER TABLE data_set_types\\012\\011DROP CONSTRAINT obty_bk_uk;\\012\\012ALTER TABLE data_set_types\\012\\011DROP CONSTRAINT obty_dbin_fk;\\012\\012ALTER TABLE data_set_types\\012\\011ADD CONSTRAINT dsty_bk_uk UNIQUE (code, dbin_id);\\012\\012ALTER TABLE data_set_types\\012\\011ADD CONSTRAINT dsty_dbin_fk FOREIGN KEY (dbin_id) REFERENCES database_instances(id);\\012\\012DROP INDEX data_obty_fk_i;\\012\\012CREATE INDEX data_dsty_fk_i ON data(dsty_id);\\012	\N
+./sourceTest/sql/postgresql/036/013=database_version_logs.tsv:030	source/sql/postgresql/migration/migration-029-030.sql	SUCCESS	2009-03-23 15:34:44.72	-- -------\\012-- add modification_timestamp field to allow edition with Hibernate\\012-- -------\\012ALTER TABLE data\\012\\011ADD COLUMN modification_timestamp TIME_STAMP DEFAULT CURRENT_TIMESTAMP;\\012ALTER TABLE experiment_types\\012\\011ADD COLUMN modification_timestamp TIME_STAMP DEFAULT CURRENT_TIMESTAMP;\\012ALTER TABLE sample_types\\012\\011ADD COLUMN modification_timestamp TIME_STAMP DEFAULT CURRENT_TIMESTAMP;\\012ALTER TABLE material_types\\012\\011ADD COLUMN modification_timestamp TIME_STAMP DEFAULT CURRENT_TIMESTAMP;\\012ALTER TABLE data_set_types\\012\\011ADD COLUMN modification_timestamp TIME_STAMP DEFAULT CURRENT_TIMESTAMP;\\012ALTER TABLE controlled_vocabularies\\012\\011ADD COLUMN modification_timestamp TIME_STAMP DEFAULT CURRENT_TIMESTAMP;\\012-- -------\\012-- add properties to data sets\\012-- -------\\012CREATE TABLE DATA_SET_PROPERTIES (ID TECH_ID NOT NULL,DS_ID TECH_ID NOT NULL,DSTPT_ID TECH_ID NOT NULL,VALUE GENERIC_VALUE,CVTE_ID TECH_ID, MATE_PROP_ID TECH_ID, PERS_ID_REGISTERER TECH_ID NOT NULL,REGISTRATION_TIMESTAMP TIME_STAMP_DFL NOT NULL DEFAULT CURRENT_TIMESTAMP, MODIFICATION_TIMESTAMP TIME_STAMP DEFAULT CURRENT_TIMESTAMP);\\012CREATE TABLE DATA_SET_TYPE_PROPERTY_TYPES (ID TECH_ID NOT NULL,DSTY_ID TECH_ID NOT NULL,PRTY_ID TECH_ID NOT NULL,IS_MANDATORY BOOLEAN_CHAR NOT NULL DEFAULT 'F',IS_MANAGED_INTERNALLY BOOLEAN_CHAR NOT NULL DEFAULT 'F',PERS_ID_REGISTERER TECH_ID NOT NULL,REGISTRATION_TIMESTAMP TIME_STAMP_DFL NOT NULL DEFAULT CURRENT_TIMESTAMP);\\012\\012CREATE SEQUENCE DATA_SET_PROPERTY_ID_SEQ;\\012CREATE SEQUENCE DSTPT_ID_SEQ;\\012\\012ALTER TABLE DATA_SET_TYPE_PROPERTY_TYPES ADD CONSTRAINT DSTPT_PK PRIMARY KEY(ID);\\012ALTER TABLE DATA_SET_PROPERTIES ADD CONSTRAINT DSPR_PK PRIMARY KEY(ID);\\012\\012ALTER TABLE DATA_SET_TYPE_PROPERTY_TYPES ADD CONSTRAINT DSTPT_BK_UK UNIQUE(DSTY_ID,PRTY_ID);\\012ALTER TABLE DATA_SET_PROPERTIES ADD CONSTRAINT DSPR_BK_UK UNIQUE(DS_ID,DSTPT_ID);\\012\\012\\012ALTER TABLE DATA_SET_TYPE_PROPERTY_TYPES ADD CONSTRAINT DSTPT_DSTY_FK FOREIGN KEY (DSTY_ID) REFERENCES DATA_SET_TYPES(ID);\\012ALTER TABLE DATA_SET_TYPE_PROPERTY_TYPES ADD CONSTRAINT DSTPT_PERS_FK FOREIGN KEY (PERS_ID_REGISTERER) REFERENCES PERSONS(ID);\\012ALTER TABLE DATA_SET_TYPE_PROPERTY_TYPES ADD CONSTRAINT DSTPT_PRTY_FK FOREIGN KEY (PRTY_ID) REFERENCES PROPERTY_TYPES(ID);\\012ALTER TABLE DATA_SET_PROPERTIES ADD CONSTRAINT DSPR_CVTE_FK FOREIGN KEY (CVTE_ID) REFERENCES CONTROLLED_VOCABULARY_TERMS(ID);\\012ALTER TABLE DATA_SET_PROPERTIES ADD CONSTRAINT DSPR_DSTPT_FK FOREIGN KEY (DSTPT_ID) REFERENCES DATA_SET_TYPE_PROPERTY_TYPES(ID) ON DELETE CASCADE;\\012ALTER TABLE DATA_SET_PROPERTIES ADD CONSTRAINT DSPR_DS_FK FOREIGN KEY (DS_ID) REFERENCES DATA(ID);\\012ALTER TABLE DATA_SET_PROPERTIES ADD CONSTRAINT DSPR_PERS_FK FOREIGN KEY (PERS_ID_REGISTERER) REFERENCES PERSONS(ID);\\012ALTER TABLE DATA_SET_PROPERTIES ADD CONSTRAINT DSPR_MAPR_FK FOREIGN KEY (MATE_PROP_ID) REFERENCES MATERIALS(ID);\\012\\012ALTER TABLE DATA_SET_PROPERTIES ADD CONSTRAINT DSPR_CK CHECK \\012\\011((VALUE IS NOT NULL AND CVTE_ID IS NULL AND MATE_PROP_ID IS NULL) OR \\012\\011 (VALUE IS NULL AND CVTE_ID IS NOT NULL AND MATE_PROP_ID IS NULL) OR\\012\\011 (VALUE IS NULL AND CVTE_ID IS NULL AND MATE_PROP_ID IS NOT NULL)\\012\\011);\\012\\012CREATE INDEX DSPR_CVTE_FK_I ON DATA_SET_PROPERTIES (CVTE_ID);\\012CREATE INDEX DSPR_DSTPT_FK_I ON DATA_SET_PROPERTIES (DSTPT_ID);\\012CREATE INDEX DSPR_DS_FK_I ON DATA_SET_PROPERTIES (DS_ID);\\012CREATE INDEX DSPR_PERS_FK_I ON DATA_SET_PROPERTIES (PERS_ID_REGISTERER);\\012CREATE INDEX DSTPT_DSTY_FK_I ON DATA_SET_TYPE_PROPERTY_TYPES (DSTY_ID);\\012CREATE INDEX DSTPT_PERS_FK_I ON DATA_SET_TYPE_PROPERTY_TYPES (PERS_ID_REGISTERER);\\012CREATE INDEX DSTPT_PRTY_FK_I ON DATA_SET_TYPE_PROPERTY_TYPES (PRTY_ID);\\012\\012CREATE OR REPLACE FUNCTION DATA_SET_PROPERTY_WITH_MATERIAL_DATA_TYPE_CHECK() RETURNS trigger AS $$\\012DECLARE\\012   v_type_id  CODE;\\012   v_type_id_prop  CODE;\\012BEGIN\\012   if NEW.mate_prop_id IS NOT NULL then\\012\\011\\011\\011-- find material type id of the property type \\012\\011\\011\\011select pt.maty_prop_id into v_type_id_prop \\012\\011\\011\\011  from data_set_type_property_types dstpt, property_types pt \\012\\011\\011\\011 where NEW.dstpt_id = dstpt.id AND dstpt.prty_id = pt.id;\\012\\011\\011\\012\\011\\011\\011if v_type_id_prop IS NOT NULL then\\012\\011\\011\\011\\011-- find material type id of the material which consists the entity's property value\\012\\011\\011\\011\\011select entity.maty_id into v_type_id \\012\\011\\011\\011\\011  from materials entity\\012\\011\\011\\011\\011 where NEW.mate_prop_id = entity.id;\\012\\011\\011\\011\\011if v_type_id != v_type_id_prop then\\012\\011\\011\\011\\011\\011RAISE EXCEPTION 'Insert/Update of property value referencing material (id: %) failed, as referenced material type is different than expected (id %, expected id: %).', \\012\\011\\011\\011\\011\\011\\011\\011\\011\\011\\011\\011\\011 NEW.mate_prop_id, v_type_id, v_type_id_prop;\\012\\011\\011\\011\\011end if;\\012\\011\\011\\011end if;\\012   end if;\\012   RETURN NEW;\\012END;\\012$$ LANGUAGE 'plpgsql';\\012\\012CREATE TRIGGER DATA_SET_PROPERTY_WITH_MATERIAL_DATA_TYPE_CHECK BEFORE INSERT OR UPDATE ON data_set_properties\\012    FOR EACH ROW EXECUTE PROCEDURE DATA_SET_PROPERTY_WITH_MATERIAL_DATA_TYPE_CHECK();   \\012	\N
+./sourceTest/sql/postgresql/036/013=database_version_logs.tsv:032	source/sql/postgresql/migration/migration-031-032.sql	SUCCESS	2009-04-09 09:36:36.20	-- -------\\012-- Modify MATERIAL_BATCHES\\012-- -------\\012\\012ALTER TABLE material_batches\\012    DROP COLUMN proc_id;\\012\\012-- -------\\012-- Modify SAMPLES\\012-- -------\\012\\012ALTER TABLE samples\\012    ADD COLUMN expe_id tech_id;\\012\\012ALTER TABLE samples\\012    ADD CONSTRAINT samp_expe_fk FOREIGN KEY (expe_id) REFERENCES experiments(id);\\012\\012CREATE INDEX samp_expe_fk_i ON samples USING btree (expe_id);\\012\\012-- relink samples directly to experiments\\012\\012UPDATE samples\\012SET expe_id = (SELECT e.id FROM experiments e, procedures p, sample_inputs si \\012               WHERE si.samp_id = samples.id AND si.proc_id = p.id AND p.expe_id = e.id AND e.inva_id IS NULL);\\012\\012\\012-- -------\\012-- Modify DATA\\012-- -------\\012\\012ALTER TABLE data\\012    ADD COLUMN expe_id tech_id;\\012\\012ALTER TABLE data\\012    ADD CONSTRAINT data_expe_fk FOREIGN KEY (expe_id) REFERENCES experiments(id);\\012\\012CREATE INDEX data_expe_fk_i ON data USING btree (expe_id);\\012\\012UPDATE data\\012SET expe_id = (SELECT e.id FROM experiments e, procedures p \\012               WHERE data.proc_id_produced_by = p.id AND p.expe_id = e.id);\\012\\012ALTER TABLE data\\012    ALTER COLUMN expe_id SET NOT NULL;\\012\\012ALTER TABLE data\\012    DROP COLUMN proc_id_produced_by;\\012\\012-- -------\\012-- Drop PROCEDURES, PROCEDURE_TYPES, and SAMPLE_INPUTS\\012-- -------\\012\\012DROP TABLE sample_inputs;\\012DROP TABLE procedures;\\012DROP TABLE procedure_types;\\012\\012DROP SEQUENCE procedure_id_seq;\\012DROP SEQUENCE procedure_type_id_seq;\\012\\012-- -------\\012-- Add CODE_SEQ\\012-- -------\\012\\012CREATE SEQUENCE CODE_SEQ;\\012\\012-- -------\\012-- Add new columns to DATA_STORES\\012-- -------\\012\\012ALTER TABLE data_stores\\012    ADD COLUMN remote_url character varying(250),\\012    ADD COLUMN session_token character varying(50),\\012    ADD COLUMN modification_timestamp time_stamp DEFAULT now();\\012\\012UPDATE data_stores\\012SET remote_url = '', session_token='';\\012\\012ALTER TABLE data_stores\\012    ALTER COLUMN remote_url SET NOT NULL,\\012    ALTER COLUMN session_token SET NOT NULL;\\012\\012-- -------\\012-- Drop foreign keys onto DATA_STORES\\012-- -------\\012\\012ALTER TABLE database_instances\\012    DROP COLUMN dast_id;\\012\\012ALTER TABLE groups\\012    DROP COLUMN dast_id;\\012\\012ALTER TABLE projects\\012    DROP COLUMN dast_id;\\012\\012ALTER TABLE experiments\\012    DROP COLUMN dast_id;\\012\\012-- -------\\012-- Add foreign key from DATA onto DATA_STORES\\012-- -------\\012\\012ALTER TABLE data\\012    ADD COLUMN dast_id tech_id;\\012\\012ALTER TABLE data\\012    ADD CONSTRAINT data_dast_fk FOREIGN KEY (dast_id) REFERENCES data_stores(id);\\012\\012UPDATE data\\012SET dast_id = (select id from data_stores where code = 'STANDARD');\\012\\012ALTER TABLE data\\012    ALTER COLUMN dast_id SET NOT NULL;\\012\\012\\012------------------------------------------------------------------------------------\\012--  Purpose:  Replace trigger SAMPLE_CODE_UNIQUENESS_CHECK \\012------------------------------------------------------------------------------------\\012\\012CREATE OR REPLACE FUNCTION SAMPLE_CODE_UNIQUENESS_CHECK() RETURNS trigger AS $$\\012DECLARE\\012   counter  INTEGER;\\012BEGIN\\012    LOCK TABLE samples IN EXCLUSIVE MODE;\\012    IF (NEW.samp_id_part_of is NULL) THEN\\012        IF (NEW.dbin_id is not NULL) THEN\\012            SELECT count(*) into counter FROM samples \\012                where id != NEW.id and code = NEW.code and samp_id_part_of is NULL and dbin_id = NEW.dbin_id;\\012            IF (counter > 0) THEN\\012                RAISE EXCEPTION 'Insert/Update of Sample (Code: %) failed because database instance sample with the same code already exists.', NEW.code;\\012            END IF;\\012        ELSIF (NEW.grou_id is not NULL) THEN\\012            SELECT count(*) into counter FROM samples \\012                where id != NEW.id and code = NEW.code and samp_id_part_of is NULL and grou_id = NEW.grou_id;\\012            IF (counter > 0) THEN\\012                RAISE EXCEPTION 'Insert/Update of Sample (Code: %) failed because group sample with the same code already exists.', NEW.code;\\012            END IF;\\012        END IF;\\012        ELSE\\012        IF (NEW.dbin_id is not NULL) THEN\\012            SELECT count(*) into counter FROM samples \\012                where id != NEW.id and code = NEW.code and samp_id_part_of = NEW.samp_id_part_of and dbin_id = NEW.dbin_id;\\012            IF (counter > 0) THEN\\012                RAISE EXCEPTION 'Insert/Update of Sample (Code: %) failed because database instance sample with the same code and being the part of the same parent already exists.', NEW.code;\\012            END IF;\\012        ELSIF (NEW.grou_id is not NULL) THEN\\012            SELECT count(*) into counter FROM samples \\012                where id != NEW.id and code = NEW.code and samp_id_part_of = NEW.samp_id_part_of and grou_id = NEW.grou_id;\\012            IF (counter > 0) THEN\\012                RAISE EXCEPTION 'Insert/Update of Sample (Code: %) failed because group sample with the same code and being the part of the same parent already exists.', NEW.code;\\012            END IF;\\012        END IF;\\012        END IF;   \\012   RETURN NEW;\\012END;\\012$$ LANGUAGE 'plpgsql';\\012\\012\\012\\012	\N
+./sourceTest/sql/postgresql/036/013=database_version_logs.tsv:034	source/sql/postgresql/migration/migration-033-034.sql	SUCCESS	2009-05-26 08:32:49.935	------------------------------------------------------------------------------------\\012-- Create sequence for generating permanent identifiers starting with nextval of existing dataset sequence.\\012------------------------------------------------------------------------------------\\012CREATE FUNCTION CREATE_SEQUENCE(EXISTING_SEQUENCE VARCHAR, NEW_SEQUENCE VARCHAR) RETURNS VOID AS $$\\012DECLARE\\012  CURR_SEQ_VAL   INTEGER;\\012BEGIN\\012  SELECT INTO CURR_SEQ_VAL NEXTVAL(EXISTING_SEQUENCE);\\012  EXECUTE 'CREATE SEQUENCE ' || NEW_SEQUENCE || ' START WITH ' || CURR_SEQ_VAL;\\012  RETURN;\\012END;\\012$$ LANGUAGE 'plpgsql';\\012\\012SELECT CREATE_SEQUENCE('DATA_ID_SEQ', 'PERM_ID_SEQ');\\012DROP FUNCTION CREATE_SEQUENCE(VARCHAR, VARCHAR);\\012\\012------------------------------------------------------------------------------------\\012-- Add perm_id columns to samples and experiments.\\012------------------------------------------------------------------------------------\\012ALTER TABLE SAMPLES ADD COLUMN PERM_ID CODE;\\012ALTER TABLE EXPERIMENTS ADD COLUMN PERM_ID CODE;\\012\\012UPDATE SAMPLES SET PERM_ID = to_char(registration_timestamp,'YYYYMMDDHHSSMS') || '-' || NEXTVAL('PERM_ID_SEQ');\\012UPDATE EXPERIMENTS SET PERM_ID = to_char(registration_timestamp,'YYYYMMDDHHSSMS') || '-' || NEXTVAL('PERM_ID_SEQ');\\012ALTER TABLE SAMPLES ALTER COLUMN PERM_ID SET NOT NULL;\\012ALTER TABLE EXPERIMENTS ALTER COLUMN PERM_ID SET NOT NULL;\\012ALTER TABLE SAMPLES ADD CONSTRAINT SAMP_PI_UK UNIQUE(PERM_ID);\\012ALTER TABLE EXPERIMENTS ADD CONSTRAINT EXPE_PI_UK UNIQUE(PERM_ID);\\012\\012\\012------------------------------------------------------------------------------------\\012-- Add column is_chosen_from_list to controlled_vocabularies.\\012------------------------------------------------------------------------------------\\012ALTER TABLE controlled_vocabularies ADD COLUMN is_chosen_from_list BOOLEAN_CHAR NOT NULL DEFAULT TRUE;\\012ALTER TABLE controlled_vocabularies ADD COLUMN source_uri CHARACTER VARYING(250);\\012------------------------------------------------------------------------------------\\012-- Modify Data table - remove arc connection between Sample and Data table, use a flag instead\\012------------------------------------------------------------------------------------\\012\\012-- add new columns\\012\\012ALTER TABLE data\\012    ADD COLUMN is_derived boolean_char;\\012ALTER TABLE data\\012    ADD COLUMN samp_id tech_id;\\012\\012-- update values in new columns\\012\\012UPDATE data\\012    SET is_derived = (samp_id_derived_from IS NOT NULL); \\012UPDATE data\\012    SET samp_id = samp_id_derived_from \\012    WHERE is_derived = 'TRUE';\\012UPDATE data\\012    SET samp_id = samp_id_acquired_from \\012    WHERE is_derived = 'FALSE';\\012\\012-- add constraints and indexes to new columns\\012\\012ALTER TABLE data\\012    ALTER COLUMN is_derived SET NOT NULL;\\012ALTER TABLE data\\012    ALTER COLUMN samp_id SET NOT NULL;   \\012ALTER TABLE data\\012    ADD CONSTRAINT data_samp_fk FOREIGN KEY (samp_id) REFERENCES samples (id);\\012CREATE INDEX data_samp_fk_i ON data USING btree (samp_id);\\012\\012-- remove old columns\\012\\012ALTER TABLE data\\012    DROP COLUMN samp_id_acquired_from;\\012ALTER TABLE data\\012    DROP COLUMN samp_id_derived_from;\\012    \\012------------------------------------------------------------------------------------\\012-- Granting SELECT privilege to group openbis_readonly\\012------------------------------------------------------------------------------------\\012\\012GRANT SELECT ON SEQUENCE attachment_content_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE attachment_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE code_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE controlled_vocabulary_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE cvte_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE data_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE data_set_property_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE data_set_relationship_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE data_set_type_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE data_store_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE data_type_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE database_instance_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE dstpt_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE etpt_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE event_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE experiment_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE experiment_property_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE experiment_type_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE file_format_type_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE group_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE invalidation_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE locator_type_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE material_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE material_property_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE material_type_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE mtpt_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE perm_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE person_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE project_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE property_type_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE role_assignment_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE sample_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE sample_property_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE sample_type_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE stpt_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE attachment_contents TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE attachments TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE controlled_vocabularies TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE controlled_vocabulary_terms TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE data TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE data_set_properties TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE data_set_relationships TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE data_set_type_property_types TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE data_set_types TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE data_stores TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE data_types TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE database_instances TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE database_version_logs TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE events TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE experiment_properties TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE experiment_type_property_types TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE experiment_types TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE experiments TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE external_data TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE file_format_types TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE groups TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE invalidations TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE locator_types TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE material_properties TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE material_type_property_types TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE material_types TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE materials TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE persons TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE projects TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE property_types TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE role_assignments TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE sample_properties TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE sample_type_property_types TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE sample_types TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE samples TO GROUP OPENBIS_READONLY;\\012\\012------------------------------------------------------------------------------------\\012-- Delete MATERIAL_BATCHES table\\012------------------------------------------------------------------------------------\\012\\012-- WARNING: Potential data lost!!!\\012-- WARNING: Potential data lost!!!\\012-- WARNING: Potential data lost!!!\\012\\012DROP TABLE SAMPLE_MATERIAL_BATCHES;\\012DROP TABLE MATERIAL_BATCHES;\\012DROP SEQUENCE MATERIAL_BATCH_ID_SEQ;\\012\\012------------------------------------------------------------------------------------\\012-- Delete MATE_ID_INHIBITOR_OF from table MATERIALS\\012------------------------------------------------------------------------------------\\012\\012-- WARNING: Potential data lost!!!\\012-- WARNING: Potential data lost!!!\\012-- WARNING: Potential data lost!!!\\012\\012ALTER TABLE MATERIALS DROP COLUMN MATE_ID_INHIBITOR_OF;\\012	\N
+./sourceTest/sql/postgresql/036/schema-036.sql:    LANGUAGE plpgsql;
+./sourceTest/sql/postgresql/036/schema-036.sql:    LANGUAGE plpgsql;
+./sourceTest/sql/postgresql/036/schema-036.sql:    LANGUAGE plpgsql;
+./sourceTest/sql/postgresql/036/schema-036.sql:    LANGUAGE plpgsql;
+./sourceTest/sql/postgresql/036/schema-036.sql:    LANGUAGE plpgsql;
+./sourceTest/sql/postgresql/036/schema-036.sql:    LANGUAGE plpgsql;
+./sourceTest/sql/postgresql/036/schema-036.sql:    LANGUAGE plpgsql;
+./sourceTest/sql/postgresql/036/schema-036.sql:    LANGUAGE plpgsql;
+./sourceTest/sql/postgresql/037/.svn/text-base/015=database_version_logs.tsv.svn-base:027	D:\\User\\felmer\\dev-workspace\\openbis/source/sql/postgresql/027/function-027.sql	SUCCESS	2008-11-05 09:18:00.403	-- Creating Functions\\012\\012------------------------------------------------------------------------------------\\012--  Purpose:  Create function RENAME_SEQUENCE() that is required for renaming the sequences belonging to tables\\012------------------------------------------------------------------------------------\\012CREATE FUNCTION RENAME_SEQUENCE(OLD_NAME VARCHAR, NEW_NAME VARCHAR) RETURNS INTEGER AS $$\\012DECLARE\\012  CURR_SEQ_VAL   INTEGER;\\012BEGIN\\012  SELECT INTO CURR_SEQ_VAL NEXTVAL(OLD_NAME);\\012  EXECUTE 'CREATE SEQUENCE ' || NEW_NAME || ' START WITH ' || CURR_SEQ_VAL;\\012  EXECUTE 'DROP SEQUENCE ' || OLD_NAME;\\012  RETURN CURR_SEQ_VAL;\\012END;\\012$$ LANGUAGE 'plpgsql';\\012\\012\\012------------------------------------------------------------------------------------\\012--  Purpose:  Create trigger CONTROLLED_VOCABULARY_CHECK \\012------------------------------------------------------------------------------------\\012\\012CREATE OR REPLACE FUNCTION CONTROLLED_VOCABULARY_CHECK() RETURNS trigger AS $$\\012DECLARE\\012   v_code  CODE;\\012BEGIN\\012\\012   select code into v_code from data_types where id = NEW.daty_id;\\012\\012   -- Check if the data is of type "CONTROLLEDVOCABULARY"\\012   if v_code = 'CONTROLLEDVOCABULARY' then\\012      if NEW.covo_id IS NULL then\\012         RAISE EXCEPTION 'Insert/Update of Property Type (Code: %) failed, as its Data Type is CONTROLLEDVOCABULARY, but it is not linked to a Controlled Vocabulary.', NEW.code;\\012      end if;\\012   end if;\\012\\012   RETURN NEW;\\012\\012END;\\012$$ LANGUAGE 'plpgsql';\\012\\012CREATE TRIGGER CONTROLLED_VOCABULARY_CHECK BEFORE INSERT OR UPDATE ON PROPERTY_TYPES\\012    FOR EACH ROW EXECUTE PROCEDURE CONTROLLED_VOCABULARY_CHECK();\\012\\012\\012------------------------------------------------------------------------------------\\012--  Purpose:  Create trigger EXTERNAL_DATA_STORAGE_FORMAT_CHECK \\012------------------------------------------------------------------------------------\\012\\012CREATE OR REPLACE FUNCTION EXTERNAL_DATA_STORAGE_FORMAT_CHECK() RETURNS trigger AS $$\\012DECLARE\\012   v_covo_code  CODE;\\012   data_code CODE;\\012BEGIN\\012\\012   select code into v_covo_code from controlled_vocabularies\\012      where is_internal_namespace = true and \\012         id = (select covo_id from controlled_vocabulary_terms where id = NEW.cvte_id_stor_fmt);\\012   -- Check if the data storage format is a term of the controlled vocabulary "STORAGE_FORMAT"\\012   if v_covo_code != 'STORAGE_FORMAT' then\\012      select code into data_code from data where id = NEW.data_id; \\012      RAISE EXCEPTION 'Insert/Update of Data (Code: %) failed, as its Storage Format is %, but is required to be STORAGE_FORMAT.', data_code, v_covo_code;\\012   end if;\\012\\012   RETURN NEW;\\012\\012END;\\012$$ LANGUAGE 'plpgsql';\\012\\012CREATE TRIGGER EXTERNAL_DATA_STORAGE_FORMAT_CHECK BEFORE INSERT OR UPDATE ON EXTERNAL_DATA\\012    FOR EACH ROW EXECUTE PROCEDURE EXTERNAL_DATA_STORAGE_FORMAT_CHECK();\\012\\012------------------------------------------------------------------------------------\\012--  Purpose:  Create trigger SAMPLE_CODE_UNIQUENESS_CHECK \\012------------------------------------------------------------------------------------\\012\\012CREATE OR REPLACE FUNCTION SAMPLE_CODE_UNIQUENESS_CHECK() RETURNS trigger AS $$\\012DECLARE\\012   counter  INTEGER;\\012BEGIN\\012\\011IF (NEW.samp_id_part_of is NULL) THEN\\012\\011\\011IF (NEW.dbin_id is not NULL) THEN\\012\\011\\011\\011SELECT count(*) into counter FROM samples \\012\\011\\011\\011\\011where id != NEW.id and code = NEW.code and samp_id_part_of is NULL and dbin_id = NEW.dbin_id;\\012\\011\\011\\011IF (counter > 0) THEN\\012\\011\\011\\011\\011RAISE EXCEPTION 'Insert/Update of Sample (Code: %) failed because database instance sample with the same code already exists.', NEW.code;\\012\\011\\011\\011END IF;\\012\\011\\011ELSIF (NEW.grou_id is not NULL) THEN\\012\\011\\011\\011SELECT count(*) into counter FROM samples \\012\\011\\011\\011\\011where id != NEW.id and code = NEW.code and samp_id_part_of is NULL and grou_id = NEW.grou_id;\\012\\011\\011\\011IF (counter > 0) THEN\\012\\011\\011\\011\\011RAISE EXCEPTION 'Insert/Update of Sample (Code: %) failed because group sample with the same code already exists.', NEW.code;\\012\\011\\011\\011END IF;\\012\\011\\011END IF;\\012        ELSE\\012\\011\\011IF (NEW.dbin_id is not NULL) THEN\\012\\011\\011\\011SELECT count(*) into counter FROM samples \\012\\011\\011\\011\\011where id != NEW.id and code = NEW.code and samp_id_part_of = NEW.samp_id_part_of and dbin_id = NEW.dbin_id;\\012\\011\\011\\011IF (counter > 0) THEN\\012\\011\\011\\011\\011RAISE EXCEPTION 'Insert/Update of Sample (Code: %) failed because database instance sample with the same code and being the part of the same parent already exists.', NEW.code;\\012\\011\\011\\011END IF;\\012\\011\\011ELSIF (NEW.grou_id is not NULL) THEN\\012\\011\\011\\011SELECT count(*) into counter FROM samples \\012\\011\\011\\011\\011where id != NEW.id and code = NEW.code and samp_id_part_of = NEW.samp_id_part_of and grou_id = NEW.grou_id;\\012\\011\\011\\011IF (counter > 0) THEN\\012\\011\\011\\011\\011RAISE EXCEPTION 'Insert/Update of Sample (Code: %) failed because group sample with the same code and being the part of the same parent already exists.', NEW.code;\\012\\011\\011\\011END IF;\\012\\011\\011END IF;\\012        END IF;   \\012   RETURN NEW;\\012END;\\012$$ LANGUAGE 'plpgsql';\\012\\012CREATE TRIGGER SAMPLE_CODE_UNIQUENESS_CHECK BEFORE INSERT OR UPDATE ON SAMPLES\\012    FOR EACH ROW EXECUTE PROCEDURE SAMPLE_CODE_UNIQUENESS_CHECK();\\012	\N
+./sourceTest/sql/postgresql/037/.svn/text-base/015=database_version_logs.tsv.svn-base:028	source/sql/postgresql/migration/migration-027-028.sql	SUCCESS	2008-11-18 13:24:17.508	-- Create EXPERIMENT_ATTACHMENT_CONTENTS.\\012CREATE TABLE EXPERIMENT_ATTACHMENT_CONTENTS (ID TECH_ID NOT NULL,VALUE FILE NOT NULL);\\012CREATE SEQUENCE EXPERIMENT_ATTACHMENT_CONTENT_ID_SEQ;\\012ALTER TABLE EXPERIMENT_ATTACHMENT_CONTENTS ADD CONSTRAINT EXAC_PK PRIMARY KEY(ID);\\012\\012-- Alter EXPERIMENT_ATTACHMENTS by adding the new column which has a NULL constraint.\\012-- The NOT NULL constraint is added later on.\\012ALTER TABLE EXPERIMENT_ATTACHMENTS ADD COLUMN EXAC_ID TECH_ID;\\012\\012-- Does the VALUE migration between EXPERIMENT_ATTACHMENTS to EXPERIMENT_ATTACHMENT_CONTENTS.\\012CREATE OR REPLACE FUNCTION move_exp_att_content() RETURNS integer AS $$\\012DECLARE\\012    rec RECORD;\\012    seq BIGINT;\\012BEGIN\\012  FOR rec IN SELECT id, value FROM EXPERIMENT_ATTACHMENTS LOOP\\012  \\011seq := nextval('EXPERIMENT_ATTACHMENT_CONTENT_ID_SEQ');\\012    INSERT INTO EXPERIMENT_ATTACHMENT_CONTENTS (id, value) VALUES (seq, rec.value);\\012    UPDATE EXPERIMENT_ATTACHMENTS SET exac_id = seq WHERE id = rec.id;\\012  END LOOP;\\012  RETURN 1;\\012END;\\012$$ LANGUAGE 'plpgsql';\\012\\012-- Call the function.\\012SELECT move_exp_att_content();\\012DROP FUNCTION move_exp_att_content();\\012\\012\\012-- Finish EXPERIMENT_ATTACHMENTS changes.\\012ALTER TABLE EXPERIMENT_ATTACHMENTS ADD CONSTRAINT EXAT_CONT_FK FOREIGN KEY (EXAC_ID) REFERENCES EXPERIMENT_ATTACHMENT_CONTENTS(ID);\\012ALTER TABLE EXPERIMENT_ATTACHMENTS DROP COLUMN VALUE;\\012ALTER TABLE EXPERIMENT_ATTACHMENTS ALTER COLUMN EXAC_ID SET NOT NULL;\\012	\N
+./sourceTest/sql/postgresql/037/.svn/text-base/015=database_version_logs.tsv.svn-base:029	source/sql/postgresql/migration/migration-028-029.sql	SUCCESS	2009-03-18 10:50:20.105	-- -------\\012-- add modification_timestamp field to allow edition with Hibernate\\012-- -------\\012\\012ALTER TABLE samples\\012\\011ADD COLUMN modification_timestamp TIME_STAMP DEFAULT CURRENT_TIMESTAMP;\\012\\012ALTER TABLE experiments\\012\\011ADD COLUMN modification_timestamp TIME_STAMP DEFAULT CURRENT_TIMESTAMP;\\012\\012ALTER TABLE materials\\012\\011ADD COLUMN modification_timestamp TIME_STAMP DEFAULT CURRENT_TIMESTAMP;\\012\\012ALTER TABLE experiment_properties\\012\\011ADD COLUMN modification_timestamp TIME_STAMP DEFAULT CURRENT_TIMESTAMP;\\012\\012ALTER TABLE material_properties\\012\\011ADD COLUMN modification_timestamp TIME_STAMP DEFAULT CURRENT_TIMESTAMP;\\012\\012ALTER TABLE sample_properties\\012\\011ADD COLUMN modification_timestamp TIME_STAMP DEFAULT CURRENT_TIMESTAMP;\\012\\012-- -------\\012-- add property data type which references materials\\012-- -------\\012\\012ALTER TABLE property_types\\012\\011ADD COLUMN maty_prop_id tech_id;\\012\\012ALTER TABLE property_types\\012\\011ADD CONSTRAINT prty_maty_fk FOREIGN KEY (maty_prop_id) REFERENCES material_types(id);\\012\\012ALTER TABLE experiment_properties\\012\\011ADD COLUMN mate_prop_id tech_id;\\012\\012ALTER TABLE material_properties\\012\\011ADD COLUMN mate_prop_id tech_id;\\012\\012ALTER TABLE sample_properties\\012\\011ADD COLUMN mate_prop_id tech_id;\\012\\012ALTER TABLE experiment_properties\\012\\011ADD CONSTRAINT expr_mapr_fk FOREIGN KEY (mate_prop_id) REFERENCES materials(id);\\012\\012ALTER TABLE material_properties\\012\\011ADD CONSTRAINT mapr_mapr_fk FOREIGN KEY (mate_prop_id) REFERENCES materials(id);\\012\\012ALTER TABLE sample_properties\\012\\011ADD CONSTRAINT sapr_mapr_fk FOREIGN KEY (mate_prop_id) REFERENCES materials(id);\\012\\012insert into data_types\\012(id\\012 ,code\\012 ,description)\\012 values \\012 (nextval('DATA_TYPE_ID_SEQ')\\012 ,'MATERIAL'\\012 ,'Reference to a material'\\012);\\012\\012ALTER TABLE MATERIAL_PROPERTIES DROP CONSTRAINT MAPR_CK;\\012ALTER TABLE MATERIAL_PROPERTIES ADD CONSTRAINT MAPR_CK CHECK \\012\\011((VALUE IS NOT NULL AND CVTE_ID IS NULL AND MATE_PROP_ID IS NULL) OR \\012\\011 (VALUE IS NULL AND CVTE_ID IS NOT NULL AND MATE_PROP_ID IS NULL) OR\\012\\011 (VALUE IS NULL AND CVTE_ID IS NULL AND MATE_PROP_ID IS NOT NULL)\\012\\011);\\012\\012ALTER TABLE EXPERIMENT_PROPERTIES DROP CONSTRAINT EXPR_CK;\\012ALTER TABLE EXPERIMENT_PROPERTIES ADD CONSTRAINT EXPR_CK CHECK \\012\\011((VALUE IS NOT NULL AND CVTE_ID IS NULL AND MATE_PROP_ID IS NULL) OR \\012\\011 (VALUE IS NULL AND CVTE_ID IS NOT NULL AND MATE_PROP_ID IS NULL) OR\\012\\011 (VALUE IS NULL AND CVTE_ID IS NULL AND MATE_PROP_ID IS NOT NULL)\\012\\011);\\012\\012ALTER TABLE SAMPLE_PROPERTIES DROP CONSTRAINT SAPR_CK;\\012ALTER TABLE SAMPLE_PROPERTIES ADD CONSTRAINT SAPR_CK CHECK \\012\\011((VALUE IS NOT NULL AND CVTE_ID IS NULL AND MATE_PROP_ID IS NULL) OR \\012\\011 (VALUE IS NULL AND CVTE_ID IS NOT NULL AND MATE_PROP_ID IS NULL) OR\\012\\011 (VALUE IS NULL AND CVTE_ID IS NULL AND MATE_PROP_ID IS NOT NULL)\\012\\011);\\012\\012------------------------------------------------------------------------------------\\012--  Purpose:  Create trigger MATERIAL/SAMPLE/EXPERIMENT _PROPERTY_WITH_MATERIAL_DATA_TYPE_CHECK\\012--            It checks that if material property value is assigned to the entity,\\012--\\011\\011\\011\\011\\011\\011then the material type is equal to the one described by property type.\\012------------------------------------------------------------------------------------\\012\\012CREATE OR REPLACE FUNCTION MATERIAL_PROPERTY_WITH_MATERIAL_DATA_TYPE_CHECK() RETURNS trigger AS $$\\012DECLARE\\012   v_type_id  CODE;\\012   v_type_id_prop  CODE;\\012BEGIN\\012   if NEW.mate_prop_id IS NOT NULL then\\012\\011\\011\\011-- find material type id of the property type \\012\\011\\011\\011select pt.maty_prop_id into v_type_id_prop \\012\\011\\011\\011  from material_type_property_types etpt, property_types pt \\012\\011\\011\\011 where NEW.mtpt_id = etpt.id AND etpt.prty_id = pt.id;\\012\\011\\011\\012\\011\\011\\011if v_type_id_prop IS NOT NULL then\\012\\011\\011\\011\\011-- find material type id of the material which consists the entity's property value\\012\\011\\011\\011\\011select entity.maty_id into v_type_id \\012\\011\\011\\011\\011  from materials entity\\012\\011\\011\\011\\011 where NEW.mate_prop_id = entity.id;\\012\\011\\011\\011\\011if v_type_id != v_type_id_prop then\\012\\011\\011\\011\\011\\011RAISE EXCEPTION 'Insert/Update of property value referencing material (id: %) failed, as referenced material type is different than expected (id %, expected id: %).', \\012\\011\\011\\011\\011\\011\\011\\011 NEW.mate_prop_id, v_type_id, v_type_id_prop;\\012\\011\\011\\011\\011end if;\\012\\011\\011\\011end if;\\012   end if;\\012   RETURN NEW;\\012END;\\012$$ LANGUAGE 'plpgsql';\\012\\012CREATE TRIGGER MATERIAL_PROPERTY_WITH_MATERIAL_DATA_TYPE_CHECK BEFORE INSERT OR UPDATE ON material_properties\\012    FOR EACH ROW EXECUTE PROCEDURE MATERIAL_PROPERTY_WITH_MATERIAL_DATA_TYPE_CHECK();\\012    \\012CREATE OR REPLACE FUNCTION SAMPLE_PROPERTY_WITH_MATERIAL_DATA_TYPE_CHECK() RETURNS trigger AS $$\\012DECLARE\\012   v_type_id  CODE;\\012   v_type_id_prop  CODE;\\012BEGIN\\012   if NEW.mate_prop_id IS NOT NULL then\\012\\011\\011\\011-- find material type id of the property type \\012\\011\\011\\011select pt.maty_prop_id into v_type_id_prop \\012\\011\\011\\011  from sample_type_property_types etpt, property_types pt \\012\\011\\011\\011 where NEW.stpt_id = etpt.id AND etpt.prty_id = pt.id;\\012\\011\\011\\012\\011\\011\\011if v_type_id_prop IS NOT NULL then\\012\\011\\011\\011\\011-- find material type id of the material which consists the entity's property value\\012\\011\\011\\011\\011select entity.maty_id into v_type_id \\012\\011\\011\\011\\011  from materials entity\\012\\011\\011\\011\\011 where NEW.mate_prop_id = entity.id;\\012\\011\\011\\011\\011if v_type_id != v_type_id_prop then\\012\\011\\011\\011\\011\\011RAISE EXCEPTION 'Insert/Update of property value referencing material (id: %) failed, as referenced material type is different than expected (id %, expected id: %).', \\012\\011\\011\\011\\011\\011\\011\\011\\011\\011\\011\\011\\011 NEW.mate_prop_id, v_type_id, v_type_id_prop;\\012\\011\\011\\011\\011end if;\\012\\011\\011\\011end if;\\012   end if;\\012   RETURN NEW;\\012END;\\012$$ LANGUAGE 'plpgsql';\\012\\012CREATE TRIGGER SAMPLE_PROPERTY_WITH_MATERIAL_DATA_TYPE_CHECK BEFORE INSERT OR UPDATE ON sample_properties\\012    FOR EACH ROW EXECUTE PROCEDURE SAMPLE_PROPERTY_WITH_MATERIAL_DATA_TYPE_CHECK();\\012    \\012CREATE OR REPLACE FUNCTION EXPERIMENT_PROPERTY_WITH_MATERIAL_DATA_TYPE_CHECK() RETURNS trigger AS $$\\012DECLARE\\012   v_type_id  CODE;\\012   v_type_id_prop  CODE;\\012BEGIN\\012   if NEW.mate_prop_id IS NOT NULL then\\012\\011\\011\\011-- find material type id of the property type \\012\\011\\011\\011select pt.maty_prop_id into v_type_id_prop \\012\\011\\011\\011  from experiment_type_property_types etpt, property_types pt \\012\\011\\011\\011 where NEW.etpt_id = etpt.id AND etpt.prty_id = pt.id;\\012\\011\\011\\012\\011\\011\\011if v_type_id_prop IS NOT NULL then\\012\\011\\011\\011\\011-- find material type id of the material which consists the entity's property value\\012\\011\\011\\011\\011select entity.maty_id into v_type_id \\012\\011\\011\\011\\011  from materials entity\\012\\011\\011\\011\\011 where NEW.mate_prop_id = entity.id;\\012\\011\\011\\011\\011if v_type_id != v_type_id_prop then\\012\\011\\011\\011\\011\\011RAISE EXCEPTION 'Insert/Update of property value referencing material (id: %) failed, as referenced material type is different than expected (id %, expected id: %).', \\012\\011\\011\\011\\011\\011\\011\\011\\011\\011\\011\\011\\011 NEW.mate_prop_id, v_type_id, v_type_id_prop;\\012\\011\\011\\011\\011end if;\\012\\011\\011\\011end if;\\012   end if;\\012   RETURN NEW;\\012END;\\012$$ LANGUAGE 'plpgsql';\\012\\012CREATE TRIGGER EXPERIMENT_PROPERTY_WITH_MATERIAL_DATA_TYPE_CHECK BEFORE INSERT OR UPDATE ON experiment_properties\\012    FOR EACH ROW EXECUTE PROCEDURE EXPERIMENT_PROPERTY_WITH_MATERIAL_DATA_TYPE_CHECK();\\012       \\012-- -------\\012-- remove the reminescents of the OBSERVABLE_TYPE\\012-- -------\\012\\012ALTER TABLE data\\012\\011DROP CONSTRAINT data_obty_fk;\\012\\012ALTER TABLE data_set_types\\012\\011DROP CONSTRAINT obty_pk;\\012\\012ALTER TABLE data_set_types\\012\\011ADD CONSTRAINT dsty_pk PRIMARY KEY (id);\\012\\012ALTER TABLE data\\012\\011ADD CONSTRAINT data_dsty_fk FOREIGN KEY (dsty_id) REFERENCES data_set_types(id);\\012\\012ALTER TABLE data_set_types\\012\\011DROP CONSTRAINT obty_bk_uk;\\012\\012ALTER TABLE data_set_types\\012\\011DROP CONSTRAINT obty_dbin_fk;\\012\\012ALTER TABLE data_set_types\\012\\011ADD CONSTRAINT dsty_bk_uk UNIQUE (code, dbin_id);\\012\\012ALTER TABLE data_set_types\\012\\011ADD CONSTRAINT dsty_dbin_fk FOREIGN KEY (dbin_id) REFERENCES database_instances(id);\\012\\012DROP INDEX data_obty_fk_i;\\012\\012CREATE INDEX data_dsty_fk_i ON data(dsty_id);\\012	\N
+./sourceTest/sql/postgresql/037/.svn/text-base/015=database_version_logs.tsv.svn-base:030	source/sql/postgresql/migration/migration-029-030.sql	SUCCESS	2009-03-23 15:34:44.72	-- -------\\012-- add modification_timestamp field to allow edition with Hibernate\\012-- -------\\012ALTER TABLE data\\012\\011ADD COLUMN modification_timestamp TIME_STAMP DEFAULT CURRENT_TIMESTAMP;\\012ALTER TABLE experiment_types\\012\\011ADD COLUMN modification_timestamp TIME_STAMP DEFAULT CURRENT_TIMESTAMP;\\012ALTER TABLE sample_types\\012\\011ADD COLUMN modification_timestamp TIME_STAMP DEFAULT CURRENT_TIMESTAMP;\\012ALTER TABLE material_types\\012\\011ADD COLUMN modification_timestamp TIME_STAMP DEFAULT CURRENT_TIMESTAMP;\\012ALTER TABLE data_set_types\\012\\011ADD COLUMN modification_timestamp TIME_STAMP DEFAULT CURRENT_TIMESTAMP;\\012ALTER TABLE controlled_vocabularies\\012\\011ADD COLUMN modification_timestamp TIME_STAMP DEFAULT CURRENT_TIMESTAMP;\\012-- -------\\012-- add properties to data sets\\012-- -------\\012CREATE TABLE DATA_SET_PROPERTIES (ID TECH_ID NOT NULL,DS_ID TECH_ID NOT NULL,DSTPT_ID TECH_ID NOT NULL,VALUE GENERIC_VALUE,CVTE_ID TECH_ID, MATE_PROP_ID TECH_ID, PERS_ID_REGISTERER TECH_ID NOT NULL,REGISTRATION_TIMESTAMP TIME_STAMP_DFL NOT NULL DEFAULT CURRENT_TIMESTAMP, MODIFICATION_TIMESTAMP TIME_STAMP DEFAULT CURRENT_TIMESTAMP);\\012CREATE TABLE DATA_SET_TYPE_PROPERTY_TYPES (ID TECH_ID NOT NULL,DSTY_ID TECH_ID NOT NULL,PRTY_ID TECH_ID NOT NULL,IS_MANDATORY BOOLEAN_CHAR NOT NULL DEFAULT 'F',IS_MANAGED_INTERNALLY BOOLEAN_CHAR NOT NULL DEFAULT 'F',PERS_ID_REGISTERER TECH_ID NOT NULL,REGISTRATION_TIMESTAMP TIME_STAMP_DFL NOT NULL DEFAULT CURRENT_TIMESTAMP);\\012\\012CREATE SEQUENCE DATA_SET_PROPERTY_ID_SEQ;\\012CREATE SEQUENCE DSTPT_ID_SEQ;\\012\\012ALTER TABLE DATA_SET_TYPE_PROPERTY_TYPES ADD CONSTRAINT DSTPT_PK PRIMARY KEY(ID);\\012ALTER TABLE DATA_SET_PROPERTIES ADD CONSTRAINT DSPR_PK PRIMARY KEY(ID);\\012\\012ALTER TABLE DATA_SET_TYPE_PROPERTY_TYPES ADD CONSTRAINT DSTPT_BK_UK UNIQUE(DSTY_ID,PRTY_ID);\\012ALTER TABLE DATA_SET_PROPERTIES ADD CONSTRAINT DSPR_BK_UK UNIQUE(DS_ID,DSTPT_ID);\\012\\012\\012ALTER TABLE DATA_SET_TYPE_PROPERTY_TYPES ADD CONSTRAINT DSTPT_DSTY_FK FOREIGN KEY (DSTY_ID) REFERENCES DATA_SET_TYPES(ID);\\012ALTER TABLE DATA_SET_TYPE_PROPERTY_TYPES ADD CONSTRAINT DSTPT_PERS_FK FOREIGN KEY (PERS_ID_REGISTERER) REFERENCES PERSONS(ID);\\012ALTER TABLE DATA_SET_TYPE_PROPERTY_TYPES ADD CONSTRAINT DSTPT_PRTY_FK FOREIGN KEY (PRTY_ID) REFERENCES PROPERTY_TYPES(ID);\\012ALTER TABLE DATA_SET_PROPERTIES ADD CONSTRAINT DSPR_CVTE_FK FOREIGN KEY (CVTE_ID) REFERENCES CONTROLLED_VOCABULARY_TERMS(ID);\\012ALTER TABLE DATA_SET_PROPERTIES ADD CONSTRAINT DSPR_DSTPT_FK FOREIGN KEY (DSTPT_ID) REFERENCES DATA_SET_TYPE_PROPERTY_TYPES(ID) ON DELETE CASCADE;\\012ALTER TABLE DATA_SET_PROPERTIES ADD CONSTRAINT DSPR_DS_FK FOREIGN KEY (DS_ID) REFERENCES DATA(ID);\\012ALTER TABLE DATA_SET_PROPERTIES ADD CONSTRAINT DSPR_PERS_FK FOREIGN KEY (PERS_ID_REGISTERER) REFERENCES PERSONS(ID);\\012ALTER TABLE DATA_SET_PROPERTIES ADD CONSTRAINT DSPR_MAPR_FK FOREIGN KEY (MATE_PROP_ID) REFERENCES MATERIALS(ID);\\012\\012ALTER TABLE DATA_SET_PROPERTIES ADD CONSTRAINT DSPR_CK CHECK \\012\\011((VALUE IS NOT NULL AND CVTE_ID IS NULL AND MATE_PROP_ID IS NULL) OR \\012\\011 (VALUE IS NULL AND CVTE_ID IS NOT NULL AND MATE_PROP_ID IS NULL) OR\\012\\011 (VALUE IS NULL AND CVTE_ID IS NULL AND MATE_PROP_ID IS NOT NULL)\\012\\011);\\012\\012CREATE INDEX DSPR_CVTE_FK_I ON DATA_SET_PROPERTIES (CVTE_ID);\\012CREATE INDEX DSPR_DSTPT_FK_I ON DATA_SET_PROPERTIES (DSTPT_ID);\\012CREATE INDEX DSPR_DS_FK_I ON DATA_SET_PROPERTIES (DS_ID);\\012CREATE INDEX DSPR_PERS_FK_I ON DATA_SET_PROPERTIES (PERS_ID_REGISTERER);\\012CREATE INDEX DSTPT_DSTY_FK_I ON DATA_SET_TYPE_PROPERTY_TYPES (DSTY_ID);\\012CREATE INDEX DSTPT_PERS_FK_I ON DATA_SET_TYPE_PROPERTY_TYPES (PERS_ID_REGISTERER);\\012CREATE INDEX DSTPT_PRTY_FK_I ON DATA_SET_TYPE_PROPERTY_TYPES (PRTY_ID);\\012\\012CREATE OR REPLACE FUNCTION DATA_SET_PROPERTY_WITH_MATERIAL_DATA_TYPE_CHECK() RETURNS trigger AS $$\\012DECLARE\\012   v_type_id  CODE;\\012   v_type_id_prop  CODE;\\012BEGIN\\012   if NEW.mate_prop_id IS NOT NULL then\\012\\011\\011\\011-- find material type id of the property type \\012\\011\\011\\011select pt.maty_prop_id into v_type_id_prop \\012\\011\\011\\011  from data_set_type_property_types dstpt, property_types pt \\012\\011\\011\\011 where NEW.dstpt_id = dstpt.id AND dstpt.prty_id = pt.id;\\012\\011\\011\\012\\011\\011\\011if v_type_id_prop IS NOT NULL then\\012\\011\\011\\011\\011-- find material type id of the material which consists the entity's property value\\012\\011\\011\\011\\011select entity.maty_id into v_type_id \\012\\011\\011\\011\\011  from materials entity\\012\\011\\011\\011\\011 where NEW.mate_prop_id = entity.id;\\012\\011\\011\\011\\011if v_type_id != v_type_id_prop then\\012\\011\\011\\011\\011\\011RAISE EXCEPTION 'Insert/Update of property value referencing material (id: %) failed, as referenced material type is different than expected (id %, expected id: %).', \\012\\011\\011\\011\\011\\011\\011\\011\\011\\011\\011\\011\\011 NEW.mate_prop_id, v_type_id, v_type_id_prop;\\012\\011\\011\\011\\011end if;\\012\\011\\011\\011end if;\\012   end if;\\012   RETURN NEW;\\012END;\\012$$ LANGUAGE 'plpgsql';\\012\\012CREATE TRIGGER DATA_SET_PROPERTY_WITH_MATERIAL_DATA_TYPE_CHECK BEFORE INSERT OR UPDATE ON data_set_properties\\012    FOR EACH ROW EXECUTE PROCEDURE DATA_SET_PROPERTY_WITH_MATERIAL_DATA_TYPE_CHECK();   \\012	\N
+./sourceTest/sql/postgresql/037/.svn/text-base/015=database_version_logs.tsv.svn-base:032	source/sql/postgresql/migration/migration-031-032.sql	SUCCESS	2009-04-09 09:36:36.20	-- -------\\012-- Modify MATERIAL_BATCHES\\012-- -------\\012\\012ALTER TABLE material_batches\\012    DROP COLUMN proc_id;\\012\\012-- -------\\012-- Modify SAMPLES\\012-- -------\\012\\012ALTER TABLE samples\\012    ADD COLUMN expe_id tech_id;\\012\\012ALTER TABLE samples\\012    ADD CONSTRAINT samp_expe_fk FOREIGN KEY (expe_id) REFERENCES experiments(id);\\012\\012CREATE INDEX samp_expe_fk_i ON samples USING btree (expe_id);\\012\\012-- relink samples directly to experiments\\012\\012UPDATE samples\\012SET expe_id = (SELECT e.id FROM experiments e, procedures p, sample_inputs si \\012               WHERE si.samp_id = samples.id AND si.proc_id = p.id AND p.expe_id = e.id AND e.inva_id IS NULL);\\012\\012\\012-- -------\\012-- Modify DATA\\012-- -------\\012\\012ALTER TABLE data\\012    ADD COLUMN expe_id tech_id;\\012\\012ALTER TABLE data\\012    ADD CONSTRAINT data_expe_fk FOREIGN KEY (expe_id) REFERENCES experiments(id);\\012\\012CREATE INDEX data_expe_fk_i ON data USING btree (expe_id);\\012\\012UPDATE data\\012SET expe_id = (SELECT e.id FROM experiments e, procedures p \\012               WHERE data.proc_id_produced_by = p.id AND p.expe_id = e.id);\\012\\012ALTER TABLE data\\012    ALTER COLUMN expe_id SET NOT NULL;\\012\\012ALTER TABLE data\\012    DROP COLUMN proc_id_produced_by;\\012\\012-- -------\\012-- Drop PROCEDURES, PROCEDURE_TYPES, and SAMPLE_INPUTS\\012-- -------\\012\\012DROP TABLE sample_inputs;\\012DROP TABLE procedures;\\012DROP TABLE procedure_types;\\012\\012DROP SEQUENCE procedure_id_seq;\\012DROP SEQUENCE procedure_type_id_seq;\\012\\012-- -------\\012-- Add CODE_SEQ\\012-- -------\\012\\012CREATE SEQUENCE CODE_SEQ;\\012\\012-- -------\\012-- Add new columns to DATA_STORES\\012-- -------\\012\\012ALTER TABLE data_stores\\012    ADD COLUMN remote_url character varying(250),\\012    ADD COLUMN session_token character varying(50),\\012    ADD COLUMN modification_timestamp time_stamp DEFAULT now();\\012\\012UPDATE data_stores\\012SET remote_url = '', session_token='';\\012\\012ALTER TABLE data_stores\\012    ALTER COLUMN remote_url SET NOT NULL,\\012    ALTER COLUMN session_token SET NOT NULL;\\012\\012-- -------\\012-- Drop foreign keys onto DATA_STORES\\012-- -------\\012\\012ALTER TABLE database_instances\\012    DROP COLUMN dast_id;\\012\\012ALTER TABLE groups\\012    DROP COLUMN dast_id;\\012\\012ALTER TABLE projects\\012    DROP COLUMN dast_id;\\012\\012ALTER TABLE experiments\\012    DROP COLUMN dast_id;\\012\\012-- -------\\012-- Add foreign key from DATA onto DATA_STORES\\012-- -------\\012\\012ALTER TABLE data\\012    ADD COLUMN dast_id tech_id;\\012\\012ALTER TABLE data\\012    ADD CONSTRAINT data_dast_fk FOREIGN KEY (dast_id) REFERENCES data_stores(id);\\012\\012UPDATE data\\012SET dast_id = (select id from data_stores where code = 'STANDARD');\\012\\012ALTER TABLE data\\012    ALTER COLUMN dast_id SET NOT NULL;\\012\\012\\012------------------------------------------------------------------------------------\\012--  Purpose:  Replace trigger SAMPLE_CODE_UNIQUENESS_CHECK \\012------------------------------------------------------------------------------------\\012\\012CREATE OR REPLACE FUNCTION SAMPLE_CODE_UNIQUENESS_CHECK() RETURNS trigger AS $$\\012DECLARE\\012   counter  INTEGER;\\012BEGIN\\012    LOCK TABLE samples IN EXCLUSIVE MODE;\\012    IF (NEW.samp_id_part_of is NULL) THEN\\012        IF (NEW.dbin_id is not NULL) THEN\\012            SELECT count(*) into counter FROM samples \\012                where id != NEW.id and code = NEW.code and samp_id_part_of is NULL and dbin_id = NEW.dbin_id;\\012            IF (counter > 0) THEN\\012                RAISE EXCEPTION 'Insert/Update of Sample (Code: %) failed because database instance sample with the same code already exists.', NEW.code;\\012            END IF;\\012        ELSIF (NEW.grou_id is not NULL) THEN\\012            SELECT count(*) into counter FROM samples \\012                where id != NEW.id and code = NEW.code and samp_id_part_of is NULL and grou_id = NEW.grou_id;\\012            IF (counter > 0) THEN\\012                RAISE EXCEPTION 'Insert/Update of Sample (Code: %) failed because group sample with the same code already exists.', NEW.code;\\012            END IF;\\012        END IF;\\012        ELSE\\012        IF (NEW.dbin_id is not NULL) THEN\\012            SELECT count(*) into counter FROM samples \\012                where id != NEW.id and code = NEW.code and samp_id_part_of = NEW.samp_id_part_of and dbin_id = NEW.dbin_id;\\012            IF (counter > 0) THEN\\012                RAISE EXCEPTION 'Insert/Update of Sample (Code: %) failed because database instance sample with the same code and being the part of the same parent already exists.', NEW.code;\\012            END IF;\\012        ELSIF (NEW.grou_id is not NULL) THEN\\012            SELECT count(*) into counter FROM samples \\012                where id != NEW.id and code = NEW.code and samp_id_part_of = NEW.samp_id_part_of and grou_id = NEW.grou_id;\\012            IF (counter > 0) THEN\\012                RAISE EXCEPTION 'Insert/Update of Sample (Code: %) failed because group sample with the same code and being the part of the same parent already exists.', NEW.code;\\012            END IF;\\012        END IF;\\012        END IF;   \\012   RETURN NEW;\\012END;\\012$$ LANGUAGE 'plpgsql';\\012\\012\\012\\012	\N
+./sourceTest/sql/postgresql/037/.svn/text-base/015=database_version_logs.tsv.svn-base:034	source/sql/postgresql/migration/migration-033-034.sql	SUCCESS	2009-05-26 08:32:49.935	------------------------------------------------------------------------------------\\012-- Create sequence for generating permanent identifiers starting with nextval of existing dataset sequence.\\012------------------------------------------------------------------------------------\\012CREATE FUNCTION CREATE_SEQUENCE(EXISTING_SEQUENCE VARCHAR, NEW_SEQUENCE VARCHAR) RETURNS VOID AS $$\\012DECLARE\\012  CURR_SEQ_VAL   INTEGER;\\012BEGIN\\012  SELECT INTO CURR_SEQ_VAL NEXTVAL(EXISTING_SEQUENCE);\\012  EXECUTE 'CREATE SEQUENCE ' || NEW_SEQUENCE || ' START WITH ' || CURR_SEQ_VAL;\\012  RETURN;\\012END;\\012$$ LANGUAGE 'plpgsql';\\012\\012SELECT CREATE_SEQUENCE('DATA_ID_SEQ', 'PERM_ID_SEQ');\\012DROP FUNCTION CREATE_SEQUENCE(VARCHAR, VARCHAR);\\012\\012------------------------------------------------------------------------------------\\012-- Add perm_id columns to samples and experiments.\\012------------------------------------------------------------------------------------\\012ALTER TABLE SAMPLES ADD COLUMN PERM_ID CODE;\\012ALTER TABLE EXPERIMENTS ADD COLUMN PERM_ID CODE;\\012\\012UPDATE SAMPLES SET PERM_ID = to_char(registration_timestamp,'YYYYMMDDHHSSMS') || '-' || NEXTVAL('PERM_ID_SEQ');\\012UPDATE EXPERIMENTS SET PERM_ID = to_char(registration_timestamp,'YYYYMMDDHHSSMS') || '-' || NEXTVAL('PERM_ID_SEQ');\\012ALTER TABLE SAMPLES ALTER COLUMN PERM_ID SET NOT NULL;\\012ALTER TABLE EXPERIMENTS ALTER COLUMN PERM_ID SET NOT NULL;\\012ALTER TABLE SAMPLES ADD CONSTRAINT SAMP_PI_UK UNIQUE(PERM_ID);\\012ALTER TABLE EXPERIMENTS ADD CONSTRAINT EXPE_PI_UK UNIQUE(PERM_ID);\\012\\012\\012------------------------------------------------------------------------------------\\012-- Add column is_chosen_from_list to controlled_vocabularies.\\012------------------------------------------------------------------------------------\\012ALTER TABLE controlled_vocabularies ADD COLUMN is_chosen_from_list BOOLEAN_CHAR NOT NULL DEFAULT TRUE;\\012ALTER TABLE controlled_vocabularies ADD COLUMN source_uri CHARACTER VARYING(250);\\012------------------------------------------------------------------------------------\\012-- Modify Data table - remove arc connection between Sample and Data table, use a flag instead\\012------------------------------------------------------------------------------------\\012\\012-- add new columns\\012\\012ALTER TABLE data\\012    ADD COLUMN is_derived boolean_char;\\012ALTER TABLE data\\012    ADD COLUMN samp_id tech_id;\\012\\012-- update values in new columns\\012\\012UPDATE data\\012    SET is_derived = (samp_id_derived_from IS NOT NULL); \\012UPDATE data\\012    SET samp_id = samp_id_derived_from \\012    WHERE is_derived = 'TRUE';\\012UPDATE data\\012    SET samp_id = samp_id_acquired_from \\012    WHERE is_derived = 'FALSE';\\012\\012-- add constraints and indexes to new columns\\012\\012ALTER TABLE data\\012    ALTER COLUMN is_derived SET NOT NULL;\\012ALTER TABLE data\\012    ALTER COLUMN samp_id SET NOT NULL;   \\012ALTER TABLE data\\012    ADD CONSTRAINT data_samp_fk FOREIGN KEY (samp_id) REFERENCES samples (id);\\012CREATE INDEX data_samp_fk_i ON data USING btree (samp_id);\\012\\012-- remove old columns\\012\\012ALTER TABLE data\\012    DROP COLUMN samp_id_acquired_from;\\012ALTER TABLE data\\012    DROP COLUMN samp_id_derived_from;\\012    \\012------------------------------------------------------------------------------------\\012-- Granting SELECT privilege to group openbis_readonly\\012------------------------------------------------------------------------------------\\012\\012GRANT SELECT ON SEQUENCE attachment_content_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE attachment_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE code_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE controlled_vocabulary_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE cvte_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE data_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE data_set_property_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE data_set_relationship_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE data_set_type_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE data_store_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE data_type_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE database_instance_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE dstpt_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE etpt_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE event_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE experiment_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE experiment_property_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE experiment_type_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE file_format_type_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE group_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE invalidation_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE locator_type_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE material_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE material_property_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE material_type_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE mtpt_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE perm_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE person_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE project_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE property_type_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE role_assignment_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE sample_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE sample_property_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE sample_type_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE stpt_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE attachment_contents TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE attachments TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE controlled_vocabularies TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE controlled_vocabulary_terms TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE data TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE data_set_properties TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE data_set_relationships TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE data_set_type_property_types TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE data_set_types TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE data_stores TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE data_types TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE database_instances TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE database_version_logs TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE events TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE experiment_properties TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE experiment_type_property_types TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE experiment_types TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE experiments TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE external_data TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE file_format_types TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE groups TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE invalidations TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE locator_types TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE material_properties TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE material_type_property_types TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE material_types TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE materials TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE persons TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE projects TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE property_types TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE role_assignments TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE sample_properties TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE sample_type_property_types TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE sample_types TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE samples TO GROUP OPENBIS_READONLY;\\012\\012------------------------------------------------------------------------------------\\012-- Delete MATERIAL_BATCHES table\\012------------------------------------------------------------------------------------\\012\\012-- WARNING: Potential data lost!!!\\012-- WARNING: Potential data lost!!!\\012-- WARNING: Potential data lost!!!\\012\\012DROP TABLE SAMPLE_MATERIAL_BATCHES;\\012DROP TABLE MATERIAL_BATCHES;\\012DROP SEQUENCE MATERIAL_BATCH_ID_SEQ;\\012\\012------------------------------------------------------------------------------------\\012-- Delete MATE_ID_INHIBITOR_OF from table MATERIALS\\012------------------------------------------------------------------------------------\\012\\012-- WARNING: Potential data lost!!!\\012-- WARNING: Potential data lost!!!\\012-- WARNING: Potential data lost!!!\\012\\012ALTER TABLE MATERIALS DROP COLUMN MATE_ID_INHIBITOR_OF;\\012	\N
+./sourceTest/sql/postgresql/037/.svn/text-base/schema-037.sql.svn-base:    LANGUAGE plpgsql;
+./sourceTest/sql/postgresql/037/.svn/text-base/schema-037.sql.svn-base:    LANGUAGE plpgsql;
+./sourceTest/sql/postgresql/037/.svn/text-base/schema-037.sql.svn-base:    LANGUAGE plpgsql;
+./sourceTest/sql/postgresql/037/.svn/text-base/schema-037.sql.svn-base:    LANGUAGE plpgsql;
+./sourceTest/sql/postgresql/037/.svn/text-base/schema-037.sql.svn-base:    LANGUAGE plpgsql;
+./sourceTest/sql/postgresql/037/.svn/text-base/schema-037.sql.svn-base:    LANGUAGE plpgsql;
+./sourceTest/sql/postgresql/037/.svn/text-base/schema-037.sql.svn-base:    LANGUAGE plpgsql;
+./sourceTest/sql/postgresql/037/.svn/text-base/schema-037.sql.svn-base:    LANGUAGE plpgsql;
+./sourceTest/sql/postgresql/037/015=database_version_logs.tsv:027	D:\\User\\felmer\\dev-workspace\\openbis/source/sql/postgresql/027/function-027.sql	SUCCESS	2008-11-05 09:18:00.403	-- Creating Functions\\012\\012------------------------------------------------------------------------------------\\012--  Purpose:  Create function RENAME_SEQUENCE() that is required for renaming the sequences belonging to tables\\012------------------------------------------------------------------------------------\\012CREATE FUNCTION RENAME_SEQUENCE(OLD_NAME VARCHAR, NEW_NAME VARCHAR) RETURNS INTEGER AS $$\\012DECLARE\\012  CURR_SEQ_VAL   INTEGER;\\012BEGIN\\012  SELECT INTO CURR_SEQ_VAL NEXTVAL(OLD_NAME);\\012  EXECUTE 'CREATE SEQUENCE ' || NEW_NAME || ' START WITH ' || CURR_SEQ_VAL;\\012  EXECUTE 'DROP SEQUENCE ' || OLD_NAME;\\012  RETURN CURR_SEQ_VAL;\\012END;\\012$$ LANGUAGE 'plpgsql';\\012\\012\\012------------------------------------------------------------------------------------\\012--  Purpose:  Create trigger CONTROLLED_VOCABULARY_CHECK \\012------------------------------------------------------------------------------------\\012\\012CREATE OR REPLACE FUNCTION CONTROLLED_VOCABULARY_CHECK() RETURNS trigger AS $$\\012DECLARE\\012   v_code  CODE;\\012BEGIN\\012\\012   select code into v_code from data_types where id = NEW.daty_id;\\012\\012   -- Check if the data is of type "CONTROLLEDVOCABULARY"\\012   if v_code = 'CONTROLLEDVOCABULARY' then\\012      if NEW.covo_id IS NULL then\\012         RAISE EXCEPTION 'Insert/Update of Property Type (Code: %) failed, as its Data Type is CONTROLLEDVOCABULARY, but it is not linked to a Controlled Vocabulary.', NEW.code;\\012      end if;\\012   end if;\\012\\012   RETURN NEW;\\012\\012END;\\012$$ LANGUAGE 'plpgsql';\\012\\012CREATE TRIGGER CONTROLLED_VOCABULARY_CHECK BEFORE INSERT OR UPDATE ON PROPERTY_TYPES\\012    FOR EACH ROW EXECUTE PROCEDURE CONTROLLED_VOCABULARY_CHECK();\\012\\012\\012------------------------------------------------------------------------------------\\012--  Purpose:  Create trigger EXTERNAL_DATA_STORAGE_FORMAT_CHECK \\012------------------------------------------------------------------------------------\\012\\012CREATE OR REPLACE FUNCTION EXTERNAL_DATA_STORAGE_FORMAT_CHECK() RETURNS trigger AS $$\\012DECLARE\\012   v_covo_code  CODE;\\012   data_code CODE;\\012BEGIN\\012\\012   select code into v_covo_code from controlled_vocabularies\\012      where is_internal_namespace = true and \\012         id = (select covo_id from controlled_vocabulary_terms where id = NEW.cvte_id_stor_fmt);\\012   -- Check if the data storage format is a term of the controlled vocabulary "STORAGE_FORMAT"\\012   if v_covo_code != 'STORAGE_FORMAT' then\\012      select code into data_code from data where id = NEW.data_id; \\012      RAISE EXCEPTION 'Insert/Update of Data (Code: %) failed, as its Storage Format is %, but is required to be STORAGE_FORMAT.', data_code, v_covo_code;\\012   end if;\\012\\012   RETURN NEW;\\012\\012END;\\012$$ LANGUAGE 'plpgsql';\\012\\012CREATE TRIGGER EXTERNAL_DATA_STORAGE_FORMAT_CHECK BEFORE INSERT OR UPDATE ON EXTERNAL_DATA\\012    FOR EACH ROW EXECUTE PROCEDURE EXTERNAL_DATA_STORAGE_FORMAT_CHECK();\\012\\012------------------------------------------------------------------------------------\\012--  Purpose:  Create trigger SAMPLE_CODE_UNIQUENESS_CHECK \\012------------------------------------------------------------------------------------\\012\\012CREATE OR REPLACE FUNCTION SAMPLE_CODE_UNIQUENESS_CHECK() RETURNS trigger AS $$\\012DECLARE\\012   counter  INTEGER;\\012BEGIN\\012\\011IF (NEW.samp_id_part_of is NULL) THEN\\012\\011\\011IF (NEW.dbin_id is not NULL) THEN\\012\\011\\011\\011SELECT count(*) into counter FROM samples \\012\\011\\011\\011\\011where id != NEW.id and code = NEW.code and samp_id_part_of is NULL and dbin_id = NEW.dbin_id;\\012\\011\\011\\011IF (counter > 0) THEN\\012\\011\\011\\011\\011RAISE EXCEPTION 'Insert/Update of Sample (Code: %) failed because database instance sample with the same code already exists.', NEW.code;\\012\\011\\011\\011END IF;\\012\\011\\011ELSIF (NEW.grou_id is not NULL) THEN\\012\\011\\011\\011SELECT count(*) into counter FROM samples \\012\\011\\011\\011\\011where id != NEW.id and code = NEW.code and samp_id_part_of is NULL and grou_id = NEW.grou_id;\\012\\011\\011\\011IF (counter > 0) THEN\\012\\011\\011\\011\\011RAISE EXCEPTION 'Insert/Update of Sample (Code: %) failed because group sample with the same code already exists.', NEW.code;\\012\\011\\011\\011END IF;\\012\\011\\011END IF;\\012        ELSE\\012\\011\\011IF (NEW.dbin_id is not NULL) THEN\\012\\011\\011\\011SELECT count(*) into counter FROM samples \\012\\011\\011\\011\\011where id != NEW.id and code = NEW.code and samp_id_part_of = NEW.samp_id_part_of and dbin_id = NEW.dbin_id;\\012\\011\\011\\011IF (counter > 0) THEN\\012\\011\\011\\011\\011RAISE EXCEPTION 'Insert/Update of Sample (Code: %) failed because database instance sample with the same code and being the part of the same parent already exists.', NEW.code;\\012\\011\\011\\011END IF;\\012\\011\\011ELSIF (NEW.grou_id is not NULL) THEN\\012\\011\\011\\011SELECT count(*) into counter FROM samples \\012\\011\\011\\011\\011where id != NEW.id and code = NEW.code and samp_id_part_of = NEW.samp_id_part_of and grou_id = NEW.grou_id;\\012\\011\\011\\011IF (counter > 0) THEN\\012\\011\\011\\011\\011RAISE EXCEPTION 'Insert/Update of Sample (Code: %) failed because group sample with the same code and being the part of the same parent already exists.', NEW.code;\\012\\011\\011\\011END IF;\\012\\011\\011END IF;\\012        END IF;   \\012   RETURN NEW;\\012END;\\012$$ LANGUAGE 'plpgsql';\\012\\012CREATE TRIGGER SAMPLE_CODE_UNIQUENESS_CHECK BEFORE INSERT OR UPDATE ON SAMPLES\\012    FOR EACH ROW EXECUTE PROCEDURE SAMPLE_CODE_UNIQUENESS_CHECK();\\012	\N
+./sourceTest/sql/postgresql/037/015=database_version_logs.tsv:028	source/sql/postgresql/migration/migration-027-028.sql	SUCCESS	2008-11-18 13:24:17.508	-- Create EXPERIMENT_ATTACHMENT_CONTENTS.\\012CREATE TABLE EXPERIMENT_ATTACHMENT_CONTENTS (ID TECH_ID NOT NULL,VALUE FILE NOT NULL);\\012CREATE SEQUENCE EXPERIMENT_ATTACHMENT_CONTENT_ID_SEQ;\\012ALTER TABLE EXPERIMENT_ATTACHMENT_CONTENTS ADD CONSTRAINT EXAC_PK PRIMARY KEY(ID);\\012\\012-- Alter EXPERIMENT_ATTACHMENTS by adding the new column which has a NULL constraint.\\012-- The NOT NULL constraint is added later on.\\012ALTER TABLE EXPERIMENT_ATTACHMENTS ADD COLUMN EXAC_ID TECH_ID;\\012\\012-- Does the VALUE migration between EXPERIMENT_ATTACHMENTS to EXPERIMENT_ATTACHMENT_CONTENTS.\\012CREATE OR REPLACE FUNCTION move_exp_att_content() RETURNS integer AS $$\\012DECLARE\\012    rec RECORD;\\012    seq BIGINT;\\012BEGIN\\012  FOR rec IN SELECT id, value FROM EXPERIMENT_ATTACHMENTS LOOP\\012  \\011seq := nextval('EXPERIMENT_ATTACHMENT_CONTENT_ID_SEQ');\\012    INSERT INTO EXPERIMENT_ATTACHMENT_CONTENTS (id, value) VALUES (seq, rec.value);\\012    UPDATE EXPERIMENT_ATTACHMENTS SET exac_id = seq WHERE id = rec.id;\\012  END LOOP;\\012  RETURN 1;\\012END;\\012$$ LANGUAGE 'plpgsql';\\012\\012-- Call the function.\\012SELECT move_exp_att_content();\\012DROP FUNCTION move_exp_att_content();\\012\\012\\012-- Finish EXPERIMENT_ATTACHMENTS changes.\\012ALTER TABLE EXPERIMENT_ATTACHMENTS ADD CONSTRAINT EXAT_CONT_FK FOREIGN KEY (EXAC_ID) REFERENCES EXPERIMENT_ATTACHMENT_CONTENTS(ID);\\012ALTER TABLE EXPERIMENT_ATTACHMENTS DROP COLUMN VALUE;\\012ALTER TABLE EXPERIMENT_ATTACHMENTS ALTER COLUMN EXAC_ID SET NOT NULL;\\012	\N
+./sourceTest/sql/postgresql/037/015=database_version_logs.tsv:029	source/sql/postgresql/migration/migration-028-029.sql	SUCCESS	2009-03-18 10:50:20.105	-- -------\\012-- add modification_timestamp field to allow edition with Hibernate\\012-- -------\\012\\012ALTER TABLE samples\\012\\011ADD COLUMN modification_timestamp TIME_STAMP DEFAULT CURRENT_TIMESTAMP;\\012\\012ALTER TABLE experiments\\012\\011ADD COLUMN modification_timestamp TIME_STAMP DEFAULT CURRENT_TIMESTAMP;\\012\\012ALTER TABLE materials\\012\\011ADD COLUMN modification_timestamp TIME_STAMP DEFAULT CURRENT_TIMESTAMP;\\012\\012ALTER TABLE experiment_properties\\012\\011ADD COLUMN modification_timestamp TIME_STAMP DEFAULT CURRENT_TIMESTAMP;\\012\\012ALTER TABLE material_properties\\012\\011ADD COLUMN modification_timestamp TIME_STAMP DEFAULT CURRENT_TIMESTAMP;\\012\\012ALTER TABLE sample_properties\\012\\011ADD COLUMN modification_timestamp TIME_STAMP DEFAULT CURRENT_TIMESTAMP;\\012\\012-- -------\\012-- add property data type which references materials\\012-- -------\\012\\012ALTER TABLE property_types\\012\\011ADD COLUMN maty_prop_id tech_id;\\012\\012ALTER TABLE property_types\\012\\011ADD CONSTRAINT prty_maty_fk FOREIGN KEY (maty_prop_id) REFERENCES material_types(id);\\012\\012ALTER TABLE experiment_properties\\012\\011ADD COLUMN mate_prop_id tech_id;\\012\\012ALTER TABLE material_properties\\012\\011ADD COLUMN mate_prop_id tech_id;\\012\\012ALTER TABLE sample_properties\\012\\011ADD COLUMN mate_prop_id tech_id;\\012\\012ALTER TABLE experiment_properties\\012\\011ADD CONSTRAINT expr_mapr_fk FOREIGN KEY (mate_prop_id) REFERENCES materials(id);\\012\\012ALTER TABLE material_properties\\012\\011ADD CONSTRAINT mapr_mapr_fk FOREIGN KEY (mate_prop_id) REFERENCES materials(id);\\012\\012ALTER TABLE sample_properties\\012\\011ADD CONSTRAINT sapr_mapr_fk FOREIGN KEY (mate_prop_id) REFERENCES materials(id);\\012\\012insert into data_types\\012(id\\012 ,code\\012 ,description)\\012 values \\012 (nextval('DATA_TYPE_ID_SEQ')\\012 ,'MATERIAL'\\012 ,'Reference to a material'\\012);\\012\\012ALTER TABLE MATERIAL_PROPERTIES DROP CONSTRAINT MAPR_CK;\\012ALTER TABLE MATERIAL_PROPERTIES ADD CONSTRAINT MAPR_CK CHECK \\012\\011((VALUE IS NOT NULL AND CVTE_ID IS NULL AND MATE_PROP_ID IS NULL) OR \\012\\011 (VALUE IS NULL AND CVTE_ID IS NOT NULL AND MATE_PROP_ID IS NULL) OR\\012\\011 (VALUE IS NULL AND CVTE_ID IS NULL AND MATE_PROP_ID IS NOT NULL)\\012\\011);\\012\\012ALTER TABLE EXPERIMENT_PROPERTIES DROP CONSTRAINT EXPR_CK;\\012ALTER TABLE EXPERIMENT_PROPERTIES ADD CONSTRAINT EXPR_CK CHECK \\012\\011((VALUE IS NOT NULL AND CVTE_ID IS NULL AND MATE_PROP_ID IS NULL) OR \\012\\011 (VALUE IS NULL AND CVTE_ID IS NOT NULL AND MATE_PROP_ID IS NULL) OR\\012\\011 (VALUE IS NULL AND CVTE_ID IS NULL AND MATE_PROP_ID IS NOT NULL)\\012\\011);\\012\\012ALTER TABLE SAMPLE_PROPERTIES DROP CONSTRAINT SAPR_CK;\\012ALTER TABLE SAMPLE_PROPERTIES ADD CONSTRAINT SAPR_CK CHECK \\012\\011((VALUE IS NOT NULL AND CVTE_ID IS NULL AND MATE_PROP_ID IS NULL) OR \\012\\011 (VALUE IS NULL AND CVTE_ID IS NOT NULL AND MATE_PROP_ID IS NULL) OR\\012\\011 (VALUE IS NULL AND CVTE_ID IS NULL AND MATE_PROP_ID IS NOT NULL)\\012\\011);\\012\\012------------------------------------------------------------------------------------\\012--  Purpose:  Create trigger MATERIAL/SAMPLE/EXPERIMENT _PROPERTY_WITH_MATERIAL_DATA_TYPE_CHECK\\012--            It checks that if material property value is assigned to the entity,\\012--\\011\\011\\011\\011\\011\\011then the material type is equal to the one described by property type.\\012------------------------------------------------------------------------------------\\012\\012CREATE OR REPLACE FUNCTION MATERIAL_PROPERTY_WITH_MATERIAL_DATA_TYPE_CHECK() RETURNS trigger AS $$\\012DECLARE\\012   v_type_id  CODE;\\012   v_type_id_prop  CODE;\\012BEGIN\\012   if NEW.mate_prop_id IS NOT NULL then\\012\\011\\011\\011-- find material type id of the property type \\012\\011\\011\\011select pt.maty_prop_id into v_type_id_prop \\012\\011\\011\\011  from material_type_property_types etpt, property_types pt \\012\\011\\011\\011 where NEW.mtpt_id = etpt.id AND etpt.prty_id = pt.id;\\012\\011\\011\\012\\011\\011\\011if v_type_id_prop IS NOT NULL then\\012\\011\\011\\011\\011-- find material type id of the material which consists the entity's property value\\012\\011\\011\\011\\011select entity.maty_id into v_type_id \\012\\011\\011\\011\\011  from materials entity\\012\\011\\011\\011\\011 where NEW.mate_prop_id = entity.id;\\012\\011\\011\\011\\011if v_type_id != v_type_id_prop then\\012\\011\\011\\011\\011\\011RAISE EXCEPTION 'Insert/Update of property value referencing material (id: %) failed, as referenced material type is different than expected (id %, expected id: %).', \\012\\011\\011\\011\\011\\011\\011\\011 NEW.mate_prop_id, v_type_id, v_type_id_prop;\\012\\011\\011\\011\\011end if;\\012\\011\\011\\011end if;\\012   end if;\\012   RETURN NEW;\\012END;\\012$$ LANGUAGE 'plpgsql';\\012\\012CREATE TRIGGER MATERIAL_PROPERTY_WITH_MATERIAL_DATA_TYPE_CHECK BEFORE INSERT OR UPDATE ON material_properties\\012    FOR EACH ROW EXECUTE PROCEDURE MATERIAL_PROPERTY_WITH_MATERIAL_DATA_TYPE_CHECK();\\012    \\012CREATE OR REPLACE FUNCTION SAMPLE_PROPERTY_WITH_MATERIAL_DATA_TYPE_CHECK() RETURNS trigger AS $$\\012DECLARE\\012   v_type_id  CODE;\\012   v_type_id_prop  CODE;\\012BEGIN\\012   if NEW.mate_prop_id IS NOT NULL then\\012\\011\\011\\011-- find material type id of the property type \\012\\011\\011\\011select pt.maty_prop_id into v_type_id_prop \\012\\011\\011\\011  from sample_type_property_types etpt, property_types pt \\012\\011\\011\\011 where NEW.stpt_id = etpt.id AND etpt.prty_id = pt.id;\\012\\011\\011\\012\\011\\011\\011if v_type_id_prop IS NOT NULL then\\012\\011\\011\\011\\011-- find material type id of the material which consists the entity's property value\\012\\011\\011\\011\\011select entity.maty_id into v_type_id \\012\\011\\011\\011\\011  from materials entity\\012\\011\\011\\011\\011 where NEW.mate_prop_id = entity.id;\\012\\011\\011\\011\\011if v_type_id != v_type_id_prop then\\012\\011\\011\\011\\011\\011RAISE EXCEPTION 'Insert/Update of property value referencing material (id: %) failed, as referenced material type is different than expected (id %, expected id: %).', \\012\\011\\011\\011\\011\\011\\011\\011\\011\\011\\011\\011\\011 NEW.mate_prop_id, v_type_id, v_type_id_prop;\\012\\011\\011\\011\\011end if;\\012\\011\\011\\011end if;\\012   end if;\\012   RETURN NEW;\\012END;\\012$$ LANGUAGE 'plpgsql';\\012\\012CREATE TRIGGER SAMPLE_PROPERTY_WITH_MATERIAL_DATA_TYPE_CHECK BEFORE INSERT OR UPDATE ON sample_properties\\012    FOR EACH ROW EXECUTE PROCEDURE SAMPLE_PROPERTY_WITH_MATERIAL_DATA_TYPE_CHECK();\\012    \\012CREATE OR REPLACE FUNCTION EXPERIMENT_PROPERTY_WITH_MATERIAL_DATA_TYPE_CHECK() RETURNS trigger AS $$\\012DECLARE\\012   v_type_id  CODE;\\012   v_type_id_prop  CODE;\\012BEGIN\\012   if NEW.mate_prop_id IS NOT NULL then\\012\\011\\011\\011-- find material type id of the property type \\012\\011\\011\\011select pt.maty_prop_id into v_type_id_prop \\012\\011\\011\\011  from experiment_type_property_types etpt, property_types pt \\012\\011\\011\\011 where NEW.etpt_id = etpt.id AND etpt.prty_id = pt.id;\\012\\011\\011\\012\\011\\011\\011if v_type_id_prop IS NOT NULL then\\012\\011\\011\\011\\011-- find material type id of the material which consists the entity's property value\\012\\011\\011\\011\\011select entity.maty_id into v_type_id \\012\\011\\011\\011\\011  from materials entity\\012\\011\\011\\011\\011 where NEW.mate_prop_id = entity.id;\\012\\011\\011\\011\\011if v_type_id != v_type_id_prop then\\012\\011\\011\\011\\011\\011RAISE EXCEPTION 'Insert/Update of property value referencing material (id: %) failed, as referenced material type is different than expected (id %, expected id: %).', \\012\\011\\011\\011\\011\\011\\011\\011\\011\\011\\011\\011\\011 NEW.mate_prop_id, v_type_id, v_type_id_prop;\\012\\011\\011\\011\\011end if;\\012\\011\\011\\011end if;\\012   end if;\\012   RETURN NEW;\\012END;\\012$$ LANGUAGE 'plpgsql';\\012\\012CREATE TRIGGER EXPERIMENT_PROPERTY_WITH_MATERIAL_DATA_TYPE_CHECK BEFORE INSERT OR UPDATE ON experiment_properties\\012    FOR EACH ROW EXECUTE PROCEDURE EXPERIMENT_PROPERTY_WITH_MATERIAL_DATA_TYPE_CHECK();\\012       \\012-- -------\\012-- remove the reminescents of the OBSERVABLE_TYPE\\012-- -------\\012\\012ALTER TABLE data\\012\\011DROP CONSTRAINT data_obty_fk;\\012\\012ALTER TABLE data_set_types\\012\\011DROP CONSTRAINT obty_pk;\\012\\012ALTER TABLE data_set_types\\012\\011ADD CONSTRAINT dsty_pk PRIMARY KEY (id);\\012\\012ALTER TABLE data\\012\\011ADD CONSTRAINT data_dsty_fk FOREIGN KEY (dsty_id) REFERENCES data_set_types(id);\\012\\012ALTER TABLE data_set_types\\012\\011DROP CONSTRAINT obty_bk_uk;\\012\\012ALTER TABLE data_set_types\\012\\011DROP CONSTRAINT obty_dbin_fk;\\012\\012ALTER TABLE data_set_types\\012\\011ADD CONSTRAINT dsty_bk_uk UNIQUE (code, dbin_id);\\012\\012ALTER TABLE data_set_types\\012\\011ADD CONSTRAINT dsty_dbin_fk FOREIGN KEY (dbin_id) REFERENCES database_instances(id);\\012\\012DROP INDEX data_obty_fk_i;\\012\\012CREATE INDEX data_dsty_fk_i ON data(dsty_id);\\012	\N
+./sourceTest/sql/postgresql/037/015=database_version_logs.tsv:030	source/sql/postgresql/migration/migration-029-030.sql	SUCCESS	2009-03-23 15:34:44.72	-- -------\\012-- add modification_timestamp field to allow edition with Hibernate\\012-- -------\\012ALTER TABLE data\\012\\011ADD COLUMN modification_timestamp TIME_STAMP DEFAULT CURRENT_TIMESTAMP;\\012ALTER TABLE experiment_types\\012\\011ADD COLUMN modification_timestamp TIME_STAMP DEFAULT CURRENT_TIMESTAMP;\\012ALTER TABLE sample_types\\012\\011ADD COLUMN modification_timestamp TIME_STAMP DEFAULT CURRENT_TIMESTAMP;\\012ALTER TABLE material_types\\012\\011ADD COLUMN modification_timestamp TIME_STAMP DEFAULT CURRENT_TIMESTAMP;\\012ALTER TABLE data_set_types\\012\\011ADD COLUMN modification_timestamp TIME_STAMP DEFAULT CURRENT_TIMESTAMP;\\012ALTER TABLE controlled_vocabularies\\012\\011ADD COLUMN modification_timestamp TIME_STAMP DEFAULT CURRENT_TIMESTAMP;\\012-- -------\\012-- add properties to data sets\\012-- -------\\012CREATE TABLE DATA_SET_PROPERTIES (ID TECH_ID NOT NULL,DS_ID TECH_ID NOT NULL,DSTPT_ID TECH_ID NOT NULL,VALUE GENERIC_VALUE,CVTE_ID TECH_ID, MATE_PROP_ID TECH_ID, PERS_ID_REGISTERER TECH_ID NOT NULL,REGISTRATION_TIMESTAMP TIME_STAMP_DFL NOT NULL DEFAULT CURRENT_TIMESTAMP, MODIFICATION_TIMESTAMP TIME_STAMP DEFAULT CURRENT_TIMESTAMP);\\012CREATE TABLE DATA_SET_TYPE_PROPERTY_TYPES (ID TECH_ID NOT NULL,DSTY_ID TECH_ID NOT NULL,PRTY_ID TECH_ID NOT NULL,IS_MANDATORY BOOLEAN_CHAR NOT NULL DEFAULT 'F',IS_MANAGED_INTERNALLY BOOLEAN_CHAR NOT NULL DEFAULT 'F',PERS_ID_REGISTERER TECH_ID NOT NULL,REGISTRATION_TIMESTAMP TIME_STAMP_DFL NOT NULL DEFAULT CURRENT_TIMESTAMP);\\012\\012CREATE SEQUENCE DATA_SET_PROPERTY_ID_SEQ;\\012CREATE SEQUENCE DSTPT_ID_SEQ;\\012\\012ALTER TABLE DATA_SET_TYPE_PROPERTY_TYPES ADD CONSTRAINT DSTPT_PK PRIMARY KEY(ID);\\012ALTER TABLE DATA_SET_PROPERTIES ADD CONSTRAINT DSPR_PK PRIMARY KEY(ID);\\012\\012ALTER TABLE DATA_SET_TYPE_PROPERTY_TYPES ADD CONSTRAINT DSTPT_BK_UK UNIQUE(DSTY_ID,PRTY_ID);\\012ALTER TABLE DATA_SET_PROPERTIES ADD CONSTRAINT DSPR_BK_UK UNIQUE(DS_ID,DSTPT_ID);\\012\\012\\012ALTER TABLE DATA_SET_TYPE_PROPERTY_TYPES ADD CONSTRAINT DSTPT_DSTY_FK FOREIGN KEY (DSTY_ID) REFERENCES DATA_SET_TYPES(ID);\\012ALTER TABLE DATA_SET_TYPE_PROPERTY_TYPES ADD CONSTRAINT DSTPT_PERS_FK FOREIGN KEY (PERS_ID_REGISTERER) REFERENCES PERSONS(ID);\\012ALTER TABLE DATA_SET_TYPE_PROPERTY_TYPES ADD CONSTRAINT DSTPT_PRTY_FK FOREIGN KEY (PRTY_ID) REFERENCES PROPERTY_TYPES(ID);\\012ALTER TABLE DATA_SET_PROPERTIES ADD CONSTRAINT DSPR_CVTE_FK FOREIGN KEY (CVTE_ID) REFERENCES CONTROLLED_VOCABULARY_TERMS(ID);\\012ALTER TABLE DATA_SET_PROPERTIES ADD CONSTRAINT DSPR_DSTPT_FK FOREIGN KEY (DSTPT_ID) REFERENCES DATA_SET_TYPE_PROPERTY_TYPES(ID) ON DELETE CASCADE;\\012ALTER TABLE DATA_SET_PROPERTIES ADD CONSTRAINT DSPR_DS_FK FOREIGN KEY (DS_ID) REFERENCES DATA(ID);\\012ALTER TABLE DATA_SET_PROPERTIES ADD CONSTRAINT DSPR_PERS_FK FOREIGN KEY (PERS_ID_REGISTERER) REFERENCES PERSONS(ID);\\012ALTER TABLE DATA_SET_PROPERTIES ADD CONSTRAINT DSPR_MAPR_FK FOREIGN KEY (MATE_PROP_ID) REFERENCES MATERIALS(ID);\\012\\012ALTER TABLE DATA_SET_PROPERTIES ADD CONSTRAINT DSPR_CK CHECK \\012\\011((VALUE IS NOT NULL AND CVTE_ID IS NULL AND MATE_PROP_ID IS NULL) OR \\012\\011 (VALUE IS NULL AND CVTE_ID IS NOT NULL AND MATE_PROP_ID IS NULL) OR\\012\\011 (VALUE IS NULL AND CVTE_ID IS NULL AND MATE_PROP_ID IS NOT NULL)\\012\\011);\\012\\012CREATE INDEX DSPR_CVTE_FK_I ON DATA_SET_PROPERTIES (CVTE_ID);\\012CREATE INDEX DSPR_DSTPT_FK_I ON DATA_SET_PROPERTIES (DSTPT_ID);\\012CREATE INDEX DSPR_DS_FK_I ON DATA_SET_PROPERTIES (DS_ID);\\012CREATE INDEX DSPR_PERS_FK_I ON DATA_SET_PROPERTIES (PERS_ID_REGISTERER);\\012CREATE INDEX DSTPT_DSTY_FK_I ON DATA_SET_TYPE_PROPERTY_TYPES (DSTY_ID);\\012CREATE INDEX DSTPT_PERS_FK_I ON DATA_SET_TYPE_PROPERTY_TYPES (PERS_ID_REGISTERER);\\012CREATE INDEX DSTPT_PRTY_FK_I ON DATA_SET_TYPE_PROPERTY_TYPES (PRTY_ID);\\012\\012CREATE OR REPLACE FUNCTION DATA_SET_PROPERTY_WITH_MATERIAL_DATA_TYPE_CHECK() RETURNS trigger AS $$\\012DECLARE\\012   v_type_id  CODE;\\012   v_type_id_prop  CODE;\\012BEGIN\\012   if NEW.mate_prop_id IS NOT NULL then\\012\\011\\011\\011-- find material type id of the property type \\012\\011\\011\\011select pt.maty_prop_id into v_type_id_prop \\012\\011\\011\\011  from data_set_type_property_types dstpt, property_types pt \\012\\011\\011\\011 where NEW.dstpt_id = dstpt.id AND dstpt.prty_id = pt.id;\\012\\011\\011\\012\\011\\011\\011if v_type_id_prop IS NOT NULL then\\012\\011\\011\\011\\011-- find material type id of the material which consists the entity's property value\\012\\011\\011\\011\\011select entity.maty_id into v_type_id \\012\\011\\011\\011\\011  from materials entity\\012\\011\\011\\011\\011 where NEW.mate_prop_id = entity.id;\\012\\011\\011\\011\\011if v_type_id != v_type_id_prop then\\012\\011\\011\\011\\011\\011RAISE EXCEPTION 'Insert/Update of property value referencing material (id: %) failed, as referenced material type is different than expected (id %, expected id: %).', \\012\\011\\011\\011\\011\\011\\011\\011\\011\\011\\011\\011\\011 NEW.mate_prop_id, v_type_id, v_type_id_prop;\\012\\011\\011\\011\\011end if;\\012\\011\\011\\011end if;\\012   end if;\\012   RETURN NEW;\\012END;\\012$$ LANGUAGE 'plpgsql';\\012\\012CREATE TRIGGER DATA_SET_PROPERTY_WITH_MATERIAL_DATA_TYPE_CHECK BEFORE INSERT OR UPDATE ON data_set_properties\\012    FOR EACH ROW EXECUTE PROCEDURE DATA_SET_PROPERTY_WITH_MATERIAL_DATA_TYPE_CHECK();   \\012	\N
+./sourceTest/sql/postgresql/037/015=database_version_logs.tsv:032	source/sql/postgresql/migration/migration-031-032.sql	SUCCESS	2009-04-09 09:36:36.20	-- -------\\012-- Modify MATERIAL_BATCHES\\012-- -------\\012\\012ALTER TABLE material_batches\\012    DROP COLUMN proc_id;\\012\\012-- -------\\012-- Modify SAMPLES\\012-- -------\\012\\012ALTER TABLE samples\\012    ADD COLUMN expe_id tech_id;\\012\\012ALTER TABLE samples\\012    ADD CONSTRAINT samp_expe_fk FOREIGN KEY (expe_id) REFERENCES experiments(id);\\012\\012CREATE INDEX samp_expe_fk_i ON samples USING btree (expe_id);\\012\\012-- relink samples directly to experiments\\012\\012UPDATE samples\\012SET expe_id = (SELECT e.id FROM experiments e, procedures p, sample_inputs si \\012               WHERE si.samp_id = samples.id AND si.proc_id = p.id AND p.expe_id = e.id AND e.inva_id IS NULL);\\012\\012\\012-- -------\\012-- Modify DATA\\012-- -------\\012\\012ALTER TABLE data\\012    ADD COLUMN expe_id tech_id;\\012\\012ALTER TABLE data\\012    ADD CONSTRAINT data_expe_fk FOREIGN KEY (expe_id) REFERENCES experiments(id);\\012\\012CREATE INDEX data_expe_fk_i ON data USING btree (expe_id);\\012\\012UPDATE data\\012SET expe_id = (SELECT e.id FROM experiments e, procedures p \\012               WHERE data.proc_id_produced_by = p.id AND p.expe_id = e.id);\\012\\012ALTER TABLE data\\012    ALTER COLUMN expe_id SET NOT NULL;\\012\\012ALTER TABLE data\\012    DROP COLUMN proc_id_produced_by;\\012\\012-- -------\\012-- Drop PROCEDURES, PROCEDURE_TYPES, and SAMPLE_INPUTS\\012-- -------\\012\\012DROP TABLE sample_inputs;\\012DROP TABLE procedures;\\012DROP TABLE procedure_types;\\012\\012DROP SEQUENCE procedure_id_seq;\\012DROP SEQUENCE procedure_type_id_seq;\\012\\012-- -------\\012-- Add CODE_SEQ\\012-- -------\\012\\012CREATE SEQUENCE CODE_SEQ;\\012\\012-- -------\\012-- Add new columns to DATA_STORES\\012-- -------\\012\\012ALTER TABLE data_stores\\012    ADD COLUMN remote_url character varying(250),\\012    ADD COLUMN session_token character varying(50),\\012    ADD COLUMN modification_timestamp time_stamp DEFAULT now();\\012\\012UPDATE data_stores\\012SET remote_url = '', session_token='';\\012\\012ALTER TABLE data_stores\\012    ALTER COLUMN remote_url SET NOT NULL,\\012    ALTER COLUMN session_token SET NOT NULL;\\012\\012-- -------\\012-- Drop foreign keys onto DATA_STORES\\012-- -------\\012\\012ALTER TABLE database_instances\\012    DROP COLUMN dast_id;\\012\\012ALTER TABLE groups\\012    DROP COLUMN dast_id;\\012\\012ALTER TABLE projects\\012    DROP COLUMN dast_id;\\012\\012ALTER TABLE experiments\\012    DROP COLUMN dast_id;\\012\\012-- -------\\012-- Add foreign key from DATA onto DATA_STORES\\012-- -------\\012\\012ALTER TABLE data\\012    ADD COLUMN dast_id tech_id;\\012\\012ALTER TABLE data\\012    ADD CONSTRAINT data_dast_fk FOREIGN KEY (dast_id) REFERENCES data_stores(id);\\012\\012UPDATE data\\012SET dast_id = (select id from data_stores where code = 'STANDARD');\\012\\012ALTER TABLE data\\012    ALTER COLUMN dast_id SET NOT NULL;\\012\\012\\012------------------------------------------------------------------------------------\\012--  Purpose:  Replace trigger SAMPLE_CODE_UNIQUENESS_CHECK \\012------------------------------------------------------------------------------------\\012\\012CREATE OR REPLACE FUNCTION SAMPLE_CODE_UNIQUENESS_CHECK() RETURNS trigger AS $$\\012DECLARE\\012   counter  INTEGER;\\012BEGIN\\012    LOCK TABLE samples IN EXCLUSIVE MODE;\\012    IF (NEW.samp_id_part_of is NULL) THEN\\012        IF (NEW.dbin_id is not NULL) THEN\\012            SELECT count(*) into counter FROM samples \\012                where id != NEW.id and code = NEW.code and samp_id_part_of is NULL and dbin_id = NEW.dbin_id;\\012            IF (counter > 0) THEN\\012                RAISE EXCEPTION 'Insert/Update of Sample (Code: %) failed because database instance sample with the same code already exists.', NEW.code;\\012            END IF;\\012        ELSIF (NEW.grou_id is not NULL) THEN\\012            SELECT count(*) into counter FROM samples \\012                where id != NEW.id and code = NEW.code and samp_id_part_of is NULL and grou_id = NEW.grou_id;\\012            IF (counter > 0) THEN\\012                RAISE EXCEPTION 'Insert/Update of Sample (Code: %) failed because group sample with the same code already exists.', NEW.code;\\012            END IF;\\012        END IF;\\012        ELSE\\012        IF (NEW.dbin_id is not NULL) THEN\\012            SELECT count(*) into counter FROM samples \\012                where id != NEW.id and code = NEW.code and samp_id_part_of = NEW.samp_id_part_of and dbin_id = NEW.dbin_id;\\012            IF (counter > 0) THEN\\012                RAISE EXCEPTION 'Insert/Update of Sample (Code: %) failed because database instance sample with the same code and being the part of the same parent already exists.', NEW.code;\\012            END IF;\\012        ELSIF (NEW.grou_id is not NULL) THEN\\012            SELECT count(*) into counter FROM samples \\012                where id != NEW.id and code = NEW.code and samp_id_part_of = NEW.samp_id_part_of and grou_id = NEW.grou_id;\\012            IF (counter > 0) THEN\\012                RAISE EXCEPTION 'Insert/Update of Sample (Code: %) failed because group sample with the same code and being the part of the same parent already exists.', NEW.code;\\012            END IF;\\012        END IF;\\012        END IF;   \\012   RETURN NEW;\\012END;\\012$$ LANGUAGE 'plpgsql';\\012\\012\\012\\012	\N
+./sourceTest/sql/postgresql/037/015=database_version_logs.tsv:034	source/sql/postgresql/migration/migration-033-034.sql	SUCCESS	2009-05-26 08:32:49.935	------------------------------------------------------------------------------------\\012-- Create sequence for generating permanent identifiers starting with nextval of existing dataset sequence.\\012------------------------------------------------------------------------------------\\012CREATE FUNCTION CREATE_SEQUENCE(EXISTING_SEQUENCE VARCHAR, NEW_SEQUENCE VARCHAR) RETURNS VOID AS $$\\012DECLARE\\012  CURR_SEQ_VAL   INTEGER;\\012BEGIN\\012  SELECT INTO CURR_SEQ_VAL NEXTVAL(EXISTING_SEQUENCE);\\012  EXECUTE 'CREATE SEQUENCE ' || NEW_SEQUENCE || ' START WITH ' || CURR_SEQ_VAL;\\012  RETURN;\\012END;\\012$$ LANGUAGE 'plpgsql';\\012\\012SELECT CREATE_SEQUENCE('DATA_ID_SEQ', 'PERM_ID_SEQ');\\012DROP FUNCTION CREATE_SEQUENCE(VARCHAR, VARCHAR);\\012\\012------------------------------------------------------------------------------------\\012-- Add perm_id columns to samples and experiments.\\012------------------------------------------------------------------------------------\\012ALTER TABLE SAMPLES ADD COLUMN PERM_ID CODE;\\012ALTER TABLE EXPERIMENTS ADD COLUMN PERM_ID CODE;\\012\\012UPDATE SAMPLES SET PERM_ID = to_char(registration_timestamp,'YYYYMMDDHHSSMS') || '-' || NEXTVAL('PERM_ID_SEQ');\\012UPDATE EXPERIMENTS SET PERM_ID = to_char(registration_timestamp,'YYYYMMDDHHSSMS') || '-' || NEXTVAL('PERM_ID_SEQ');\\012ALTER TABLE SAMPLES ALTER COLUMN PERM_ID SET NOT NULL;\\012ALTER TABLE EXPERIMENTS ALTER COLUMN PERM_ID SET NOT NULL;\\012ALTER TABLE SAMPLES ADD CONSTRAINT SAMP_PI_UK UNIQUE(PERM_ID);\\012ALTER TABLE EXPERIMENTS ADD CONSTRAINT EXPE_PI_UK UNIQUE(PERM_ID);\\012\\012\\012------------------------------------------------------------------------------------\\012-- Add column is_chosen_from_list to controlled_vocabularies.\\012------------------------------------------------------------------------------------\\012ALTER TABLE controlled_vocabularies ADD COLUMN is_chosen_from_list BOOLEAN_CHAR NOT NULL DEFAULT TRUE;\\012ALTER TABLE controlled_vocabularies ADD COLUMN source_uri CHARACTER VARYING(250);\\012------------------------------------------------------------------------------------\\012-- Modify Data table - remove arc connection between Sample and Data table, use a flag instead\\012------------------------------------------------------------------------------------\\012\\012-- add new columns\\012\\012ALTER TABLE data\\012    ADD COLUMN is_derived boolean_char;\\012ALTER TABLE data\\012    ADD COLUMN samp_id tech_id;\\012\\012-- update values in new columns\\012\\012UPDATE data\\012    SET is_derived = (samp_id_derived_from IS NOT NULL); \\012UPDATE data\\012    SET samp_id = samp_id_derived_from \\012    WHERE is_derived = 'TRUE';\\012UPDATE data\\012    SET samp_id = samp_id_acquired_from \\012    WHERE is_derived = 'FALSE';\\012\\012-- add constraints and indexes to new columns\\012\\012ALTER TABLE data\\012    ALTER COLUMN is_derived SET NOT NULL;\\012ALTER TABLE data\\012    ALTER COLUMN samp_id SET NOT NULL;   \\012ALTER TABLE data\\012    ADD CONSTRAINT data_samp_fk FOREIGN KEY (samp_id) REFERENCES samples (id);\\012CREATE INDEX data_samp_fk_i ON data USING btree (samp_id);\\012\\012-- remove old columns\\012\\012ALTER TABLE data\\012    DROP COLUMN samp_id_acquired_from;\\012ALTER TABLE data\\012    DROP COLUMN samp_id_derived_from;\\012    \\012------------------------------------------------------------------------------------\\012-- Granting SELECT privilege to group openbis_readonly\\012------------------------------------------------------------------------------------\\012\\012GRANT SELECT ON SEQUENCE attachment_content_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE attachment_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE code_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE controlled_vocabulary_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE cvte_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE data_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE data_set_property_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE data_set_relationship_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE data_set_type_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE data_store_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE data_type_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE database_instance_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE dstpt_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE etpt_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE event_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE experiment_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE experiment_property_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE experiment_type_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE file_format_type_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE group_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE invalidation_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE locator_type_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE material_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE material_property_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE material_type_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE mtpt_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE perm_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE person_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE project_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE property_type_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE role_assignment_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE sample_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE sample_property_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE sample_type_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE stpt_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE attachment_contents TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE attachments TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE controlled_vocabularies TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE controlled_vocabulary_terms TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE data TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE data_set_properties TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE data_set_relationships TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE data_set_type_property_types TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE data_set_types TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE data_stores TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE data_types TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE database_instances TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE database_version_logs TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE events TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE experiment_properties TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE experiment_type_property_types TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE experiment_types TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE experiments TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE external_data TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE file_format_types TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE groups TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE invalidations TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE locator_types TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE material_properties TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE material_type_property_types TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE material_types TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE materials TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE persons TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE projects TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE property_types TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE role_assignments TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE sample_properties TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE sample_type_property_types TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE sample_types TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE samples TO GROUP OPENBIS_READONLY;\\012\\012------------------------------------------------------------------------------------\\012-- Delete MATERIAL_BATCHES table\\012------------------------------------------------------------------------------------\\012\\012-- WARNING: Potential data lost!!!\\012-- WARNING: Potential data lost!!!\\012-- WARNING: Potential data lost!!!\\012\\012DROP TABLE SAMPLE_MATERIAL_BATCHES;\\012DROP TABLE MATERIAL_BATCHES;\\012DROP SEQUENCE MATERIAL_BATCH_ID_SEQ;\\012\\012------------------------------------------------------------------------------------\\012-- Delete MATE_ID_INHIBITOR_OF from table MATERIALS\\012------------------------------------------------------------------------------------\\012\\012-- WARNING: Potential data lost!!!\\012-- WARNING: Potential data lost!!!\\012-- WARNING: Potential data lost!!!\\012\\012ALTER TABLE MATERIALS DROP COLUMN MATE_ID_INHIBITOR_OF;\\012	\N
+./sourceTest/sql/postgresql/037/schema-037.sql:    LANGUAGE plpgsql;
+./sourceTest/sql/postgresql/037/schema-037.sql:    LANGUAGE plpgsql;
+./sourceTest/sql/postgresql/037/schema-037.sql:    LANGUAGE plpgsql;
+./sourceTest/sql/postgresql/037/schema-037.sql:    LANGUAGE plpgsql;
+./sourceTest/sql/postgresql/037/schema-037.sql:    LANGUAGE plpgsql;
+./sourceTest/sql/postgresql/037/schema-037.sql:    LANGUAGE plpgsql;
+./sourceTest/sql/postgresql/037/schema-037.sql:    LANGUAGE plpgsql;
+./sourceTest/sql/postgresql/037/schema-037.sql:    LANGUAGE plpgsql;
+./sourceTest/sql/postgresql/038/.svn/text-base/015=database_version_logs.tsv.svn-base:027	D:\\User\\felmer\\dev-workspace\\openbis/source/sql/postgresql/027/function-027.sql	SUCCESS	2008-11-05 09:18:00.403	-- Creating Functions\\012\\012------------------------------------------------------------------------------------\\012--  Purpose:  Create function RENAME_SEQUENCE() that is required for renaming the sequences belonging to tables\\012------------------------------------------------------------------------------------\\012CREATE FUNCTION RENAME_SEQUENCE(OLD_NAME VARCHAR, NEW_NAME VARCHAR) RETURNS INTEGER AS $$\\012DECLARE\\012  CURR_SEQ_VAL   INTEGER;\\012BEGIN\\012  SELECT INTO CURR_SEQ_VAL NEXTVAL(OLD_NAME);\\012  EXECUTE 'CREATE SEQUENCE ' || NEW_NAME || ' START WITH ' || CURR_SEQ_VAL;\\012  EXECUTE 'DROP SEQUENCE ' || OLD_NAME;\\012  RETURN CURR_SEQ_VAL;\\012END;\\012$$ LANGUAGE 'plpgsql';\\012\\012\\012------------------------------------------------------------------------------------\\012--  Purpose:  Create trigger CONTROLLED_VOCABULARY_CHECK \\012------------------------------------------------------------------------------------\\012\\012CREATE OR REPLACE FUNCTION CONTROLLED_VOCABULARY_CHECK() RETURNS trigger AS $$\\012DECLARE\\012   v_code  CODE;\\012BEGIN\\012\\012   select code into v_code from data_types where id = NEW.daty_id;\\012\\012   -- Check if the data is of type "CONTROLLEDVOCABULARY"\\012   if v_code = 'CONTROLLEDVOCABULARY' then\\012      if NEW.covo_id IS NULL then\\012         RAISE EXCEPTION 'Insert/Update of Property Type (Code: %) failed, as its Data Type is CONTROLLEDVOCABULARY, but it is not linked to a Controlled Vocabulary.', NEW.code;\\012      end if;\\012   end if;\\012\\012   RETURN NEW;\\012\\012END;\\012$$ LANGUAGE 'plpgsql';\\012\\012CREATE TRIGGER CONTROLLED_VOCABULARY_CHECK BEFORE INSERT OR UPDATE ON PROPERTY_TYPES\\012    FOR EACH ROW EXECUTE PROCEDURE CONTROLLED_VOCABULARY_CHECK();\\012\\012\\012------------------------------------------------------------------------------------\\012--  Purpose:  Create trigger EXTERNAL_DATA_STORAGE_FORMAT_CHECK \\012------------------------------------------------------------------------------------\\012\\012CREATE OR REPLACE FUNCTION EXTERNAL_DATA_STORAGE_FORMAT_CHECK() RETURNS trigger AS $$\\012DECLARE\\012   v_covo_code  CODE;\\012   data_code CODE;\\012BEGIN\\012\\012   select code into v_covo_code from controlled_vocabularies\\012      where is_internal_namespace = true and \\012         id = (select covo_id from controlled_vocabulary_terms where id = NEW.cvte_id_stor_fmt);\\012   -- Check if the data storage format is a term of the controlled vocabulary "STORAGE_FORMAT"\\012   if v_covo_code != 'STORAGE_FORMAT' then\\012      select code into data_code from data where id = NEW.data_id; \\012      RAISE EXCEPTION 'Insert/Update of Data (Code: %) failed, as its Storage Format is %, but is required to be STORAGE_FORMAT.', data_code, v_covo_code;\\012   end if;\\012\\012   RETURN NEW;\\012\\012END;\\012$$ LANGUAGE 'plpgsql';\\012\\012CREATE TRIGGER EXTERNAL_DATA_STORAGE_FORMAT_CHECK BEFORE INSERT OR UPDATE ON EXTERNAL_DATA\\012    FOR EACH ROW EXECUTE PROCEDURE EXTERNAL_DATA_STORAGE_FORMAT_CHECK();\\012\\012------------------------------------------------------------------------------------\\012--  Purpose:  Create trigger SAMPLE_CODE_UNIQUENESS_CHECK \\012------------------------------------------------------------------------------------\\012\\012CREATE OR REPLACE FUNCTION SAMPLE_CODE_UNIQUENESS_CHECK() RETURNS trigger AS $$\\012DECLARE\\012   counter  INTEGER;\\012BEGIN\\012\\011IF (NEW.samp_id_part_of is NULL) THEN\\012\\011\\011IF (NEW.dbin_id is not NULL) THEN\\012\\011\\011\\011SELECT count(*) into counter FROM samples \\012\\011\\011\\011\\011where id != NEW.id and code = NEW.code and samp_id_part_of is NULL and dbin_id = NEW.dbin_id;\\012\\011\\011\\011IF (counter > 0) THEN\\012\\011\\011\\011\\011RAISE EXCEPTION 'Insert/Update of Sample (Code: %) failed because database instance sample with the same code already exists.', NEW.code;\\012\\011\\011\\011END IF;\\012\\011\\011ELSIF (NEW.grou_id is not NULL) THEN\\012\\011\\011\\011SELECT count(*) into counter FROM samples \\012\\011\\011\\011\\011where id != NEW.id and code = NEW.code and samp_id_part_of is NULL and grou_id = NEW.grou_id;\\012\\011\\011\\011IF (counter > 0) THEN\\012\\011\\011\\011\\011RAISE EXCEPTION 'Insert/Update of Sample (Code: %) failed because group sample with the same code already exists.', NEW.code;\\012\\011\\011\\011END IF;\\012\\011\\011END IF;\\012        ELSE\\012\\011\\011IF (NEW.dbin_id is not NULL) THEN\\012\\011\\011\\011SELECT count(*) into counter FROM samples \\012\\011\\011\\011\\011where id != NEW.id and code = NEW.code and samp_id_part_of = NEW.samp_id_part_of and dbin_id = NEW.dbin_id;\\012\\011\\011\\011IF (counter > 0) THEN\\012\\011\\011\\011\\011RAISE EXCEPTION 'Insert/Update of Sample (Code: %) failed because database instance sample with the same code and being the part of the same parent already exists.', NEW.code;\\012\\011\\011\\011END IF;\\012\\011\\011ELSIF (NEW.grou_id is not NULL) THEN\\012\\011\\011\\011SELECT count(*) into counter FROM samples \\012\\011\\011\\011\\011where id != NEW.id and code = NEW.code and samp_id_part_of = NEW.samp_id_part_of and grou_id = NEW.grou_id;\\012\\011\\011\\011IF (counter > 0) THEN\\012\\011\\011\\011\\011RAISE EXCEPTION 'Insert/Update of Sample (Code: %) failed because group sample with the same code and being the part of the same parent already exists.', NEW.code;\\012\\011\\011\\011END IF;\\012\\011\\011END IF;\\012        END IF;   \\012   RETURN NEW;\\012END;\\012$$ LANGUAGE 'plpgsql';\\012\\012CREATE TRIGGER SAMPLE_CODE_UNIQUENESS_CHECK BEFORE INSERT OR UPDATE ON SAMPLES\\012    FOR EACH ROW EXECUTE PROCEDURE SAMPLE_CODE_UNIQUENESS_CHECK();\\012	\N
+./sourceTest/sql/postgresql/038/.svn/text-base/015=database_version_logs.tsv.svn-base:028	source/sql/postgresql/migration/migration-027-028.sql	SUCCESS	2008-11-18 13:24:17.508	-- Create EXPERIMENT_ATTACHMENT_CONTENTS.\\012CREATE TABLE EXPERIMENT_ATTACHMENT_CONTENTS (ID TECH_ID NOT NULL,VALUE FILE NOT NULL);\\012CREATE SEQUENCE EXPERIMENT_ATTACHMENT_CONTENT_ID_SEQ;\\012ALTER TABLE EXPERIMENT_ATTACHMENT_CONTENTS ADD CONSTRAINT EXAC_PK PRIMARY KEY(ID);\\012\\012-- Alter EXPERIMENT_ATTACHMENTS by adding the new column which has a NULL constraint.\\012-- The NOT NULL constraint is added later on.\\012ALTER TABLE EXPERIMENT_ATTACHMENTS ADD COLUMN EXAC_ID TECH_ID;\\012\\012-- Does the VALUE migration between EXPERIMENT_ATTACHMENTS to EXPERIMENT_ATTACHMENT_CONTENTS.\\012CREATE OR REPLACE FUNCTION move_exp_att_content() RETURNS integer AS $$\\012DECLARE\\012    rec RECORD;\\012    seq BIGINT;\\012BEGIN\\012  FOR rec IN SELECT id, value FROM EXPERIMENT_ATTACHMENTS LOOP\\012  \\011seq := nextval('EXPERIMENT_ATTACHMENT_CONTENT_ID_SEQ');\\012    INSERT INTO EXPERIMENT_ATTACHMENT_CONTENTS (id, value) VALUES (seq, rec.value);\\012    UPDATE EXPERIMENT_ATTACHMENTS SET exac_id = seq WHERE id = rec.id;\\012  END LOOP;\\012  RETURN 1;\\012END;\\012$$ LANGUAGE 'plpgsql';\\012\\012-- Call the function.\\012SELECT move_exp_att_content();\\012DROP FUNCTION move_exp_att_content();\\012\\012\\012-- Finish EXPERIMENT_ATTACHMENTS changes.\\012ALTER TABLE EXPERIMENT_ATTACHMENTS ADD CONSTRAINT EXAT_CONT_FK FOREIGN KEY (EXAC_ID) REFERENCES EXPERIMENT_ATTACHMENT_CONTENTS(ID);\\012ALTER TABLE EXPERIMENT_ATTACHMENTS DROP COLUMN VALUE;\\012ALTER TABLE EXPERIMENT_ATTACHMENTS ALTER COLUMN EXAC_ID SET NOT NULL;\\012	\N
+./sourceTest/sql/postgresql/038/.svn/text-base/015=database_version_logs.tsv.svn-base:029	source/sql/postgresql/migration/migration-028-029.sql	SUCCESS	2009-03-18 10:50:20.105	-- -------\\012-- add modification_timestamp field to allow edition with Hibernate\\012-- -------\\012\\012ALTER TABLE samples\\012\\011ADD COLUMN modification_timestamp TIME_STAMP DEFAULT CURRENT_TIMESTAMP;\\012\\012ALTER TABLE experiments\\012\\011ADD COLUMN modification_timestamp TIME_STAMP DEFAULT CURRENT_TIMESTAMP;\\012\\012ALTER TABLE materials\\012\\011ADD COLUMN modification_timestamp TIME_STAMP DEFAULT CURRENT_TIMESTAMP;\\012\\012ALTER TABLE experiment_properties\\012\\011ADD COLUMN modification_timestamp TIME_STAMP DEFAULT CURRENT_TIMESTAMP;\\012\\012ALTER TABLE material_properties\\012\\011ADD COLUMN modification_timestamp TIME_STAMP DEFAULT CURRENT_TIMESTAMP;\\012\\012ALTER TABLE sample_properties\\012\\011ADD COLUMN modification_timestamp TIME_STAMP DEFAULT CURRENT_TIMESTAMP;\\012\\012-- -------\\012-- add property data type which references materials\\012-- -------\\012\\012ALTER TABLE property_types\\012\\011ADD COLUMN maty_prop_id tech_id;\\012\\012ALTER TABLE property_types\\012\\011ADD CONSTRAINT prty_maty_fk FOREIGN KEY (maty_prop_id) REFERENCES material_types(id);\\012\\012ALTER TABLE experiment_properties\\012\\011ADD COLUMN mate_prop_id tech_id;\\012\\012ALTER TABLE material_properties\\012\\011ADD COLUMN mate_prop_id tech_id;\\012\\012ALTER TABLE sample_properties\\012\\011ADD COLUMN mate_prop_id tech_id;\\012\\012ALTER TABLE experiment_properties\\012\\011ADD CONSTRAINT expr_mapr_fk FOREIGN KEY (mate_prop_id) REFERENCES materials(id);\\012\\012ALTER TABLE material_properties\\012\\011ADD CONSTRAINT mapr_mapr_fk FOREIGN KEY (mate_prop_id) REFERENCES materials(id);\\012\\012ALTER TABLE sample_properties\\012\\011ADD CONSTRAINT sapr_mapr_fk FOREIGN KEY (mate_prop_id) REFERENCES materials(id);\\012\\012insert into data_types\\012(id\\012 ,code\\012 ,description)\\012 values \\012 (nextval('DATA_TYPE_ID_SEQ')\\012 ,'MATERIAL'\\012 ,'Reference to a material'\\012);\\012\\012ALTER TABLE MATERIAL_PROPERTIES DROP CONSTRAINT MAPR_CK;\\012ALTER TABLE MATERIAL_PROPERTIES ADD CONSTRAINT MAPR_CK CHECK \\012\\011((VALUE IS NOT NULL AND CVTE_ID IS NULL AND MATE_PROP_ID IS NULL) OR \\012\\011 (VALUE IS NULL AND CVTE_ID IS NOT NULL AND MATE_PROP_ID IS NULL) OR\\012\\011 (VALUE IS NULL AND CVTE_ID IS NULL AND MATE_PROP_ID IS NOT NULL)\\012\\011);\\012\\012ALTER TABLE EXPERIMENT_PROPERTIES DROP CONSTRAINT EXPR_CK;\\012ALTER TABLE EXPERIMENT_PROPERTIES ADD CONSTRAINT EXPR_CK CHECK \\012\\011((VALUE IS NOT NULL AND CVTE_ID IS NULL AND MATE_PROP_ID IS NULL) OR \\012\\011 (VALUE IS NULL AND CVTE_ID IS NOT NULL AND MATE_PROP_ID IS NULL) OR\\012\\011 (VALUE IS NULL AND CVTE_ID IS NULL AND MATE_PROP_ID IS NOT NULL)\\012\\011);\\012\\012ALTER TABLE SAMPLE_PROPERTIES DROP CONSTRAINT SAPR_CK;\\012ALTER TABLE SAMPLE_PROPERTIES ADD CONSTRAINT SAPR_CK CHECK \\012\\011((VALUE IS NOT NULL AND CVTE_ID IS NULL AND MATE_PROP_ID IS NULL) OR \\012\\011 (VALUE IS NULL AND CVTE_ID IS NOT NULL AND MATE_PROP_ID IS NULL) OR\\012\\011 (VALUE IS NULL AND CVTE_ID IS NULL AND MATE_PROP_ID IS NOT NULL)\\012\\011);\\012\\012------------------------------------------------------------------------------------\\012--  Purpose:  Create trigger MATERIAL/SAMPLE/EXPERIMENT _PROPERTY_WITH_MATERIAL_DATA_TYPE_CHECK\\012--            It checks that if material property value is assigned to the entity,\\012--\\011\\011\\011\\011\\011\\011then the material type is equal to the one described by property type.\\012------------------------------------------------------------------------------------\\012\\012CREATE OR REPLACE FUNCTION MATERIAL_PROPERTY_WITH_MATERIAL_DATA_TYPE_CHECK() RETURNS trigger AS $$\\012DECLARE\\012   v_type_id  CODE;\\012   v_type_id_prop  CODE;\\012BEGIN\\012   if NEW.mate_prop_id IS NOT NULL then\\012\\011\\011\\011-- find material type id of the property type \\012\\011\\011\\011select pt.maty_prop_id into v_type_id_prop \\012\\011\\011\\011  from material_type_property_types etpt, property_types pt \\012\\011\\011\\011 where NEW.mtpt_id = etpt.id AND etpt.prty_id = pt.id;\\012\\011\\011\\012\\011\\011\\011if v_type_id_prop IS NOT NULL then\\012\\011\\011\\011\\011-- find material type id of the material which consists the entity's property value\\012\\011\\011\\011\\011select entity.maty_id into v_type_id \\012\\011\\011\\011\\011  from materials entity\\012\\011\\011\\011\\011 where NEW.mate_prop_id = entity.id;\\012\\011\\011\\011\\011if v_type_id != v_type_id_prop then\\012\\011\\011\\011\\011\\011RAISE EXCEPTION 'Insert/Update of property value referencing material (id: %) failed, as referenced material type is different than expected (id %, expected id: %).', \\012\\011\\011\\011\\011\\011\\011\\011 NEW.mate_prop_id, v_type_id, v_type_id_prop;\\012\\011\\011\\011\\011end if;\\012\\011\\011\\011end if;\\012   end if;\\012   RETURN NEW;\\012END;\\012$$ LANGUAGE 'plpgsql';\\012\\012CREATE TRIGGER MATERIAL_PROPERTY_WITH_MATERIAL_DATA_TYPE_CHECK BEFORE INSERT OR UPDATE ON material_properties\\012    FOR EACH ROW EXECUTE PROCEDURE MATERIAL_PROPERTY_WITH_MATERIAL_DATA_TYPE_CHECK();\\012    \\012CREATE OR REPLACE FUNCTION SAMPLE_PROPERTY_WITH_MATERIAL_DATA_TYPE_CHECK() RETURNS trigger AS $$\\012DECLARE\\012   v_type_id  CODE;\\012   v_type_id_prop  CODE;\\012BEGIN\\012   if NEW.mate_prop_id IS NOT NULL then\\012\\011\\011\\011-- find material type id of the property type \\012\\011\\011\\011select pt.maty_prop_id into v_type_id_prop \\012\\011\\011\\011  from sample_type_property_types etpt, property_types pt \\012\\011\\011\\011 where NEW.stpt_id = etpt.id AND etpt.prty_id = pt.id;\\012\\011\\011\\012\\011\\011\\011if v_type_id_prop IS NOT NULL then\\012\\011\\011\\011\\011-- find material type id of the material which consists the entity's property value\\012\\011\\011\\011\\011select entity.maty_id into v_type_id \\012\\011\\011\\011\\011  from materials entity\\012\\011\\011\\011\\011 where NEW.mate_prop_id = entity.id;\\012\\011\\011\\011\\011if v_type_id != v_type_id_prop then\\012\\011\\011\\011\\011\\011RAISE EXCEPTION 'Insert/Update of property value referencing material (id: %) failed, as referenced material type is different than expected (id %, expected id: %).', \\012\\011\\011\\011\\011\\011\\011\\011\\011\\011\\011\\011\\011 NEW.mate_prop_id, v_type_id, v_type_id_prop;\\012\\011\\011\\011\\011end if;\\012\\011\\011\\011end if;\\012   end if;\\012   RETURN NEW;\\012END;\\012$$ LANGUAGE 'plpgsql';\\012\\012CREATE TRIGGER SAMPLE_PROPERTY_WITH_MATERIAL_DATA_TYPE_CHECK BEFORE INSERT OR UPDATE ON sample_properties\\012    FOR EACH ROW EXECUTE PROCEDURE SAMPLE_PROPERTY_WITH_MATERIAL_DATA_TYPE_CHECK();\\012    \\012CREATE OR REPLACE FUNCTION EXPERIMENT_PROPERTY_WITH_MATERIAL_DATA_TYPE_CHECK() RETURNS trigger AS $$\\012DECLARE\\012   v_type_id  CODE;\\012   v_type_id_prop  CODE;\\012BEGIN\\012   if NEW.mate_prop_id IS NOT NULL then\\012\\011\\011\\011-- find material type id of the property type \\012\\011\\011\\011select pt.maty_prop_id into v_type_id_prop \\012\\011\\011\\011  from experiment_type_property_types etpt, property_types pt \\012\\011\\011\\011 where NEW.etpt_id = etpt.id AND etpt.prty_id = pt.id;\\012\\011\\011\\012\\011\\011\\011if v_type_id_prop IS NOT NULL then\\012\\011\\011\\011\\011-- find material type id of the material which consists the entity's property value\\012\\011\\011\\011\\011select entity.maty_id into v_type_id \\012\\011\\011\\011\\011  from materials entity\\012\\011\\011\\011\\011 where NEW.mate_prop_id = entity.id;\\012\\011\\011\\011\\011if v_type_id != v_type_id_prop then\\012\\011\\011\\011\\011\\011RAISE EXCEPTION 'Insert/Update of property value referencing material (id: %) failed, as referenced material type is different than expected (id %, expected id: %).', \\012\\011\\011\\011\\011\\011\\011\\011\\011\\011\\011\\011\\011 NEW.mate_prop_id, v_type_id, v_type_id_prop;\\012\\011\\011\\011\\011end if;\\012\\011\\011\\011end if;\\012   end if;\\012   RETURN NEW;\\012END;\\012$$ LANGUAGE 'plpgsql';\\012\\012CREATE TRIGGER EXPERIMENT_PROPERTY_WITH_MATERIAL_DATA_TYPE_CHECK BEFORE INSERT OR UPDATE ON experiment_properties\\012    FOR EACH ROW EXECUTE PROCEDURE EXPERIMENT_PROPERTY_WITH_MATERIAL_DATA_TYPE_CHECK();\\012       \\012-- -------\\012-- remove the reminescents of the OBSERVABLE_TYPE\\012-- -------\\012\\012ALTER TABLE data\\012\\011DROP CONSTRAINT data_obty_fk;\\012\\012ALTER TABLE data_set_types\\012\\011DROP CONSTRAINT obty_pk;\\012\\012ALTER TABLE data_set_types\\012\\011ADD CONSTRAINT dsty_pk PRIMARY KEY (id);\\012\\012ALTER TABLE data\\012\\011ADD CONSTRAINT data_dsty_fk FOREIGN KEY (dsty_id) REFERENCES data_set_types(id);\\012\\012ALTER TABLE data_set_types\\012\\011DROP CONSTRAINT obty_bk_uk;\\012\\012ALTER TABLE data_set_types\\012\\011DROP CONSTRAINT obty_dbin_fk;\\012\\012ALTER TABLE data_set_types\\012\\011ADD CONSTRAINT dsty_bk_uk UNIQUE (code, dbin_id);\\012\\012ALTER TABLE data_set_types\\012\\011ADD CONSTRAINT dsty_dbin_fk FOREIGN KEY (dbin_id) REFERENCES database_instances(id);\\012\\012DROP INDEX data_obty_fk_i;\\012\\012CREATE INDEX data_dsty_fk_i ON data(dsty_id);\\012	\N
+./sourceTest/sql/postgresql/038/.svn/text-base/015=database_version_logs.tsv.svn-base:030	source/sql/postgresql/migration/migration-029-030.sql	SUCCESS	2009-03-23 15:34:44.72	-- -------\\012-- add modification_timestamp field to allow edition with Hibernate\\012-- -------\\012ALTER TABLE data\\012\\011ADD COLUMN modification_timestamp TIME_STAMP DEFAULT CURRENT_TIMESTAMP;\\012ALTER TABLE experiment_types\\012\\011ADD COLUMN modification_timestamp TIME_STAMP DEFAULT CURRENT_TIMESTAMP;\\012ALTER TABLE sample_types\\012\\011ADD COLUMN modification_timestamp TIME_STAMP DEFAULT CURRENT_TIMESTAMP;\\012ALTER TABLE material_types\\012\\011ADD COLUMN modification_timestamp TIME_STAMP DEFAULT CURRENT_TIMESTAMP;\\012ALTER TABLE data_set_types\\012\\011ADD COLUMN modification_timestamp TIME_STAMP DEFAULT CURRENT_TIMESTAMP;\\012ALTER TABLE controlled_vocabularies\\012\\011ADD COLUMN modification_timestamp TIME_STAMP DEFAULT CURRENT_TIMESTAMP;\\012-- -------\\012-- add properties to data sets\\012-- -------\\012CREATE TABLE DATA_SET_PROPERTIES (ID TECH_ID NOT NULL,DS_ID TECH_ID NOT NULL,DSTPT_ID TECH_ID NOT NULL,VALUE GENERIC_VALUE,CVTE_ID TECH_ID, MATE_PROP_ID TECH_ID, PERS_ID_REGISTERER TECH_ID NOT NULL,REGISTRATION_TIMESTAMP TIME_STAMP_DFL NOT NULL DEFAULT CURRENT_TIMESTAMP, MODIFICATION_TIMESTAMP TIME_STAMP DEFAULT CURRENT_TIMESTAMP);\\012CREATE TABLE DATA_SET_TYPE_PROPERTY_TYPES (ID TECH_ID NOT NULL,DSTY_ID TECH_ID NOT NULL,PRTY_ID TECH_ID NOT NULL,IS_MANDATORY BOOLEAN_CHAR NOT NULL DEFAULT 'F',IS_MANAGED_INTERNALLY BOOLEAN_CHAR NOT NULL DEFAULT 'F',PERS_ID_REGISTERER TECH_ID NOT NULL,REGISTRATION_TIMESTAMP TIME_STAMP_DFL NOT NULL DEFAULT CURRENT_TIMESTAMP);\\012\\012CREATE SEQUENCE DATA_SET_PROPERTY_ID_SEQ;\\012CREATE SEQUENCE DSTPT_ID_SEQ;\\012\\012ALTER TABLE DATA_SET_TYPE_PROPERTY_TYPES ADD CONSTRAINT DSTPT_PK PRIMARY KEY(ID);\\012ALTER TABLE DATA_SET_PROPERTIES ADD CONSTRAINT DSPR_PK PRIMARY KEY(ID);\\012\\012ALTER TABLE DATA_SET_TYPE_PROPERTY_TYPES ADD CONSTRAINT DSTPT_BK_UK UNIQUE(DSTY_ID,PRTY_ID);\\012ALTER TABLE DATA_SET_PROPERTIES ADD CONSTRAINT DSPR_BK_UK UNIQUE(DS_ID,DSTPT_ID);\\012\\012\\012ALTER TABLE DATA_SET_TYPE_PROPERTY_TYPES ADD CONSTRAINT DSTPT_DSTY_FK FOREIGN KEY (DSTY_ID) REFERENCES DATA_SET_TYPES(ID);\\012ALTER TABLE DATA_SET_TYPE_PROPERTY_TYPES ADD CONSTRAINT DSTPT_PERS_FK FOREIGN KEY (PERS_ID_REGISTERER) REFERENCES PERSONS(ID);\\012ALTER TABLE DATA_SET_TYPE_PROPERTY_TYPES ADD CONSTRAINT DSTPT_PRTY_FK FOREIGN KEY (PRTY_ID) REFERENCES PROPERTY_TYPES(ID);\\012ALTER TABLE DATA_SET_PROPERTIES ADD CONSTRAINT DSPR_CVTE_FK FOREIGN KEY (CVTE_ID) REFERENCES CONTROLLED_VOCABULARY_TERMS(ID);\\012ALTER TABLE DATA_SET_PROPERTIES ADD CONSTRAINT DSPR_DSTPT_FK FOREIGN KEY (DSTPT_ID) REFERENCES DATA_SET_TYPE_PROPERTY_TYPES(ID) ON DELETE CASCADE;\\012ALTER TABLE DATA_SET_PROPERTIES ADD CONSTRAINT DSPR_DS_FK FOREIGN KEY (DS_ID) REFERENCES DATA(ID);\\012ALTER TABLE DATA_SET_PROPERTIES ADD CONSTRAINT DSPR_PERS_FK FOREIGN KEY (PERS_ID_REGISTERER) REFERENCES PERSONS(ID);\\012ALTER TABLE DATA_SET_PROPERTIES ADD CONSTRAINT DSPR_MAPR_FK FOREIGN KEY (MATE_PROP_ID) REFERENCES MATERIALS(ID);\\012\\012ALTER TABLE DATA_SET_PROPERTIES ADD CONSTRAINT DSPR_CK CHECK \\012\\011((VALUE IS NOT NULL AND CVTE_ID IS NULL AND MATE_PROP_ID IS NULL) OR \\012\\011 (VALUE IS NULL AND CVTE_ID IS NOT NULL AND MATE_PROP_ID IS NULL) OR\\012\\011 (VALUE IS NULL AND CVTE_ID IS NULL AND MATE_PROP_ID IS NOT NULL)\\012\\011);\\012\\012CREATE INDEX DSPR_CVTE_FK_I ON DATA_SET_PROPERTIES (CVTE_ID);\\012CREATE INDEX DSPR_DSTPT_FK_I ON DATA_SET_PROPERTIES (DSTPT_ID);\\012CREATE INDEX DSPR_DS_FK_I ON DATA_SET_PROPERTIES (DS_ID);\\012CREATE INDEX DSPR_PERS_FK_I ON DATA_SET_PROPERTIES (PERS_ID_REGISTERER);\\012CREATE INDEX DSTPT_DSTY_FK_I ON DATA_SET_TYPE_PROPERTY_TYPES (DSTY_ID);\\012CREATE INDEX DSTPT_PERS_FK_I ON DATA_SET_TYPE_PROPERTY_TYPES (PERS_ID_REGISTERER);\\012CREATE INDEX DSTPT_PRTY_FK_I ON DATA_SET_TYPE_PROPERTY_TYPES (PRTY_ID);\\012\\012CREATE OR REPLACE FUNCTION DATA_SET_PROPERTY_WITH_MATERIAL_DATA_TYPE_CHECK() RETURNS trigger AS $$\\012DECLARE\\012   v_type_id  CODE;\\012   v_type_id_prop  CODE;\\012BEGIN\\012   if NEW.mate_prop_id IS NOT NULL then\\012\\011\\011\\011-- find material type id of the property type \\012\\011\\011\\011select pt.maty_prop_id into v_type_id_prop \\012\\011\\011\\011  from data_set_type_property_types dstpt, property_types pt \\012\\011\\011\\011 where NEW.dstpt_id = dstpt.id AND dstpt.prty_id = pt.id;\\012\\011\\011\\012\\011\\011\\011if v_type_id_prop IS NOT NULL then\\012\\011\\011\\011\\011-- find material type id of the material which consists the entity's property value\\012\\011\\011\\011\\011select entity.maty_id into v_type_id \\012\\011\\011\\011\\011  from materials entity\\012\\011\\011\\011\\011 where NEW.mate_prop_id = entity.id;\\012\\011\\011\\011\\011if v_type_id != v_type_id_prop then\\012\\011\\011\\011\\011\\011RAISE EXCEPTION 'Insert/Update of property value referencing material (id: %) failed, as referenced material type is different than expected (id %, expected id: %).', \\012\\011\\011\\011\\011\\011\\011\\011\\011\\011\\011\\011\\011 NEW.mate_prop_id, v_type_id, v_type_id_prop;\\012\\011\\011\\011\\011end if;\\012\\011\\011\\011end if;\\012   end if;\\012   RETURN NEW;\\012END;\\012$$ LANGUAGE 'plpgsql';\\012\\012CREATE TRIGGER DATA_SET_PROPERTY_WITH_MATERIAL_DATA_TYPE_CHECK BEFORE INSERT OR UPDATE ON data_set_properties\\012    FOR EACH ROW EXECUTE PROCEDURE DATA_SET_PROPERTY_WITH_MATERIAL_DATA_TYPE_CHECK();   \\012	\N
+./sourceTest/sql/postgresql/038/.svn/text-base/015=database_version_logs.tsv.svn-base:032	source/sql/postgresql/migration/migration-031-032.sql	SUCCESS	2009-04-09 09:36:36.20	-- -------\\012-- Modify MATERIAL_BATCHES\\012-- -------\\012\\012ALTER TABLE material_batches\\012    DROP COLUMN proc_id;\\012\\012-- -------\\012-- Modify SAMPLES\\012-- -------\\012\\012ALTER TABLE samples\\012    ADD COLUMN expe_id tech_id;\\012\\012ALTER TABLE samples\\012    ADD CONSTRAINT samp_expe_fk FOREIGN KEY (expe_id) REFERENCES experiments(id);\\012\\012CREATE INDEX samp_expe_fk_i ON samples USING btree (expe_id);\\012\\012-- relink samples directly to experiments\\012\\012UPDATE samples\\012SET expe_id = (SELECT e.id FROM experiments e, procedures p, sample_inputs si \\012               WHERE si.samp_id = samples.id AND si.proc_id = p.id AND p.expe_id = e.id AND e.inva_id IS NULL);\\012\\012\\012-- -------\\012-- Modify DATA\\012-- -------\\012\\012ALTER TABLE data\\012    ADD COLUMN expe_id tech_id;\\012\\012ALTER TABLE data\\012    ADD CONSTRAINT data_expe_fk FOREIGN KEY (expe_id) REFERENCES experiments(id);\\012\\012CREATE INDEX data_expe_fk_i ON data USING btree (expe_id);\\012\\012UPDATE data\\012SET expe_id = (SELECT e.id FROM experiments e, procedures p \\012               WHERE data.proc_id_produced_by = p.id AND p.expe_id = e.id);\\012\\012ALTER TABLE data\\012    ALTER COLUMN expe_id SET NOT NULL;\\012\\012ALTER TABLE data\\012    DROP COLUMN proc_id_produced_by;\\012\\012-- -------\\012-- Drop PROCEDURES, PROCEDURE_TYPES, and SAMPLE_INPUTS\\012-- -------\\012\\012DROP TABLE sample_inputs;\\012DROP TABLE procedures;\\012DROP TABLE procedure_types;\\012\\012DROP SEQUENCE procedure_id_seq;\\012DROP SEQUENCE procedure_type_id_seq;\\012\\012-- -------\\012-- Add CODE_SEQ\\012-- -------\\012\\012CREATE SEQUENCE CODE_SEQ;\\012\\012-- -------\\012-- Add new columns to DATA_STORES\\012-- -------\\012\\012ALTER TABLE data_stores\\012    ADD COLUMN remote_url character varying(250),\\012    ADD COLUMN session_token character varying(50),\\012    ADD COLUMN modification_timestamp time_stamp DEFAULT now();\\012\\012UPDATE data_stores\\012SET remote_url = '', session_token='';\\012\\012ALTER TABLE data_stores\\012    ALTER COLUMN remote_url SET NOT NULL,\\012    ALTER COLUMN session_token SET NOT NULL;\\012\\012-- -------\\012-- Drop foreign keys onto DATA_STORES\\012-- -------\\012\\012ALTER TABLE database_instances\\012    DROP COLUMN dast_id;\\012\\012ALTER TABLE groups\\012    DROP COLUMN dast_id;\\012\\012ALTER TABLE projects\\012    DROP COLUMN dast_id;\\012\\012ALTER TABLE experiments\\012    DROP COLUMN dast_id;\\012\\012-- -------\\012-- Add foreign key from DATA onto DATA_STORES\\012-- -------\\012\\012ALTER TABLE data\\012    ADD COLUMN dast_id tech_id;\\012\\012ALTER TABLE data\\012    ADD CONSTRAINT data_dast_fk FOREIGN KEY (dast_id) REFERENCES data_stores(id);\\012\\012UPDATE data\\012SET dast_id = (select id from data_stores where code = 'STANDARD');\\012\\012ALTER TABLE data\\012    ALTER COLUMN dast_id SET NOT NULL;\\012\\012\\012------------------------------------------------------------------------------------\\012--  Purpose:  Replace trigger SAMPLE_CODE_UNIQUENESS_CHECK \\012------------------------------------------------------------------------------------\\012\\012CREATE OR REPLACE FUNCTION SAMPLE_CODE_UNIQUENESS_CHECK() RETURNS trigger AS $$\\012DECLARE\\012   counter  INTEGER;\\012BEGIN\\012    LOCK TABLE samples IN EXCLUSIVE MODE;\\012    IF (NEW.samp_id_part_of is NULL) THEN\\012        IF (NEW.dbin_id is not NULL) THEN\\012            SELECT count(*) into counter FROM samples \\012                where id != NEW.id and code = NEW.code and samp_id_part_of is NULL and dbin_id = NEW.dbin_id;\\012            IF (counter > 0) THEN\\012                RAISE EXCEPTION 'Insert/Update of Sample (Code: %) failed because database instance sample with the same code already exists.', NEW.code;\\012            END IF;\\012        ELSIF (NEW.grou_id is not NULL) THEN\\012            SELECT count(*) into counter FROM samples \\012                where id != NEW.id and code = NEW.code and samp_id_part_of is NULL and grou_id = NEW.grou_id;\\012            IF (counter > 0) THEN\\012                RAISE EXCEPTION 'Insert/Update of Sample (Code: %) failed because group sample with the same code already exists.', NEW.code;\\012            END IF;\\012        END IF;\\012        ELSE\\012        IF (NEW.dbin_id is not NULL) THEN\\012            SELECT count(*) into counter FROM samples \\012                where id != NEW.id and code = NEW.code and samp_id_part_of = NEW.samp_id_part_of and dbin_id = NEW.dbin_id;\\012            IF (counter > 0) THEN\\012                RAISE EXCEPTION 'Insert/Update of Sample (Code: %) failed because database instance sample with the same code and being the part of the same parent already exists.', NEW.code;\\012            END IF;\\012        ELSIF (NEW.grou_id is not NULL) THEN\\012            SELECT count(*) into counter FROM samples \\012                where id != NEW.id and code = NEW.code and samp_id_part_of = NEW.samp_id_part_of and grou_id = NEW.grou_id;\\012            IF (counter > 0) THEN\\012                RAISE EXCEPTION 'Insert/Update of Sample (Code: %) failed because group sample with the same code and being the part of the same parent already exists.', NEW.code;\\012            END IF;\\012        END IF;\\012        END IF;   \\012   RETURN NEW;\\012END;\\012$$ LANGUAGE 'plpgsql';\\012\\012\\012\\012	\N
+./sourceTest/sql/postgresql/038/.svn/text-base/015=database_version_logs.tsv.svn-base:034	source/sql/postgresql/migration/migration-033-034.sql	SUCCESS	2009-05-26 08:32:49.935	------------------------------------------------------------------------------------\\012-- Create sequence for generating permanent identifiers starting with nextval of existing dataset sequence.\\012------------------------------------------------------------------------------------\\012CREATE FUNCTION CREATE_SEQUENCE(EXISTING_SEQUENCE VARCHAR, NEW_SEQUENCE VARCHAR) RETURNS VOID AS $$\\012DECLARE\\012  CURR_SEQ_VAL   INTEGER;\\012BEGIN\\012  SELECT INTO CURR_SEQ_VAL NEXTVAL(EXISTING_SEQUENCE);\\012  EXECUTE 'CREATE SEQUENCE ' || NEW_SEQUENCE || ' START WITH ' || CURR_SEQ_VAL;\\012  RETURN;\\012END;\\012$$ LANGUAGE 'plpgsql';\\012\\012SELECT CREATE_SEQUENCE('DATA_ID_SEQ', 'PERM_ID_SEQ');\\012DROP FUNCTION CREATE_SEQUENCE(VARCHAR, VARCHAR);\\012\\012------------------------------------------------------------------------------------\\012-- Add perm_id columns to samples and experiments.\\012------------------------------------------------------------------------------------\\012ALTER TABLE SAMPLES ADD COLUMN PERM_ID CODE;\\012ALTER TABLE EXPERIMENTS ADD COLUMN PERM_ID CODE;\\012\\012UPDATE SAMPLES SET PERM_ID = to_char(registration_timestamp,'YYYYMMDDHHSSMS') || '-' || NEXTVAL('PERM_ID_SEQ');\\012UPDATE EXPERIMENTS SET PERM_ID = to_char(registration_timestamp,'YYYYMMDDHHSSMS') || '-' || NEXTVAL('PERM_ID_SEQ');\\012ALTER TABLE SAMPLES ALTER COLUMN PERM_ID SET NOT NULL;\\012ALTER TABLE EXPERIMENTS ALTER COLUMN PERM_ID SET NOT NULL;\\012ALTER TABLE SAMPLES ADD CONSTRAINT SAMP_PI_UK UNIQUE(PERM_ID);\\012ALTER TABLE EXPERIMENTS ADD CONSTRAINT EXPE_PI_UK UNIQUE(PERM_ID);\\012\\012\\012------------------------------------------------------------------------------------\\012-- Add column is_chosen_from_list to controlled_vocabularies.\\012------------------------------------------------------------------------------------\\012ALTER TABLE controlled_vocabularies ADD COLUMN is_chosen_from_list BOOLEAN_CHAR NOT NULL DEFAULT TRUE;\\012ALTER TABLE controlled_vocabularies ADD COLUMN source_uri CHARACTER VARYING(250);\\012------------------------------------------------------------------------------------\\012-- Modify Data table - remove arc connection between Sample and Data table, use a flag instead\\012------------------------------------------------------------------------------------\\012\\012-- add new columns\\012\\012ALTER TABLE data\\012    ADD COLUMN is_derived boolean_char;\\012ALTER TABLE data\\012    ADD COLUMN samp_id tech_id;\\012\\012-- update values in new columns\\012\\012UPDATE data\\012    SET is_derived = (samp_id_derived_from IS NOT NULL); \\012UPDATE data\\012    SET samp_id = samp_id_derived_from \\012    WHERE is_derived = 'TRUE';\\012UPDATE data\\012    SET samp_id = samp_id_acquired_from \\012    WHERE is_derived = 'FALSE';\\012\\012-- add constraints and indexes to new columns\\012\\012ALTER TABLE data\\012    ALTER COLUMN is_derived SET NOT NULL;\\012ALTER TABLE data\\012    ALTER COLUMN samp_id SET NOT NULL;   \\012ALTER TABLE data\\012    ADD CONSTRAINT data_samp_fk FOREIGN KEY (samp_id) REFERENCES samples (id);\\012CREATE INDEX data_samp_fk_i ON data USING btree (samp_id);\\012\\012-- remove old columns\\012\\012ALTER TABLE data\\012    DROP COLUMN samp_id_acquired_from;\\012ALTER TABLE data\\012    DROP COLUMN samp_id_derived_from;\\012    \\012------------------------------------------------------------------------------------\\012-- Granting SELECT privilege to group openbis_readonly\\012------------------------------------------------------------------------------------\\012\\012GRANT SELECT ON SEQUENCE attachment_content_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE attachment_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE code_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE controlled_vocabulary_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE cvte_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE data_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE data_set_property_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE data_set_relationship_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE data_set_type_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE data_store_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE data_type_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE database_instance_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE dstpt_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE etpt_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE event_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE experiment_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE experiment_property_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE experiment_type_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE file_format_type_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE group_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE invalidation_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE locator_type_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE material_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE material_property_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE material_type_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE mtpt_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE perm_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE person_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE project_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE property_type_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE role_assignment_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE sample_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE sample_property_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE sample_type_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE stpt_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE attachment_contents TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE attachments TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE controlled_vocabularies TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE controlled_vocabulary_terms TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE data TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE data_set_properties TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE data_set_relationships TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE data_set_type_property_types TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE data_set_types TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE data_stores TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE data_types TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE database_instances TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE database_version_logs TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE events TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE experiment_properties TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE experiment_type_property_types TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE experiment_types TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE experiments TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE external_data TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE file_format_types TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE groups TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE invalidations TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE locator_types TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE material_properties TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE material_type_property_types TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE material_types TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE materials TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE persons TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE projects TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE property_types TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE role_assignments TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE sample_properties TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE sample_type_property_types TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE sample_types TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE samples TO GROUP OPENBIS_READONLY;\\012\\012------------------------------------------------------------------------------------\\012-- Delete MATERIAL_BATCHES table\\012------------------------------------------------------------------------------------\\012\\012-- WARNING: Potential data lost!!!\\012-- WARNING: Potential data lost!!!\\012-- WARNING: Potential data lost!!!\\012\\012DROP TABLE SAMPLE_MATERIAL_BATCHES;\\012DROP TABLE MATERIAL_BATCHES;\\012DROP SEQUENCE MATERIAL_BATCH_ID_SEQ;\\012\\012------------------------------------------------------------------------------------\\012-- Delete MATE_ID_INHIBITOR_OF from table MATERIALS\\012------------------------------------------------------------------------------------\\012\\012-- WARNING: Potential data lost!!!\\012-- WARNING: Potential data lost!!!\\012-- WARNING: Potential data lost!!!\\012\\012ALTER TABLE MATERIALS DROP COLUMN MATE_ID_INHIBITOR_OF;\\012	\N
+./sourceTest/sql/postgresql/038/.svn/text-base/schema-038.sql.svn-base:    LANGUAGE plpgsql;
+./sourceTest/sql/postgresql/038/.svn/text-base/schema-038.sql.svn-base:    LANGUAGE plpgsql;
+./sourceTest/sql/postgresql/038/.svn/text-base/schema-038.sql.svn-base:    LANGUAGE plpgsql;
+./sourceTest/sql/postgresql/038/.svn/text-base/schema-038.sql.svn-base:    LANGUAGE plpgsql;
+./sourceTest/sql/postgresql/038/.svn/text-base/schema-038.sql.svn-base:    LANGUAGE plpgsql;
+./sourceTest/sql/postgresql/038/.svn/text-base/schema-038.sql.svn-base:    LANGUAGE plpgsql;
+./sourceTest/sql/postgresql/038/.svn/text-base/schema-038.sql.svn-base:    LANGUAGE plpgsql;
+./sourceTest/sql/postgresql/038/.svn/text-base/schema-038.sql.svn-base:    LANGUAGE plpgsql;
+./sourceTest/sql/postgresql/038/015=database_version_logs.tsv:027	D:\\User\\felmer\\dev-workspace\\openbis/source/sql/postgresql/027/function-027.sql	SUCCESS	2008-11-05 09:18:00.403	-- Creating Functions\\012\\012------------------------------------------------------------------------------------\\012--  Purpose:  Create function RENAME_SEQUENCE() that is required for renaming the sequences belonging to tables\\012------------------------------------------------------------------------------------\\012CREATE FUNCTION RENAME_SEQUENCE(OLD_NAME VARCHAR, NEW_NAME VARCHAR) RETURNS INTEGER AS $$\\012DECLARE\\012  CURR_SEQ_VAL   INTEGER;\\012BEGIN\\012  SELECT INTO CURR_SEQ_VAL NEXTVAL(OLD_NAME);\\012  EXECUTE 'CREATE SEQUENCE ' || NEW_NAME || ' START WITH ' || CURR_SEQ_VAL;\\012  EXECUTE 'DROP SEQUENCE ' || OLD_NAME;\\012  RETURN CURR_SEQ_VAL;\\012END;\\012$$ LANGUAGE 'plpgsql';\\012\\012\\012------------------------------------------------------------------------------------\\012--  Purpose:  Create trigger CONTROLLED_VOCABULARY_CHECK \\012------------------------------------------------------------------------------------\\012\\012CREATE OR REPLACE FUNCTION CONTROLLED_VOCABULARY_CHECK() RETURNS trigger AS $$\\012DECLARE\\012   v_code  CODE;\\012BEGIN\\012\\012   select code into v_code from data_types where id = NEW.daty_id;\\012\\012   -- Check if the data is of type "CONTROLLEDVOCABULARY"\\012   if v_code = 'CONTROLLEDVOCABULARY' then\\012      if NEW.covo_id IS NULL then\\012         RAISE EXCEPTION 'Insert/Update of Property Type (Code: %) failed, as its Data Type is CONTROLLEDVOCABULARY, but it is not linked to a Controlled Vocabulary.', NEW.code;\\012      end if;\\012   end if;\\012\\012   RETURN NEW;\\012\\012END;\\012$$ LANGUAGE 'plpgsql';\\012\\012CREATE TRIGGER CONTROLLED_VOCABULARY_CHECK BEFORE INSERT OR UPDATE ON PROPERTY_TYPES\\012    FOR EACH ROW EXECUTE PROCEDURE CONTROLLED_VOCABULARY_CHECK();\\012\\012\\012------------------------------------------------------------------------------------\\012--  Purpose:  Create trigger EXTERNAL_DATA_STORAGE_FORMAT_CHECK \\012------------------------------------------------------------------------------------\\012\\012CREATE OR REPLACE FUNCTION EXTERNAL_DATA_STORAGE_FORMAT_CHECK() RETURNS trigger AS $$\\012DECLARE\\012   v_covo_code  CODE;\\012   data_code CODE;\\012BEGIN\\012\\012   select code into v_covo_code from controlled_vocabularies\\012      where is_internal_namespace = true and \\012         id = (select covo_id from controlled_vocabulary_terms where id = NEW.cvte_id_stor_fmt);\\012   -- Check if the data storage format is a term of the controlled vocabulary "STORAGE_FORMAT"\\012   if v_covo_code != 'STORAGE_FORMAT' then\\012      select code into data_code from data where id = NEW.data_id; \\012      RAISE EXCEPTION 'Insert/Update of Data (Code: %) failed, as its Storage Format is %, but is required to be STORAGE_FORMAT.', data_code, v_covo_code;\\012   end if;\\012\\012   RETURN NEW;\\012\\012END;\\012$$ LANGUAGE 'plpgsql';\\012\\012CREATE TRIGGER EXTERNAL_DATA_STORAGE_FORMAT_CHECK BEFORE INSERT OR UPDATE ON EXTERNAL_DATA\\012    FOR EACH ROW EXECUTE PROCEDURE EXTERNAL_DATA_STORAGE_FORMAT_CHECK();\\012\\012------------------------------------------------------------------------------------\\012--  Purpose:  Create trigger SAMPLE_CODE_UNIQUENESS_CHECK \\012------------------------------------------------------------------------------------\\012\\012CREATE OR REPLACE FUNCTION SAMPLE_CODE_UNIQUENESS_CHECK() RETURNS trigger AS $$\\012DECLARE\\012   counter  INTEGER;\\012BEGIN\\012\\011IF (NEW.samp_id_part_of is NULL) THEN\\012\\011\\011IF (NEW.dbin_id is not NULL) THEN\\012\\011\\011\\011SELECT count(*) into counter FROM samples \\012\\011\\011\\011\\011where id != NEW.id and code = NEW.code and samp_id_part_of is NULL and dbin_id = NEW.dbin_id;\\012\\011\\011\\011IF (counter > 0) THEN\\012\\011\\011\\011\\011RAISE EXCEPTION 'Insert/Update of Sample (Code: %) failed because database instance sample with the same code already exists.', NEW.code;\\012\\011\\011\\011END IF;\\012\\011\\011ELSIF (NEW.grou_id is not NULL) THEN\\012\\011\\011\\011SELECT count(*) into counter FROM samples \\012\\011\\011\\011\\011where id != NEW.id and code = NEW.code and samp_id_part_of is NULL and grou_id = NEW.grou_id;\\012\\011\\011\\011IF (counter > 0) THEN\\012\\011\\011\\011\\011RAISE EXCEPTION 'Insert/Update of Sample (Code: %) failed because group sample with the same code already exists.', NEW.code;\\012\\011\\011\\011END IF;\\012\\011\\011END IF;\\012        ELSE\\012\\011\\011IF (NEW.dbin_id is not NULL) THEN\\012\\011\\011\\011SELECT count(*) into counter FROM samples \\012\\011\\011\\011\\011where id != NEW.id and code = NEW.code and samp_id_part_of = NEW.samp_id_part_of and dbin_id = NEW.dbin_id;\\012\\011\\011\\011IF (counter > 0) THEN\\012\\011\\011\\011\\011RAISE EXCEPTION 'Insert/Update of Sample (Code: %) failed because database instance sample with the same code and being the part of the same parent already exists.', NEW.code;\\012\\011\\011\\011END IF;\\012\\011\\011ELSIF (NEW.grou_id is not NULL) THEN\\012\\011\\011\\011SELECT count(*) into counter FROM samples \\012\\011\\011\\011\\011where id != NEW.id and code = NEW.code and samp_id_part_of = NEW.samp_id_part_of and grou_id = NEW.grou_id;\\012\\011\\011\\011IF (counter > 0) THEN\\012\\011\\011\\011\\011RAISE EXCEPTION 'Insert/Update of Sample (Code: %) failed because group sample with the same code and being the part of the same parent already exists.', NEW.code;\\012\\011\\011\\011END IF;\\012\\011\\011END IF;\\012        END IF;   \\012   RETURN NEW;\\012END;\\012$$ LANGUAGE 'plpgsql';\\012\\012CREATE TRIGGER SAMPLE_CODE_UNIQUENESS_CHECK BEFORE INSERT OR UPDATE ON SAMPLES\\012    FOR EACH ROW EXECUTE PROCEDURE SAMPLE_CODE_UNIQUENESS_CHECK();\\012	\N
+./sourceTest/sql/postgresql/038/015=database_version_logs.tsv:028	source/sql/postgresql/migration/migration-027-028.sql	SUCCESS	2008-11-18 13:24:17.508	-- Create EXPERIMENT_ATTACHMENT_CONTENTS.\\012CREATE TABLE EXPERIMENT_ATTACHMENT_CONTENTS (ID TECH_ID NOT NULL,VALUE FILE NOT NULL);\\012CREATE SEQUENCE EXPERIMENT_ATTACHMENT_CONTENT_ID_SEQ;\\012ALTER TABLE EXPERIMENT_ATTACHMENT_CONTENTS ADD CONSTRAINT EXAC_PK PRIMARY KEY(ID);\\012\\012-- Alter EXPERIMENT_ATTACHMENTS by adding the new column which has a NULL constraint.\\012-- The NOT NULL constraint is added later on.\\012ALTER TABLE EXPERIMENT_ATTACHMENTS ADD COLUMN EXAC_ID TECH_ID;\\012\\012-- Does the VALUE migration between EXPERIMENT_ATTACHMENTS to EXPERIMENT_ATTACHMENT_CONTENTS.\\012CREATE OR REPLACE FUNCTION move_exp_att_content() RETURNS integer AS $$\\012DECLARE\\012    rec RECORD;\\012    seq BIGINT;\\012BEGIN\\012  FOR rec IN SELECT id, value FROM EXPERIMENT_ATTACHMENTS LOOP\\012  \\011seq := nextval('EXPERIMENT_ATTACHMENT_CONTENT_ID_SEQ');\\012    INSERT INTO EXPERIMENT_ATTACHMENT_CONTENTS (id, value) VALUES (seq, rec.value);\\012    UPDATE EXPERIMENT_ATTACHMENTS SET exac_id = seq WHERE id = rec.id;\\012  END LOOP;\\012  RETURN 1;\\012END;\\012$$ LANGUAGE 'plpgsql';\\012\\012-- Call the function.\\012SELECT move_exp_att_content();\\012DROP FUNCTION move_exp_att_content();\\012\\012\\012-- Finish EXPERIMENT_ATTACHMENTS changes.\\012ALTER TABLE EXPERIMENT_ATTACHMENTS ADD CONSTRAINT EXAT_CONT_FK FOREIGN KEY (EXAC_ID) REFERENCES EXPERIMENT_ATTACHMENT_CONTENTS(ID);\\012ALTER TABLE EXPERIMENT_ATTACHMENTS DROP COLUMN VALUE;\\012ALTER TABLE EXPERIMENT_ATTACHMENTS ALTER COLUMN EXAC_ID SET NOT NULL;\\012	\N
+./sourceTest/sql/postgresql/038/015=database_version_logs.tsv:029	source/sql/postgresql/migration/migration-028-029.sql	SUCCESS	2009-03-18 10:50:20.105	-- -------\\012-- add modification_timestamp field to allow edition with Hibernate\\012-- -------\\012\\012ALTER TABLE samples\\012\\011ADD COLUMN modification_timestamp TIME_STAMP DEFAULT CURRENT_TIMESTAMP;\\012\\012ALTER TABLE experiments\\012\\011ADD COLUMN modification_timestamp TIME_STAMP DEFAULT CURRENT_TIMESTAMP;\\012\\012ALTER TABLE materials\\012\\011ADD COLUMN modification_timestamp TIME_STAMP DEFAULT CURRENT_TIMESTAMP;\\012\\012ALTER TABLE experiment_properties\\012\\011ADD COLUMN modification_timestamp TIME_STAMP DEFAULT CURRENT_TIMESTAMP;\\012\\012ALTER TABLE material_properties\\012\\011ADD COLUMN modification_timestamp TIME_STAMP DEFAULT CURRENT_TIMESTAMP;\\012\\012ALTER TABLE sample_properties\\012\\011ADD COLUMN modification_timestamp TIME_STAMP DEFAULT CURRENT_TIMESTAMP;\\012\\012-- -------\\012-- add property data type which references materials\\012-- -------\\012\\012ALTER TABLE property_types\\012\\011ADD COLUMN maty_prop_id tech_id;\\012\\012ALTER TABLE property_types\\012\\011ADD CONSTRAINT prty_maty_fk FOREIGN KEY (maty_prop_id) REFERENCES material_types(id);\\012\\012ALTER TABLE experiment_properties\\012\\011ADD COLUMN mate_prop_id tech_id;\\012\\012ALTER TABLE material_properties\\012\\011ADD COLUMN mate_prop_id tech_id;\\012\\012ALTER TABLE sample_properties\\012\\011ADD COLUMN mate_prop_id tech_id;\\012\\012ALTER TABLE experiment_properties\\012\\011ADD CONSTRAINT expr_mapr_fk FOREIGN KEY (mate_prop_id) REFERENCES materials(id);\\012\\012ALTER TABLE material_properties\\012\\011ADD CONSTRAINT mapr_mapr_fk FOREIGN KEY (mate_prop_id) REFERENCES materials(id);\\012\\012ALTER TABLE sample_properties\\012\\011ADD CONSTRAINT sapr_mapr_fk FOREIGN KEY (mate_prop_id) REFERENCES materials(id);\\012\\012insert into data_types\\012(id\\012 ,code\\012 ,description)\\012 values \\012 (nextval('DATA_TYPE_ID_SEQ')\\012 ,'MATERIAL'\\012 ,'Reference to a material'\\012);\\012\\012ALTER TABLE MATERIAL_PROPERTIES DROP CONSTRAINT MAPR_CK;\\012ALTER TABLE MATERIAL_PROPERTIES ADD CONSTRAINT MAPR_CK CHECK \\012\\011((VALUE IS NOT NULL AND CVTE_ID IS NULL AND MATE_PROP_ID IS NULL) OR \\012\\011 (VALUE IS NULL AND CVTE_ID IS NOT NULL AND MATE_PROP_ID IS NULL) OR\\012\\011 (VALUE IS NULL AND CVTE_ID IS NULL AND MATE_PROP_ID IS NOT NULL)\\012\\011);\\012\\012ALTER TABLE EXPERIMENT_PROPERTIES DROP CONSTRAINT EXPR_CK;\\012ALTER TABLE EXPERIMENT_PROPERTIES ADD CONSTRAINT EXPR_CK CHECK \\012\\011((VALUE IS NOT NULL AND CVTE_ID IS NULL AND MATE_PROP_ID IS NULL) OR \\012\\011 (VALUE IS NULL AND CVTE_ID IS NOT NULL AND MATE_PROP_ID IS NULL) OR\\012\\011 (VALUE IS NULL AND CVTE_ID IS NULL AND MATE_PROP_ID IS NOT NULL)\\012\\011);\\012\\012ALTER TABLE SAMPLE_PROPERTIES DROP CONSTRAINT SAPR_CK;\\012ALTER TABLE SAMPLE_PROPERTIES ADD CONSTRAINT SAPR_CK CHECK \\012\\011((VALUE IS NOT NULL AND CVTE_ID IS NULL AND MATE_PROP_ID IS NULL) OR \\012\\011 (VALUE IS NULL AND CVTE_ID IS NOT NULL AND MATE_PROP_ID IS NULL) OR\\012\\011 (VALUE IS NULL AND CVTE_ID IS NULL AND MATE_PROP_ID IS NOT NULL)\\012\\011);\\012\\012------------------------------------------------------------------------------------\\012--  Purpose:  Create trigger MATERIAL/SAMPLE/EXPERIMENT _PROPERTY_WITH_MATERIAL_DATA_TYPE_CHECK\\012--            It checks that if material property value is assigned to the entity,\\012--\\011\\011\\011\\011\\011\\011then the material type is equal to the one described by property type.\\012------------------------------------------------------------------------------------\\012\\012CREATE OR REPLACE FUNCTION MATERIAL_PROPERTY_WITH_MATERIAL_DATA_TYPE_CHECK() RETURNS trigger AS $$\\012DECLARE\\012   v_type_id  CODE;\\012   v_type_id_prop  CODE;\\012BEGIN\\012   if NEW.mate_prop_id IS NOT NULL then\\012\\011\\011\\011-- find material type id of the property type \\012\\011\\011\\011select pt.maty_prop_id into v_type_id_prop \\012\\011\\011\\011  from material_type_property_types etpt, property_types pt \\012\\011\\011\\011 where NEW.mtpt_id = etpt.id AND etpt.prty_id = pt.id;\\012\\011\\011\\012\\011\\011\\011if v_type_id_prop IS NOT NULL then\\012\\011\\011\\011\\011-- find material type id of the material which consists the entity's property value\\012\\011\\011\\011\\011select entity.maty_id into v_type_id \\012\\011\\011\\011\\011  from materials entity\\012\\011\\011\\011\\011 where NEW.mate_prop_id = entity.id;\\012\\011\\011\\011\\011if v_type_id != v_type_id_prop then\\012\\011\\011\\011\\011\\011RAISE EXCEPTION 'Insert/Update of property value referencing material (id: %) failed, as referenced material type is different than expected (id %, expected id: %).', \\012\\011\\011\\011\\011\\011\\011\\011 NEW.mate_prop_id, v_type_id, v_type_id_prop;\\012\\011\\011\\011\\011end if;\\012\\011\\011\\011end if;\\012   end if;\\012   RETURN NEW;\\012END;\\012$$ LANGUAGE 'plpgsql';\\012\\012CREATE TRIGGER MATERIAL_PROPERTY_WITH_MATERIAL_DATA_TYPE_CHECK BEFORE INSERT OR UPDATE ON material_properties\\012    FOR EACH ROW EXECUTE PROCEDURE MATERIAL_PROPERTY_WITH_MATERIAL_DATA_TYPE_CHECK();\\012    \\012CREATE OR REPLACE FUNCTION SAMPLE_PROPERTY_WITH_MATERIAL_DATA_TYPE_CHECK() RETURNS trigger AS $$\\012DECLARE\\012   v_type_id  CODE;\\012   v_type_id_prop  CODE;\\012BEGIN\\012   if NEW.mate_prop_id IS NOT NULL then\\012\\011\\011\\011-- find material type id of the property type \\012\\011\\011\\011select pt.maty_prop_id into v_type_id_prop \\012\\011\\011\\011  from sample_type_property_types etpt, property_types pt \\012\\011\\011\\011 where NEW.stpt_id = etpt.id AND etpt.prty_id = pt.id;\\012\\011\\011\\012\\011\\011\\011if v_type_id_prop IS NOT NULL then\\012\\011\\011\\011\\011-- find material type id of the material which consists the entity's property value\\012\\011\\011\\011\\011select entity.maty_id into v_type_id \\012\\011\\011\\011\\011  from materials entity\\012\\011\\011\\011\\011 where NEW.mate_prop_id = entity.id;\\012\\011\\011\\011\\011if v_type_id != v_type_id_prop then\\012\\011\\011\\011\\011\\011RAISE EXCEPTION 'Insert/Update of property value referencing material (id: %) failed, as referenced material type is different than expected (id %, expected id: %).', \\012\\011\\011\\011\\011\\011\\011\\011\\011\\011\\011\\011\\011 NEW.mate_prop_id, v_type_id, v_type_id_prop;\\012\\011\\011\\011\\011end if;\\012\\011\\011\\011end if;\\012   end if;\\012   RETURN NEW;\\012END;\\012$$ LANGUAGE 'plpgsql';\\012\\012CREATE TRIGGER SAMPLE_PROPERTY_WITH_MATERIAL_DATA_TYPE_CHECK BEFORE INSERT OR UPDATE ON sample_properties\\012    FOR EACH ROW EXECUTE PROCEDURE SAMPLE_PROPERTY_WITH_MATERIAL_DATA_TYPE_CHECK();\\012    \\012CREATE OR REPLACE FUNCTION EXPERIMENT_PROPERTY_WITH_MATERIAL_DATA_TYPE_CHECK() RETURNS trigger AS $$\\012DECLARE\\012   v_type_id  CODE;\\012   v_type_id_prop  CODE;\\012BEGIN\\012   if NEW.mate_prop_id IS NOT NULL then\\012\\011\\011\\011-- find material type id of the property type \\012\\011\\011\\011select pt.maty_prop_id into v_type_id_prop \\012\\011\\011\\011  from experiment_type_property_types etpt, property_types pt \\012\\011\\011\\011 where NEW.etpt_id = etpt.id AND etpt.prty_id = pt.id;\\012\\011\\011\\012\\011\\011\\011if v_type_id_prop IS NOT NULL then\\012\\011\\011\\011\\011-- find material type id of the material which consists the entity's property value\\012\\011\\011\\011\\011select entity.maty_id into v_type_id \\012\\011\\011\\011\\011  from materials entity\\012\\011\\011\\011\\011 where NEW.mate_prop_id = entity.id;\\012\\011\\011\\011\\011if v_type_id != v_type_id_prop then\\012\\011\\011\\011\\011\\011RAISE EXCEPTION 'Insert/Update of property value referencing material (id: %) failed, as referenced material type is different than expected (id %, expected id: %).', \\012\\011\\011\\011\\011\\011\\011\\011\\011\\011\\011\\011\\011 NEW.mate_prop_id, v_type_id, v_type_id_prop;\\012\\011\\011\\011\\011end if;\\012\\011\\011\\011end if;\\012   end if;\\012   RETURN NEW;\\012END;\\012$$ LANGUAGE 'plpgsql';\\012\\012CREATE TRIGGER EXPERIMENT_PROPERTY_WITH_MATERIAL_DATA_TYPE_CHECK BEFORE INSERT OR UPDATE ON experiment_properties\\012    FOR EACH ROW EXECUTE PROCEDURE EXPERIMENT_PROPERTY_WITH_MATERIAL_DATA_TYPE_CHECK();\\012       \\012-- -------\\012-- remove the reminescents of the OBSERVABLE_TYPE\\012-- -------\\012\\012ALTER TABLE data\\012\\011DROP CONSTRAINT data_obty_fk;\\012\\012ALTER TABLE data_set_types\\012\\011DROP CONSTRAINT obty_pk;\\012\\012ALTER TABLE data_set_types\\012\\011ADD CONSTRAINT dsty_pk PRIMARY KEY (id);\\012\\012ALTER TABLE data\\012\\011ADD CONSTRAINT data_dsty_fk FOREIGN KEY (dsty_id) REFERENCES data_set_types(id);\\012\\012ALTER TABLE data_set_types\\012\\011DROP CONSTRAINT obty_bk_uk;\\012\\012ALTER TABLE data_set_types\\012\\011DROP CONSTRAINT obty_dbin_fk;\\012\\012ALTER TABLE data_set_types\\012\\011ADD CONSTRAINT dsty_bk_uk UNIQUE (code, dbin_id);\\012\\012ALTER TABLE data_set_types\\012\\011ADD CONSTRAINT dsty_dbin_fk FOREIGN KEY (dbin_id) REFERENCES database_instances(id);\\012\\012DROP INDEX data_obty_fk_i;\\012\\012CREATE INDEX data_dsty_fk_i ON data(dsty_id);\\012	\N
+./sourceTest/sql/postgresql/038/015=database_version_logs.tsv:030	source/sql/postgresql/migration/migration-029-030.sql	SUCCESS	2009-03-23 15:34:44.72	-- -------\\012-- add modification_timestamp field to allow edition with Hibernate\\012-- -------\\012ALTER TABLE data\\012\\011ADD COLUMN modification_timestamp TIME_STAMP DEFAULT CURRENT_TIMESTAMP;\\012ALTER TABLE experiment_types\\012\\011ADD COLUMN modification_timestamp TIME_STAMP DEFAULT CURRENT_TIMESTAMP;\\012ALTER TABLE sample_types\\012\\011ADD COLUMN modification_timestamp TIME_STAMP DEFAULT CURRENT_TIMESTAMP;\\012ALTER TABLE material_types\\012\\011ADD COLUMN modification_timestamp TIME_STAMP DEFAULT CURRENT_TIMESTAMP;\\012ALTER TABLE data_set_types\\012\\011ADD COLUMN modification_timestamp TIME_STAMP DEFAULT CURRENT_TIMESTAMP;\\012ALTER TABLE controlled_vocabularies\\012\\011ADD COLUMN modification_timestamp TIME_STAMP DEFAULT CURRENT_TIMESTAMP;\\012-- -------\\012-- add properties to data sets\\012-- -------\\012CREATE TABLE DATA_SET_PROPERTIES (ID TECH_ID NOT NULL,DS_ID TECH_ID NOT NULL,DSTPT_ID TECH_ID NOT NULL,VALUE GENERIC_VALUE,CVTE_ID TECH_ID, MATE_PROP_ID TECH_ID, PERS_ID_REGISTERER TECH_ID NOT NULL,REGISTRATION_TIMESTAMP TIME_STAMP_DFL NOT NULL DEFAULT CURRENT_TIMESTAMP, MODIFICATION_TIMESTAMP TIME_STAMP DEFAULT CURRENT_TIMESTAMP);\\012CREATE TABLE DATA_SET_TYPE_PROPERTY_TYPES (ID TECH_ID NOT NULL,DSTY_ID TECH_ID NOT NULL,PRTY_ID TECH_ID NOT NULL,IS_MANDATORY BOOLEAN_CHAR NOT NULL DEFAULT 'F',IS_MANAGED_INTERNALLY BOOLEAN_CHAR NOT NULL DEFAULT 'F',PERS_ID_REGISTERER TECH_ID NOT NULL,REGISTRATION_TIMESTAMP TIME_STAMP_DFL NOT NULL DEFAULT CURRENT_TIMESTAMP);\\012\\012CREATE SEQUENCE DATA_SET_PROPERTY_ID_SEQ;\\012CREATE SEQUENCE DSTPT_ID_SEQ;\\012\\012ALTER TABLE DATA_SET_TYPE_PROPERTY_TYPES ADD CONSTRAINT DSTPT_PK PRIMARY KEY(ID);\\012ALTER TABLE DATA_SET_PROPERTIES ADD CONSTRAINT DSPR_PK PRIMARY KEY(ID);\\012\\012ALTER TABLE DATA_SET_TYPE_PROPERTY_TYPES ADD CONSTRAINT DSTPT_BK_UK UNIQUE(DSTY_ID,PRTY_ID);\\012ALTER TABLE DATA_SET_PROPERTIES ADD CONSTRAINT DSPR_BK_UK UNIQUE(DS_ID,DSTPT_ID);\\012\\012\\012ALTER TABLE DATA_SET_TYPE_PROPERTY_TYPES ADD CONSTRAINT DSTPT_DSTY_FK FOREIGN KEY (DSTY_ID) REFERENCES DATA_SET_TYPES(ID);\\012ALTER TABLE DATA_SET_TYPE_PROPERTY_TYPES ADD CONSTRAINT DSTPT_PERS_FK FOREIGN KEY (PERS_ID_REGISTERER) REFERENCES PERSONS(ID);\\012ALTER TABLE DATA_SET_TYPE_PROPERTY_TYPES ADD CONSTRAINT DSTPT_PRTY_FK FOREIGN KEY (PRTY_ID) REFERENCES PROPERTY_TYPES(ID);\\012ALTER TABLE DATA_SET_PROPERTIES ADD CONSTRAINT DSPR_CVTE_FK FOREIGN KEY (CVTE_ID) REFERENCES CONTROLLED_VOCABULARY_TERMS(ID);\\012ALTER TABLE DATA_SET_PROPERTIES ADD CONSTRAINT DSPR_DSTPT_FK FOREIGN KEY (DSTPT_ID) REFERENCES DATA_SET_TYPE_PROPERTY_TYPES(ID) ON DELETE CASCADE;\\012ALTER TABLE DATA_SET_PROPERTIES ADD CONSTRAINT DSPR_DS_FK FOREIGN KEY (DS_ID) REFERENCES DATA(ID);\\012ALTER TABLE DATA_SET_PROPERTIES ADD CONSTRAINT DSPR_PERS_FK FOREIGN KEY (PERS_ID_REGISTERER) REFERENCES PERSONS(ID);\\012ALTER TABLE DATA_SET_PROPERTIES ADD CONSTRAINT DSPR_MAPR_FK FOREIGN KEY (MATE_PROP_ID) REFERENCES MATERIALS(ID);\\012\\012ALTER TABLE DATA_SET_PROPERTIES ADD CONSTRAINT DSPR_CK CHECK \\012\\011((VALUE IS NOT NULL AND CVTE_ID IS NULL AND MATE_PROP_ID IS NULL) OR \\012\\011 (VALUE IS NULL AND CVTE_ID IS NOT NULL AND MATE_PROP_ID IS NULL) OR\\012\\011 (VALUE IS NULL AND CVTE_ID IS NULL AND MATE_PROP_ID IS NOT NULL)\\012\\011);\\012\\012CREATE INDEX DSPR_CVTE_FK_I ON DATA_SET_PROPERTIES (CVTE_ID);\\012CREATE INDEX DSPR_DSTPT_FK_I ON DATA_SET_PROPERTIES (DSTPT_ID);\\012CREATE INDEX DSPR_DS_FK_I ON DATA_SET_PROPERTIES (DS_ID);\\012CREATE INDEX DSPR_PERS_FK_I ON DATA_SET_PROPERTIES (PERS_ID_REGISTERER);\\012CREATE INDEX DSTPT_DSTY_FK_I ON DATA_SET_TYPE_PROPERTY_TYPES (DSTY_ID);\\012CREATE INDEX DSTPT_PERS_FK_I ON DATA_SET_TYPE_PROPERTY_TYPES (PERS_ID_REGISTERER);\\012CREATE INDEX DSTPT_PRTY_FK_I ON DATA_SET_TYPE_PROPERTY_TYPES (PRTY_ID);\\012\\012CREATE OR REPLACE FUNCTION DATA_SET_PROPERTY_WITH_MATERIAL_DATA_TYPE_CHECK() RETURNS trigger AS $$\\012DECLARE\\012   v_type_id  CODE;\\012   v_type_id_prop  CODE;\\012BEGIN\\012   if NEW.mate_prop_id IS NOT NULL then\\012\\011\\011\\011-- find material type id of the property type \\012\\011\\011\\011select pt.maty_prop_id into v_type_id_prop \\012\\011\\011\\011  from data_set_type_property_types dstpt, property_types pt \\012\\011\\011\\011 where NEW.dstpt_id = dstpt.id AND dstpt.prty_id = pt.id;\\012\\011\\011\\012\\011\\011\\011if v_type_id_prop IS NOT NULL then\\012\\011\\011\\011\\011-- find material type id of the material which consists the entity's property value\\012\\011\\011\\011\\011select entity.maty_id into v_type_id \\012\\011\\011\\011\\011  from materials entity\\012\\011\\011\\011\\011 where NEW.mate_prop_id = entity.id;\\012\\011\\011\\011\\011if v_type_id != v_type_id_prop then\\012\\011\\011\\011\\011\\011RAISE EXCEPTION 'Insert/Update of property value referencing material (id: %) failed, as referenced material type is different than expected (id %, expected id: %).', \\012\\011\\011\\011\\011\\011\\011\\011\\011\\011\\011\\011\\011 NEW.mate_prop_id, v_type_id, v_type_id_prop;\\012\\011\\011\\011\\011end if;\\012\\011\\011\\011end if;\\012   end if;\\012   RETURN NEW;\\012END;\\012$$ LANGUAGE 'plpgsql';\\012\\012CREATE TRIGGER DATA_SET_PROPERTY_WITH_MATERIAL_DATA_TYPE_CHECK BEFORE INSERT OR UPDATE ON data_set_properties\\012    FOR EACH ROW EXECUTE PROCEDURE DATA_SET_PROPERTY_WITH_MATERIAL_DATA_TYPE_CHECK();   \\012	\N
+./sourceTest/sql/postgresql/038/015=database_version_logs.tsv:032	source/sql/postgresql/migration/migration-031-032.sql	SUCCESS	2009-04-09 09:36:36.20	-- -------\\012-- Modify MATERIAL_BATCHES\\012-- -------\\012\\012ALTER TABLE material_batches\\012    DROP COLUMN proc_id;\\012\\012-- -------\\012-- Modify SAMPLES\\012-- -------\\012\\012ALTER TABLE samples\\012    ADD COLUMN expe_id tech_id;\\012\\012ALTER TABLE samples\\012    ADD CONSTRAINT samp_expe_fk FOREIGN KEY (expe_id) REFERENCES experiments(id);\\012\\012CREATE INDEX samp_expe_fk_i ON samples USING btree (expe_id);\\012\\012-- relink samples directly to experiments\\012\\012UPDATE samples\\012SET expe_id = (SELECT e.id FROM experiments e, procedures p, sample_inputs si \\012               WHERE si.samp_id = samples.id AND si.proc_id = p.id AND p.expe_id = e.id AND e.inva_id IS NULL);\\012\\012\\012-- -------\\012-- Modify DATA\\012-- -------\\012\\012ALTER TABLE data\\012    ADD COLUMN expe_id tech_id;\\012\\012ALTER TABLE data\\012    ADD CONSTRAINT data_expe_fk FOREIGN KEY (expe_id) REFERENCES experiments(id);\\012\\012CREATE INDEX data_expe_fk_i ON data USING btree (expe_id);\\012\\012UPDATE data\\012SET expe_id = (SELECT e.id FROM experiments e, procedures p \\012               WHERE data.proc_id_produced_by = p.id AND p.expe_id = e.id);\\012\\012ALTER TABLE data\\012    ALTER COLUMN expe_id SET NOT NULL;\\012\\012ALTER TABLE data\\012    DROP COLUMN proc_id_produced_by;\\012\\012-- -------\\012-- Drop PROCEDURES, PROCEDURE_TYPES, and SAMPLE_INPUTS\\012-- -------\\012\\012DROP TABLE sample_inputs;\\012DROP TABLE procedures;\\012DROP TABLE procedure_types;\\012\\012DROP SEQUENCE procedure_id_seq;\\012DROP SEQUENCE procedure_type_id_seq;\\012\\012-- -------\\012-- Add CODE_SEQ\\012-- -------\\012\\012CREATE SEQUENCE CODE_SEQ;\\012\\012-- -------\\012-- Add new columns to DATA_STORES\\012-- -------\\012\\012ALTER TABLE data_stores\\012    ADD COLUMN remote_url character varying(250),\\012    ADD COLUMN session_token character varying(50),\\012    ADD COLUMN modification_timestamp time_stamp DEFAULT now();\\012\\012UPDATE data_stores\\012SET remote_url = '', session_token='';\\012\\012ALTER TABLE data_stores\\012    ALTER COLUMN remote_url SET NOT NULL,\\012    ALTER COLUMN session_token SET NOT NULL;\\012\\012-- -------\\012-- Drop foreign keys onto DATA_STORES\\012-- -------\\012\\012ALTER TABLE database_instances\\012    DROP COLUMN dast_id;\\012\\012ALTER TABLE groups\\012    DROP COLUMN dast_id;\\012\\012ALTER TABLE projects\\012    DROP COLUMN dast_id;\\012\\012ALTER TABLE experiments\\012    DROP COLUMN dast_id;\\012\\012-- -------\\012-- Add foreign key from DATA onto DATA_STORES\\012-- -------\\012\\012ALTER TABLE data\\012    ADD COLUMN dast_id tech_id;\\012\\012ALTER TABLE data\\012    ADD CONSTRAINT data_dast_fk FOREIGN KEY (dast_id) REFERENCES data_stores(id);\\012\\012UPDATE data\\012SET dast_id = (select id from data_stores where code = 'STANDARD');\\012\\012ALTER TABLE data\\012    ALTER COLUMN dast_id SET NOT NULL;\\012\\012\\012------------------------------------------------------------------------------------\\012--  Purpose:  Replace trigger SAMPLE_CODE_UNIQUENESS_CHECK \\012------------------------------------------------------------------------------------\\012\\012CREATE OR REPLACE FUNCTION SAMPLE_CODE_UNIQUENESS_CHECK() RETURNS trigger AS $$\\012DECLARE\\012   counter  INTEGER;\\012BEGIN\\012    LOCK TABLE samples IN EXCLUSIVE MODE;\\012    IF (NEW.samp_id_part_of is NULL) THEN\\012        IF (NEW.dbin_id is not NULL) THEN\\012            SELECT count(*) into counter FROM samples \\012                where id != NEW.id and code = NEW.code and samp_id_part_of is NULL and dbin_id = NEW.dbin_id;\\012            IF (counter > 0) THEN\\012                RAISE EXCEPTION 'Insert/Update of Sample (Code: %) failed because database instance sample with the same code already exists.', NEW.code;\\012            END IF;\\012        ELSIF (NEW.grou_id is not NULL) THEN\\012            SELECT count(*) into counter FROM samples \\012                where id != NEW.id and code = NEW.code and samp_id_part_of is NULL and grou_id = NEW.grou_id;\\012            IF (counter > 0) THEN\\012                RAISE EXCEPTION 'Insert/Update of Sample (Code: %) failed because group sample with the same code already exists.', NEW.code;\\012            END IF;\\012        END IF;\\012        ELSE\\012        IF (NEW.dbin_id is not NULL) THEN\\012            SELECT count(*) into counter FROM samples \\012                where id != NEW.id and code = NEW.code and samp_id_part_of = NEW.samp_id_part_of and dbin_id = NEW.dbin_id;\\012            IF (counter > 0) THEN\\012                RAISE EXCEPTION 'Insert/Update of Sample (Code: %) failed because database instance sample with the same code and being the part of the same parent already exists.', NEW.code;\\012            END IF;\\012        ELSIF (NEW.grou_id is not NULL) THEN\\012            SELECT count(*) into counter FROM samples \\012                where id != NEW.id and code = NEW.code and samp_id_part_of = NEW.samp_id_part_of and grou_id = NEW.grou_id;\\012            IF (counter > 0) THEN\\012                RAISE EXCEPTION 'Insert/Update of Sample (Code: %) failed because group sample with the same code and being the part of the same parent already exists.', NEW.code;\\012            END IF;\\012        END IF;\\012        END IF;   \\012   RETURN NEW;\\012END;\\012$$ LANGUAGE 'plpgsql';\\012\\012\\012\\012	\N
+./sourceTest/sql/postgresql/038/015=database_version_logs.tsv:034	source/sql/postgresql/migration/migration-033-034.sql	SUCCESS	2009-05-26 08:32:49.935	------------------------------------------------------------------------------------\\012-- Create sequence for generating permanent identifiers starting with nextval of existing dataset sequence.\\012------------------------------------------------------------------------------------\\012CREATE FUNCTION CREATE_SEQUENCE(EXISTING_SEQUENCE VARCHAR, NEW_SEQUENCE VARCHAR) RETURNS VOID AS $$\\012DECLARE\\012  CURR_SEQ_VAL   INTEGER;\\012BEGIN\\012  SELECT INTO CURR_SEQ_VAL NEXTVAL(EXISTING_SEQUENCE);\\012  EXECUTE 'CREATE SEQUENCE ' || NEW_SEQUENCE || ' START WITH ' || CURR_SEQ_VAL;\\012  RETURN;\\012END;\\012$$ LANGUAGE 'plpgsql';\\012\\012SELECT CREATE_SEQUENCE('DATA_ID_SEQ', 'PERM_ID_SEQ');\\012DROP FUNCTION CREATE_SEQUENCE(VARCHAR, VARCHAR);\\012\\012------------------------------------------------------------------------------------\\012-- Add perm_id columns to samples and experiments.\\012------------------------------------------------------------------------------------\\012ALTER TABLE SAMPLES ADD COLUMN PERM_ID CODE;\\012ALTER TABLE EXPERIMENTS ADD COLUMN PERM_ID CODE;\\012\\012UPDATE SAMPLES SET PERM_ID = to_char(registration_timestamp,'YYYYMMDDHHSSMS') || '-' || NEXTVAL('PERM_ID_SEQ');\\012UPDATE EXPERIMENTS SET PERM_ID = to_char(registration_timestamp,'YYYYMMDDHHSSMS') || '-' || NEXTVAL('PERM_ID_SEQ');\\012ALTER TABLE SAMPLES ALTER COLUMN PERM_ID SET NOT NULL;\\012ALTER TABLE EXPERIMENTS ALTER COLUMN PERM_ID SET NOT NULL;\\012ALTER TABLE SAMPLES ADD CONSTRAINT SAMP_PI_UK UNIQUE(PERM_ID);\\012ALTER TABLE EXPERIMENTS ADD CONSTRAINT EXPE_PI_UK UNIQUE(PERM_ID);\\012\\012\\012------------------------------------------------------------------------------------\\012-- Add column is_chosen_from_list to controlled_vocabularies.\\012------------------------------------------------------------------------------------\\012ALTER TABLE controlled_vocabularies ADD COLUMN is_chosen_from_list BOOLEAN_CHAR NOT NULL DEFAULT TRUE;\\012ALTER TABLE controlled_vocabularies ADD COLUMN source_uri CHARACTER VARYING(250);\\012------------------------------------------------------------------------------------\\012-- Modify Data table - remove arc connection between Sample and Data table, use a flag instead\\012------------------------------------------------------------------------------------\\012\\012-- add new columns\\012\\012ALTER TABLE data\\012    ADD COLUMN is_derived boolean_char;\\012ALTER TABLE data\\012    ADD COLUMN samp_id tech_id;\\012\\012-- update values in new columns\\012\\012UPDATE data\\012    SET is_derived = (samp_id_derived_from IS NOT NULL); \\012UPDATE data\\012    SET samp_id = samp_id_derived_from \\012    WHERE is_derived = 'TRUE';\\012UPDATE data\\012    SET samp_id = samp_id_acquired_from \\012    WHERE is_derived = 'FALSE';\\012\\012-- add constraints and indexes to new columns\\012\\012ALTER TABLE data\\012    ALTER COLUMN is_derived SET NOT NULL;\\012ALTER TABLE data\\012    ALTER COLUMN samp_id SET NOT NULL;   \\012ALTER TABLE data\\012    ADD CONSTRAINT data_samp_fk FOREIGN KEY (samp_id) REFERENCES samples (id);\\012CREATE INDEX data_samp_fk_i ON data USING btree (samp_id);\\012\\012-- remove old columns\\012\\012ALTER TABLE data\\012    DROP COLUMN samp_id_acquired_from;\\012ALTER TABLE data\\012    DROP COLUMN samp_id_derived_from;\\012    \\012------------------------------------------------------------------------------------\\012-- Granting SELECT privilege to group openbis_readonly\\012------------------------------------------------------------------------------------\\012\\012GRANT SELECT ON SEQUENCE attachment_content_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE attachment_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE code_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE controlled_vocabulary_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE cvte_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE data_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE data_set_property_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE data_set_relationship_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE data_set_type_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE data_store_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE data_type_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE database_instance_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE dstpt_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE etpt_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE event_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE experiment_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE experiment_property_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE experiment_type_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE file_format_type_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE group_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE invalidation_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE locator_type_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE material_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE material_property_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE material_type_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE mtpt_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE perm_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE person_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE project_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE property_type_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE role_assignment_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE sample_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE sample_property_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE sample_type_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE stpt_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE attachment_contents TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE attachments TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE controlled_vocabularies TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE controlled_vocabulary_terms TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE data TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE data_set_properties TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE data_set_relationships TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE data_set_type_property_types TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE data_set_types TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE data_stores TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE data_types TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE database_instances TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE database_version_logs TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE events TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE experiment_properties TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE experiment_type_property_types TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE experiment_types TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE experiments TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE external_data TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE file_format_types TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE groups TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE invalidations TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE locator_types TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE material_properties TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE material_type_property_types TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE material_types TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE materials TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE persons TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE projects TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE property_types TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE role_assignments TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE sample_properties TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE sample_type_property_types TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE sample_types TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE samples TO GROUP OPENBIS_READONLY;\\012\\012------------------------------------------------------------------------------------\\012-- Delete MATERIAL_BATCHES table\\012------------------------------------------------------------------------------------\\012\\012-- WARNING: Potential data lost!!!\\012-- WARNING: Potential data lost!!!\\012-- WARNING: Potential data lost!!!\\012\\012DROP TABLE SAMPLE_MATERIAL_BATCHES;\\012DROP TABLE MATERIAL_BATCHES;\\012DROP SEQUENCE MATERIAL_BATCH_ID_SEQ;\\012\\012------------------------------------------------------------------------------------\\012-- Delete MATE_ID_INHIBITOR_OF from table MATERIALS\\012------------------------------------------------------------------------------------\\012\\012-- WARNING: Potential data lost!!!\\012-- WARNING: Potential data lost!!!\\012-- WARNING: Potential data lost!!!\\012\\012ALTER TABLE MATERIALS DROP COLUMN MATE_ID_INHIBITOR_OF;\\012	\N
+./sourceTest/sql/postgresql/038/schema-038.sql:    LANGUAGE plpgsql;
+./sourceTest/sql/postgresql/038/schema-038.sql:    LANGUAGE plpgsql;
+./sourceTest/sql/postgresql/038/schema-038.sql:    LANGUAGE plpgsql;
+./sourceTest/sql/postgresql/038/schema-038.sql:    LANGUAGE plpgsql;
+./sourceTest/sql/postgresql/038/schema-038.sql:    LANGUAGE plpgsql;
+./sourceTest/sql/postgresql/038/schema-038.sql:    LANGUAGE plpgsql;
+./sourceTest/sql/postgresql/038/schema-038.sql:    LANGUAGE plpgsql;
+./sourceTest/sql/postgresql/038/schema-038.sql:    LANGUAGE plpgsql;
+./sourceTest/sql/postgresql/039/.svn/text-base/017=database_version_logs.tsv.svn-base:027	D:\\User\\felmer\\dev-workspace\\openbis/source/sql/postgresql/027/function-027.sql	SUCCESS	2008-11-05 09:18:00.403	-- Creating Functions\\012\\012------------------------------------------------------------------------------------\\012--  Purpose:  Create function RENAME_SEQUENCE() that is required for renaming the sequences belonging to tables\\012------------------------------------------------------------------------------------\\012CREATE FUNCTION RENAME_SEQUENCE(OLD_NAME VARCHAR, NEW_NAME VARCHAR) RETURNS INTEGER AS $$\\012DECLARE\\012  CURR_SEQ_VAL   INTEGER;\\012BEGIN\\012  SELECT INTO CURR_SEQ_VAL NEXTVAL(OLD_NAME);\\012  EXECUTE 'CREATE SEQUENCE ' || NEW_NAME || ' START WITH ' || CURR_SEQ_VAL;\\012  EXECUTE 'DROP SEQUENCE ' || OLD_NAME;\\012  RETURN CURR_SEQ_VAL;\\012END;\\012$$ LANGUAGE 'plpgsql';\\012\\012\\012------------------------------------------------------------------------------------\\012--  Purpose:  Create trigger CONTROLLED_VOCABULARY_CHECK \\012------------------------------------------------------------------------------------\\012\\012CREATE OR REPLACE FUNCTION CONTROLLED_VOCABULARY_CHECK() RETURNS trigger AS $$\\012DECLARE\\012   v_code  CODE;\\012BEGIN\\012\\012   select code into v_code from data_types where id = NEW.daty_id;\\012\\012   -- Check if the data is of type "CONTROLLEDVOCABULARY"\\012   if v_code = 'CONTROLLEDVOCABULARY' then\\012      if NEW.covo_id IS NULL then\\012         RAISE EXCEPTION 'Insert/Update of Property Type (Code: %) failed, as its Data Type is CONTROLLEDVOCABULARY, but it is not linked to a Controlled Vocabulary.', NEW.code;\\012      end if;\\012   end if;\\012\\012   RETURN NEW;\\012\\012END;\\012$$ LANGUAGE 'plpgsql';\\012\\012CREATE TRIGGER CONTROLLED_VOCABULARY_CHECK BEFORE INSERT OR UPDATE ON PROPERTY_TYPES\\012    FOR EACH ROW EXECUTE PROCEDURE CONTROLLED_VOCABULARY_CHECK();\\012\\012\\012------------------------------------------------------------------------------------\\012--  Purpose:  Create trigger EXTERNAL_DATA_STORAGE_FORMAT_CHECK \\012------------------------------------------------------------------------------------\\012\\012CREATE OR REPLACE FUNCTION EXTERNAL_DATA_STORAGE_FORMAT_CHECK() RETURNS trigger AS $$\\012DECLARE\\012   v_covo_code  CODE;\\012   data_code CODE;\\012BEGIN\\012\\012   select code into v_covo_code from controlled_vocabularies\\012      where is_internal_namespace = true and \\012         id = (select covo_id from controlled_vocabulary_terms where id = NEW.cvte_id_stor_fmt);\\012   -- Check if the data storage format is a term of the controlled vocabulary "STORAGE_FORMAT"\\012   if v_covo_code != 'STORAGE_FORMAT' then\\012      select code into data_code from data where id = NEW.data_id; \\012      RAISE EXCEPTION 'Insert/Update of Data (Code: %) failed, as its Storage Format is %, but is required to be STORAGE_FORMAT.', data_code, v_covo_code;\\012   end if;\\012\\012   RETURN NEW;\\012\\012END;\\012$$ LANGUAGE 'plpgsql';\\012\\012CREATE TRIGGER EXTERNAL_DATA_STORAGE_FORMAT_CHECK BEFORE INSERT OR UPDATE ON EXTERNAL_DATA\\012    FOR EACH ROW EXECUTE PROCEDURE EXTERNAL_DATA_STORAGE_FORMAT_CHECK();\\012\\012------------------------------------------------------------------------------------\\012--  Purpose:  Create trigger SAMPLE_CODE_UNIQUENESS_CHECK \\012------------------------------------------------------------------------------------\\012\\012CREATE OR REPLACE FUNCTION SAMPLE_CODE_UNIQUENESS_CHECK() RETURNS trigger AS $$\\012DECLARE\\012   counter  INTEGER;\\012BEGIN\\012\\011IF (NEW.samp_id_part_of is NULL) THEN\\012\\011\\011IF (NEW.dbin_id is not NULL) THEN\\012\\011\\011\\011SELECT count(*) into counter FROM samples \\012\\011\\011\\011\\011where id != NEW.id and code = NEW.code and samp_id_part_of is NULL and dbin_id = NEW.dbin_id;\\012\\011\\011\\011IF (counter > 0) THEN\\012\\011\\011\\011\\011RAISE EXCEPTION 'Insert/Update of Sample (Code: %) failed because database instance sample with the same code already exists.', NEW.code;\\012\\011\\011\\011END IF;\\012\\011\\011ELSIF (NEW.grou_id is not NULL) THEN\\012\\011\\011\\011SELECT count(*) into counter FROM samples \\012\\011\\011\\011\\011where id != NEW.id and code = NEW.code and samp_id_part_of is NULL and grou_id = NEW.grou_id;\\012\\011\\011\\011IF (counter > 0) THEN\\012\\011\\011\\011\\011RAISE EXCEPTION 'Insert/Update of Sample (Code: %) failed because group sample with the same code already exists.', NEW.code;\\012\\011\\011\\011END IF;\\012\\011\\011END IF;\\012        ELSE\\012\\011\\011IF (NEW.dbin_id is not NULL) THEN\\012\\011\\011\\011SELECT count(*) into counter FROM samples \\012\\011\\011\\011\\011where id != NEW.id and code = NEW.code and samp_id_part_of = NEW.samp_id_part_of and dbin_id = NEW.dbin_id;\\012\\011\\011\\011IF (counter > 0) THEN\\012\\011\\011\\011\\011RAISE EXCEPTION 'Insert/Update of Sample (Code: %) failed because database instance sample with the same code and being the part of the same parent already exists.', NEW.code;\\012\\011\\011\\011END IF;\\012\\011\\011ELSIF (NEW.grou_id is not NULL) THEN\\012\\011\\011\\011SELECT count(*) into counter FROM samples \\012\\011\\011\\011\\011where id != NEW.id and code = NEW.code and samp_id_part_of = NEW.samp_id_part_of and grou_id = NEW.grou_id;\\012\\011\\011\\011IF (counter > 0) THEN\\012\\011\\011\\011\\011RAISE EXCEPTION 'Insert/Update of Sample (Code: %) failed because group sample with the same code and being the part of the same parent already exists.', NEW.code;\\012\\011\\011\\011END IF;\\012\\011\\011END IF;\\012        END IF;   \\012   RETURN NEW;\\012END;\\012$$ LANGUAGE 'plpgsql';\\012\\012CREATE TRIGGER SAMPLE_CODE_UNIQUENESS_CHECK BEFORE INSERT OR UPDATE ON SAMPLES\\012    FOR EACH ROW EXECUTE PROCEDURE SAMPLE_CODE_UNIQUENESS_CHECK();\\012	\N
+./sourceTest/sql/postgresql/039/.svn/text-base/017=database_version_logs.tsv.svn-base:028	source/sql/postgresql/migration/migration-027-028.sql	SUCCESS	2008-11-18 13:24:17.508	-- Create EXPERIMENT_ATTACHMENT_CONTENTS.\\012CREATE TABLE EXPERIMENT_ATTACHMENT_CONTENTS (ID TECH_ID NOT NULL,VALUE FILE NOT NULL);\\012CREATE SEQUENCE EXPERIMENT_ATTACHMENT_CONTENT_ID_SEQ;\\012ALTER TABLE EXPERIMENT_ATTACHMENT_CONTENTS ADD CONSTRAINT EXAC_PK PRIMARY KEY(ID);\\012\\012-- Alter EXPERIMENT_ATTACHMENTS by adding the new column which has a NULL constraint.\\012-- The NOT NULL constraint is added later on.\\012ALTER TABLE EXPERIMENT_ATTACHMENTS ADD COLUMN EXAC_ID TECH_ID;\\012\\012-- Does the VALUE migration between EXPERIMENT_ATTACHMENTS to EXPERIMENT_ATTACHMENT_CONTENTS.\\012CREATE OR REPLACE FUNCTION move_exp_att_content() RETURNS integer AS $$\\012DECLARE\\012    rec RECORD;\\012    seq BIGINT;\\012BEGIN\\012  FOR rec IN SELECT id, value FROM EXPERIMENT_ATTACHMENTS LOOP\\012  \\011seq := nextval('EXPERIMENT_ATTACHMENT_CONTENT_ID_SEQ');\\012    INSERT INTO EXPERIMENT_ATTACHMENT_CONTENTS (id, value) VALUES (seq, rec.value);\\012    UPDATE EXPERIMENT_ATTACHMENTS SET exac_id = seq WHERE id = rec.id;\\012  END LOOP;\\012  RETURN 1;\\012END;\\012$$ LANGUAGE 'plpgsql';\\012\\012-- Call the function.\\012SELECT move_exp_att_content();\\012DROP FUNCTION move_exp_att_content();\\012\\012\\012-- Finish EXPERIMENT_ATTACHMENTS changes.\\012ALTER TABLE EXPERIMENT_ATTACHMENTS ADD CONSTRAINT EXAT_CONT_FK FOREIGN KEY (EXAC_ID) REFERENCES EXPERIMENT_ATTACHMENT_CONTENTS(ID);\\012ALTER TABLE EXPERIMENT_ATTACHMENTS DROP COLUMN VALUE;\\012ALTER TABLE EXPERIMENT_ATTACHMENTS ALTER COLUMN EXAC_ID SET NOT NULL;\\012	\N
+./sourceTest/sql/postgresql/039/.svn/text-base/017=database_version_logs.tsv.svn-base:029	source/sql/postgresql/migration/migration-028-029.sql	SUCCESS	2009-03-18 10:50:20.105	-- -------\\012-- add modification_timestamp field to allow edition with Hibernate\\012-- -------\\012\\012ALTER TABLE samples\\012\\011ADD COLUMN modification_timestamp TIME_STAMP DEFAULT CURRENT_TIMESTAMP;\\012\\012ALTER TABLE experiments\\012\\011ADD COLUMN modification_timestamp TIME_STAMP DEFAULT CURRENT_TIMESTAMP;\\012\\012ALTER TABLE materials\\012\\011ADD COLUMN modification_timestamp TIME_STAMP DEFAULT CURRENT_TIMESTAMP;\\012\\012ALTER TABLE experiment_properties\\012\\011ADD COLUMN modification_timestamp TIME_STAMP DEFAULT CURRENT_TIMESTAMP;\\012\\012ALTER TABLE material_properties\\012\\011ADD COLUMN modification_timestamp TIME_STAMP DEFAULT CURRENT_TIMESTAMP;\\012\\012ALTER TABLE sample_properties\\012\\011ADD COLUMN modification_timestamp TIME_STAMP DEFAULT CURRENT_TIMESTAMP;\\012\\012-- -------\\012-- add property data type which references materials\\012-- -------\\012\\012ALTER TABLE property_types\\012\\011ADD COLUMN maty_prop_id tech_id;\\012\\012ALTER TABLE property_types\\012\\011ADD CONSTRAINT prty_maty_fk FOREIGN KEY (maty_prop_id) REFERENCES material_types(id);\\012\\012ALTER TABLE experiment_properties\\012\\011ADD COLUMN mate_prop_id tech_id;\\012\\012ALTER TABLE material_properties\\012\\011ADD COLUMN mate_prop_id tech_id;\\012\\012ALTER TABLE sample_properties\\012\\011ADD COLUMN mate_prop_id tech_id;\\012\\012ALTER TABLE experiment_properties\\012\\011ADD CONSTRAINT expr_mapr_fk FOREIGN KEY (mate_prop_id) REFERENCES materials(id);\\012\\012ALTER TABLE material_properties\\012\\011ADD CONSTRAINT mapr_mapr_fk FOREIGN KEY (mate_prop_id) REFERENCES materials(id);\\012\\012ALTER TABLE sample_properties\\012\\011ADD CONSTRAINT sapr_mapr_fk FOREIGN KEY (mate_prop_id) REFERENCES materials(id);\\012\\012insert into data_types\\012(id\\012 ,code\\012 ,description)\\012 values \\012 (nextval('DATA_TYPE_ID_SEQ')\\012 ,'MATERIAL'\\012 ,'Reference to a material'\\012);\\012\\012ALTER TABLE MATERIAL_PROPERTIES DROP CONSTRAINT MAPR_CK;\\012ALTER TABLE MATERIAL_PROPERTIES ADD CONSTRAINT MAPR_CK CHECK \\012\\011((VALUE IS NOT NULL AND CVTE_ID IS NULL AND MATE_PROP_ID IS NULL) OR \\012\\011 (VALUE IS NULL AND CVTE_ID IS NOT NULL AND MATE_PROP_ID IS NULL) OR\\012\\011 (VALUE IS NULL AND CVTE_ID IS NULL AND MATE_PROP_ID IS NOT NULL)\\012\\011);\\012\\012ALTER TABLE EXPERIMENT_PROPERTIES DROP CONSTRAINT EXPR_CK;\\012ALTER TABLE EXPERIMENT_PROPERTIES ADD CONSTRAINT EXPR_CK CHECK \\012\\011((VALUE IS NOT NULL AND CVTE_ID IS NULL AND MATE_PROP_ID IS NULL) OR \\012\\011 (VALUE IS NULL AND CVTE_ID IS NOT NULL AND MATE_PROP_ID IS NULL) OR\\012\\011 (VALUE IS NULL AND CVTE_ID IS NULL AND MATE_PROP_ID IS NOT NULL)\\012\\011);\\012\\012ALTER TABLE SAMPLE_PROPERTIES DROP CONSTRAINT SAPR_CK;\\012ALTER TABLE SAMPLE_PROPERTIES ADD CONSTRAINT SAPR_CK CHECK \\012\\011((VALUE IS NOT NULL AND CVTE_ID IS NULL AND MATE_PROP_ID IS NULL) OR \\012\\011 (VALUE IS NULL AND CVTE_ID IS NOT NULL AND MATE_PROP_ID IS NULL) OR\\012\\011 (VALUE IS NULL AND CVTE_ID IS NULL AND MATE_PROP_ID IS NOT NULL)\\012\\011);\\012\\012------------------------------------------------------------------------------------\\012--  Purpose:  Create trigger MATERIAL/SAMPLE/EXPERIMENT _PROPERTY_WITH_MATERIAL_DATA_TYPE_CHECK\\012--            It checks that if material property value is assigned to the entity,\\012--\\011\\011\\011\\011\\011\\011then the material type is equal to the one described by property type.\\012------------------------------------------------------------------------------------\\012\\012CREATE OR REPLACE FUNCTION MATERIAL_PROPERTY_WITH_MATERIAL_DATA_TYPE_CHECK() RETURNS trigger AS $$\\012DECLARE\\012   v_type_id  CODE;\\012   v_type_id_prop  CODE;\\012BEGIN\\012   if NEW.mate_prop_id IS NOT NULL then\\012\\011\\011\\011-- find material type id of the property type \\012\\011\\011\\011select pt.maty_prop_id into v_type_id_prop \\012\\011\\011\\011  from material_type_property_types etpt, property_types pt \\012\\011\\011\\011 where NEW.mtpt_id = etpt.id AND etpt.prty_id = pt.id;\\012\\011\\011\\012\\011\\011\\011if v_type_id_prop IS NOT NULL then\\012\\011\\011\\011\\011-- find material type id of the material which consists the entity's property value\\012\\011\\011\\011\\011select entity.maty_id into v_type_id \\012\\011\\011\\011\\011  from materials entity\\012\\011\\011\\011\\011 where NEW.mate_prop_id = entity.id;\\012\\011\\011\\011\\011if v_type_id != v_type_id_prop then\\012\\011\\011\\011\\011\\011RAISE EXCEPTION 'Insert/Update of property value referencing material (id: %) failed, as referenced material type is different than expected (id %, expected id: %).', \\012\\011\\011\\011\\011\\011\\011\\011 NEW.mate_prop_id, v_type_id, v_type_id_prop;\\012\\011\\011\\011\\011end if;\\012\\011\\011\\011end if;\\012   end if;\\012   RETURN NEW;\\012END;\\012$$ LANGUAGE 'plpgsql';\\012\\012CREATE TRIGGER MATERIAL_PROPERTY_WITH_MATERIAL_DATA_TYPE_CHECK BEFORE INSERT OR UPDATE ON material_properties\\012    FOR EACH ROW EXECUTE PROCEDURE MATERIAL_PROPERTY_WITH_MATERIAL_DATA_TYPE_CHECK();\\012    \\012CREATE OR REPLACE FUNCTION SAMPLE_PROPERTY_WITH_MATERIAL_DATA_TYPE_CHECK() RETURNS trigger AS $$\\012DECLARE\\012   v_type_id  CODE;\\012   v_type_id_prop  CODE;\\012BEGIN\\012   if NEW.mate_prop_id IS NOT NULL then\\012\\011\\011\\011-- find material type id of the property type \\012\\011\\011\\011select pt.maty_prop_id into v_type_id_prop \\012\\011\\011\\011  from sample_type_property_types etpt, property_types pt \\012\\011\\011\\011 where NEW.stpt_id = etpt.id AND etpt.prty_id = pt.id;\\012\\011\\011\\012\\011\\011\\011if v_type_id_prop IS NOT NULL then\\012\\011\\011\\011\\011-- find material type id of the material which consists the entity's property value\\012\\011\\011\\011\\011select entity.maty_id into v_type_id \\012\\011\\011\\011\\011  from materials entity\\012\\011\\011\\011\\011 where NEW.mate_prop_id = entity.id;\\012\\011\\011\\011\\011if v_type_id != v_type_id_prop then\\012\\011\\011\\011\\011\\011RAISE EXCEPTION 'Insert/Update of property value referencing material (id: %) failed, as referenced material type is different than expected (id %, expected id: %).', \\012\\011\\011\\011\\011\\011\\011\\011\\011\\011\\011\\011\\011 NEW.mate_prop_id, v_type_id, v_type_id_prop;\\012\\011\\011\\011\\011end if;\\012\\011\\011\\011end if;\\012   end if;\\012   RETURN NEW;\\012END;\\012$$ LANGUAGE 'plpgsql';\\012\\012CREATE TRIGGER SAMPLE_PROPERTY_WITH_MATERIAL_DATA_TYPE_CHECK BEFORE INSERT OR UPDATE ON sample_properties\\012    FOR EACH ROW EXECUTE PROCEDURE SAMPLE_PROPERTY_WITH_MATERIAL_DATA_TYPE_CHECK();\\012    \\012CREATE OR REPLACE FUNCTION EXPERIMENT_PROPERTY_WITH_MATERIAL_DATA_TYPE_CHECK() RETURNS trigger AS $$\\012DECLARE\\012   v_type_id  CODE;\\012   v_type_id_prop  CODE;\\012BEGIN\\012   if NEW.mate_prop_id IS NOT NULL then\\012\\011\\011\\011-- find material type id of the property type \\012\\011\\011\\011select pt.maty_prop_id into v_type_id_prop \\012\\011\\011\\011  from experiment_type_property_types etpt, property_types pt \\012\\011\\011\\011 where NEW.etpt_id = etpt.id AND etpt.prty_id = pt.id;\\012\\011\\011\\012\\011\\011\\011if v_type_id_prop IS NOT NULL then\\012\\011\\011\\011\\011-- find material type id of the material which consists the entity's property value\\012\\011\\011\\011\\011select entity.maty_id into v_type_id \\012\\011\\011\\011\\011  from materials entity\\012\\011\\011\\011\\011 where NEW.mate_prop_id = entity.id;\\012\\011\\011\\011\\011if v_type_id != v_type_id_prop then\\012\\011\\011\\011\\011\\011RAISE EXCEPTION 'Insert/Update of property value referencing material (id: %) failed, as referenced material type is different than expected (id %, expected id: %).', \\012\\011\\011\\011\\011\\011\\011\\011\\011\\011\\011\\011\\011 NEW.mate_prop_id, v_type_id, v_type_id_prop;\\012\\011\\011\\011\\011end if;\\012\\011\\011\\011end if;\\012   end if;\\012   RETURN NEW;\\012END;\\012$$ LANGUAGE 'plpgsql';\\012\\012CREATE TRIGGER EXPERIMENT_PROPERTY_WITH_MATERIAL_DATA_TYPE_CHECK BEFORE INSERT OR UPDATE ON experiment_properties\\012    FOR EACH ROW EXECUTE PROCEDURE EXPERIMENT_PROPERTY_WITH_MATERIAL_DATA_TYPE_CHECK();\\012       \\012-- -------\\012-- remove the reminescents of the OBSERVABLE_TYPE\\012-- -------\\012\\012ALTER TABLE data\\012\\011DROP CONSTRAINT data_obty_fk;\\012\\012ALTER TABLE data_set_types\\012\\011DROP CONSTRAINT obty_pk;\\012\\012ALTER TABLE data_set_types\\012\\011ADD CONSTRAINT dsty_pk PRIMARY KEY (id);\\012\\012ALTER TABLE data\\012\\011ADD CONSTRAINT data_dsty_fk FOREIGN KEY (dsty_id) REFERENCES data_set_types(id);\\012\\012ALTER TABLE data_set_types\\012\\011DROP CONSTRAINT obty_bk_uk;\\012\\012ALTER TABLE data_set_types\\012\\011DROP CONSTRAINT obty_dbin_fk;\\012\\012ALTER TABLE data_set_types\\012\\011ADD CONSTRAINT dsty_bk_uk UNIQUE (code, dbin_id);\\012\\012ALTER TABLE data_set_types\\012\\011ADD CONSTRAINT dsty_dbin_fk FOREIGN KEY (dbin_id) REFERENCES database_instances(id);\\012\\012DROP INDEX data_obty_fk_i;\\012\\012CREATE INDEX data_dsty_fk_i ON data(dsty_id);\\012	\N
+./sourceTest/sql/postgresql/039/.svn/text-base/017=database_version_logs.tsv.svn-base:030	source/sql/postgresql/migration/migration-029-030.sql	SUCCESS	2009-03-23 15:34:44.72	-- -------\\012-- add modification_timestamp field to allow edition with Hibernate\\012-- -------\\012ALTER TABLE data\\012\\011ADD COLUMN modification_timestamp TIME_STAMP DEFAULT CURRENT_TIMESTAMP;\\012ALTER TABLE experiment_types\\012\\011ADD COLUMN modification_timestamp TIME_STAMP DEFAULT CURRENT_TIMESTAMP;\\012ALTER TABLE sample_types\\012\\011ADD COLUMN modification_timestamp TIME_STAMP DEFAULT CURRENT_TIMESTAMP;\\012ALTER TABLE material_types\\012\\011ADD COLUMN modification_timestamp TIME_STAMP DEFAULT CURRENT_TIMESTAMP;\\012ALTER TABLE data_set_types\\012\\011ADD COLUMN modification_timestamp TIME_STAMP DEFAULT CURRENT_TIMESTAMP;\\012ALTER TABLE controlled_vocabularies\\012\\011ADD COLUMN modification_timestamp TIME_STAMP DEFAULT CURRENT_TIMESTAMP;\\012-- -------\\012-- add properties to data sets\\012-- -------\\012CREATE TABLE DATA_SET_PROPERTIES (ID TECH_ID NOT NULL,DS_ID TECH_ID NOT NULL,DSTPT_ID TECH_ID NOT NULL,VALUE GENERIC_VALUE,CVTE_ID TECH_ID, MATE_PROP_ID TECH_ID, PERS_ID_REGISTERER TECH_ID NOT NULL,REGISTRATION_TIMESTAMP TIME_STAMP_DFL NOT NULL DEFAULT CURRENT_TIMESTAMP, MODIFICATION_TIMESTAMP TIME_STAMP DEFAULT CURRENT_TIMESTAMP);\\012CREATE TABLE DATA_SET_TYPE_PROPERTY_TYPES (ID TECH_ID NOT NULL,DSTY_ID TECH_ID NOT NULL,PRTY_ID TECH_ID NOT NULL,IS_MANDATORY BOOLEAN_CHAR NOT NULL DEFAULT 'F',IS_MANAGED_INTERNALLY BOOLEAN_CHAR NOT NULL DEFAULT 'F',PERS_ID_REGISTERER TECH_ID NOT NULL,REGISTRATION_TIMESTAMP TIME_STAMP_DFL NOT NULL DEFAULT CURRENT_TIMESTAMP);\\012\\012CREATE SEQUENCE DATA_SET_PROPERTY_ID_SEQ;\\012CREATE SEQUENCE DSTPT_ID_SEQ;\\012\\012ALTER TABLE DATA_SET_TYPE_PROPERTY_TYPES ADD CONSTRAINT DSTPT_PK PRIMARY KEY(ID);\\012ALTER TABLE DATA_SET_PROPERTIES ADD CONSTRAINT DSPR_PK PRIMARY KEY(ID);\\012\\012ALTER TABLE DATA_SET_TYPE_PROPERTY_TYPES ADD CONSTRAINT DSTPT_BK_UK UNIQUE(DSTY_ID,PRTY_ID);\\012ALTER TABLE DATA_SET_PROPERTIES ADD CONSTRAINT DSPR_BK_UK UNIQUE(DS_ID,DSTPT_ID);\\012\\012\\012ALTER TABLE DATA_SET_TYPE_PROPERTY_TYPES ADD CONSTRAINT DSTPT_DSTY_FK FOREIGN KEY (DSTY_ID) REFERENCES DATA_SET_TYPES(ID);\\012ALTER TABLE DATA_SET_TYPE_PROPERTY_TYPES ADD CONSTRAINT DSTPT_PERS_FK FOREIGN KEY (PERS_ID_REGISTERER) REFERENCES PERSONS(ID);\\012ALTER TABLE DATA_SET_TYPE_PROPERTY_TYPES ADD CONSTRAINT DSTPT_PRTY_FK FOREIGN KEY (PRTY_ID) REFERENCES PROPERTY_TYPES(ID);\\012ALTER TABLE DATA_SET_PROPERTIES ADD CONSTRAINT DSPR_CVTE_FK FOREIGN KEY (CVTE_ID) REFERENCES CONTROLLED_VOCABULARY_TERMS(ID);\\012ALTER TABLE DATA_SET_PROPERTIES ADD CONSTRAINT DSPR_DSTPT_FK FOREIGN KEY (DSTPT_ID) REFERENCES DATA_SET_TYPE_PROPERTY_TYPES(ID) ON DELETE CASCADE;\\012ALTER TABLE DATA_SET_PROPERTIES ADD CONSTRAINT DSPR_DS_FK FOREIGN KEY (DS_ID) REFERENCES DATA(ID);\\012ALTER TABLE DATA_SET_PROPERTIES ADD CONSTRAINT DSPR_PERS_FK FOREIGN KEY (PERS_ID_REGISTERER) REFERENCES PERSONS(ID);\\012ALTER TABLE DATA_SET_PROPERTIES ADD CONSTRAINT DSPR_MAPR_FK FOREIGN KEY (MATE_PROP_ID) REFERENCES MATERIALS(ID);\\012\\012ALTER TABLE DATA_SET_PROPERTIES ADD CONSTRAINT DSPR_CK CHECK \\012\\011((VALUE IS NOT NULL AND CVTE_ID IS NULL AND MATE_PROP_ID IS NULL) OR \\012\\011 (VALUE IS NULL AND CVTE_ID IS NOT NULL AND MATE_PROP_ID IS NULL) OR\\012\\011 (VALUE IS NULL AND CVTE_ID IS NULL AND MATE_PROP_ID IS NOT NULL)\\012\\011);\\012\\012CREATE INDEX DSPR_CVTE_FK_I ON DATA_SET_PROPERTIES (CVTE_ID);\\012CREATE INDEX DSPR_DSTPT_FK_I ON DATA_SET_PROPERTIES (DSTPT_ID);\\012CREATE INDEX DSPR_DS_FK_I ON DATA_SET_PROPERTIES (DS_ID);\\012CREATE INDEX DSPR_PERS_FK_I ON DATA_SET_PROPERTIES (PERS_ID_REGISTERER);\\012CREATE INDEX DSTPT_DSTY_FK_I ON DATA_SET_TYPE_PROPERTY_TYPES (DSTY_ID);\\012CREATE INDEX DSTPT_PERS_FK_I ON DATA_SET_TYPE_PROPERTY_TYPES (PERS_ID_REGISTERER);\\012CREATE INDEX DSTPT_PRTY_FK_I ON DATA_SET_TYPE_PROPERTY_TYPES (PRTY_ID);\\012\\012CREATE OR REPLACE FUNCTION DATA_SET_PROPERTY_WITH_MATERIAL_DATA_TYPE_CHECK() RETURNS trigger AS $$\\012DECLARE\\012   v_type_id  CODE;\\012   v_type_id_prop  CODE;\\012BEGIN\\012   if NEW.mate_prop_id IS NOT NULL then\\012\\011\\011\\011-- find material type id of the property type \\012\\011\\011\\011select pt.maty_prop_id into v_type_id_prop \\012\\011\\011\\011  from data_set_type_property_types dstpt, property_types pt \\012\\011\\011\\011 where NEW.dstpt_id = dstpt.id AND dstpt.prty_id = pt.id;\\012\\011\\011\\012\\011\\011\\011if v_type_id_prop IS NOT NULL then\\012\\011\\011\\011\\011-- find material type id of the material which consists the entity's property value\\012\\011\\011\\011\\011select entity.maty_id into v_type_id \\012\\011\\011\\011\\011  from materials entity\\012\\011\\011\\011\\011 where NEW.mate_prop_id = entity.id;\\012\\011\\011\\011\\011if v_type_id != v_type_id_prop then\\012\\011\\011\\011\\011\\011RAISE EXCEPTION 'Insert/Update of property value referencing material (id: %) failed, as referenced material type is different than expected (id %, expected id: %).', \\012\\011\\011\\011\\011\\011\\011\\011\\011\\011\\011\\011\\011 NEW.mate_prop_id, v_type_id, v_type_id_prop;\\012\\011\\011\\011\\011end if;\\012\\011\\011\\011end if;\\012   end if;\\012   RETURN NEW;\\012END;\\012$$ LANGUAGE 'plpgsql';\\012\\012CREATE TRIGGER DATA_SET_PROPERTY_WITH_MATERIAL_DATA_TYPE_CHECK BEFORE INSERT OR UPDATE ON data_set_properties\\012    FOR EACH ROW EXECUTE PROCEDURE DATA_SET_PROPERTY_WITH_MATERIAL_DATA_TYPE_CHECK();   \\012	\N
+./sourceTest/sql/postgresql/039/.svn/text-base/017=database_version_logs.tsv.svn-base:032	source/sql/postgresql/migration/migration-031-032.sql	SUCCESS	2009-04-09 09:36:36.20	-- -------\\012-- Modify MATERIAL_BATCHES\\012-- -------\\012\\012ALTER TABLE material_batches\\012    DROP COLUMN proc_id;\\012\\012-- -------\\012-- Modify SAMPLES\\012-- -------\\012\\012ALTER TABLE samples\\012    ADD COLUMN expe_id tech_id;\\012\\012ALTER TABLE samples\\012    ADD CONSTRAINT samp_expe_fk FOREIGN KEY (expe_id) REFERENCES experiments(id);\\012\\012CREATE INDEX samp_expe_fk_i ON samples USING btree (expe_id);\\012\\012-- relink samples directly to experiments\\012\\012UPDATE samples\\012SET expe_id = (SELECT e.id FROM experiments e, procedures p, sample_inputs si \\012               WHERE si.samp_id = samples.id AND si.proc_id = p.id AND p.expe_id = e.id AND e.inva_id IS NULL);\\012\\012\\012-- -------\\012-- Modify DATA\\012-- -------\\012\\012ALTER TABLE data\\012    ADD COLUMN expe_id tech_id;\\012\\012ALTER TABLE data\\012    ADD CONSTRAINT data_expe_fk FOREIGN KEY (expe_id) REFERENCES experiments(id);\\012\\012CREATE INDEX data_expe_fk_i ON data USING btree (expe_id);\\012\\012UPDATE data\\012SET expe_id = (SELECT e.id FROM experiments e, procedures p \\012               WHERE data.proc_id_produced_by = p.id AND p.expe_id = e.id);\\012\\012ALTER TABLE data\\012    ALTER COLUMN expe_id SET NOT NULL;\\012\\012ALTER TABLE data\\012    DROP COLUMN proc_id_produced_by;\\012\\012-- -------\\012-- Drop PROCEDURES, PROCEDURE_TYPES, and SAMPLE_INPUTS\\012-- -------\\012\\012DROP TABLE sample_inputs;\\012DROP TABLE procedures;\\012DROP TABLE procedure_types;\\012\\012DROP SEQUENCE procedure_id_seq;\\012DROP SEQUENCE procedure_type_id_seq;\\012\\012-- -------\\012-- Add CODE_SEQ\\012-- -------\\012\\012CREATE SEQUENCE CODE_SEQ;\\012\\012-- -------\\012-- Add new columns to DATA_STORES\\012-- -------\\012\\012ALTER TABLE data_stores\\012    ADD COLUMN remote_url character varying(250),\\012    ADD COLUMN session_token character varying(50),\\012    ADD COLUMN modification_timestamp time_stamp DEFAULT now();\\012\\012UPDATE data_stores\\012SET remote_url = '', session_token='';\\012\\012ALTER TABLE data_stores\\012    ALTER COLUMN remote_url SET NOT NULL,\\012    ALTER COLUMN session_token SET NOT NULL;\\012\\012-- -------\\012-- Drop foreign keys onto DATA_STORES\\012-- -------\\012\\012ALTER TABLE database_instances\\012    DROP COLUMN dast_id;\\012\\012ALTER TABLE groups\\012    DROP COLUMN dast_id;\\012\\012ALTER TABLE projects\\012    DROP COLUMN dast_id;\\012\\012ALTER TABLE experiments\\012    DROP COLUMN dast_id;\\012\\012-- -------\\012-- Add foreign key from DATA onto DATA_STORES\\012-- -------\\012\\012ALTER TABLE data\\012    ADD COLUMN dast_id tech_id;\\012\\012ALTER TABLE data\\012    ADD CONSTRAINT data_dast_fk FOREIGN KEY (dast_id) REFERENCES data_stores(id);\\012\\012UPDATE data\\012SET dast_id = (select id from data_stores where code = 'STANDARD');\\012\\012ALTER TABLE data\\012    ALTER COLUMN dast_id SET NOT NULL;\\012\\012\\012------------------------------------------------------------------------------------\\012--  Purpose:  Replace trigger SAMPLE_CODE_UNIQUENESS_CHECK \\012------------------------------------------------------------------------------------\\012\\012CREATE OR REPLACE FUNCTION SAMPLE_CODE_UNIQUENESS_CHECK() RETURNS trigger AS $$\\012DECLARE\\012   counter  INTEGER;\\012BEGIN\\012    LOCK TABLE samples IN EXCLUSIVE MODE;\\012    IF (NEW.samp_id_part_of is NULL) THEN\\012        IF (NEW.dbin_id is not NULL) THEN\\012            SELECT count(*) into counter FROM samples \\012                where id != NEW.id and code = NEW.code and samp_id_part_of is NULL and dbin_id = NEW.dbin_id;\\012            IF (counter > 0) THEN\\012                RAISE EXCEPTION 'Insert/Update of Sample (Code: %) failed because database instance sample with the same code already exists.', NEW.code;\\012            END IF;\\012        ELSIF (NEW.grou_id is not NULL) THEN\\012            SELECT count(*) into counter FROM samples \\012                where id != NEW.id and code = NEW.code and samp_id_part_of is NULL and grou_id = NEW.grou_id;\\012            IF (counter > 0) THEN\\012                RAISE EXCEPTION 'Insert/Update of Sample (Code: %) failed because group sample with the same code already exists.', NEW.code;\\012            END IF;\\012        END IF;\\012        ELSE\\012        IF (NEW.dbin_id is not NULL) THEN\\012            SELECT count(*) into counter FROM samples \\012                where id != NEW.id and code = NEW.code and samp_id_part_of = NEW.samp_id_part_of and dbin_id = NEW.dbin_id;\\012            IF (counter > 0) THEN\\012                RAISE EXCEPTION 'Insert/Update of Sample (Code: %) failed because database instance sample with the same code and being the part of the same parent already exists.', NEW.code;\\012            END IF;\\012        ELSIF (NEW.grou_id is not NULL) THEN\\012            SELECT count(*) into counter FROM samples \\012                where id != NEW.id and code = NEW.code and samp_id_part_of = NEW.samp_id_part_of and grou_id = NEW.grou_id;\\012            IF (counter > 0) THEN\\012                RAISE EXCEPTION 'Insert/Update of Sample (Code: %) failed because group sample with the same code and being the part of the same parent already exists.', NEW.code;\\012            END IF;\\012        END IF;\\012        END IF;   \\012   RETURN NEW;\\012END;\\012$$ LANGUAGE 'plpgsql';\\012\\012\\012\\012	\N
+./sourceTest/sql/postgresql/039/.svn/text-base/017=database_version_logs.tsv.svn-base:034	source/sql/postgresql/migration/migration-033-034.sql	SUCCESS	2009-05-26 08:32:49.935	------------------------------------------------------------------------------------\\012-- Create sequence for generating permanent identifiers starting with nextval of existing dataset sequence.\\012------------------------------------------------------------------------------------\\012CREATE FUNCTION CREATE_SEQUENCE(EXISTING_SEQUENCE VARCHAR, NEW_SEQUENCE VARCHAR) RETURNS VOID AS $$\\012DECLARE\\012  CURR_SEQ_VAL   INTEGER;\\012BEGIN\\012  SELECT INTO CURR_SEQ_VAL NEXTVAL(EXISTING_SEQUENCE);\\012  EXECUTE 'CREATE SEQUENCE ' || NEW_SEQUENCE || ' START WITH ' || CURR_SEQ_VAL;\\012  RETURN;\\012END;\\012$$ LANGUAGE 'plpgsql';\\012\\012SELECT CREATE_SEQUENCE('DATA_ID_SEQ', 'PERM_ID_SEQ');\\012DROP FUNCTION CREATE_SEQUENCE(VARCHAR, VARCHAR);\\012\\012------------------------------------------------------------------------------------\\012-- Add perm_id columns to samples and experiments.\\012------------------------------------------------------------------------------------\\012ALTER TABLE SAMPLES ADD COLUMN PERM_ID CODE;\\012ALTER TABLE EXPERIMENTS ADD COLUMN PERM_ID CODE;\\012\\012UPDATE SAMPLES SET PERM_ID = to_char(registration_timestamp,'YYYYMMDDHHSSMS') || '-' || NEXTVAL('PERM_ID_SEQ');\\012UPDATE EXPERIMENTS SET PERM_ID = to_char(registration_timestamp,'YYYYMMDDHHSSMS') || '-' || NEXTVAL('PERM_ID_SEQ');\\012ALTER TABLE SAMPLES ALTER COLUMN PERM_ID SET NOT NULL;\\012ALTER TABLE EXPERIMENTS ALTER COLUMN PERM_ID SET NOT NULL;\\012ALTER TABLE SAMPLES ADD CONSTRAINT SAMP_PI_UK UNIQUE(PERM_ID);\\012ALTER TABLE EXPERIMENTS ADD CONSTRAINT EXPE_PI_UK UNIQUE(PERM_ID);\\012\\012\\012------------------------------------------------------------------------------------\\012-- Add column is_chosen_from_list to controlled_vocabularies.\\012------------------------------------------------------------------------------------\\012ALTER TABLE controlled_vocabularies ADD COLUMN is_chosen_from_list BOOLEAN_CHAR NOT NULL DEFAULT TRUE;\\012ALTER TABLE controlled_vocabularies ADD COLUMN source_uri CHARACTER VARYING(250);\\012------------------------------------------------------------------------------------\\012-- Modify Data table - remove arc connection between Sample and Data table, use a flag instead\\012------------------------------------------------------------------------------------\\012\\012-- add new columns\\012\\012ALTER TABLE data\\012    ADD COLUMN is_derived boolean_char;\\012ALTER TABLE data\\012    ADD COLUMN samp_id tech_id;\\012\\012-- update values in new columns\\012\\012UPDATE data\\012    SET is_derived = (samp_id_derived_from IS NOT NULL); \\012UPDATE data\\012    SET samp_id = samp_id_derived_from \\012    WHERE is_derived = 'TRUE';\\012UPDATE data\\012    SET samp_id = samp_id_acquired_from \\012    WHERE is_derived = 'FALSE';\\012\\012-- add constraints and indexes to new columns\\012\\012ALTER TABLE data\\012    ALTER COLUMN is_derived SET NOT NULL;\\012ALTER TABLE data\\012    ALTER COLUMN samp_id SET NOT NULL;   \\012ALTER TABLE data\\012    ADD CONSTRAINT data_samp_fk FOREIGN KEY (samp_id) REFERENCES samples (id);\\012CREATE INDEX data_samp_fk_i ON data USING btree (samp_id);\\012\\012-- remove old columns\\012\\012ALTER TABLE data\\012    DROP COLUMN samp_id_acquired_from;\\012ALTER TABLE data\\012    DROP COLUMN samp_id_derived_from;\\012    \\012------------------------------------------------------------------------------------\\012-- Granting SELECT privilege to group openbis_readonly\\012------------------------------------------------------------------------------------\\012\\012GRANT SELECT ON SEQUENCE attachment_content_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE attachment_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE code_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE controlled_vocabulary_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE cvte_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE data_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE data_set_property_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE data_set_relationship_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE data_set_type_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE data_store_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE data_type_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE database_instance_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE dstpt_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE etpt_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE event_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE experiment_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE experiment_property_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE experiment_type_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE file_format_type_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE group_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE invalidation_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE locator_type_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE material_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE material_property_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE material_type_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE mtpt_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE perm_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE person_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE project_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE property_type_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE role_assignment_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE sample_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE sample_property_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE sample_type_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE stpt_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE attachment_contents TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE attachments TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE controlled_vocabularies TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE controlled_vocabulary_terms TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE data TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE data_set_properties TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE data_set_relationships TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE data_set_type_property_types TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE data_set_types TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE data_stores TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE data_types TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE database_instances TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE database_version_logs TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE events TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE experiment_properties TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE experiment_type_property_types TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE experiment_types TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE experiments TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE external_data TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE file_format_types TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE groups TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE invalidations TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE locator_types TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE material_properties TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE material_type_property_types TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE material_types TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE materials TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE persons TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE projects TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE property_types TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE role_assignments TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE sample_properties TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE sample_type_property_types TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE sample_types TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE samples TO GROUP OPENBIS_READONLY;\\012\\012------------------------------------------------------------------------------------\\012-- Delete MATERIAL_BATCHES table\\012------------------------------------------------------------------------------------\\012\\012-- WARNING: Potential data lost!!!\\012-- WARNING: Potential data lost!!!\\012-- WARNING: Potential data lost!!!\\012\\012DROP TABLE SAMPLE_MATERIAL_BATCHES;\\012DROP TABLE MATERIAL_BATCHES;\\012DROP SEQUENCE MATERIAL_BATCH_ID_SEQ;\\012\\012------------------------------------------------------------------------------------\\012-- Delete MATE_ID_INHIBITOR_OF from table MATERIALS\\012------------------------------------------------------------------------------------\\012\\012-- WARNING: Potential data lost!!!\\012-- WARNING: Potential data lost!!!\\012-- WARNING: Potential data lost!!!\\012\\012ALTER TABLE MATERIALS DROP COLUMN MATE_ID_INHIBITOR_OF;\\012	\N
+./sourceTest/sql/postgresql/039/.svn/text-base/schema-039.sql.svn-base:    LANGUAGE plpgsql;
+./sourceTest/sql/postgresql/039/.svn/text-base/schema-039.sql.svn-base:    LANGUAGE plpgsql;
+./sourceTest/sql/postgresql/039/.svn/text-base/schema-039.sql.svn-base:    LANGUAGE plpgsql;
+./sourceTest/sql/postgresql/039/.svn/text-base/schema-039.sql.svn-base:    LANGUAGE plpgsql;
+./sourceTest/sql/postgresql/039/.svn/text-base/schema-039.sql.svn-base:    LANGUAGE plpgsql;
+./sourceTest/sql/postgresql/039/.svn/text-base/schema-039.sql.svn-base:    LANGUAGE plpgsql;
+./sourceTest/sql/postgresql/039/.svn/text-base/schema-039.sql.svn-base:    LANGUAGE plpgsql;
+./sourceTest/sql/postgresql/039/.svn/text-base/schema-039.sql.svn-base:    LANGUAGE plpgsql;
+./sourceTest/sql/postgresql/039/017=database_version_logs.tsv:027	D:\\User\\felmer\\dev-workspace\\openbis/source/sql/postgresql/027/function-027.sql	SUCCESS	2008-11-05 09:18:00.403	-- Creating Functions\\012\\012------------------------------------------------------------------------------------\\012--  Purpose:  Create function RENAME_SEQUENCE() that is required for renaming the sequences belonging to tables\\012------------------------------------------------------------------------------------\\012CREATE FUNCTION RENAME_SEQUENCE(OLD_NAME VARCHAR, NEW_NAME VARCHAR) RETURNS INTEGER AS $$\\012DECLARE\\012  CURR_SEQ_VAL   INTEGER;\\012BEGIN\\012  SELECT INTO CURR_SEQ_VAL NEXTVAL(OLD_NAME);\\012  EXECUTE 'CREATE SEQUENCE ' || NEW_NAME || ' START WITH ' || CURR_SEQ_VAL;\\012  EXECUTE 'DROP SEQUENCE ' || OLD_NAME;\\012  RETURN CURR_SEQ_VAL;\\012END;\\012$$ LANGUAGE 'plpgsql';\\012\\012\\012------------------------------------------------------------------------------------\\012--  Purpose:  Create trigger CONTROLLED_VOCABULARY_CHECK \\012------------------------------------------------------------------------------------\\012\\012CREATE OR REPLACE FUNCTION CONTROLLED_VOCABULARY_CHECK() RETURNS trigger AS $$\\012DECLARE\\012   v_code  CODE;\\012BEGIN\\012\\012   select code into v_code from data_types where id = NEW.daty_id;\\012\\012   -- Check if the data is of type "CONTROLLEDVOCABULARY"\\012   if v_code = 'CONTROLLEDVOCABULARY' then\\012      if NEW.covo_id IS NULL then\\012         RAISE EXCEPTION 'Insert/Update of Property Type (Code: %) failed, as its Data Type is CONTROLLEDVOCABULARY, but it is not linked to a Controlled Vocabulary.', NEW.code;\\012      end if;\\012   end if;\\012\\012   RETURN NEW;\\012\\012END;\\012$$ LANGUAGE 'plpgsql';\\012\\012CREATE TRIGGER CONTROLLED_VOCABULARY_CHECK BEFORE INSERT OR UPDATE ON PROPERTY_TYPES\\012    FOR EACH ROW EXECUTE PROCEDURE CONTROLLED_VOCABULARY_CHECK();\\012\\012\\012------------------------------------------------------------------------------------\\012--  Purpose:  Create trigger EXTERNAL_DATA_STORAGE_FORMAT_CHECK \\012------------------------------------------------------------------------------------\\012\\012CREATE OR REPLACE FUNCTION EXTERNAL_DATA_STORAGE_FORMAT_CHECK() RETURNS trigger AS $$\\012DECLARE\\012   v_covo_code  CODE;\\012   data_code CODE;\\012BEGIN\\012\\012   select code into v_covo_code from controlled_vocabularies\\012      where is_internal_namespace = true and \\012         id = (select covo_id from controlled_vocabulary_terms where id = NEW.cvte_id_stor_fmt);\\012   -- Check if the data storage format is a term of the controlled vocabulary "STORAGE_FORMAT"\\012   if v_covo_code != 'STORAGE_FORMAT' then\\012      select code into data_code from data where id = NEW.data_id; \\012      RAISE EXCEPTION 'Insert/Update of Data (Code: %) failed, as its Storage Format is %, but is required to be STORAGE_FORMAT.', data_code, v_covo_code;\\012   end if;\\012\\012   RETURN NEW;\\012\\012END;\\012$$ LANGUAGE 'plpgsql';\\012\\012CREATE TRIGGER EXTERNAL_DATA_STORAGE_FORMAT_CHECK BEFORE INSERT OR UPDATE ON EXTERNAL_DATA\\012    FOR EACH ROW EXECUTE PROCEDURE EXTERNAL_DATA_STORAGE_FORMAT_CHECK();\\012\\012------------------------------------------------------------------------------------\\012--  Purpose:  Create trigger SAMPLE_CODE_UNIQUENESS_CHECK \\012------------------------------------------------------------------------------------\\012\\012CREATE OR REPLACE FUNCTION SAMPLE_CODE_UNIQUENESS_CHECK() RETURNS trigger AS $$\\012DECLARE\\012   counter  INTEGER;\\012BEGIN\\012\\011IF (NEW.samp_id_part_of is NULL) THEN\\012\\011\\011IF (NEW.dbin_id is not NULL) THEN\\012\\011\\011\\011SELECT count(*) into counter FROM samples \\012\\011\\011\\011\\011where id != NEW.id and code = NEW.code and samp_id_part_of is NULL and dbin_id = NEW.dbin_id;\\012\\011\\011\\011IF (counter > 0) THEN\\012\\011\\011\\011\\011RAISE EXCEPTION 'Insert/Update of Sample (Code: %) failed because database instance sample with the same code already exists.', NEW.code;\\012\\011\\011\\011END IF;\\012\\011\\011ELSIF (NEW.grou_id is not NULL) THEN\\012\\011\\011\\011SELECT count(*) into counter FROM samples \\012\\011\\011\\011\\011where id != NEW.id and code = NEW.code and samp_id_part_of is NULL and grou_id = NEW.grou_id;\\012\\011\\011\\011IF (counter > 0) THEN\\012\\011\\011\\011\\011RAISE EXCEPTION 'Insert/Update of Sample (Code: %) failed because group sample with the same code already exists.', NEW.code;\\012\\011\\011\\011END IF;\\012\\011\\011END IF;\\012        ELSE\\012\\011\\011IF (NEW.dbin_id is not NULL) THEN\\012\\011\\011\\011SELECT count(*) into counter FROM samples \\012\\011\\011\\011\\011where id != NEW.id and code = NEW.code and samp_id_part_of = NEW.samp_id_part_of and dbin_id = NEW.dbin_id;\\012\\011\\011\\011IF (counter > 0) THEN\\012\\011\\011\\011\\011RAISE EXCEPTION 'Insert/Update of Sample (Code: %) failed because database instance sample with the same code and being the part of the same parent already exists.', NEW.code;\\012\\011\\011\\011END IF;\\012\\011\\011ELSIF (NEW.grou_id is not NULL) THEN\\012\\011\\011\\011SELECT count(*) into counter FROM samples \\012\\011\\011\\011\\011where id != NEW.id and code = NEW.code and samp_id_part_of = NEW.samp_id_part_of and grou_id = NEW.grou_id;\\012\\011\\011\\011IF (counter > 0) THEN\\012\\011\\011\\011\\011RAISE EXCEPTION 'Insert/Update of Sample (Code: %) failed because group sample with the same code and being the part of the same parent already exists.', NEW.code;\\012\\011\\011\\011END IF;\\012\\011\\011END IF;\\012        END IF;   \\012   RETURN NEW;\\012END;\\012$$ LANGUAGE 'plpgsql';\\012\\012CREATE TRIGGER SAMPLE_CODE_UNIQUENESS_CHECK BEFORE INSERT OR UPDATE ON SAMPLES\\012    FOR EACH ROW EXECUTE PROCEDURE SAMPLE_CODE_UNIQUENESS_CHECK();\\012	\N
+./sourceTest/sql/postgresql/039/017=database_version_logs.tsv:028	source/sql/postgresql/migration/migration-027-028.sql	SUCCESS	2008-11-18 13:24:17.508	-- Create EXPERIMENT_ATTACHMENT_CONTENTS.\\012CREATE TABLE EXPERIMENT_ATTACHMENT_CONTENTS (ID TECH_ID NOT NULL,VALUE FILE NOT NULL);\\012CREATE SEQUENCE EXPERIMENT_ATTACHMENT_CONTENT_ID_SEQ;\\012ALTER TABLE EXPERIMENT_ATTACHMENT_CONTENTS ADD CONSTRAINT EXAC_PK PRIMARY KEY(ID);\\012\\012-- Alter EXPERIMENT_ATTACHMENTS by adding the new column which has a NULL constraint.\\012-- The NOT NULL constraint is added later on.\\012ALTER TABLE EXPERIMENT_ATTACHMENTS ADD COLUMN EXAC_ID TECH_ID;\\012\\012-- Does the VALUE migration between EXPERIMENT_ATTACHMENTS to EXPERIMENT_ATTACHMENT_CONTENTS.\\012CREATE OR REPLACE FUNCTION move_exp_att_content() RETURNS integer AS $$\\012DECLARE\\012    rec RECORD;\\012    seq BIGINT;\\012BEGIN\\012  FOR rec IN SELECT id, value FROM EXPERIMENT_ATTACHMENTS LOOP\\012  \\011seq := nextval('EXPERIMENT_ATTACHMENT_CONTENT_ID_SEQ');\\012    INSERT INTO EXPERIMENT_ATTACHMENT_CONTENTS (id, value) VALUES (seq, rec.value);\\012    UPDATE EXPERIMENT_ATTACHMENTS SET exac_id = seq WHERE id = rec.id;\\012  END LOOP;\\012  RETURN 1;\\012END;\\012$$ LANGUAGE 'plpgsql';\\012\\012-- Call the function.\\012SELECT move_exp_att_content();\\012DROP FUNCTION move_exp_att_content();\\012\\012\\012-- Finish EXPERIMENT_ATTACHMENTS changes.\\012ALTER TABLE EXPERIMENT_ATTACHMENTS ADD CONSTRAINT EXAT_CONT_FK FOREIGN KEY (EXAC_ID) REFERENCES EXPERIMENT_ATTACHMENT_CONTENTS(ID);\\012ALTER TABLE EXPERIMENT_ATTACHMENTS DROP COLUMN VALUE;\\012ALTER TABLE EXPERIMENT_ATTACHMENTS ALTER COLUMN EXAC_ID SET NOT NULL;\\012	\N
+./sourceTest/sql/postgresql/039/017=database_version_logs.tsv:029	source/sql/postgresql/migration/migration-028-029.sql	SUCCESS	2009-03-18 10:50:20.105	-- -------\\012-- add modification_timestamp field to allow edition with Hibernate\\012-- -------\\012\\012ALTER TABLE samples\\012\\011ADD COLUMN modification_timestamp TIME_STAMP DEFAULT CURRENT_TIMESTAMP;\\012\\012ALTER TABLE experiments\\012\\011ADD COLUMN modification_timestamp TIME_STAMP DEFAULT CURRENT_TIMESTAMP;\\012\\012ALTER TABLE materials\\012\\011ADD COLUMN modification_timestamp TIME_STAMP DEFAULT CURRENT_TIMESTAMP;\\012\\012ALTER TABLE experiment_properties\\012\\011ADD COLUMN modification_timestamp TIME_STAMP DEFAULT CURRENT_TIMESTAMP;\\012\\012ALTER TABLE material_properties\\012\\011ADD COLUMN modification_timestamp TIME_STAMP DEFAULT CURRENT_TIMESTAMP;\\012\\012ALTER TABLE sample_properties\\012\\011ADD COLUMN modification_timestamp TIME_STAMP DEFAULT CURRENT_TIMESTAMP;\\012\\012-- -------\\012-- add property data type which references materials\\012-- -------\\012\\012ALTER TABLE property_types\\012\\011ADD COLUMN maty_prop_id tech_id;\\012\\012ALTER TABLE property_types\\012\\011ADD CONSTRAINT prty_maty_fk FOREIGN KEY (maty_prop_id) REFERENCES material_types(id);\\012\\012ALTER TABLE experiment_properties\\012\\011ADD COLUMN mate_prop_id tech_id;\\012\\012ALTER TABLE material_properties\\012\\011ADD COLUMN mate_prop_id tech_id;\\012\\012ALTER TABLE sample_properties\\012\\011ADD COLUMN mate_prop_id tech_id;\\012\\012ALTER TABLE experiment_properties\\012\\011ADD CONSTRAINT expr_mapr_fk FOREIGN KEY (mate_prop_id) REFERENCES materials(id);\\012\\012ALTER TABLE material_properties\\012\\011ADD CONSTRAINT mapr_mapr_fk FOREIGN KEY (mate_prop_id) REFERENCES materials(id);\\012\\012ALTER TABLE sample_properties\\012\\011ADD CONSTRAINT sapr_mapr_fk FOREIGN KEY (mate_prop_id) REFERENCES materials(id);\\012\\012insert into data_types\\012(id\\012 ,code\\012 ,description)\\012 values \\012 (nextval('DATA_TYPE_ID_SEQ')\\012 ,'MATERIAL'\\012 ,'Reference to a material'\\012);\\012\\012ALTER TABLE MATERIAL_PROPERTIES DROP CONSTRAINT MAPR_CK;\\012ALTER TABLE MATERIAL_PROPERTIES ADD CONSTRAINT MAPR_CK CHECK \\012\\011((VALUE IS NOT NULL AND CVTE_ID IS NULL AND MATE_PROP_ID IS NULL) OR \\012\\011 (VALUE IS NULL AND CVTE_ID IS NOT NULL AND MATE_PROP_ID IS NULL) OR\\012\\011 (VALUE IS NULL AND CVTE_ID IS NULL AND MATE_PROP_ID IS NOT NULL)\\012\\011);\\012\\012ALTER TABLE EXPERIMENT_PROPERTIES DROP CONSTRAINT EXPR_CK;\\012ALTER TABLE EXPERIMENT_PROPERTIES ADD CONSTRAINT EXPR_CK CHECK \\012\\011((VALUE IS NOT NULL AND CVTE_ID IS NULL AND MATE_PROP_ID IS NULL) OR \\012\\011 (VALUE IS NULL AND CVTE_ID IS NOT NULL AND MATE_PROP_ID IS NULL) OR\\012\\011 (VALUE IS NULL AND CVTE_ID IS NULL AND MATE_PROP_ID IS NOT NULL)\\012\\011);\\012\\012ALTER TABLE SAMPLE_PROPERTIES DROP CONSTRAINT SAPR_CK;\\012ALTER TABLE SAMPLE_PROPERTIES ADD CONSTRAINT SAPR_CK CHECK \\012\\011((VALUE IS NOT NULL AND CVTE_ID IS NULL AND MATE_PROP_ID IS NULL) OR \\012\\011 (VALUE IS NULL AND CVTE_ID IS NOT NULL AND MATE_PROP_ID IS NULL) OR\\012\\011 (VALUE IS NULL AND CVTE_ID IS NULL AND MATE_PROP_ID IS NOT NULL)\\012\\011);\\012\\012------------------------------------------------------------------------------------\\012--  Purpose:  Create trigger MATERIAL/SAMPLE/EXPERIMENT _PROPERTY_WITH_MATERIAL_DATA_TYPE_CHECK\\012--            It checks that if material property value is assigned to the entity,\\012--\\011\\011\\011\\011\\011\\011then the material type is equal to the one described by property type.\\012------------------------------------------------------------------------------------\\012\\012CREATE OR REPLACE FUNCTION MATERIAL_PROPERTY_WITH_MATERIAL_DATA_TYPE_CHECK() RETURNS trigger AS $$\\012DECLARE\\012   v_type_id  CODE;\\012   v_type_id_prop  CODE;\\012BEGIN\\012   if NEW.mate_prop_id IS NOT NULL then\\012\\011\\011\\011-- find material type id of the property type \\012\\011\\011\\011select pt.maty_prop_id into v_type_id_prop \\012\\011\\011\\011  from material_type_property_types etpt, property_types pt \\012\\011\\011\\011 where NEW.mtpt_id = etpt.id AND etpt.prty_id = pt.id;\\012\\011\\011\\012\\011\\011\\011if v_type_id_prop IS NOT NULL then\\012\\011\\011\\011\\011-- find material type id of the material which consists the entity's property value\\012\\011\\011\\011\\011select entity.maty_id into v_type_id \\012\\011\\011\\011\\011  from materials entity\\012\\011\\011\\011\\011 where NEW.mate_prop_id = entity.id;\\012\\011\\011\\011\\011if v_type_id != v_type_id_prop then\\012\\011\\011\\011\\011\\011RAISE EXCEPTION 'Insert/Update of property value referencing material (id: %) failed, as referenced material type is different than expected (id %, expected id: %).', \\012\\011\\011\\011\\011\\011\\011\\011 NEW.mate_prop_id, v_type_id, v_type_id_prop;\\012\\011\\011\\011\\011end if;\\012\\011\\011\\011end if;\\012   end if;\\012   RETURN NEW;\\012END;\\012$$ LANGUAGE 'plpgsql';\\012\\012CREATE TRIGGER MATERIAL_PROPERTY_WITH_MATERIAL_DATA_TYPE_CHECK BEFORE INSERT OR UPDATE ON material_properties\\012    FOR EACH ROW EXECUTE PROCEDURE MATERIAL_PROPERTY_WITH_MATERIAL_DATA_TYPE_CHECK();\\012    \\012CREATE OR REPLACE FUNCTION SAMPLE_PROPERTY_WITH_MATERIAL_DATA_TYPE_CHECK() RETURNS trigger AS $$\\012DECLARE\\012   v_type_id  CODE;\\012   v_type_id_prop  CODE;\\012BEGIN\\012   if NEW.mate_prop_id IS NOT NULL then\\012\\011\\011\\011-- find material type id of the property type \\012\\011\\011\\011select pt.maty_prop_id into v_type_id_prop \\012\\011\\011\\011  from sample_type_property_types etpt, property_types pt \\012\\011\\011\\011 where NEW.stpt_id = etpt.id AND etpt.prty_id = pt.id;\\012\\011\\011\\012\\011\\011\\011if v_type_id_prop IS NOT NULL then\\012\\011\\011\\011\\011-- find material type id of the material which consists the entity's property value\\012\\011\\011\\011\\011select entity.maty_id into v_type_id \\012\\011\\011\\011\\011  from materials entity\\012\\011\\011\\011\\011 where NEW.mate_prop_id = entity.id;\\012\\011\\011\\011\\011if v_type_id != v_type_id_prop then\\012\\011\\011\\011\\011\\011RAISE EXCEPTION 'Insert/Update of property value referencing material (id: %) failed, as referenced material type is different than expected (id %, expected id: %).', \\012\\011\\011\\011\\011\\011\\011\\011\\011\\011\\011\\011\\011 NEW.mate_prop_id, v_type_id, v_type_id_prop;\\012\\011\\011\\011\\011end if;\\012\\011\\011\\011end if;\\012   end if;\\012   RETURN NEW;\\012END;\\012$$ LANGUAGE 'plpgsql';\\012\\012CREATE TRIGGER SAMPLE_PROPERTY_WITH_MATERIAL_DATA_TYPE_CHECK BEFORE INSERT OR UPDATE ON sample_properties\\012    FOR EACH ROW EXECUTE PROCEDURE SAMPLE_PROPERTY_WITH_MATERIAL_DATA_TYPE_CHECK();\\012    \\012CREATE OR REPLACE FUNCTION EXPERIMENT_PROPERTY_WITH_MATERIAL_DATA_TYPE_CHECK() RETURNS trigger AS $$\\012DECLARE\\012   v_type_id  CODE;\\012   v_type_id_prop  CODE;\\012BEGIN\\012   if NEW.mate_prop_id IS NOT NULL then\\012\\011\\011\\011-- find material type id of the property type \\012\\011\\011\\011select pt.maty_prop_id into v_type_id_prop \\012\\011\\011\\011  from experiment_type_property_types etpt, property_types pt \\012\\011\\011\\011 where NEW.etpt_id = etpt.id AND etpt.prty_id = pt.id;\\012\\011\\011\\012\\011\\011\\011if v_type_id_prop IS NOT NULL then\\012\\011\\011\\011\\011-- find material type id of the material which consists the entity's property value\\012\\011\\011\\011\\011select entity.maty_id into v_type_id \\012\\011\\011\\011\\011  from materials entity\\012\\011\\011\\011\\011 where NEW.mate_prop_id = entity.id;\\012\\011\\011\\011\\011if v_type_id != v_type_id_prop then\\012\\011\\011\\011\\011\\011RAISE EXCEPTION 'Insert/Update of property value referencing material (id: %) failed, as referenced material type is different than expected (id %, expected id: %).', \\012\\011\\011\\011\\011\\011\\011\\011\\011\\011\\011\\011\\011 NEW.mate_prop_id, v_type_id, v_type_id_prop;\\012\\011\\011\\011\\011end if;\\012\\011\\011\\011end if;\\012   end if;\\012   RETURN NEW;\\012END;\\012$$ LANGUAGE 'plpgsql';\\012\\012CREATE TRIGGER EXPERIMENT_PROPERTY_WITH_MATERIAL_DATA_TYPE_CHECK BEFORE INSERT OR UPDATE ON experiment_properties\\012    FOR EACH ROW EXECUTE PROCEDURE EXPERIMENT_PROPERTY_WITH_MATERIAL_DATA_TYPE_CHECK();\\012       \\012-- -------\\012-- remove the reminescents of the OBSERVABLE_TYPE\\012-- -------\\012\\012ALTER TABLE data\\012\\011DROP CONSTRAINT data_obty_fk;\\012\\012ALTER TABLE data_set_types\\012\\011DROP CONSTRAINT obty_pk;\\012\\012ALTER TABLE data_set_types\\012\\011ADD CONSTRAINT dsty_pk PRIMARY KEY (id);\\012\\012ALTER TABLE data\\012\\011ADD CONSTRAINT data_dsty_fk FOREIGN KEY (dsty_id) REFERENCES data_set_types(id);\\012\\012ALTER TABLE data_set_types\\012\\011DROP CONSTRAINT obty_bk_uk;\\012\\012ALTER TABLE data_set_types\\012\\011DROP CONSTRAINT obty_dbin_fk;\\012\\012ALTER TABLE data_set_types\\012\\011ADD CONSTRAINT dsty_bk_uk UNIQUE (code, dbin_id);\\012\\012ALTER TABLE data_set_types\\012\\011ADD CONSTRAINT dsty_dbin_fk FOREIGN KEY (dbin_id) REFERENCES database_instances(id);\\012\\012DROP INDEX data_obty_fk_i;\\012\\012CREATE INDEX data_dsty_fk_i ON data(dsty_id);\\012	\N
+./sourceTest/sql/postgresql/039/017=database_version_logs.tsv:030	source/sql/postgresql/migration/migration-029-030.sql	SUCCESS	2009-03-23 15:34:44.72	-- -------\\012-- add modification_timestamp field to allow edition with Hibernate\\012-- -------\\012ALTER TABLE data\\012\\011ADD COLUMN modification_timestamp TIME_STAMP DEFAULT CURRENT_TIMESTAMP;\\012ALTER TABLE experiment_types\\012\\011ADD COLUMN modification_timestamp TIME_STAMP DEFAULT CURRENT_TIMESTAMP;\\012ALTER TABLE sample_types\\012\\011ADD COLUMN modification_timestamp TIME_STAMP DEFAULT CURRENT_TIMESTAMP;\\012ALTER TABLE material_types\\012\\011ADD COLUMN modification_timestamp TIME_STAMP DEFAULT CURRENT_TIMESTAMP;\\012ALTER TABLE data_set_types\\012\\011ADD COLUMN modification_timestamp TIME_STAMP DEFAULT CURRENT_TIMESTAMP;\\012ALTER TABLE controlled_vocabularies\\012\\011ADD COLUMN modification_timestamp TIME_STAMP DEFAULT CURRENT_TIMESTAMP;\\012-- -------\\012-- add properties to data sets\\012-- -------\\012CREATE TABLE DATA_SET_PROPERTIES (ID TECH_ID NOT NULL,DS_ID TECH_ID NOT NULL,DSTPT_ID TECH_ID NOT NULL,VALUE GENERIC_VALUE,CVTE_ID TECH_ID, MATE_PROP_ID TECH_ID, PERS_ID_REGISTERER TECH_ID NOT NULL,REGISTRATION_TIMESTAMP TIME_STAMP_DFL NOT NULL DEFAULT CURRENT_TIMESTAMP, MODIFICATION_TIMESTAMP TIME_STAMP DEFAULT CURRENT_TIMESTAMP);\\012CREATE TABLE DATA_SET_TYPE_PROPERTY_TYPES (ID TECH_ID NOT NULL,DSTY_ID TECH_ID NOT NULL,PRTY_ID TECH_ID NOT NULL,IS_MANDATORY BOOLEAN_CHAR NOT NULL DEFAULT 'F',IS_MANAGED_INTERNALLY BOOLEAN_CHAR NOT NULL DEFAULT 'F',PERS_ID_REGISTERER TECH_ID NOT NULL,REGISTRATION_TIMESTAMP TIME_STAMP_DFL NOT NULL DEFAULT CURRENT_TIMESTAMP);\\012\\012CREATE SEQUENCE DATA_SET_PROPERTY_ID_SEQ;\\012CREATE SEQUENCE DSTPT_ID_SEQ;\\012\\012ALTER TABLE DATA_SET_TYPE_PROPERTY_TYPES ADD CONSTRAINT DSTPT_PK PRIMARY KEY(ID);\\012ALTER TABLE DATA_SET_PROPERTIES ADD CONSTRAINT DSPR_PK PRIMARY KEY(ID);\\012\\012ALTER TABLE DATA_SET_TYPE_PROPERTY_TYPES ADD CONSTRAINT DSTPT_BK_UK UNIQUE(DSTY_ID,PRTY_ID);\\012ALTER TABLE DATA_SET_PROPERTIES ADD CONSTRAINT DSPR_BK_UK UNIQUE(DS_ID,DSTPT_ID);\\012\\012\\012ALTER TABLE DATA_SET_TYPE_PROPERTY_TYPES ADD CONSTRAINT DSTPT_DSTY_FK FOREIGN KEY (DSTY_ID) REFERENCES DATA_SET_TYPES(ID);\\012ALTER TABLE DATA_SET_TYPE_PROPERTY_TYPES ADD CONSTRAINT DSTPT_PERS_FK FOREIGN KEY (PERS_ID_REGISTERER) REFERENCES PERSONS(ID);\\012ALTER TABLE DATA_SET_TYPE_PROPERTY_TYPES ADD CONSTRAINT DSTPT_PRTY_FK FOREIGN KEY (PRTY_ID) REFERENCES PROPERTY_TYPES(ID);\\012ALTER TABLE DATA_SET_PROPERTIES ADD CONSTRAINT DSPR_CVTE_FK FOREIGN KEY (CVTE_ID) REFERENCES CONTROLLED_VOCABULARY_TERMS(ID);\\012ALTER TABLE DATA_SET_PROPERTIES ADD CONSTRAINT DSPR_DSTPT_FK FOREIGN KEY (DSTPT_ID) REFERENCES DATA_SET_TYPE_PROPERTY_TYPES(ID) ON DELETE CASCADE;\\012ALTER TABLE DATA_SET_PROPERTIES ADD CONSTRAINT DSPR_DS_FK FOREIGN KEY (DS_ID) REFERENCES DATA(ID);\\012ALTER TABLE DATA_SET_PROPERTIES ADD CONSTRAINT DSPR_PERS_FK FOREIGN KEY (PERS_ID_REGISTERER) REFERENCES PERSONS(ID);\\012ALTER TABLE DATA_SET_PROPERTIES ADD CONSTRAINT DSPR_MAPR_FK FOREIGN KEY (MATE_PROP_ID) REFERENCES MATERIALS(ID);\\012\\012ALTER TABLE DATA_SET_PROPERTIES ADD CONSTRAINT DSPR_CK CHECK \\012\\011((VALUE IS NOT NULL AND CVTE_ID IS NULL AND MATE_PROP_ID IS NULL) OR \\012\\011 (VALUE IS NULL AND CVTE_ID IS NOT NULL AND MATE_PROP_ID IS NULL) OR\\012\\011 (VALUE IS NULL AND CVTE_ID IS NULL AND MATE_PROP_ID IS NOT NULL)\\012\\011);\\012\\012CREATE INDEX DSPR_CVTE_FK_I ON DATA_SET_PROPERTIES (CVTE_ID);\\012CREATE INDEX DSPR_DSTPT_FK_I ON DATA_SET_PROPERTIES (DSTPT_ID);\\012CREATE INDEX DSPR_DS_FK_I ON DATA_SET_PROPERTIES (DS_ID);\\012CREATE INDEX DSPR_PERS_FK_I ON DATA_SET_PROPERTIES (PERS_ID_REGISTERER);\\012CREATE INDEX DSTPT_DSTY_FK_I ON DATA_SET_TYPE_PROPERTY_TYPES (DSTY_ID);\\012CREATE INDEX DSTPT_PERS_FK_I ON DATA_SET_TYPE_PROPERTY_TYPES (PERS_ID_REGISTERER);\\012CREATE INDEX DSTPT_PRTY_FK_I ON DATA_SET_TYPE_PROPERTY_TYPES (PRTY_ID);\\012\\012CREATE OR REPLACE FUNCTION DATA_SET_PROPERTY_WITH_MATERIAL_DATA_TYPE_CHECK() RETURNS trigger AS $$\\012DECLARE\\012   v_type_id  CODE;\\012   v_type_id_prop  CODE;\\012BEGIN\\012   if NEW.mate_prop_id IS NOT NULL then\\012\\011\\011\\011-- find material type id of the property type \\012\\011\\011\\011select pt.maty_prop_id into v_type_id_prop \\012\\011\\011\\011  from data_set_type_property_types dstpt, property_types pt \\012\\011\\011\\011 where NEW.dstpt_id = dstpt.id AND dstpt.prty_id = pt.id;\\012\\011\\011\\012\\011\\011\\011if v_type_id_prop IS NOT NULL then\\012\\011\\011\\011\\011-- find material type id of the material which consists the entity's property value\\012\\011\\011\\011\\011select entity.maty_id into v_type_id \\012\\011\\011\\011\\011  from materials entity\\012\\011\\011\\011\\011 where NEW.mate_prop_id = entity.id;\\012\\011\\011\\011\\011if v_type_id != v_type_id_prop then\\012\\011\\011\\011\\011\\011RAISE EXCEPTION 'Insert/Update of property value referencing material (id: %) failed, as referenced material type is different than expected (id %, expected id: %).', \\012\\011\\011\\011\\011\\011\\011\\011\\011\\011\\011\\011\\011 NEW.mate_prop_id, v_type_id, v_type_id_prop;\\012\\011\\011\\011\\011end if;\\012\\011\\011\\011end if;\\012   end if;\\012   RETURN NEW;\\012END;\\012$$ LANGUAGE 'plpgsql';\\012\\012CREATE TRIGGER DATA_SET_PROPERTY_WITH_MATERIAL_DATA_TYPE_CHECK BEFORE INSERT OR UPDATE ON data_set_properties\\012    FOR EACH ROW EXECUTE PROCEDURE DATA_SET_PROPERTY_WITH_MATERIAL_DATA_TYPE_CHECK();   \\012	\N
+./sourceTest/sql/postgresql/039/017=database_version_logs.tsv:032	source/sql/postgresql/migration/migration-031-032.sql	SUCCESS	2009-04-09 09:36:36.20	-- -------\\012-- Modify MATERIAL_BATCHES\\012-- -------\\012\\012ALTER TABLE material_batches\\012    DROP COLUMN proc_id;\\012\\012-- -------\\012-- Modify SAMPLES\\012-- -------\\012\\012ALTER TABLE samples\\012    ADD COLUMN expe_id tech_id;\\012\\012ALTER TABLE samples\\012    ADD CONSTRAINT samp_expe_fk FOREIGN KEY (expe_id) REFERENCES experiments(id);\\012\\012CREATE INDEX samp_expe_fk_i ON samples USING btree (expe_id);\\012\\012-- relink samples directly to experiments\\012\\012UPDATE samples\\012SET expe_id = (SELECT e.id FROM experiments e, procedures p, sample_inputs si \\012               WHERE si.samp_id = samples.id AND si.proc_id = p.id AND p.expe_id = e.id AND e.inva_id IS NULL);\\012\\012\\012-- -------\\012-- Modify DATA\\012-- -------\\012\\012ALTER TABLE data\\012    ADD COLUMN expe_id tech_id;\\012\\012ALTER TABLE data\\012    ADD CONSTRAINT data_expe_fk FOREIGN KEY (expe_id) REFERENCES experiments(id);\\012\\012CREATE INDEX data_expe_fk_i ON data USING btree (expe_id);\\012\\012UPDATE data\\012SET expe_id = (SELECT e.id FROM experiments e, procedures p \\012               WHERE data.proc_id_produced_by = p.id AND p.expe_id = e.id);\\012\\012ALTER TABLE data\\012    ALTER COLUMN expe_id SET NOT NULL;\\012\\012ALTER TABLE data\\012    DROP COLUMN proc_id_produced_by;\\012\\012-- -------\\012-- Drop PROCEDURES, PROCEDURE_TYPES, and SAMPLE_INPUTS\\012-- -------\\012\\012DROP TABLE sample_inputs;\\012DROP TABLE procedures;\\012DROP TABLE procedure_types;\\012\\012DROP SEQUENCE procedure_id_seq;\\012DROP SEQUENCE procedure_type_id_seq;\\012\\012-- -------\\012-- Add CODE_SEQ\\012-- -------\\012\\012CREATE SEQUENCE CODE_SEQ;\\012\\012-- -------\\012-- Add new columns to DATA_STORES\\012-- -------\\012\\012ALTER TABLE data_stores\\012    ADD COLUMN remote_url character varying(250),\\012    ADD COLUMN session_token character varying(50),\\012    ADD COLUMN modification_timestamp time_stamp DEFAULT now();\\012\\012UPDATE data_stores\\012SET remote_url = '', session_token='';\\012\\012ALTER TABLE data_stores\\012    ALTER COLUMN remote_url SET NOT NULL,\\012    ALTER COLUMN session_token SET NOT NULL;\\012\\012-- -------\\012-- Drop foreign keys onto DATA_STORES\\012-- -------\\012\\012ALTER TABLE database_instances\\012    DROP COLUMN dast_id;\\012\\012ALTER TABLE groups\\012    DROP COLUMN dast_id;\\012\\012ALTER TABLE projects\\012    DROP COLUMN dast_id;\\012\\012ALTER TABLE experiments\\012    DROP COLUMN dast_id;\\012\\012-- -------\\012-- Add foreign key from DATA onto DATA_STORES\\012-- -------\\012\\012ALTER TABLE data\\012    ADD COLUMN dast_id tech_id;\\012\\012ALTER TABLE data\\012    ADD CONSTRAINT data_dast_fk FOREIGN KEY (dast_id) REFERENCES data_stores(id);\\012\\012UPDATE data\\012SET dast_id = (select id from data_stores where code = 'STANDARD');\\012\\012ALTER TABLE data\\012    ALTER COLUMN dast_id SET NOT NULL;\\012\\012\\012------------------------------------------------------------------------------------\\012--  Purpose:  Replace trigger SAMPLE_CODE_UNIQUENESS_CHECK \\012------------------------------------------------------------------------------------\\012\\012CREATE OR REPLACE FUNCTION SAMPLE_CODE_UNIQUENESS_CHECK() RETURNS trigger AS $$\\012DECLARE\\012   counter  INTEGER;\\012BEGIN\\012    LOCK TABLE samples IN EXCLUSIVE MODE;\\012    IF (NEW.samp_id_part_of is NULL) THEN\\012        IF (NEW.dbin_id is not NULL) THEN\\012            SELECT count(*) into counter FROM samples \\012                where id != NEW.id and code = NEW.code and samp_id_part_of is NULL and dbin_id = NEW.dbin_id;\\012            IF (counter > 0) THEN\\012                RAISE EXCEPTION 'Insert/Update of Sample (Code: %) failed because database instance sample with the same code already exists.', NEW.code;\\012            END IF;\\012        ELSIF (NEW.grou_id is not NULL) THEN\\012            SELECT count(*) into counter FROM samples \\012                where id != NEW.id and code = NEW.code and samp_id_part_of is NULL and grou_id = NEW.grou_id;\\012            IF (counter > 0) THEN\\012                RAISE EXCEPTION 'Insert/Update of Sample (Code: %) failed because group sample with the same code already exists.', NEW.code;\\012            END IF;\\012        END IF;\\012        ELSE\\012        IF (NEW.dbin_id is not NULL) THEN\\012            SELECT count(*) into counter FROM samples \\012                where id != NEW.id and code = NEW.code and samp_id_part_of = NEW.samp_id_part_of and dbin_id = NEW.dbin_id;\\012            IF (counter > 0) THEN\\012                RAISE EXCEPTION 'Insert/Update of Sample (Code: %) failed because database instance sample with the same code and being the part of the same parent already exists.', NEW.code;\\012            END IF;\\012        ELSIF (NEW.grou_id is not NULL) THEN\\012            SELECT count(*) into counter FROM samples \\012                where id != NEW.id and code = NEW.code and samp_id_part_of = NEW.samp_id_part_of and grou_id = NEW.grou_id;\\012            IF (counter > 0) THEN\\012                RAISE EXCEPTION 'Insert/Update of Sample (Code: %) failed because group sample with the same code and being the part of the same parent already exists.', NEW.code;\\012            END IF;\\012        END IF;\\012        END IF;   \\012   RETURN NEW;\\012END;\\012$$ LANGUAGE 'plpgsql';\\012\\012\\012\\012	\N
+./sourceTest/sql/postgresql/039/017=database_version_logs.tsv:034	source/sql/postgresql/migration/migration-033-034.sql	SUCCESS	2009-05-26 08:32:49.935	------------------------------------------------------------------------------------\\012-- Create sequence for generating permanent identifiers starting with nextval of existing dataset sequence.\\012------------------------------------------------------------------------------------\\012CREATE FUNCTION CREATE_SEQUENCE(EXISTING_SEQUENCE VARCHAR, NEW_SEQUENCE VARCHAR) RETURNS VOID AS $$\\012DECLARE\\012  CURR_SEQ_VAL   INTEGER;\\012BEGIN\\012  SELECT INTO CURR_SEQ_VAL NEXTVAL(EXISTING_SEQUENCE);\\012  EXECUTE 'CREATE SEQUENCE ' || NEW_SEQUENCE || ' START WITH ' || CURR_SEQ_VAL;\\012  RETURN;\\012END;\\012$$ LANGUAGE 'plpgsql';\\012\\012SELECT CREATE_SEQUENCE('DATA_ID_SEQ', 'PERM_ID_SEQ');\\012DROP FUNCTION CREATE_SEQUENCE(VARCHAR, VARCHAR);\\012\\012------------------------------------------------------------------------------------\\012-- Add perm_id columns to samples and experiments.\\012------------------------------------------------------------------------------------\\012ALTER TABLE SAMPLES ADD COLUMN PERM_ID CODE;\\012ALTER TABLE EXPERIMENTS ADD COLUMN PERM_ID CODE;\\012\\012UPDATE SAMPLES SET PERM_ID = to_char(registration_timestamp,'YYYYMMDDHHSSMS') || '-' || NEXTVAL('PERM_ID_SEQ');\\012UPDATE EXPERIMENTS SET PERM_ID = to_char(registration_timestamp,'YYYYMMDDHHSSMS') || '-' || NEXTVAL('PERM_ID_SEQ');\\012ALTER TABLE SAMPLES ALTER COLUMN PERM_ID SET NOT NULL;\\012ALTER TABLE EXPERIMENTS ALTER COLUMN PERM_ID SET NOT NULL;\\012ALTER TABLE SAMPLES ADD CONSTRAINT SAMP_PI_UK UNIQUE(PERM_ID);\\012ALTER TABLE EXPERIMENTS ADD CONSTRAINT EXPE_PI_UK UNIQUE(PERM_ID);\\012\\012\\012------------------------------------------------------------------------------------\\012-- Add column is_chosen_from_list to controlled_vocabularies.\\012------------------------------------------------------------------------------------\\012ALTER TABLE controlled_vocabularies ADD COLUMN is_chosen_from_list BOOLEAN_CHAR NOT NULL DEFAULT TRUE;\\012ALTER TABLE controlled_vocabularies ADD COLUMN source_uri CHARACTER VARYING(250);\\012------------------------------------------------------------------------------------\\012-- Modify Data table - remove arc connection between Sample and Data table, use a flag instead\\012------------------------------------------------------------------------------------\\012\\012-- add new columns\\012\\012ALTER TABLE data\\012    ADD COLUMN is_derived boolean_char;\\012ALTER TABLE data\\012    ADD COLUMN samp_id tech_id;\\012\\012-- update values in new columns\\012\\012UPDATE data\\012    SET is_derived = (samp_id_derived_from IS NOT NULL); \\012UPDATE data\\012    SET samp_id = samp_id_derived_from \\012    WHERE is_derived = 'TRUE';\\012UPDATE data\\012    SET samp_id = samp_id_acquired_from \\012    WHERE is_derived = 'FALSE';\\012\\012-- add constraints and indexes to new columns\\012\\012ALTER TABLE data\\012    ALTER COLUMN is_derived SET NOT NULL;\\012ALTER TABLE data\\012    ALTER COLUMN samp_id SET NOT NULL;   \\012ALTER TABLE data\\012    ADD CONSTRAINT data_samp_fk FOREIGN KEY (samp_id) REFERENCES samples (id);\\012CREATE INDEX data_samp_fk_i ON data USING btree (samp_id);\\012\\012-- remove old columns\\012\\012ALTER TABLE data\\012    DROP COLUMN samp_id_acquired_from;\\012ALTER TABLE data\\012    DROP COLUMN samp_id_derived_from;\\012    \\012------------------------------------------------------------------------------------\\012-- Granting SELECT privilege to group openbis_readonly\\012------------------------------------------------------------------------------------\\012\\012GRANT SELECT ON SEQUENCE attachment_content_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE attachment_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE code_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE controlled_vocabulary_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE cvte_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE data_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE data_set_property_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE data_set_relationship_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE data_set_type_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE data_store_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE data_type_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE database_instance_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE dstpt_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE etpt_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE event_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE experiment_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE experiment_property_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE experiment_type_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE file_format_type_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE group_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE invalidation_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE locator_type_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE material_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE material_property_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE material_type_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE mtpt_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE perm_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE person_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE project_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE property_type_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE role_assignment_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE sample_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE sample_property_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE sample_type_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE stpt_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE attachment_contents TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE attachments TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE controlled_vocabularies TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE controlled_vocabulary_terms TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE data TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE data_set_properties TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE data_set_relationships TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE data_set_type_property_types TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE data_set_types TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE data_stores TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE data_types TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE database_instances TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE database_version_logs TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE events TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE experiment_properties TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE experiment_type_property_types TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE experiment_types TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE experiments TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE external_data TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE file_format_types TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE groups TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE invalidations TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE locator_types TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE material_properties TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE material_type_property_types TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE material_types TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE materials TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE persons TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE projects TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE property_types TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE role_assignments TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE sample_properties TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE sample_type_property_types TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE sample_types TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE samples TO GROUP OPENBIS_READONLY;\\012\\012------------------------------------------------------------------------------------\\012-- Delete MATERIAL_BATCHES table\\012------------------------------------------------------------------------------------\\012\\012-- WARNING: Potential data lost!!!\\012-- WARNING: Potential data lost!!!\\012-- WARNING: Potential data lost!!!\\012\\012DROP TABLE SAMPLE_MATERIAL_BATCHES;\\012DROP TABLE MATERIAL_BATCHES;\\012DROP SEQUENCE MATERIAL_BATCH_ID_SEQ;\\012\\012------------------------------------------------------------------------------------\\012-- Delete MATE_ID_INHIBITOR_OF from table MATERIALS\\012------------------------------------------------------------------------------------\\012\\012-- WARNING: Potential data lost!!!\\012-- WARNING: Potential data lost!!!\\012-- WARNING: Potential data lost!!!\\012\\012ALTER TABLE MATERIALS DROP COLUMN MATE_ID_INHIBITOR_OF;\\012	\N
+./sourceTest/sql/postgresql/039/schema-039.sql:    LANGUAGE plpgsql;
+./sourceTest/sql/postgresql/039/schema-039.sql:    LANGUAGE plpgsql;
+./sourceTest/sql/postgresql/039/schema-039.sql:    LANGUAGE plpgsql;
+./sourceTest/sql/postgresql/039/schema-039.sql:    LANGUAGE plpgsql;
+./sourceTest/sql/postgresql/039/schema-039.sql:    LANGUAGE plpgsql;
+./sourceTest/sql/postgresql/039/schema-039.sql:    LANGUAGE plpgsql;
+./sourceTest/sql/postgresql/039/schema-039.sql:    LANGUAGE plpgsql;
+./sourceTest/sql/postgresql/039/schema-039.sql:    LANGUAGE plpgsql;
+./sourceTest/sql/postgresql/040/.svn/text-base/017=database_version_logs.tsv.svn-base:027	D:\\User\\felmer\\dev-workspace\\openbis/source/sql/postgresql/027/function-027.sql	SUCCESS	2008-11-05 09:18:00.403	-- Creating Functions\\012\\012------------------------------------------------------------------------------------\\012--  Purpose:  Create function RENAME_SEQUENCE() that is required for renaming the sequences belonging to tables\\012------------------------------------------------------------------------------------\\012CREATE FUNCTION RENAME_SEQUENCE(OLD_NAME VARCHAR, NEW_NAME VARCHAR) RETURNS INTEGER AS $$\\012DECLARE\\012  CURR_SEQ_VAL   INTEGER;\\012BEGIN\\012  SELECT INTO CURR_SEQ_VAL NEXTVAL(OLD_NAME);\\012  EXECUTE 'CREATE SEQUENCE ' || NEW_NAME || ' START WITH ' || CURR_SEQ_VAL;\\012  EXECUTE 'DROP SEQUENCE ' || OLD_NAME;\\012  RETURN CURR_SEQ_VAL;\\012END;\\012$$ LANGUAGE 'plpgsql';\\012\\012\\012------------------------------------------------------------------------------------\\012--  Purpose:  Create trigger CONTROLLED_VOCABULARY_CHECK \\012------------------------------------------------------------------------------------\\012\\012CREATE OR REPLACE FUNCTION CONTROLLED_VOCABULARY_CHECK() RETURNS trigger AS $$\\012DECLARE\\012   v_code  CODE;\\012BEGIN\\012\\012   select code into v_code from data_types where id = NEW.daty_id;\\012\\012   -- Check if the data is of type "CONTROLLEDVOCABULARY"\\012   if v_code = 'CONTROLLEDVOCABULARY' then\\012      if NEW.covo_id IS NULL then\\012         RAISE EXCEPTION 'Insert/Update of Property Type (Code: %) failed, as its Data Type is CONTROLLEDVOCABULARY, but it is not linked to a Controlled Vocabulary.', NEW.code;\\012      end if;\\012   end if;\\012\\012   RETURN NEW;\\012\\012END;\\012$$ LANGUAGE 'plpgsql';\\012\\012CREATE TRIGGER CONTROLLED_VOCABULARY_CHECK BEFORE INSERT OR UPDATE ON PROPERTY_TYPES\\012    FOR EACH ROW EXECUTE PROCEDURE CONTROLLED_VOCABULARY_CHECK();\\012\\012\\012------------------------------------------------------------------------------------\\012--  Purpose:  Create trigger EXTERNAL_DATA_STORAGE_FORMAT_CHECK \\012------------------------------------------------------------------------------------\\012\\012CREATE OR REPLACE FUNCTION EXTERNAL_DATA_STORAGE_FORMAT_CHECK() RETURNS trigger AS $$\\012DECLARE\\012   v_covo_code  CODE;\\012   data_code CODE;\\012BEGIN\\012\\012   select code into v_covo_code from controlled_vocabularies\\012      where is_internal_namespace = true and \\012         id = (select covo_id from controlled_vocabulary_terms where id = NEW.cvte_id_stor_fmt);\\012   -- Check if the data storage format is a term of the controlled vocabulary "STORAGE_FORMAT"\\012   if v_covo_code != 'STORAGE_FORMAT' then\\012      select code into data_code from data where id = NEW.data_id; \\012      RAISE EXCEPTION 'Insert/Update of Data (Code: %) failed, as its Storage Format is %, but is required to be STORAGE_FORMAT.', data_code, v_covo_code;\\012   end if;\\012\\012   RETURN NEW;\\012\\012END;\\012$$ LANGUAGE 'plpgsql';\\012\\012CREATE TRIGGER EXTERNAL_DATA_STORAGE_FORMAT_CHECK BEFORE INSERT OR UPDATE ON EXTERNAL_DATA\\012    FOR EACH ROW EXECUTE PROCEDURE EXTERNAL_DATA_STORAGE_FORMAT_CHECK();\\012\\012------------------------------------------------------------------------------------\\012--  Purpose:  Create trigger SAMPLE_CODE_UNIQUENESS_CHECK \\012------------------------------------------------------------------------------------\\012\\012CREATE OR REPLACE FUNCTION SAMPLE_CODE_UNIQUENESS_CHECK() RETURNS trigger AS $$\\012DECLARE\\012   counter  INTEGER;\\012BEGIN\\012\\011IF (NEW.samp_id_part_of is NULL) THEN\\012\\011\\011IF (NEW.dbin_id is not NULL) THEN\\012\\011\\011\\011SELECT count(*) into counter FROM samples \\012\\011\\011\\011\\011where id != NEW.id and code = NEW.code and samp_id_part_of is NULL and dbin_id = NEW.dbin_id;\\012\\011\\011\\011IF (counter > 0) THEN\\012\\011\\011\\011\\011RAISE EXCEPTION 'Insert/Update of Sample (Code: %) failed because database instance sample with the same code already exists.', NEW.code;\\012\\011\\011\\011END IF;\\012\\011\\011ELSIF (NEW.grou_id is not NULL) THEN\\012\\011\\011\\011SELECT count(*) into counter FROM samples \\012\\011\\011\\011\\011where id != NEW.id and code = NEW.code and samp_id_part_of is NULL and grou_id = NEW.grou_id;\\012\\011\\011\\011IF (counter > 0) THEN\\012\\011\\011\\011\\011RAISE EXCEPTION 'Insert/Update of Sample (Code: %) failed because group sample with the same code already exists.', NEW.code;\\012\\011\\011\\011END IF;\\012\\011\\011END IF;\\012        ELSE\\012\\011\\011IF (NEW.dbin_id is not NULL) THEN\\012\\011\\011\\011SELECT count(*) into counter FROM samples \\012\\011\\011\\011\\011where id != NEW.id and code = NEW.code and samp_id_part_of = NEW.samp_id_part_of and dbin_id = NEW.dbin_id;\\012\\011\\011\\011IF (counter > 0) THEN\\012\\011\\011\\011\\011RAISE EXCEPTION 'Insert/Update of Sample (Code: %) failed because database instance sample with the same code and being the part of the same parent already exists.', NEW.code;\\012\\011\\011\\011END IF;\\012\\011\\011ELSIF (NEW.grou_id is not NULL) THEN\\012\\011\\011\\011SELECT count(*) into counter FROM samples \\012\\011\\011\\011\\011where id != NEW.id and code = NEW.code and samp_id_part_of = NEW.samp_id_part_of and grou_id = NEW.grou_id;\\012\\011\\011\\011IF (counter > 0) THEN\\012\\011\\011\\011\\011RAISE EXCEPTION 'Insert/Update of Sample (Code: %) failed because group sample with the same code and being the part of the same parent already exists.', NEW.code;\\012\\011\\011\\011END IF;\\012\\011\\011END IF;\\012        END IF;   \\012   RETURN NEW;\\012END;\\012$$ LANGUAGE 'plpgsql';\\012\\012CREATE TRIGGER SAMPLE_CODE_UNIQUENESS_CHECK BEFORE INSERT OR UPDATE ON SAMPLES\\012    FOR EACH ROW EXECUTE PROCEDURE SAMPLE_CODE_UNIQUENESS_CHECK();\\012	\N
+./sourceTest/sql/postgresql/040/.svn/text-base/017=database_version_logs.tsv.svn-base:028	source/sql/postgresql/migration/migration-027-028.sql	SUCCESS	2008-11-18 13:24:17.508	-- Create EXPERIMENT_ATTACHMENT_CONTENTS.\\012CREATE TABLE EXPERIMENT_ATTACHMENT_CONTENTS (ID TECH_ID NOT NULL,VALUE FILE NOT NULL);\\012CREATE SEQUENCE EXPERIMENT_ATTACHMENT_CONTENT_ID_SEQ;\\012ALTER TABLE EXPERIMENT_ATTACHMENT_CONTENTS ADD CONSTRAINT EXAC_PK PRIMARY KEY(ID);\\012\\012-- Alter EXPERIMENT_ATTACHMENTS by adding the new column which has a NULL constraint.\\012-- The NOT NULL constraint is added later on.\\012ALTER TABLE EXPERIMENT_ATTACHMENTS ADD COLUMN EXAC_ID TECH_ID;\\012\\012-- Does the VALUE migration between EXPERIMENT_ATTACHMENTS to EXPERIMENT_ATTACHMENT_CONTENTS.\\012CREATE OR REPLACE FUNCTION move_exp_att_content() RETURNS integer AS $$\\012DECLARE\\012    rec RECORD;\\012    seq BIGINT;\\012BEGIN\\012  FOR rec IN SELECT id, value FROM EXPERIMENT_ATTACHMENTS LOOP\\012  \\011seq := nextval('EXPERIMENT_ATTACHMENT_CONTENT_ID_SEQ');\\012    INSERT INTO EXPERIMENT_ATTACHMENT_CONTENTS (id, value) VALUES (seq, rec.value);\\012    UPDATE EXPERIMENT_ATTACHMENTS SET exac_id = seq WHERE id = rec.id;\\012  END LOOP;\\012  RETURN 1;\\012END;\\012$$ LANGUAGE 'plpgsql';\\012\\012-- Call the function.\\012SELECT move_exp_att_content();\\012DROP FUNCTION move_exp_att_content();\\012\\012\\012-- Finish EXPERIMENT_ATTACHMENTS changes.\\012ALTER TABLE EXPERIMENT_ATTACHMENTS ADD CONSTRAINT EXAT_CONT_FK FOREIGN KEY (EXAC_ID) REFERENCES EXPERIMENT_ATTACHMENT_CONTENTS(ID);\\012ALTER TABLE EXPERIMENT_ATTACHMENTS DROP COLUMN VALUE;\\012ALTER TABLE EXPERIMENT_ATTACHMENTS ALTER COLUMN EXAC_ID SET NOT NULL;\\012	\N
+./sourceTest/sql/postgresql/040/.svn/text-base/017=database_version_logs.tsv.svn-base:029	source/sql/postgresql/migration/migration-028-029.sql	SUCCESS	2009-03-18 10:50:20.105	-- -------\\012-- add modification_timestamp field to allow edition with Hibernate\\012-- -------\\012\\012ALTER TABLE samples\\012\\011ADD COLUMN modification_timestamp TIME_STAMP DEFAULT CURRENT_TIMESTAMP;\\012\\012ALTER TABLE experiments\\012\\011ADD COLUMN modification_timestamp TIME_STAMP DEFAULT CURRENT_TIMESTAMP;\\012\\012ALTER TABLE materials\\012\\011ADD COLUMN modification_timestamp TIME_STAMP DEFAULT CURRENT_TIMESTAMP;\\012\\012ALTER TABLE experiment_properties\\012\\011ADD COLUMN modification_timestamp TIME_STAMP DEFAULT CURRENT_TIMESTAMP;\\012\\012ALTER TABLE material_properties\\012\\011ADD COLUMN modification_timestamp TIME_STAMP DEFAULT CURRENT_TIMESTAMP;\\012\\012ALTER TABLE sample_properties\\012\\011ADD COLUMN modification_timestamp TIME_STAMP DEFAULT CURRENT_TIMESTAMP;\\012\\012-- -------\\012-- add property data type which references materials\\012-- -------\\012\\012ALTER TABLE property_types\\012\\011ADD COLUMN maty_prop_id tech_id;\\012\\012ALTER TABLE property_types\\012\\011ADD CONSTRAINT prty_maty_fk FOREIGN KEY (maty_prop_id) REFERENCES material_types(id);\\012\\012ALTER TABLE experiment_properties\\012\\011ADD COLUMN mate_prop_id tech_id;\\012\\012ALTER TABLE material_properties\\012\\011ADD COLUMN mate_prop_id tech_id;\\012\\012ALTER TABLE sample_properties\\012\\011ADD COLUMN mate_prop_id tech_id;\\012\\012ALTER TABLE experiment_properties\\012\\011ADD CONSTRAINT expr_mapr_fk FOREIGN KEY (mate_prop_id) REFERENCES materials(id);\\012\\012ALTER TABLE material_properties\\012\\011ADD CONSTRAINT mapr_mapr_fk FOREIGN KEY (mate_prop_id) REFERENCES materials(id);\\012\\012ALTER TABLE sample_properties\\012\\011ADD CONSTRAINT sapr_mapr_fk FOREIGN KEY (mate_prop_id) REFERENCES materials(id);\\012\\012insert into data_types\\012(id\\012 ,code\\012 ,description)\\012 values \\012 (nextval('DATA_TYPE_ID_SEQ')\\012 ,'MATERIAL'\\012 ,'Reference to a material'\\012);\\012\\012ALTER TABLE MATERIAL_PROPERTIES DROP CONSTRAINT MAPR_CK;\\012ALTER TABLE MATERIAL_PROPERTIES ADD CONSTRAINT MAPR_CK CHECK \\012\\011((VALUE IS NOT NULL AND CVTE_ID IS NULL AND MATE_PROP_ID IS NULL) OR \\012\\011 (VALUE IS NULL AND CVTE_ID IS NOT NULL AND MATE_PROP_ID IS NULL) OR\\012\\011 (VALUE IS NULL AND CVTE_ID IS NULL AND MATE_PROP_ID IS NOT NULL)\\012\\011);\\012\\012ALTER TABLE EXPERIMENT_PROPERTIES DROP CONSTRAINT EXPR_CK;\\012ALTER TABLE EXPERIMENT_PROPERTIES ADD CONSTRAINT EXPR_CK CHECK \\012\\011((VALUE IS NOT NULL AND CVTE_ID IS NULL AND MATE_PROP_ID IS NULL) OR \\012\\011 (VALUE IS NULL AND CVTE_ID IS NOT NULL AND MATE_PROP_ID IS NULL) OR\\012\\011 (VALUE IS NULL AND CVTE_ID IS NULL AND MATE_PROP_ID IS NOT NULL)\\012\\011);\\012\\012ALTER TABLE SAMPLE_PROPERTIES DROP CONSTRAINT SAPR_CK;\\012ALTER TABLE SAMPLE_PROPERTIES ADD CONSTRAINT SAPR_CK CHECK \\012\\011((VALUE IS NOT NULL AND CVTE_ID IS NULL AND MATE_PROP_ID IS NULL) OR \\012\\011 (VALUE IS NULL AND CVTE_ID IS NOT NULL AND MATE_PROP_ID IS NULL) OR\\012\\011 (VALUE IS NULL AND CVTE_ID IS NULL AND MATE_PROP_ID IS NOT NULL)\\012\\011);\\012\\012------------------------------------------------------------------------------------\\012--  Purpose:  Create trigger MATERIAL/SAMPLE/EXPERIMENT _PROPERTY_WITH_MATERIAL_DATA_TYPE_CHECK\\012--            It checks that if material property value is assigned to the entity,\\012--\\011\\011\\011\\011\\011\\011then the material type is equal to the one described by property type.\\012------------------------------------------------------------------------------------\\012\\012CREATE OR REPLACE FUNCTION MATERIAL_PROPERTY_WITH_MATERIAL_DATA_TYPE_CHECK() RETURNS trigger AS $$\\012DECLARE\\012   v_type_id  CODE;\\012   v_type_id_prop  CODE;\\012BEGIN\\012   if NEW.mate_prop_id IS NOT NULL then\\012\\011\\011\\011-- find material type id of the property type \\012\\011\\011\\011select pt.maty_prop_id into v_type_id_prop \\012\\011\\011\\011  from material_type_property_types etpt, property_types pt \\012\\011\\011\\011 where NEW.mtpt_id = etpt.id AND etpt.prty_id = pt.id;\\012\\011\\011\\012\\011\\011\\011if v_type_id_prop IS NOT NULL then\\012\\011\\011\\011\\011-- find material type id of the material which consists the entity's property value\\012\\011\\011\\011\\011select entity.maty_id into v_type_id \\012\\011\\011\\011\\011  from materials entity\\012\\011\\011\\011\\011 where NEW.mate_prop_id = entity.id;\\012\\011\\011\\011\\011if v_type_id != v_type_id_prop then\\012\\011\\011\\011\\011\\011RAISE EXCEPTION 'Insert/Update of property value referencing material (id: %) failed, as referenced material type is different than expected (id %, expected id: %).', \\012\\011\\011\\011\\011\\011\\011\\011 NEW.mate_prop_id, v_type_id, v_type_id_prop;\\012\\011\\011\\011\\011end if;\\012\\011\\011\\011end if;\\012   end if;\\012   RETURN NEW;\\012END;\\012$$ LANGUAGE 'plpgsql';\\012\\012CREATE TRIGGER MATERIAL_PROPERTY_WITH_MATERIAL_DATA_TYPE_CHECK BEFORE INSERT OR UPDATE ON material_properties\\012    FOR EACH ROW EXECUTE PROCEDURE MATERIAL_PROPERTY_WITH_MATERIAL_DATA_TYPE_CHECK();\\012    \\012CREATE OR REPLACE FUNCTION SAMPLE_PROPERTY_WITH_MATERIAL_DATA_TYPE_CHECK() RETURNS trigger AS $$\\012DECLARE\\012   v_type_id  CODE;\\012   v_type_id_prop  CODE;\\012BEGIN\\012   if NEW.mate_prop_id IS NOT NULL then\\012\\011\\011\\011-- find material type id of the property type \\012\\011\\011\\011select pt.maty_prop_id into v_type_id_prop \\012\\011\\011\\011  from sample_type_property_types etpt, property_types pt \\012\\011\\011\\011 where NEW.stpt_id = etpt.id AND etpt.prty_id = pt.id;\\012\\011\\011\\012\\011\\011\\011if v_type_id_prop IS NOT NULL then\\012\\011\\011\\011\\011-- find material type id of the material which consists the entity's property value\\012\\011\\011\\011\\011select entity.maty_id into v_type_id \\012\\011\\011\\011\\011  from materials entity\\012\\011\\011\\011\\011 where NEW.mate_prop_id = entity.id;\\012\\011\\011\\011\\011if v_type_id != v_type_id_prop then\\012\\011\\011\\011\\011\\011RAISE EXCEPTION 'Insert/Update of property value referencing material (id: %) failed, as referenced material type is different than expected (id %, expected id: %).', \\012\\011\\011\\011\\011\\011\\011\\011\\011\\011\\011\\011\\011 NEW.mate_prop_id, v_type_id, v_type_id_prop;\\012\\011\\011\\011\\011end if;\\012\\011\\011\\011end if;\\012   end if;\\012   RETURN NEW;\\012END;\\012$$ LANGUAGE 'plpgsql';\\012\\012CREATE TRIGGER SAMPLE_PROPERTY_WITH_MATERIAL_DATA_TYPE_CHECK BEFORE INSERT OR UPDATE ON sample_properties\\012    FOR EACH ROW EXECUTE PROCEDURE SAMPLE_PROPERTY_WITH_MATERIAL_DATA_TYPE_CHECK();\\012    \\012CREATE OR REPLACE FUNCTION EXPERIMENT_PROPERTY_WITH_MATERIAL_DATA_TYPE_CHECK() RETURNS trigger AS $$\\012DECLARE\\012   v_type_id  CODE;\\012   v_type_id_prop  CODE;\\012BEGIN\\012   if NEW.mate_prop_id IS NOT NULL then\\012\\011\\011\\011-- find material type id of the property type \\012\\011\\011\\011select pt.maty_prop_id into v_type_id_prop \\012\\011\\011\\011  from experiment_type_property_types etpt, property_types pt \\012\\011\\011\\011 where NEW.etpt_id = etpt.id AND etpt.prty_id = pt.id;\\012\\011\\011\\012\\011\\011\\011if v_type_id_prop IS NOT NULL then\\012\\011\\011\\011\\011-- find material type id of the material which consists the entity's property value\\012\\011\\011\\011\\011select entity.maty_id into v_type_id \\012\\011\\011\\011\\011  from materials entity\\012\\011\\011\\011\\011 where NEW.mate_prop_id = entity.id;\\012\\011\\011\\011\\011if v_type_id != v_type_id_prop then\\012\\011\\011\\011\\011\\011RAISE EXCEPTION 'Insert/Update of property value referencing material (id: %) failed, as referenced material type is different than expected (id %, expected id: %).', \\012\\011\\011\\011\\011\\011\\011\\011\\011\\011\\011\\011\\011 NEW.mate_prop_id, v_type_id, v_type_id_prop;\\012\\011\\011\\011\\011end if;\\012\\011\\011\\011end if;\\012   end if;\\012   RETURN NEW;\\012END;\\012$$ LANGUAGE 'plpgsql';\\012\\012CREATE TRIGGER EXPERIMENT_PROPERTY_WITH_MATERIAL_DATA_TYPE_CHECK BEFORE INSERT OR UPDATE ON experiment_properties\\012    FOR EACH ROW EXECUTE PROCEDURE EXPERIMENT_PROPERTY_WITH_MATERIAL_DATA_TYPE_CHECK();\\012       \\012-- -------\\012-- remove the reminescents of the OBSERVABLE_TYPE\\012-- -------\\012\\012ALTER TABLE data\\012\\011DROP CONSTRAINT data_obty_fk;\\012\\012ALTER TABLE data_set_types\\012\\011DROP CONSTRAINT obty_pk;\\012\\012ALTER TABLE data_set_types\\012\\011ADD CONSTRAINT dsty_pk PRIMARY KEY (id);\\012\\012ALTER TABLE data\\012\\011ADD CONSTRAINT data_dsty_fk FOREIGN KEY (dsty_id) REFERENCES data_set_types(id);\\012\\012ALTER TABLE data_set_types\\012\\011DROP CONSTRAINT obty_bk_uk;\\012\\012ALTER TABLE data_set_types\\012\\011DROP CONSTRAINT obty_dbin_fk;\\012\\012ALTER TABLE data_set_types\\012\\011ADD CONSTRAINT dsty_bk_uk UNIQUE (code, dbin_id);\\012\\012ALTER TABLE data_set_types\\012\\011ADD CONSTRAINT dsty_dbin_fk FOREIGN KEY (dbin_id) REFERENCES database_instances(id);\\012\\012DROP INDEX data_obty_fk_i;\\012\\012CREATE INDEX data_dsty_fk_i ON data(dsty_id);\\012	\N
+./sourceTest/sql/postgresql/040/.svn/text-base/017=database_version_logs.tsv.svn-base:030	source/sql/postgresql/migration/migration-029-030.sql	SUCCESS	2009-03-23 15:34:44.72	-- -------\\012-- add modification_timestamp field to allow edition with Hibernate\\012-- -------\\012ALTER TABLE data\\012\\011ADD COLUMN modification_timestamp TIME_STAMP DEFAULT CURRENT_TIMESTAMP;\\012ALTER TABLE experiment_types\\012\\011ADD COLUMN modification_timestamp TIME_STAMP DEFAULT CURRENT_TIMESTAMP;\\012ALTER TABLE sample_types\\012\\011ADD COLUMN modification_timestamp TIME_STAMP DEFAULT CURRENT_TIMESTAMP;\\012ALTER TABLE material_types\\012\\011ADD COLUMN modification_timestamp TIME_STAMP DEFAULT CURRENT_TIMESTAMP;\\012ALTER TABLE data_set_types\\012\\011ADD COLUMN modification_timestamp TIME_STAMP DEFAULT CURRENT_TIMESTAMP;\\012ALTER TABLE controlled_vocabularies\\012\\011ADD COLUMN modification_timestamp TIME_STAMP DEFAULT CURRENT_TIMESTAMP;\\012-- -------\\012-- add properties to data sets\\012-- -------\\012CREATE TABLE DATA_SET_PROPERTIES (ID TECH_ID NOT NULL,DS_ID TECH_ID NOT NULL,DSTPT_ID TECH_ID NOT NULL,VALUE GENERIC_VALUE,CVTE_ID TECH_ID, MATE_PROP_ID TECH_ID, PERS_ID_REGISTERER TECH_ID NOT NULL,REGISTRATION_TIMESTAMP TIME_STAMP_DFL NOT NULL DEFAULT CURRENT_TIMESTAMP, MODIFICATION_TIMESTAMP TIME_STAMP DEFAULT CURRENT_TIMESTAMP);\\012CREATE TABLE DATA_SET_TYPE_PROPERTY_TYPES (ID TECH_ID NOT NULL,DSTY_ID TECH_ID NOT NULL,PRTY_ID TECH_ID NOT NULL,IS_MANDATORY BOOLEAN_CHAR NOT NULL DEFAULT 'F',IS_MANAGED_INTERNALLY BOOLEAN_CHAR NOT NULL DEFAULT 'F',PERS_ID_REGISTERER TECH_ID NOT NULL,REGISTRATION_TIMESTAMP TIME_STAMP_DFL NOT NULL DEFAULT CURRENT_TIMESTAMP);\\012\\012CREATE SEQUENCE DATA_SET_PROPERTY_ID_SEQ;\\012CREATE SEQUENCE DSTPT_ID_SEQ;\\012\\012ALTER TABLE DATA_SET_TYPE_PROPERTY_TYPES ADD CONSTRAINT DSTPT_PK PRIMARY KEY(ID);\\012ALTER TABLE DATA_SET_PROPERTIES ADD CONSTRAINT DSPR_PK PRIMARY KEY(ID);\\012\\012ALTER TABLE DATA_SET_TYPE_PROPERTY_TYPES ADD CONSTRAINT DSTPT_BK_UK UNIQUE(DSTY_ID,PRTY_ID);\\012ALTER TABLE DATA_SET_PROPERTIES ADD CONSTRAINT DSPR_BK_UK UNIQUE(DS_ID,DSTPT_ID);\\012\\012\\012ALTER TABLE DATA_SET_TYPE_PROPERTY_TYPES ADD CONSTRAINT DSTPT_DSTY_FK FOREIGN KEY (DSTY_ID) REFERENCES DATA_SET_TYPES(ID);\\012ALTER TABLE DATA_SET_TYPE_PROPERTY_TYPES ADD CONSTRAINT DSTPT_PERS_FK FOREIGN KEY (PERS_ID_REGISTERER) REFERENCES PERSONS(ID);\\012ALTER TABLE DATA_SET_TYPE_PROPERTY_TYPES ADD CONSTRAINT DSTPT_PRTY_FK FOREIGN KEY (PRTY_ID) REFERENCES PROPERTY_TYPES(ID);\\012ALTER TABLE DATA_SET_PROPERTIES ADD CONSTRAINT DSPR_CVTE_FK FOREIGN KEY (CVTE_ID) REFERENCES CONTROLLED_VOCABULARY_TERMS(ID);\\012ALTER TABLE DATA_SET_PROPERTIES ADD CONSTRAINT DSPR_DSTPT_FK FOREIGN KEY (DSTPT_ID) REFERENCES DATA_SET_TYPE_PROPERTY_TYPES(ID) ON DELETE CASCADE;\\012ALTER TABLE DATA_SET_PROPERTIES ADD CONSTRAINT DSPR_DS_FK FOREIGN KEY (DS_ID) REFERENCES DATA(ID);\\012ALTER TABLE DATA_SET_PROPERTIES ADD CONSTRAINT DSPR_PERS_FK FOREIGN KEY (PERS_ID_REGISTERER) REFERENCES PERSONS(ID);\\012ALTER TABLE DATA_SET_PROPERTIES ADD CONSTRAINT DSPR_MAPR_FK FOREIGN KEY (MATE_PROP_ID) REFERENCES MATERIALS(ID);\\012\\012ALTER TABLE DATA_SET_PROPERTIES ADD CONSTRAINT DSPR_CK CHECK \\012\\011((VALUE IS NOT NULL AND CVTE_ID IS NULL AND MATE_PROP_ID IS NULL) OR \\012\\011 (VALUE IS NULL AND CVTE_ID IS NOT NULL AND MATE_PROP_ID IS NULL) OR\\012\\011 (VALUE IS NULL AND CVTE_ID IS NULL AND MATE_PROP_ID IS NOT NULL)\\012\\011);\\012\\012CREATE INDEX DSPR_CVTE_FK_I ON DATA_SET_PROPERTIES (CVTE_ID);\\012CREATE INDEX DSPR_DSTPT_FK_I ON DATA_SET_PROPERTIES (DSTPT_ID);\\012CREATE INDEX DSPR_DS_FK_I ON DATA_SET_PROPERTIES (DS_ID);\\012CREATE INDEX DSPR_PERS_FK_I ON DATA_SET_PROPERTIES (PERS_ID_REGISTERER);\\012CREATE INDEX DSTPT_DSTY_FK_I ON DATA_SET_TYPE_PROPERTY_TYPES (DSTY_ID);\\012CREATE INDEX DSTPT_PERS_FK_I ON DATA_SET_TYPE_PROPERTY_TYPES (PERS_ID_REGISTERER);\\012CREATE INDEX DSTPT_PRTY_FK_I ON DATA_SET_TYPE_PROPERTY_TYPES (PRTY_ID);\\012\\012CREATE OR REPLACE FUNCTION DATA_SET_PROPERTY_WITH_MATERIAL_DATA_TYPE_CHECK() RETURNS trigger AS $$\\012DECLARE\\012   v_type_id  CODE;\\012   v_type_id_prop  CODE;\\012BEGIN\\012   if NEW.mate_prop_id IS NOT NULL then\\012\\011\\011\\011-- find material type id of the property type \\012\\011\\011\\011select pt.maty_prop_id into v_type_id_prop \\012\\011\\011\\011  from data_set_type_property_types dstpt, property_types pt \\012\\011\\011\\011 where NEW.dstpt_id = dstpt.id AND dstpt.prty_id = pt.id;\\012\\011\\011\\012\\011\\011\\011if v_type_id_prop IS NOT NULL then\\012\\011\\011\\011\\011-- find material type id of the material which consists the entity's property value\\012\\011\\011\\011\\011select entity.maty_id into v_type_id \\012\\011\\011\\011\\011  from materials entity\\012\\011\\011\\011\\011 where NEW.mate_prop_id = entity.id;\\012\\011\\011\\011\\011if v_type_id != v_type_id_prop then\\012\\011\\011\\011\\011\\011RAISE EXCEPTION 'Insert/Update of property value referencing material (id: %) failed, as referenced material type is different than expected (id %, expected id: %).', \\012\\011\\011\\011\\011\\011\\011\\011\\011\\011\\011\\011\\011 NEW.mate_prop_id, v_type_id, v_type_id_prop;\\012\\011\\011\\011\\011end if;\\012\\011\\011\\011end if;\\012   end if;\\012   RETURN NEW;\\012END;\\012$$ LANGUAGE 'plpgsql';\\012\\012CREATE TRIGGER DATA_SET_PROPERTY_WITH_MATERIAL_DATA_TYPE_CHECK BEFORE INSERT OR UPDATE ON data_set_properties\\012    FOR EACH ROW EXECUTE PROCEDURE DATA_SET_PROPERTY_WITH_MATERIAL_DATA_TYPE_CHECK();   \\012	\N
+./sourceTest/sql/postgresql/040/.svn/text-base/017=database_version_logs.tsv.svn-base:032	source/sql/postgresql/migration/migration-031-032.sql	SUCCESS	2009-04-09 09:36:36.20	-- -------\\012-- Modify MATERIAL_BATCHES\\012-- -------\\012\\012ALTER TABLE material_batches\\012    DROP COLUMN proc_id;\\012\\012-- -------\\012-- Modify SAMPLES\\012-- -------\\012\\012ALTER TABLE samples\\012    ADD COLUMN expe_id tech_id;\\012\\012ALTER TABLE samples\\012    ADD CONSTRAINT samp_expe_fk FOREIGN KEY (expe_id) REFERENCES experiments(id);\\012\\012CREATE INDEX samp_expe_fk_i ON samples USING btree (expe_id);\\012\\012-- relink samples directly to experiments\\012\\012UPDATE samples\\012SET expe_id = (SELECT e.id FROM experiments e, procedures p, sample_inputs si \\012               WHERE si.samp_id = samples.id AND si.proc_id = p.id AND p.expe_id = e.id AND e.inva_id IS NULL);\\012\\012\\012-- -------\\012-- Modify DATA\\012-- -------\\012\\012ALTER TABLE data\\012    ADD COLUMN expe_id tech_id;\\012\\012ALTER TABLE data\\012    ADD CONSTRAINT data_expe_fk FOREIGN KEY (expe_id) REFERENCES experiments(id);\\012\\012CREATE INDEX data_expe_fk_i ON data USING btree (expe_id);\\012\\012UPDATE data\\012SET expe_id = (SELECT e.id FROM experiments e, procedures p \\012               WHERE data.proc_id_produced_by = p.id AND p.expe_id = e.id);\\012\\012ALTER TABLE data\\012    ALTER COLUMN expe_id SET NOT NULL;\\012\\012ALTER TABLE data\\012    DROP COLUMN proc_id_produced_by;\\012\\012-- -------\\012-- Drop PROCEDURES, PROCEDURE_TYPES, and SAMPLE_INPUTS\\012-- -------\\012\\012DROP TABLE sample_inputs;\\012DROP TABLE procedures;\\012DROP TABLE procedure_types;\\012\\012DROP SEQUENCE procedure_id_seq;\\012DROP SEQUENCE procedure_type_id_seq;\\012\\012-- -------\\012-- Add CODE_SEQ\\012-- -------\\012\\012CREATE SEQUENCE CODE_SEQ;\\012\\012-- -------\\012-- Add new columns to DATA_STORES\\012-- -------\\012\\012ALTER TABLE data_stores\\012    ADD COLUMN remote_url character varying(250),\\012    ADD COLUMN session_token character varying(50),\\012    ADD COLUMN modification_timestamp time_stamp DEFAULT now();\\012\\012UPDATE data_stores\\012SET remote_url = '', session_token='';\\012\\012ALTER TABLE data_stores\\012    ALTER COLUMN remote_url SET NOT NULL,\\012    ALTER COLUMN session_token SET NOT NULL;\\012\\012-- -------\\012-- Drop foreign keys onto DATA_STORES\\012-- -------\\012\\012ALTER TABLE database_instances\\012    DROP COLUMN dast_id;\\012\\012ALTER TABLE groups\\012    DROP COLUMN dast_id;\\012\\012ALTER TABLE projects\\012    DROP COLUMN dast_id;\\012\\012ALTER TABLE experiments\\012    DROP COLUMN dast_id;\\012\\012-- -------\\012-- Add foreign key from DATA onto DATA_STORES\\012-- -------\\012\\012ALTER TABLE data\\012    ADD COLUMN dast_id tech_id;\\012\\012ALTER TABLE data\\012    ADD CONSTRAINT data_dast_fk FOREIGN KEY (dast_id) REFERENCES data_stores(id);\\012\\012UPDATE data\\012SET dast_id = (select id from data_stores where code = 'STANDARD');\\012\\012ALTER TABLE data\\012    ALTER COLUMN dast_id SET NOT NULL;\\012\\012\\012------------------------------------------------------------------------------------\\012--  Purpose:  Replace trigger SAMPLE_CODE_UNIQUENESS_CHECK \\012------------------------------------------------------------------------------------\\012\\012CREATE OR REPLACE FUNCTION SAMPLE_CODE_UNIQUENESS_CHECK() RETURNS trigger AS $$\\012DECLARE\\012   counter  INTEGER;\\012BEGIN\\012    LOCK TABLE samples IN EXCLUSIVE MODE;\\012    IF (NEW.samp_id_part_of is NULL) THEN\\012        IF (NEW.dbin_id is not NULL) THEN\\012            SELECT count(*) into counter FROM samples \\012                where id != NEW.id and code = NEW.code and samp_id_part_of is NULL and dbin_id = NEW.dbin_id;\\012            IF (counter > 0) THEN\\012                RAISE EXCEPTION 'Insert/Update of Sample (Code: %) failed because database instance sample with the same code already exists.', NEW.code;\\012            END IF;\\012        ELSIF (NEW.grou_id is not NULL) THEN\\012            SELECT count(*) into counter FROM samples \\012                where id != NEW.id and code = NEW.code and samp_id_part_of is NULL and grou_id = NEW.grou_id;\\012            IF (counter > 0) THEN\\012                RAISE EXCEPTION 'Insert/Update of Sample (Code: %) failed because group sample with the same code already exists.', NEW.code;\\012            END IF;\\012        END IF;\\012        ELSE\\012        IF (NEW.dbin_id is not NULL) THEN\\012            SELECT count(*) into counter FROM samples \\012                where id != NEW.id and code = NEW.code and samp_id_part_of = NEW.samp_id_part_of and dbin_id = NEW.dbin_id;\\012            IF (counter > 0) THEN\\012                RAISE EXCEPTION 'Insert/Update of Sample (Code: %) failed because database instance sample with the same code and being the part of the same parent already exists.', NEW.code;\\012            END IF;\\012        ELSIF (NEW.grou_id is not NULL) THEN\\012            SELECT count(*) into counter FROM samples \\012                where id != NEW.id and code = NEW.code and samp_id_part_of = NEW.samp_id_part_of and grou_id = NEW.grou_id;\\012            IF (counter > 0) THEN\\012                RAISE EXCEPTION 'Insert/Update of Sample (Code: %) failed because group sample with the same code and being the part of the same parent already exists.', NEW.code;\\012            END IF;\\012        END IF;\\012        END IF;   \\012   RETURN NEW;\\012END;\\012$$ LANGUAGE 'plpgsql';\\012\\012\\012\\012	\N
+./sourceTest/sql/postgresql/040/.svn/text-base/017=database_version_logs.tsv.svn-base:034	source/sql/postgresql/migration/migration-033-034.sql	SUCCESS	2009-05-26 08:32:49.935	------------------------------------------------------------------------------------\\012-- Create sequence for generating permanent identifiers starting with nextval of existing dataset sequence.\\012------------------------------------------------------------------------------------\\012CREATE FUNCTION CREATE_SEQUENCE(EXISTING_SEQUENCE VARCHAR, NEW_SEQUENCE VARCHAR) RETURNS VOID AS $$\\012DECLARE\\012  CURR_SEQ_VAL   INTEGER;\\012BEGIN\\012  SELECT INTO CURR_SEQ_VAL NEXTVAL(EXISTING_SEQUENCE);\\012  EXECUTE 'CREATE SEQUENCE ' || NEW_SEQUENCE || ' START WITH ' || CURR_SEQ_VAL;\\012  RETURN;\\012END;\\012$$ LANGUAGE 'plpgsql';\\012\\012SELECT CREATE_SEQUENCE('DATA_ID_SEQ', 'PERM_ID_SEQ');\\012DROP FUNCTION CREATE_SEQUENCE(VARCHAR, VARCHAR);\\012\\012------------------------------------------------------------------------------------\\012-- Add perm_id columns to samples and experiments.\\012------------------------------------------------------------------------------------\\012ALTER TABLE SAMPLES ADD COLUMN PERM_ID CODE;\\012ALTER TABLE EXPERIMENTS ADD COLUMN PERM_ID CODE;\\012\\012UPDATE SAMPLES SET PERM_ID = to_char(registration_timestamp,'YYYYMMDDHHSSMS') || '-' || NEXTVAL('PERM_ID_SEQ');\\012UPDATE EXPERIMENTS SET PERM_ID = to_char(registration_timestamp,'YYYYMMDDHHSSMS') || '-' || NEXTVAL('PERM_ID_SEQ');\\012ALTER TABLE SAMPLES ALTER COLUMN PERM_ID SET NOT NULL;\\012ALTER TABLE EXPERIMENTS ALTER COLUMN PERM_ID SET NOT NULL;\\012ALTER TABLE SAMPLES ADD CONSTRAINT SAMP_PI_UK UNIQUE(PERM_ID);\\012ALTER TABLE EXPERIMENTS ADD CONSTRAINT EXPE_PI_UK UNIQUE(PERM_ID);\\012\\012\\012------------------------------------------------------------------------------------\\012-- Add column is_chosen_from_list to controlled_vocabularies.\\012------------------------------------------------------------------------------------\\012ALTER TABLE controlled_vocabularies ADD COLUMN is_chosen_from_list BOOLEAN_CHAR NOT NULL DEFAULT TRUE;\\012ALTER TABLE controlled_vocabularies ADD COLUMN source_uri CHARACTER VARYING(250);\\012------------------------------------------------------------------------------------\\012-- Modify Data table - remove arc connection between Sample and Data table, use a flag instead\\012------------------------------------------------------------------------------------\\012\\012-- add new columns\\012\\012ALTER TABLE data\\012    ADD COLUMN is_derived boolean_char;\\012ALTER TABLE data\\012    ADD COLUMN samp_id tech_id;\\012\\012-- update values in new columns\\012\\012UPDATE data\\012    SET is_derived = (samp_id_derived_from IS NOT NULL); \\012UPDATE data\\012    SET samp_id = samp_id_derived_from \\012    WHERE is_derived = 'TRUE';\\012UPDATE data\\012    SET samp_id = samp_id_acquired_from \\012    WHERE is_derived = 'FALSE';\\012\\012-- add constraints and indexes to new columns\\012\\012ALTER TABLE data\\012    ALTER COLUMN is_derived SET NOT NULL;\\012ALTER TABLE data\\012    ALTER COLUMN samp_id SET NOT NULL;   \\012ALTER TABLE data\\012    ADD CONSTRAINT data_samp_fk FOREIGN KEY (samp_id) REFERENCES samples (id);\\012CREATE INDEX data_samp_fk_i ON data USING btree (samp_id);\\012\\012-- remove old columns\\012\\012ALTER TABLE data\\012    DROP COLUMN samp_id_acquired_from;\\012ALTER TABLE data\\012    DROP COLUMN samp_id_derived_from;\\012    \\012------------------------------------------------------------------------------------\\012-- Granting SELECT privilege to group openbis_readonly\\012------------------------------------------------------------------------------------\\012\\012GRANT SELECT ON SEQUENCE attachment_content_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE attachment_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE code_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE controlled_vocabulary_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE cvte_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE data_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE data_set_property_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE data_set_relationship_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE data_set_type_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE data_store_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE data_type_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE database_instance_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE dstpt_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE etpt_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE event_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE experiment_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE experiment_property_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE experiment_type_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE file_format_type_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE group_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE invalidation_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE locator_type_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE material_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE material_property_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE material_type_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE mtpt_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE perm_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE person_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE project_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE property_type_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE role_assignment_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE sample_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE sample_property_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE sample_type_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE stpt_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE attachment_contents TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE attachments TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE controlled_vocabularies TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE controlled_vocabulary_terms TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE data TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE data_set_properties TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE data_set_relationships TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE data_set_type_property_types TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE data_set_types TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE data_stores TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE data_types TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE database_instances TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE database_version_logs TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE events TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE experiment_properties TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE experiment_type_property_types TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE experiment_types TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE experiments TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE external_data TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE file_format_types TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE groups TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE invalidations TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE locator_types TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE material_properties TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE material_type_property_types TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE material_types TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE materials TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE persons TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE projects TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE property_types TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE role_assignments TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE sample_properties TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE sample_type_property_types TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE sample_types TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE samples TO GROUP OPENBIS_READONLY;\\012\\012------------------------------------------------------------------------------------\\012-- Delete MATERIAL_BATCHES table\\012------------------------------------------------------------------------------------\\012\\012-- WARNING: Potential data lost!!!\\012-- WARNING: Potential data lost!!!\\012-- WARNING: Potential data lost!!!\\012\\012DROP TABLE SAMPLE_MATERIAL_BATCHES;\\012DROP TABLE MATERIAL_BATCHES;\\012DROP SEQUENCE MATERIAL_BATCH_ID_SEQ;\\012\\012------------------------------------------------------------------------------------\\012-- Delete MATE_ID_INHIBITOR_OF from table MATERIALS\\012------------------------------------------------------------------------------------\\012\\012-- WARNING: Potential data lost!!!\\012-- WARNING: Potential data lost!!!\\012-- WARNING: Potential data lost!!!\\012\\012ALTER TABLE MATERIALS DROP COLUMN MATE_ID_INHIBITOR_OF;\\012	\N
+./sourceTest/sql/postgresql/040/.svn/text-base/schema-040.sql.svn-base:    LANGUAGE plpgsql;
+./sourceTest/sql/postgresql/040/.svn/text-base/schema-040.sql.svn-base:    LANGUAGE plpgsql;
+./sourceTest/sql/postgresql/040/.svn/text-base/schema-040.sql.svn-base:    LANGUAGE plpgsql;
+./sourceTest/sql/postgresql/040/.svn/text-base/schema-040.sql.svn-base:    LANGUAGE plpgsql;
+./sourceTest/sql/postgresql/040/.svn/text-base/schema-040.sql.svn-base:    LANGUAGE plpgsql;
+./sourceTest/sql/postgresql/040/.svn/text-base/schema-040.sql.svn-base:    LANGUAGE plpgsql;
+./sourceTest/sql/postgresql/040/.svn/text-base/schema-040.sql.svn-base:    LANGUAGE plpgsql;
+./sourceTest/sql/postgresql/040/.svn/text-base/schema-040.sql.svn-base:    LANGUAGE plpgsql;
+./sourceTest/sql/postgresql/040/017=database_version_logs.tsv:027	D:\\User\\felmer\\dev-workspace\\openbis/source/sql/postgresql/027/function-027.sql	SUCCESS	2008-11-05 09:18:00.403	-- Creating Functions\\012\\012------------------------------------------------------------------------------------\\012--  Purpose:  Create function RENAME_SEQUENCE() that is required for renaming the sequences belonging to tables\\012------------------------------------------------------------------------------------\\012CREATE FUNCTION RENAME_SEQUENCE(OLD_NAME VARCHAR, NEW_NAME VARCHAR) RETURNS INTEGER AS $$\\012DECLARE\\012  CURR_SEQ_VAL   INTEGER;\\012BEGIN\\012  SELECT INTO CURR_SEQ_VAL NEXTVAL(OLD_NAME);\\012  EXECUTE 'CREATE SEQUENCE ' || NEW_NAME || ' START WITH ' || CURR_SEQ_VAL;\\012  EXECUTE 'DROP SEQUENCE ' || OLD_NAME;\\012  RETURN CURR_SEQ_VAL;\\012END;\\012$$ LANGUAGE 'plpgsql';\\012\\012\\012------------------------------------------------------------------------------------\\012--  Purpose:  Create trigger CONTROLLED_VOCABULARY_CHECK \\012------------------------------------------------------------------------------------\\012\\012CREATE OR REPLACE FUNCTION CONTROLLED_VOCABULARY_CHECK() RETURNS trigger AS $$\\012DECLARE\\012   v_code  CODE;\\012BEGIN\\012\\012   select code into v_code from data_types where id = NEW.daty_id;\\012\\012   -- Check if the data is of type "CONTROLLEDVOCABULARY"\\012   if v_code = 'CONTROLLEDVOCABULARY' then\\012      if NEW.covo_id IS NULL then\\012         RAISE EXCEPTION 'Insert/Update of Property Type (Code: %) failed, as its Data Type is CONTROLLEDVOCABULARY, but it is not linked to a Controlled Vocabulary.', NEW.code;\\012      end if;\\012   end if;\\012\\012   RETURN NEW;\\012\\012END;\\012$$ LANGUAGE 'plpgsql';\\012\\012CREATE TRIGGER CONTROLLED_VOCABULARY_CHECK BEFORE INSERT OR UPDATE ON PROPERTY_TYPES\\012    FOR EACH ROW EXECUTE PROCEDURE CONTROLLED_VOCABULARY_CHECK();\\012\\012\\012------------------------------------------------------------------------------------\\012--  Purpose:  Create trigger EXTERNAL_DATA_STORAGE_FORMAT_CHECK \\012------------------------------------------------------------------------------------\\012\\012CREATE OR REPLACE FUNCTION EXTERNAL_DATA_STORAGE_FORMAT_CHECK() RETURNS trigger AS $$\\012DECLARE\\012   v_covo_code  CODE;\\012   data_code CODE;\\012BEGIN\\012\\012   select code into v_covo_code from controlled_vocabularies\\012      where is_internal_namespace = true and \\012         id = (select covo_id from controlled_vocabulary_terms where id = NEW.cvte_id_stor_fmt);\\012   -- Check if the data storage format is a term of the controlled vocabulary "STORAGE_FORMAT"\\012   if v_covo_code != 'STORAGE_FORMAT' then\\012      select code into data_code from data where id = NEW.data_id; \\012      RAISE EXCEPTION 'Insert/Update of Data (Code: %) failed, as its Storage Format is %, but is required to be STORAGE_FORMAT.', data_code, v_covo_code;\\012   end if;\\012\\012   RETURN NEW;\\012\\012END;\\012$$ LANGUAGE 'plpgsql';\\012\\012CREATE TRIGGER EXTERNAL_DATA_STORAGE_FORMAT_CHECK BEFORE INSERT OR UPDATE ON EXTERNAL_DATA\\012    FOR EACH ROW EXECUTE PROCEDURE EXTERNAL_DATA_STORAGE_FORMAT_CHECK();\\012\\012------------------------------------------------------------------------------------\\012--  Purpose:  Create trigger SAMPLE_CODE_UNIQUENESS_CHECK \\012------------------------------------------------------------------------------------\\012\\012CREATE OR REPLACE FUNCTION SAMPLE_CODE_UNIQUENESS_CHECK() RETURNS trigger AS $$\\012DECLARE\\012   counter  INTEGER;\\012BEGIN\\012\\011IF (NEW.samp_id_part_of is NULL) THEN\\012\\011\\011IF (NEW.dbin_id is not NULL) THEN\\012\\011\\011\\011SELECT count(*) into counter FROM samples \\012\\011\\011\\011\\011where id != NEW.id and code = NEW.code and samp_id_part_of is NULL and dbin_id = NEW.dbin_id;\\012\\011\\011\\011IF (counter > 0) THEN\\012\\011\\011\\011\\011RAISE EXCEPTION 'Insert/Update of Sample (Code: %) failed because database instance sample with the same code already exists.', NEW.code;\\012\\011\\011\\011END IF;\\012\\011\\011ELSIF (NEW.grou_id is not NULL) THEN\\012\\011\\011\\011SELECT count(*) into counter FROM samples \\012\\011\\011\\011\\011where id != NEW.id and code = NEW.code and samp_id_part_of is NULL and grou_id = NEW.grou_id;\\012\\011\\011\\011IF (counter > 0) THEN\\012\\011\\011\\011\\011RAISE EXCEPTION 'Insert/Update of Sample (Code: %) failed because group sample with the same code already exists.', NEW.code;\\012\\011\\011\\011END IF;\\012\\011\\011END IF;\\012        ELSE\\012\\011\\011IF (NEW.dbin_id is not NULL) THEN\\012\\011\\011\\011SELECT count(*) into counter FROM samples \\012\\011\\011\\011\\011where id != NEW.id and code = NEW.code and samp_id_part_of = NEW.samp_id_part_of and dbin_id = NEW.dbin_id;\\012\\011\\011\\011IF (counter > 0) THEN\\012\\011\\011\\011\\011RAISE EXCEPTION 'Insert/Update of Sample (Code: %) failed because database instance sample with the same code and being the part of the same parent already exists.', NEW.code;\\012\\011\\011\\011END IF;\\012\\011\\011ELSIF (NEW.grou_id is not NULL) THEN\\012\\011\\011\\011SELECT count(*) into counter FROM samples \\012\\011\\011\\011\\011where id != NEW.id and code = NEW.code and samp_id_part_of = NEW.samp_id_part_of and grou_id = NEW.grou_id;\\012\\011\\011\\011IF (counter > 0) THEN\\012\\011\\011\\011\\011RAISE EXCEPTION 'Insert/Update of Sample (Code: %) failed because group sample with the same code and being the part of the same parent already exists.', NEW.code;\\012\\011\\011\\011END IF;\\012\\011\\011END IF;\\012        END IF;   \\012   RETURN NEW;\\012END;\\012$$ LANGUAGE 'plpgsql';\\012\\012CREATE TRIGGER SAMPLE_CODE_UNIQUENESS_CHECK BEFORE INSERT OR UPDATE ON SAMPLES\\012    FOR EACH ROW EXECUTE PROCEDURE SAMPLE_CODE_UNIQUENESS_CHECK();\\012	\N
+./sourceTest/sql/postgresql/040/017=database_version_logs.tsv:028	source/sql/postgresql/migration/migration-027-028.sql	SUCCESS	2008-11-18 13:24:17.508	-- Create EXPERIMENT_ATTACHMENT_CONTENTS.\\012CREATE TABLE EXPERIMENT_ATTACHMENT_CONTENTS (ID TECH_ID NOT NULL,VALUE FILE NOT NULL);\\012CREATE SEQUENCE EXPERIMENT_ATTACHMENT_CONTENT_ID_SEQ;\\012ALTER TABLE EXPERIMENT_ATTACHMENT_CONTENTS ADD CONSTRAINT EXAC_PK PRIMARY KEY(ID);\\012\\012-- Alter EXPERIMENT_ATTACHMENTS by adding the new column which has a NULL constraint.\\012-- The NOT NULL constraint is added later on.\\012ALTER TABLE EXPERIMENT_ATTACHMENTS ADD COLUMN EXAC_ID TECH_ID;\\012\\012-- Does the VALUE migration between EXPERIMENT_ATTACHMENTS to EXPERIMENT_ATTACHMENT_CONTENTS.\\012CREATE OR REPLACE FUNCTION move_exp_att_content() RETURNS integer AS $$\\012DECLARE\\012    rec RECORD;\\012    seq BIGINT;\\012BEGIN\\012  FOR rec IN SELECT id, value FROM EXPERIMENT_ATTACHMENTS LOOP\\012  \\011seq := nextval('EXPERIMENT_ATTACHMENT_CONTENT_ID_SEQ');\\012    INSERT INTO EXPERIMENT_ATTACHMENT_CONTENTS (id, value) VALUES (seq, rec.value);\\012    UPDATE EXPERIMENT_ATTACHMENTS SET exac_id = seq WHERE id = rec.id;\\012  END LOOP;\\012  RETURN 1;\\012END;\\012$$ LANGUAGE 'plpgsql';\\012\\012-- Call the function.\\012SELECT move_exp_att_content();\\012DROP FUNCTION move_exp_att_content();\\012\\012\\012-- Finish EXPERIMENT_ATTACHMENTS changes.\\012ALTER TABLE EXPERIMENT_ATTACHMENTS ADD CONSTRAINT EXAT_CONT_FK FOREIGN KEY (EXAC_ID) REFERENCES EXPERIMENT_ATTACHMENT_CONTENTS(ID);\\012ALTER TABLE EXPERIMENT_ATTACHMENTS DROP COLUMN VALUE;\\012ALTER TABLE EXPERIMENT_ATTACHMENTS ALTER COLUMN EXAC_ID SET NOT NULL;\\012	\N
+./sourceTest/sql/postgresql/040/017=database_version_logs.tsv:029	source/sql/postgresql/migration/migration-028-029.sql	SUCCESS	2009-03-18 10:50:20.105	-- -------\\012-- add modification_timestamp field to allow edition with Hibernate\\012-- -------\\012\\012ALTER TABLE samples\\012\\011ADD COLUMN modification_timestamp TIME_STAMP DEFAULT CURRENT_TIMESTAMP;\\012\\012ALTER TABLE experiments\\012\\011ADD COLUMN modification_timestamp TIME_STAMP DEFAULT CURRENT_TIMESTAMP;\\012\\012ALTER TABLE materials\\012\\011ADD COLUMN modification_timestamp TIME_STAMP DEFAULT CURRENT_TIMESTAMP;\\012\\012ALTER TABLE experiment_properties\\012\\011ADD COLUMN modification_timestamp TIME_STAMP DEFAULT CURRENT_TIMESTAMP;\\012\\012ALTER TABLE material_properties\\012\\011ADD COLUMN modification_timestamp TIME_STAMP DEFAULT CURRENT_TIMESTAMP;\\012\\012ALTER TABLE sample_properties\\012\\011ADD COLUMN modification_timestamp TIME_STAMP DEFAULT CURRENT_TIMESTAMP;\\012\\012-- -------\\012-- add property data type which references materials\\012-- -------\\012\\012ALTER TABLE property_types\\012\\011ADD COLUMN maty_prop_id tech_id;\\012\\012ALTER TABLE property_types\\012\\011ADD CONSTRAINT prty_maty_fk FOREIGN KEY (maty_prop_id) REFERENCES material_types(id);\\012\\012ALTER TABLE experiment_properties\\012\\011ADD COLUMN mate_prop_id tech_id;\\012\\012ALTER TABLE material_properties\\012\\011ADD COLUMN mate_prop_id tech_id;\\012\\012ALTER TABLE sample_properties\\012\\011ADD COLUMN mate_prop_id tech_id;\\012\\012ALTER TABLE experiment_properties\\012\\011ADD CONSTRAINT expr_mapr_fk FOREIGN KEY (mate_prop_id) REFERENCES materials(id);\\012\\012ALTER TABLE material_properties\\012\\011ADD CONSTRAINT mapr_mapr_fk FOREIGN KEY (mate_prop_id) REFERENCES materials(id);\\012\\012ALTER TABLE sample_properties\\012\\011ADD CONSTRAINT sapr_mapr_fk FOREIGN KEY (mate_prop_id) REFERENCES materials(id);\\012\\012insert into data_types\\012(id\\012 ,code\\012 ,description)\\012 values \\012 (nextval('DATA_TYPE_ID_SEQ')\\012 ,'MATERIAL'\\012 ,'Reference to a material'\\012);\\012\\012ALTER TABLE MATERIAL_PROPERTIES DROP CONSTRAINT MAPR_CK;\\012ALTER TABLE MATERIAL_PROPERTIES ADD CONSTRAINT MAPR_CK CHECK \\012\\011((VALUE IS NOT NULL AND CVTE_ID IS NULL AND MATE_PROP_ID IS NULL) OR \\012\\011 (VALUE IS NULL AND CVTE_ID IS NOT NULL AND MATE_PROP_ID IS NULL) OR\\012\\011 (VALUE IS NULL AND CVTE_ID IS NULL AND MATE_PROP_ID IS NOT NULL)\\012\\011);\\012\\012ALTER TABLE EXPERIMENT_PROPERTIES DROP CONSTRAINT EXPR_CK;\\012ALTER TABLE EXPERIMENT_PROPERTIES ADD CONSTRAINT EXPR_CK CHECK \\012\\011((VALUE IS NOT NULL AND CVTE_ID IS NULL AND MATE_PROP_ID IS NULL) OR \\012\\011 (VALUE IS NULL AND CVTE_ID IS NOT NULL AND MATE_PROP_ID IS NULL) OR\\012\\011 (VALUE IS NULL AND CVTE_ID IS NULL AND MATE_PROP_ID IS NOT NULL)\\012\\011);\\012\\012ALTER TABLE SAMPLE_PROPERTIES DROP CONSTRAINT SAPR_CK;\\012ALTER TABLE SAMPLE_PROPERTIES ADD CONSTRAINT SAPR_CK CHECK \\012\\011((VALUE IS NOT NULL AND CVTE_ID IS NULL AND MATE_PROP_ID IS NULL) OR \\012\\011 (VALUE IS NULL AND CVTE_ID IS NOT NULL AND MATE_PROP_ID IS NULL) OR\\012\\011 (VALUE IS NULL AND CVTE_ID IS NULL AND MATE_PROP_ID IS NOT NULL)\\012\\011);\\012\\012------------------------------------------------------------------------------------\\012--  Purpose:  Create trigger MATERIAL/SAMPLE/EXPERIMENT _PROPERTY_WITH_MATERIAL_DATA_TYPE_CHECK\\012--            It checks that if material property value is assigned to the entity,\\012--\\011\\011\\011\\011\\011\\011then the material type is equal to the one described by property type.\\012------------------------------------------------------------------------------------\\012\\012CREATE OR REPLACE FUNCTION MATERIAL_PROPERTY_WITH_MATERIAL_DATA_TYPE_CHECK() RETURNS trigger AS $$\\012DECLARE\\012   v_type_id  CODE;\\012   v_type_id_prop  CODE;\\012BEGIN\\012   if NEW.mate_prop_id IS NOT NULL then\\012\\011\\011\\011-- find material type id of the property type \\012\\011\\011\\011select pt.maty_prop_id into v_type_id_prop \\012\\011\\011\\011  from material_type_property_types etpt, property_types pt \\012\\011\\011\\011 where NEW.mtpt_id = etpt.id AND etpt.prty_id = pt.id;\\012\\011\\011\\012\\011\\011\\011if v_type_id_prop IS NOT NULL then\\012\\011\\011\\011\\011-- find material type id of the material which consists the entity's property value\\012\\011\\011\\011\\011select entity.maty_id into v_type_id \\012\\011\\011\\011\\011  from materials entity\\012\\011\\011\\011\\011 where NEW.mate_prop_id = entity.id;\\012\\011\\011\\011\\011if v_type_id != v_type_id_prop then\\012\\011\\011\\011\\011\\011RAISE EXCEPTION 'Insert/Update of property value referencing material (id: %) failed, as referenced material type is different than expected (id %, expected id: %).', \\012\\011\\011\\011\\011\\011\\011\\011 NEW.mate_prop_id, v_type_id, v_type_id_prop;\\012\\011\\011\\011\\011end if;\\012\\011\\011\\011end if;\\012   end if;\\012   RETURN NEW;\\012END;\\012$$ LANGUAGE 'plpgsql';\\012\\012CREATE TRIGGER MATERIAL_PROPERTY_WITH_MATERIAL_DATA_TYPE_CHECK BEFORE INSERT OR UPDATE ON material_properties\\012    FOR EACH ROW EXECUTE PROCEDURE MATERIAL_PROPERTY_WITH_MATERIAL_DATA_TYPE_CHECK();\\012    \\012CREATE OR REPLACE FUNCTION SAMPLE_PROPERTY_WITH_MATERIAL_DATA_TYPE_CHECK() RETURNS trigger AS $$\\012DECLARE\\012   v_type_id  CODE;\\012   v_type_id_prop  CODE;\\012BEGIN\\012   if NEW.mate_prop_id IS NOT NULL then\\012\\011\\011\\011-- find material type id of the property type \\012\\011\\011\\011select pt.maty_prop_id into v_type_id_prop \\012\\011\\011\\011  from sample_type_property_types etpt, property_types pt \\012\\011\\011\\011 where NEW.stpt_id = etpt.id AND etpt.prty_id = pt.id;\\012\\011\\011\\012\\011\\011\\011if v_type_id_prop IS NOT NULL then\\012\\011\\011\\011\\011-- find material type id of the material which consists the entity's property value\\012\\011\\011\\011\\011select entity.maty_id into v_type_id \\012\\011\\011\\011\\011  from materials entity\\012\\011\\011\\011\\011 where NEW.mate_prop_id = entity.id;\\012\\011\\011\\011\\011if v_type_id != v_type_id_prop then\\012\\011\\011\\011\\011\\011RAISE EXCEPTION 'Insert/Update of property value referencing material (id: %) failed, as referenced material type is different than expected (id %, expected id: %).', \\012\\011\\011\\011\\011\\011\\011\\011\\011\\011\\011\\011\\011 NEW.mate_prop_id, v_type_id, v_type_id_prop;\\012\\011\\011\\011\\011end if;\\012\\011\\011\\011end if;\\012   end if;\\012   RETURN NEW;\\012END;\\012$$ LANGUAGE 'plpgsql';\\012\\012CREATE TRIGGER SAMPLE_PROPERTY_WITH_MATERIAL_DATA_TYPE_CHECK BEFORE INSERT OR UPDATE ON sample_properties\\012    FOR EACH ROW EXECUTE PROCEDURE SAMPLE_PROPERTY_WITH_MATERIAL_DATA_TYPE_CHECK();\\012    \\012CREATE OR REPLACE FUNCTION EXPERIMENT_PROPERTY_WITH_MATERIAL_DATA_TYPE_CHECK() RETURNS trigger AS $$\\012DECLARE\\012   v_type_id  CODE;\\012   v_type_id_prop  CODE;\\012BEGIN\\012   if NEW.mate_prop_id IS NOT NULL then\\012\\011\\011\\011-- find material type id of the property type \\012\\011\\011\\011select pt.maty_prop_id into v_type_id_prop \\012\\011\\011\\011  from experiment_type_property_types etpt, property_types pt \\012\\011\\011\\011 where NEW.etpt_id = etpt.id AND etpt.prty_id = pt.id;\\012\\011\\011\\012\\011\\011\\011if v_type_id_prop IS NOT NULL then\\012\\011\\011\\011\\011-- find material type id of the material which consists the entity's property value\\012\\011\\011\\011\\011select entity.maty_id into v_type_id \\012\\011\\011\\011\\011  from materials entity\\012\\011\\011\\011\\011 where NEW.mate_prop_id = entity.id;\\012\\011\\011\\011\\011if v_type_id != v_type_id_prop then\\012\\011\\011\\011\\011\\011RAISE EXCEPTION 'Insert/Update of property value referencing material (id: %) failed, as referenced material type is different than expected (id %, expected id: %).', \\012\\011\\011\\011\\011\\011\\011\\011\\011\\011\\011\\011\\011 NEW.mate_prop_id, v_type_id, v_type_id_prop;\\012\\011\\011\\011\\011end if;\\012\\011\\011\\011end if;\\012   end if;\\012   RETURN NEW;\\012END;\\012$$ LANGUAGE 'plpgsql';\\012\\012CREATE TRIGGER EXPERIMENT_PROPERTY_WITH_MATERIAL_DATA_TYPE_CHECK BEFORE INSERT OR UPDATE ON experiment_properties\\012    FOR EACH ROW EXECUTE PROCEDURE EXPERIMENT_PROPERTY_WITH_MATERIAL_DATA_TYPE_CHECK();\\012       \\012-- -------\\012-- remove the reminescents of the OBSERVABLE_TYPE\\012-- -------\\012\\012ALTER TABLE data\\012\\011DROP CONSTRAINT data_obty_fk;\\012\\012ALTER TABLE data_set_types\\012\\011DROP CONSTRAINT obty_pk;\\012\\012ALTER TABLE data_set_types\\012\\011ADD CONSTRAINT dsty_pk PRIMARY KEY (id);\\012\\012ALTER TABLE data\\012\\011ADD CONSTRAINT data_dsty_fk FOREIGN KEY (dsty_id) REFERENCES data_set_types(id);\\012\\012ALTER TABLE data_set_types\\012\\011DROP CONSTRAINT obty_bk_uk;\\012\\012ALTER TABLE data_set_types\\012\\011DROP CONSTRAINT obty_dbin_fk;\\012\\012ALTER TABLE data_set_types\\012\\011ADD CONSTRAINT dsty_bk_uk UNIQUE (code, dbin_id);\\012\\012ALTER TABLE data_set_types\\012\\011ADD CONSTRAINT dsty_dbin_fk FOREIGN KEY (dbin_id) REFERENCES database_instances(id);\\012\\012DROP INDEX data_obty_fk_i;\\012\\012CREATE INDEX data_dsty_fk_i ON data(dsty_id);\\012	\N
+./sourceTest/sql/postgresql/040/017=database_version_logs.tsv:030	source/sql/postgresql/migration/migration-029-030.sql	SUCCESS	2009-03-23 15:34:44.72	-- -------\\012-- add modification_timestamp field to allow edition with Hibernate\\012-- -------\\012ALTER TABLE data\\012\\011ADD COLUMN modification_timestamp TIME_STAMP DEFAULT CURRENT_TIMESTAMP;\\012ALTER TABLE experiment_types\\012\\011ADD COLUMN modification_timestamp TIME_STAMP DEFAULT CURRENT_TIMESTAMP;\\012ALTER TABLE sample_types\\012\\011ADD COLUMN modification_timestamp TIME_STAMP DEFAULT CURRENT_TIMESTAMP;\\012ALTER TABLE material_types\\012\\011ADD COLUMN modification_timestamp TIME_STAMP DEFAULT CURRENT_TIMESTAMP;\\012ALTER TABLE data_set_types\\012\\011ADD COLUMN modification_timestamp TIME_STAMP DEFAULT CURRENT_TIMESTAMP;\\012ALTER TABLE controlled_vocabularies\\012\\011ADD COLUMN modification_timestamp TIME_STAMP DEFAULT CURRENT_TIMESTAMP;\\012-- -------\\012-- add properties to data sets\\012-- -------\\012CREATE TABLE DATA_SET_PROPERTIES (ID TECH_ID NOT NULL,DS_ID TECH_ID NOT NULL,DSTPT_ID TECH_ID NOT NULL,VALUE GENERIC_VALUE,CVTE_ID TECH_ID, MATE_PROP_ID TECH_ID, PERS_ID_REGISTERER TECH_ID NOT NULL,REGISTRATION_TIMESTAMP TIME_STAMP_DFL NOT NULL DEFAULT CURRENT_TIMESTAMP, MODIFICATION_TIMESTAMP TIME_STAMP DEFAULT CURRENT_TIMESTAMP);\\012CREATE TABLE DATA_SET_TYPE_PROPERTY_TYPES (ID TECH_ID NOT NULL,DSTY_ID TECH_ID NOT NULL,PRTY_ID TECH_ID NOT NULL,IS_MANDATORY BOOLEAN_CHAR NOT NULL DEFAULT 'F',IS_MANAGED_INTERNALLY BOOLEAN_CHAR NOT NULL DEFAULT 'F',PERS_ID_REGISTERER TECH_ID NOT NULL,REGISTRATION_TIMESTAMP TIME_STAMP_DFL NOT NULL DEFAULT CURRENT_TIMESTAMP);\\012\\012CREATE SEQUENCE DATA_SET_PROPERTY_ID_SEQ;\\012CREATE SEQUENCE DSTPT_ID_SEQ;\\012\\012ALTER TABLE DATA_SET_TYPE_PROPERTY_TYPES ADD CONSTRAINT DSTPT_PK PRIMARY KEY(ID);\\012ALTER TABLE DATA_SET_PROPERTIES ADD CONSTRAINT DSPR_PK PRIMARY KEY(ID);\\012\\012ALTER TABLE DATA_SET_TYPE_PROPERTY_TYPES ADD CONSTRAINT DSTPT_BK_UK UNIQUE(DSTY_ID,PRTY_ID);\\012ALTER TABLE DATA_SET_PROPERTIES ADD CONSTRAINT DSPR_BK_UK UNIQUE(DS_ID,DSTPT_ID);\\012\\012\\012ALTER TABLE DATA_SET_TYPE_PROPERTY_TYPES ADD CONSTRAINT DSTPT_DSTY_FK FOREIGN KEY (DSTY_ID) REFERENCES DATA_SET_TYPES(ID);\\012ALTER TABLE DATA_SET_TYPE_PROPERTY_TYPES ADD CONSTRAINT DSTPT_PERS_FK FOREIGN KEY (PERS_ID_REGISTERER) REFERENCES PERSONS(ID);\\012ALTER TABLE DATA_SET_TYPE_PROPERTY_TYPES ADD CONSTRAINT DSTPT_PRTY_FK FOREIGN KEY (PRTY_ID) REFERENCES PROPERTY_TYPES(ID);\\012ALTER TABLE DATA_SET_PROPERTIES ADD CONSTRAINT DSPR_CVTE_FK FOREIGN KEY (CVTE_ID) REFERENCES CONTROLLED_VOCABULARY_TERMS(ID);\\012ALTER TABLE DATA_SET_PROPERTIES ADD CONSTRAINT DSPR_DSTPT_FK FOREIGN KEY (DSTPT_ID) REFERENCES DATA_SET_TYPE_PROPERTY_TYPES(ID) ON DELETE CASCADE;\\012ALTER TABLE DATA_SET_PROPERTIES ADD CONSTRAINT DSPR_DS_FK FOREIGN KEY (DS_ID) REFERENCES DATA(ID);\\012ALTER TABLE DATA_SET_PROPERTIES ADD CONSTRAINT DSPR_PERS_FK FOREIGN KEY (PERS_ID_REGISTERER) REFERENCES PERSONS(ID);\\012ALTER TABLE DATA_SET_PROPERTIES ADD CONSTRAINT DSPR_MAPR_FK FOREIGN KEY (MATE_PROP_ID) REFERENCES MATERIALS(ID);\\012\\012ALTER TABLE DATA_SET_PROPERTIES ADD CONSTRAINT DSPR_CK CHECK \\012\\011((VALUE IS NOT NULL AND CVTE_ID IS NULL AND MATE_PROP_ID IS NULL) OR \\012\\011 (VALUE IS NULL AND CVTE_ID IS NOT NULL AND MATE_PROP_ID IS NULL) OR\\012\\011 (VALUE IS NULL AND CVTE_ID IS NULL AND MATE_PROP_ID IS NOT NULL)\\012\\011);\\012\\012CREATE INDEX DSPR_CVTE_FK_I ON DATA_SET_PROPERTIES (CVTE_ID);\\012CREATE INDEX DSPR_DSTPT_FK_I ON DATA_SET_PROPERTIES (DSTPT_ID);\\012CREATE INDEX DSPR_DS_FK_I ON DATA_SET_PROPERTIES (DS_ID);\\012CREATE INDEX DSPR_PERS_FK_I ON DATA_SET_PROPERTIES (PERS_ID_REGISTERER);\\012CREATE INDEX DSTPT_DSTY_FK_I ON DATA_SET_TYPE_PROPERTY_TYPES (DSTY_ID);\\012CREATE INDEX DSTPT_PERS_FK_I ON DATA_SET_TYPE_PROPERTY_TYPES (PERS_ID_REGISTERER);\\012CREATE INDEX DSTPT_PRTY_FK_I ON DATA_SET_TYPE_PROPERTY_TYPES (PRTY_ID);\\012\\012CREATE OR REPLACE FUNCTION DATA_SET_PROPERTY_WITH_MATERIAL_DATA_TYPE_CHECK() RETURNS trigger AS $$\\012DECLARE\\012   v_type_id  CODE;\\012   v_type_id_prop  CODE;\\012BEGIN\\012   if NEW.mate_prop_id IS NOT NULL then\\012\\011\\011\\011-- find material type id of the property type \\012\\011\\011\\011select pt.maty_prop_id into v_type_id_prop \\012\\011\\011\\011  from data_set_type_property_types dstpt, property_types pt \\012\\011\\011\\011 where NEW.dstpt_id = dstpt.id AND dstpt.prty_id = pt.id;\\012\\011\\011\\012\\011\\011\\011if v_type_id_prop IS NOT NULL then\\012\\011\\011\\011\\011-- find material type id of the material which consists the entity's property value\\012\\011\\011\\011\\011select entity.maty_id into v_type_id \\012\\011\\011\\011\\011  from materials entity\\012\\011\\011\\011\\011 where NEW.mate_prop_id = entity.id;\\012\\011\\011\\011\\011if v_type_id != v_type_id_prop then\\012\\011\\011\\011\\011\\011RAISE EXCEPTION 'Insert/Update of property value referencing material (id: %) failed, as referenced material type is different than expected (id %, expected id: %).', \\012\\011\\011\\011\\011\\011\\011\\011\\011\\011\\011\\011\\011 NEW.mate_prop_id, v_type_id, v_type_id_prop;\\012\\011\\011\\011\\011end if;\\012\\011\\011\\011end if;\\012   end if;\\012   RETURN NEW;\\012END;\\012$$ LANGUAGE 'plpgsql';\\012\\012CREATE TRIGGER DATA_SET_PROPERTY_WITH_MATERIAL_DATA_TYPE_CHECK BEFORE INSERT OR UPDATE ON data_set_properties\\012    FOR EACH ROW EXECUTE PROCEDURE DATA_SET_PROPERTY_WITH_MATERIAL_DATA_TYPE_CHECK();   \\012	\N
+./sourceTest/sql/postgresql/040/017=database_version_logs.tsv:032	source/sql/postgresql/migration/migration-031-032.sql	SUCCESS	2009-04-09 09:36:36.20	-- -------\\012-- Modify MATERIAL_BATCHES\\012-- -------\\012\\012ALTER TABLE material_batches\\012    DROP COLUMN proc_id;\\012\\012-- -------\\012-- Modify SAMPLES\\012-- -------\\012\\012ALTER TABLE samples\\012    ADD COLUMN expe_id tech_id;\\012\\012ALTER TABLE samples\\012    ADD CONSTRAINT samp_expe_fk FOREIGN KEY (expe_id) REFERENCES experiments(id);\\012\\012CREATE INDEX samp_expe_fk_i ON samples USING btree (expe_id);\\012\\012-- relink samples directly to experiments\\012\\012UPDATE samples\\012SET expe_id = (SELECT e.id FROM experiments e, procedures p, sample_inputs si \\012               WHERE si.samp_id = samples.id AND si.proc_id = p.id AND p.expe_id = e.id AND e.inva_id IS NULL);\\012\\012\\012-- -------\\012-- Modify DATA\\012-- -------\\012\\012ALTER TABLE data\\012    ADD COLUMN expe_id tech_id;\\012\\012ALTER TABLE data\\012    ADD CONSTRAINT data_expe_fk FOREIGN KEY (expe_id) REFERENCES experiments(id);\\012\\012CREATE INDEX data_expe_fk_i ON data USING btree (expe_id);\\012\\012UPDATE data\\012SET expe_id = (SELECT e.id FROM experiments e, procedures p \\012               WHERE data.proc_id_produced_by = p.id AND p.expe_id = e.id);\\012\\012ALTER TABLE data\\012    ALTER COLUMN expe_id SET NOT NULL;\\012\\012ALTER TABLE data\\012    DROP COLUMN proc_id_produced_by;\\012\\012-- -------\\012-- Drop PROCEDURES, PROCEDURE_TYPES, and SAMPLE_INPUTS\\012-- -------\\012\\012DROP TABLE sample_inputs;\\012DROP TABLE procedures;\\012DROP TABLE procedure_types;\\012\\012DROP SEQUENCE procedure_id_seq;\\012DROP SEQUENCE procedure_type_id_seq;\\012\\012-- -------\\012-- Add CODE_SEQ\\012-- -------\\012\\012CREATE SEQUENCE CODE_SEQ;\\012\\012-- -------\\012-- Add new columns to DATA_STORES\\012-- -------\\012\\012ALTER TABLE data_stores\\012    ADD COLUMN remote_url character varying(250),\\012    ADD COLUMN session_token character varying(50),\\012    ADD COLUMN modification_timestamp time_stamp DEFAULT now();\\012\\012UPDATE data_stores\\012SET remote_url = '', session_token='';\\012\\012ALTER TABLE data_stores\\012    ALTER COLUMN remote_url SET NOT NULL,\\012    ALTER COLUMN session_token SET NOT NULL;\\012\\012-- -------\\012-- Drop foreign keys onto DATA_STORES\\012-- -------\\012\\012ALTER TABLE database_instances\\012    DROP COLUMN dast_id;\\012\\012ALTER TABLE groups\\012    DROP COLUMN dast_id;\\012\\012ALTER TABLE projects\\012    DROP COLUMN dast_id;\\012\\012ALTER TABLE experiments\\012    DROP COLUMN dast_id;\\012\\012-- -------\\012-- Add foreign key from DATA onto DATA_STORES\\012-- -------\\012\\012ALTER TABLE data\\012    ADD COLUMN dast_id tech_id;\\012\\012ALTER TABLE data\\012    ADD CONSTRAINT data_dast_fk FOREIGN KEY (dast_id) REFERENCES data_stores(id);\\012\\012UPDATE data\\012SET dast_id = (select id from data_stores where code = 'STANDARD');\\012\\012ALTER TABLE data\\012    ALTER COLUMN dast_id SET NOT NULL;\\012\\012\\012------------------------------------------------------------------------------------\\012--  Purpose:  Replace trigger SAMPLE_CODE_UNIQUENESS_CHECK \\012------------------------------------------------------------------------------------\\012\\012CREATE OR REPLACE FUNCTION SAMPLE_CODE_UNIQUENESS_CHECK() RETURNS trigger AS $$\\012DECLARE\\012   counter  INTEGER;\\012BEGIN\\012    LOCK TABLE samples IN EXCLUSIVE MODE;\\012    IF (NEW.samp_id_part_of is NULL) THEN\\012        IF (NEW.dbin_id is not NULL) THEN\\012            SELECT count(*) into counter FROM samples \\012                where id != NEW.id and code = NEW.code and samp_id_part_of is NULL and dbin_id = NEW.dbin_id;\\012            IF (counter > 0) THEN\\012                RAISE EXCEPTION 'Insert/Update of Sample (Code: %) failed because database instance sample with the same code already exists.', NEW.code;\\012            END IF;\\012        ELSIF (NEW.grou_id is not NULL) THEN\\012            SELECT count(*) into counter FROM samples \\012                where id != NEW.id and code = NEW.code and samp_id_part_of is NULL and grou_id = NEW.grou_id;\\012            IF (counter > 0) THEN\\012                RAISE EXCEPTION 'Insert/Update of Sample (Code: %) failed because group sample with the same code already exists.', NEW.code;\\012            END IF;\\012        END IF;\\012        ELSE\\012        IF (NEW.dbin_id is not NULL) THEN\\012            SELECT count(*) into counter FROM samples \\012                where id != NEW.id and code = NEW.code and samp_id_part_of = NEW.samp_id_part_of and dbin_id = NEW.dbin_id;\\012            IF (counter > 0) THEN\\012                RAISE EXCEPTION 'Insert/Update of Sample (Code: %) failed because database instance sample with the same code and being the part of the same parent already exists.', NEW.code;\\012            END IF;\\012        ELSIF (NEW.grou_id is not NULL) THEN\\012            SELECT count(*) into counter FROM samples \\012                where id != NEW.id and code = NEW.code and samp_id_part_of = NEW.samp_id_part_of and grou_id = NEW.grou_id;\\012            IF (counter > 0) THEN\\012                RAISE EXCEPTION 'Insert/Update of Sample (Code: %) failed because group sample with the same code and being the part of the same parent already exists.', NEW.code;\\012            END IF;\\012        END IF;\\012        END IF;   \\012   RETURN NEW;\\012END;\\012$$ LANGUAGE 'plpgsql';\\012\\012\\012\\012	\N
+./sourceTest/sql/postgresql/040/017=database_version_logs.tsv:034	source/sql/postgresql/migration/migration-033-034.sql	SUCCESS	2009-05-26 08:32:49.935	------------------------------------------------------------------------------------\\012-- Create sequence for generating permanent identifiers starting with nextval of existing dataset sequence.\\012------------------------------------------------------------------------------------\\012CREATE FUNCTION CREATE_SEQUENCE(EXISTING_SEQUENCE VARCHAR, NEW_SEQUENCE VARCHAR) RETURNS VOID AS $$\\012DECLARE\\012  CURR_SEQ_VAL   INTEGER;\\012BEGIN\\012  SELECT INTO CURR_SEQ_VAL NEXTVAL(EXISTING_SEQUENCE);\\012  EXECUTE 'CREATE SEQUENCE ' || NEW_SEQUENCE || ' START WITH ' || CURR_SEQ_VAL;\\012  RETURN;\\012END;\\012$$ LANGUAGE 'plpgsql';\\012\\012SELECT CREATE_SEQUENCE('DATA_ID_SEQ', 'PERM_ID_SEQ');\\012DROP FUNCTION CREATE_SEQUENCE(VARCHAR, VARCHAR);\\012\\012------------------------------------------------------------------------------------\\012-- Add perm_id columns to samples and experiments.\\012------------------------------------------------------------------------------------\\012ALTER TABLE SAMPLES ADD COLUMN PERM_ID CODE;\\012ALTER TABLE EXPERIMENTS ADD COLUMN PERM_ID CODE;\\012\\012UPDATE SAMPLES SET PERM_ID = to_char(registration_timestamp,'YYYYMMDDHHSSMS') || '-' || NEXTVAL('PERM_ID_SEQ');\\012UPDATE EXPERIMENTS SET PERM_ID = to_char(registration_timestamp,'YYYYMMDDHHSSMS') || '-' || NEXTVAL('PERM_ID_SEQ');\\012ALTER TABLE SAMPLES ALTER COLUMN PERM_ID SET NOT NULL;\\012ALTER TABLE EXPERIMENTS ALTER COLUMN PERM_ID SET NOT NULL;\\012ALTER TABLE SAMPLES ADD CONSTRAINT SAMP_PI_UK UNIQUE(PERM_ID);\\012ALTER TABLE EXPERIMENTS ADD CONSTRAINT EXPE_PI_UK UNIQUE(PERM_ID);\\012\\012\\012------------------------------------------------------------------------------------\\012-- Add column is_chosen_from_list to controlled_vocabularies.\\012------------------------------------------------------------------------------------\\012ALTER TABLE controlled_vocabularies ADD COLUMN is_chosen_from_list BOOLEAN_CHAR NOT NULL DEFAULT TRUE;\\012ALTER TABLE controlled_vocabularies ADD COLUMN source_uri CHARACTER VARYING(250);\\012------------------------------------------------------------------------------------\\012-- Modify Data table - remove arc connection between Sample and Data table, use a flag instead\\012------------------------------------------------------------------------------------\\012\\012-- add new columns\\012\\012ALTER TABLE data\\012    ADD COLUMN is_derived boolean_char;\\012ALTER TABLE data\\012    ADD COLUMN samp_id tech_id;\\012\\012-- update values in new columns\\012\\012UPDATE data\\012    SET is_derived = (samp_id_derived_from IS NOT NULL); \\012UPDATE data\\012    SET samp_id = samp_id_derived_from \\012    WHERE is_derived = 'TRUE';\\012UPDATE data\\012    SET samp_id = samp_id_acquired_from \\012    WHERE is_derived = 'FALSE';\\012\\012-- add constraints and indexes to new columns\\012\\012ALTER TABLE data\\012    ALTER COLUMN is_derived SET NOT NULL;\\012ALTER TABLE data\\012    ALTER COLUMN samp_id SET NOT NULL;   \\012ALTER TABLE data\\012    ADD CONSTRAINT data_samp_fk FOREIGN KEY (samp_id) REFERENCES samples (id);\\012CREATE INDEX data_samp_fk_i ON data USING btree (samp_id);\\012\\012-- remove old columns\\012\\012ALTER TABLE data\\012    DROP COLUMN samp_id_acquired_from;\\012ALTER TABLE data\\012    DROP COLUMN samp_id_derived_from;\\012    \\012------------------------------------------------------------------------------------\\012-- Granting SELECT privilege to group openbis_readonly\\012------------------------------------------------------------------------------------\\012\\012GRANT SELECT ON SEQUENCE attachment_content_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE attachment_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE code_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE controlled_vocabulary_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE cvte_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE data_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE data_set_property_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE data_set_relationship_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE data_set_type_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE data_store_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE data_type_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE database_instance_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE dstpt_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE etpt_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE event_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE experiment_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE experiment_property_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE experiment_type_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE file_format_type_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE group_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE invalidation_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE locator_type_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE material_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE material_property_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE material_type_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE mtpt_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE perm_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE person_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE project_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE property_type_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE role_assignment_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE sample_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE sample_property_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE sample_type_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE stpt_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE attachment_contents TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE attachments TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE controlled_vocabularies TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE controlled_vocabulary_terms TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE data TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE data_set_properties TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE data_set_relationships TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE data_set_type_property_types TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE data_set_types TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE data_stores TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE data_types TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE database_instances TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE database_version_logs TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE events TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE experiment_properties TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE experiment_type_property_types TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE experiment_types TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE experiments TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE external_data TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE file_format_types TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE groups TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE invalidations TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE locator_types TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE material_properties TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE material_type_property_types TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE material_types TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE materials TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE persons TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE projects TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE property_types TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE role_assignments TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE sample_properties TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE sample_type_property_types TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE sample_types TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE samples TO GROUP OPENBIS_READONLY;\\012\\012------------------------------------------------------------------------------------\\012-- Delete MATERIAL_BATCHES table\\012------------------------------------------------------------------------------------\\012\\012-- WARNING: Potential data lost!!!\\012-- WARNING: Potential data lost!!!\\012-- WARNING: Potential data lost!!!\\012\\012DROP TABLE SAMPLE_MATERIAL_BATCHES;\\012DROP TABLE MATERIAL_BATCHES;\\012DROP SEQUENCE MATERIAL_BATCH_ID_SEQ;\\012\\012------------------------------------------------------------------------------------\\012-- Delete MATE_ID_INHIBITOR_OF from table MATERIALS\\012------------------------------------------------------------------------------------\\012\\012-- WARNING: Potential data lost!!!\\012-- WARNING: Potential data lost!!!\\012-- WARNING: Potential data lost!!!\\012\\012ALTER TABLE MATERIALS DROP COLUMN MATE_ID_INHIBITOR_OF;\\012	\N
+./sourceTest/sql/postgresql/040/schema-040.sql:    LANGUAGE plpgsql;
+./sourceTest/sql/postgresql/040/schema-040.sql:    LANGUAGE plpgsql;
+./sourceTest/sql/postgresql/040/schema-040.sql:    LANGUAGE plpgsql;
+./sourceTest/sql/postgresql/040/schema-040.sql:    LANGUAGE plpgsql;
+./sourceTest/sql/postgresql/040/schema-040.sql:    LANGUAGE plpgsql;
+./sourceTest/sql/postgresql/040/schema-040.sql:    LANGUAGE plpgsql;
+./sourceTest/sql/postgresql/040/schema-040.sql:    LANGUAGE plpgsql;
+./sourceTest/sql/postgresql/040/schema-040.sql:    LANGUAGE plpgsql;
+./sourceTest/sql/postgresql/041/.svn/text-base/017=database_version_logs.tsv.svn-base:027	D:\\User\\felmer\\dev-workspace\\openbis/source/sql/postgresql/027/function-027.sql	SUCCESS	2008-11-05 09:18:00.403	-- Creating Functions\\012\\012------------------------------------------------------------------------------------\\012--  Purpose:  Create function RENAME_SEQUENCE() that is required for renaming the sequences belonging to tables\\012------------------------------------------------------------------------------------\\012CREATE FUNCTION RENAME_SEQUENCE(OLD_NAME VARCHAR, NEW_NAME VARCHAR) RETURNS INTEGER AS $$\\012DECLARE\\012  CURR_SEQ_VAL   INTEGER;\\012BEGIN\\012  SELECT INTO CURR_SEQ_VAL NEXTVAL(OLD_NAME);\\012  EXECUTE 'CREATE SEQUENCE ' || NEW_NAME || ' START WITH ' || CURR_SEQ_VAL;\\012  EXECUTE 'DROP SEQUENCE ' || OLD_NAME;\\012  RETURN CURR_SEQ_VAL;\\012END;\\012$$ LANGUAGE 'plpgsql';\\012\\012\\012------------------------------------------------------------------------------------\\012--  Purpose:  Create trigger CONTROLLED_VOCABULARY_CHECK \\012------------------------------------------------------------------------------------\\012\\012CREATE OR REPLACE FUNCTION CONTROLLED_VOCABULARY_CHECK() RETURNS trigger AS $$\\012DECLARE\\012   v_code  CODE;\\012BEGIN\\012\\012   select code into v_code from data_types where id = NEW.daty_id;\\012\\012   -- Check if the data is of type "CONTROLLEDVOCABULARY"\\012   if v_code = 'CONTROLLEDVOCABULARY' then\\012      if NEW.covo_id IS NULL then\\012         RAISE EXCEPTION 'Insert/Update of Property Type (Code: %) failed, as its Data Type is CONTROLLEDVOCABULARY, but it is not linked to a Controlled Vocabulary.', NEW.code;\\012      end if;\\012   end if;\\012\\012   RETURN NEW;\\012\\012END;\\012$$ LANGUAGE 'plpgsql';\\012\\012CREATE TRIGGER CONTROLLED_VOCABULARY_CHECK BEFORE INSERT OR UPDATE ON PROPERTY_TYPES\\012    FOR EACH ROW EXECUTE PROCEDURE CONTROLLED_VOCABULARY_CHECK();\\012\\012\\012------------------------------------------------------------------------------------\\012--  Purpose:  Create trigger EXTERNAL_DATA_STORAGE_FORMAT_CHECK \\012------------------------------------------------------------------------------------\\012\\012CREATE OR REPLACE FUNCTION EXTERNAL_DATA_STORAGE_FORMAT_CHECK() RETURNS trigger AS $$\\012DECLARE\\012   v_covo_code  CODE;\\012   data_code CODE;\\012BEGIN\\012\\012   select code into v_covo_code from controlled_vocabularies\\012      where is_internal_namespace = true and \\012         id = (select covo_id from controlled_vocabulary_terms where id = NEW.cvte_id_stor_fmt);\\012   -- Check if the data storage format is a term of the controlled vocabulary "STORAGE_FORMAT"\\012   if v_covo_code != 'STORAGE_FORMAT' then\\012      select code into data_code from data where id = NEW.data_id; \\012      RAISE EXCEPTION 'Insert/Update of Data (Code: %) failed, as its Storage Format is %, but is required to be STORAGE_FORMAT.', data_code, v_covo_code;\\012   end if;\\012\\012   RETURN NEW;\\012\\012END;\\012$$ LANGUAGE 'plpgsql';\\012\\012CREATE TRIGGER EXTERNAL_DATA_STORAGE_FORMAT_CHECK BEFORE INSERT OR UPDATE ON EXTERNAL_DATA\\012    FOR EACH ROW EXECUTE PROCEDURE EXTERNAL_DATA_STORAGE_FORMAT_CHECK();\\012\\012------------------------------------------------------------------------------------\\012--  Purpose:  Create trigger SAMPLE_CODE_UNIQUENESS_CHECK \\012------------------------------------------------------------------------------------\\012\\012CREATE OR REPLACE FUNCTION SAMPLE_CODE_UNIQUENESS_CHECK() RETURNS trigger AS $$\\012DECLARE\\012   counter  INTEGER;\\012BEGIN\\012\\011IF (NEW.samp_id_part_of is NULL) THEN\\012\\011\\011IF (NEW.dbin_id is not NULL) THEN\\012\\011\\011\\011SELECT count(*) into counter FROM samples \\012\\011\\011\\011\\011where id != NEW.id and code = NEW.code and samp_id_part_of is NULL and dbin_id = NEW.dbin_id;\\012\\011\\011\\011IF (counter > 0) THEN\\012\\011\\011\\011\\011RAISE EXCEPTION 'Insert/Update of Sample (Code: %) failed because database instance sample with the same code already exists.', NEW.code;\\012\\011\\011\\011END IF;\\012\\011\\011ELSIF (NEW.grou_id is not NULL) THEN\\012\\011\\011\\011SELECT count(*) into counter FROM samples \\012\\011\\011\\011\\011where id != NEW.id and code = NEW.code and samp_id_part_of is NULL and grou_id = NEW.grou_id;\\012\\011\\011\\011IF (counter > 0) THEN\\012\\011\\011\\011\\011RAISE EXCEPTION 'Insert/Update of Sample (Code: %) failed because group sample with the same code already exists.', NEW.code;\\012\\011\\011\\011END IF;\\012\\011\\011END IF;\\012        ELSE\\012\\011\\011IF (NEW.dbin_id is not NULL) THEN\\012\\011\\011\\011SELECT count(*) into counter FROM samples \\012\\011\\011\\011\\011where id != NEW.id and code = NEW.code and samp_id_part_of = NEW.samp_id_part_of and dbin_id = NEW.dbin_id;\\012\\011\\011\\011IF (counter > 0) THEN\\012\\011\\011\\011\\011RAISE EXCEPTION 'Insert/Update of Sample (Code: %) failed because database instance sample with the same code and being the part of the same parent already exists.', NEW.code;\\012\\011\\011\\011END IF;\\012\\011\\011ELSIF (NEW.grou_id is not NULL) THEN\\012\\011\\011\\011SELECT count(*) into counter FROM samples \\012\\011\\011\\011\\011where id != NEW.id and code = NEW.code and samp_id_part_of = NEW.samp_id_part_of and grou_id = NEW.grou_id;\\012\\011\\011\\011IF (counter > 0) THEN\\012\\011\\011\\011\\011RAISE EXCEPTION 'Insert/Update of Sample (Code: %) failed because group sample with the same code and being the part of the same parent already exists.', NEW.code;\\012\\011\\011\\011END IF;\\012\\011\\011END IF;\\012        END IF;   \\012   RETURN NEW;\\012END;\\012$$ LANGUAGE 'plpgsql';\\012\\012CREATE TRIGGER SAMPLE_CODE_UNIQUENESS_CHECK BEFORE INSERT OR UPDATE ON SAMPLES\\012    FOR EACH ROW EXECUTE PROCEDURE SAMPLE_CODE_UNIQUENESS_CHECK();\\012	\N
+./sourceTest/sql/postgresql/041/.svn/text-base/017=database_version_logs.tsv.svn-base:028	source/sql/postgresql/migration/migration-027-028.sql	SUCCESS	2008-11-18 13:24:17.508	-- Create EXPERIMENT_ATTACHMENT_CONTENTS.\\012CREATE TABLE EXPERIMENT_ATTACHMENT_CONTENTS (ID TECH_ID NOT NULL,VALUE FILE NOT NULL);\\012CREATE SEQUENCE EXPERIMENT_ATTACHMENT_CONTENT_ID_SEQ;\\012ALTER TABLE EXPERIMENT_ATTACHMENT_CONTENTS ADD CONSTRAINT EXAC_PK PRIMARY KEY(ID);\\012\\012-- Alter EXPERIMENT_ATTACHMENTS by adding the new column which has a NULL constraint.\\012-- The NOT NULL constraint is added later on.\\012ALTER TABLE EXPERIMENT_ATTACHMENTS ADD COLUMN EXAC_ID TECH_ID;\\012\\012-- Does the VALUE migration between EXPERIMENT_ATTACHMENTS to EXPERIMENT_ATTACHMENT_CONTENTS.\\012CREATE OR REPLACE FUNCTION move_exp_att_content() RETURNS integer AS $$\\012DECLARE\\012    rec RECORD;\\012    seq BIGINT;\\012BEGIN\\012  FOR rec IN SELECT id, value FROM EXPERIMENT_ATTACHMENTS LOOP\\012  \\011seq := nextval('EXPERIMENT_ATTACHMENT_CONTENT_ID_SEQ');\\012    INSERT INTO EXPERIMENT_ATTACHMENT_CONTENTS (id, value) VALUES (seq, rec.value);\\012    UPDATE EXPERIMENT_ATTACHMENTS SET exac_id = seq WHERE id = rec.id;\\012  END LOOP;\\012  RETURN 1;\\012END;\\012$$ LANGUAGE 'plpgsql';\\012\\012-- Call the function.\\012SELECT move_exp_att_content();\\012DROP FUNCTION move_exp_att_content();\\012\\012\\012-- Finish EXPERIMENT_ATTACHMENTS changes.\\012ALTER TABLE EXPERIMENT_ATTACHMENTS ADD CONSTRAINT EXAT_CONT_FK FOREIGN KEY (EXAC_ID) REFERENCES EXPERIMENT_ATTACHMENT_CONTENTS(ID);\\012ALTER TABLE EXPERIMENT_ATTACHMENTS DROP COLUMN VALUE;\\012ALTER TABLE EXPERIMENT_ATTACHMENTS ALTER COLUMN EXAC_ID SET NOT NULL;\\012	\N
+./sourceTest/sql/postgresql/041/.svn/text-base/017=database_version_logs.tsv.svn-base:029	source/sql/postgresql/migration/migration-028-029.sql	SUCCESS	2009-03-18 10:50:20.105	-- -------\\012-- add modification_timestamp field to allow edition with Hibernate\\012-- -------\\012\\012ALTER TABLE samples\\012\\011ADD COLUMN modification_timestamp TIME_STAMP DEFAULT CURRENT_TIMESTAMP;\\012\\012ALTER TABLE experiments\\012\\011ADD COLUMN modification_timestamp TIME_STAMP DEFAULT CURRENT_TIMESTAMP;\\012\\012ALTER TABLE materials\\012\\011ADD COLUMN modification_timestamp TIME_STAMP DEFAULT CURRENT_TIMESTAMP;\\012\\012ALTER TABLE experiment_properties\\012\\011ADD COLUMN modification_timestamp TIME_STAMP DEFAULT CURRENT_TIMESTAMP;\\012\\012ALTER TABLE material_properties\\012\\011ADD COLUMN modification_timestamp TIME_STAMP DEFAULT CURRENT_TIMESTAMP;\\012\\012ALTER TABLE sample_properties\\012\\011ADD COLUMN modification_timestamp TIME_STAMP DEFAULT CURRENT_TIMESTAMP;\\012\\012-- -------\\012-- add property data type which references materials\\012-- -------\\012\\012ALTER TABLE property_types\\012\\011ADD COLUMN maty_prop_id tech_id;\\012\\012ALTER TABLE property_types\\012\\011ADD CONSTRAINT prty_maty_fk FOREIGN KEY (maty_prop_id) REFERENCES material_types(id);\\012\\012ALTER TABLE experiment_properties\\012\\011ADD COLUMN mate_prop_id tech_id;\\012\\012ALTER TABLE material_properties\\012\\011ADD COLUMN mate_prop_id tech_id;\\012\\012ALTER TABLE sample_properties\\012\\011ADD COLUMN mate_prop_id tech_id;\\012\\012ALTER TABLE experiment_properties\\012\\011ADD CONSTRAINT expr_mapr_fk FOREIGN KEY (mate_prop_id) REFERENCES materials(id);\\012\\012ALTER TABLE material_properties\\012\\011ADD CONSTRAINT mapr_mapr_fk FOREIGN KEY (mate_prop_id) REFERENCES materials(id);\\012\\012ALTER TABLE sample_properties\\012\\011ADD CONSTRAINT sapr_mapr_fk FOREIGN KEY (mate_prop_id) REFERENCES materials(id);\\012\\012insert into data_types\\012(id\\012 ,code\\012 ,description)\\012 values \\012 (nextval('DATA_TYPE_ID_SEQ')\\012 ,'MATERIAL'\\012 ,'Reference to a material'\\012);\\012\\012ALTER TABLE MATERIAL_PROPERTIES DROP CONSTRAINT MAPR_CK;\\012ALTER TABLE MATERIAL_PROPERTIES ADD CONSTRAINT MAPR_CK CHECK \\012\\011((VALUE IS NOT NULL AND CVTE_ID IS NULL AND MATE_PROP_ID IS NULL) OR \\012\\011 (VALUE IS NULL AND CVTE_ID IS NOT NULL AND MATE_PROP_ID IS NULL) OR\\012\\011 (VALUE IS NULL AND CVTE_ID IS NULL AND MATE_PROP_ID IS NOT NULL)\\012\\011);\\012\\012ALTER TABLE EXPERIMENT_PROPERTIES DROP CONSTRAINT EXPR_CK;\\012ALTER TABLE EXPERIMENT_PROPERTIES ADD CONSTRAINT EXPR_CK CHECK \\012\\011((VALUE IS NOT NULL AND CVTE_ID IS NULL AND MATE_PROP_ID IS NULL) OR \\012\\011 (VALUE IS NULL AND CVTE_ID IS NOT NULL AND MATE_PROP_ID IS NULL) OR\\012\\011 (VALUE IS NULL AND CVTE_ID IS NULL AND MATE_PROP_ID IS NOT NULL)\\012\\011);\\012\\012ALTER TABLE SAMPLE_PROPERTIES DROP CONSTRAINT SAPR_CK;\\012ALTER TABLE SAMPLE_PROPERTIES ADD CONSTRAINT SAPR_CK CHECK \\012\\011((VALUE IS NOT NULL AND CVTE_ID IS NULL AND MATE_PROP_ID IS NULL) OR \\012\\011 (VALUE IS NULL AND CVTE_ID IS NOT NULL AND MATE_PROP_ID IS NULL) OR\\012\\011 (VALUE IS NULL AND CVTE_ID IS NULL AND MATE_PROP_ID IS NOT NULL)\\012\\011);\\012\\012------------------------------------------------------------------------------------\\012--  Purpose:  Create trigger MATERIAL/SAMPLE/EXPERIMENT _PROPERTY_WITH_MATERIAL_DATA_TYPE_CHECK\\012--            It checks that if material property value is assigned to the entity,\\012--\\011\\011\\011\\011\\011\\011then the material type is equal to the one described by property type.\\012------------------------------------------------------------------------------------\\012\\012CREATE OR REPLACE FUNCTION MATERIAL_PROPERTY_WITH_MATERIAL_DATA_TYPE_CHECK() RETURNS trigger AS $$\\012DECLARE\\012   v_type_id  CODE;\\012   v_type_id_prop  CODE;\\012BEGIN\\012   if NEW.mate_prop_id IS NOT NULL then\\012\\011\\011\\011-- find material type id of the property type \\012\\011\\011\\011select pt.maty_prop_id into v_type_id_prop \\012\\011\\011\\011  from material_type_property_types etpt, property_types pt \\012\\011\\011\\011 where NEW.mtpt_id = etpt.id AND etpt.prty_id = pt.id;\\012\\011\\011\\012\\011\\011\\011if v_type_id_prop IS NOT NULL then\\012\\011\\011\\011\\011-- find material type id of the material which consists the entity's property value\\012\\011\\011\\011\\011select entity.maty_id into v_type_id \\012\\011\\011\\011\\011  from materials entity\\012\\011\\011\\011\\011 where NEW.mate_prop_id = entity.id;\\012\\011\\011\\011\\011if v_type_id != v_type_id_prop then\\012\\011\\011\\011\\011\\011RAISE EXCEPTION 'Insert/Update of property value referencing material (id: %) failed, as referenced material type is different than expected (id %, expected id: %).', \\012\\011\\011\\011\\011\\011\\011\\011 NEW.mate_prop_id, v_type_id, v_type_id_prop;\\012\\011\\011\\011\\011end if;\\012\\011\\011\\011end if;\\012   end if;\\012   RETURN NEW;\\012END;\\012$$ LANGUAGE 'plpgsql';\\012\\012CREATE TRIGGER MATERIAL_PROPERTY_WITH_MATERIAL_DATA_TYPE_CHECK BEFORE INSERT OR UPDATE ON material_properties\\012    FOR EACH ROW EXECUTE PROCEDURE MATERIAL_PROPERTY_WITH_MATERIAL_DATA_TYPE_CHECK();\\012    \\012CREATE OR REPLACE FUNCTION SAMPLE_PROPERTY_WITH_MATERIAL_DATA_TYPE_CHECK() RETURNS trigger AS $$\\012DECLARE\\012   v_type_id  CODE;\\012   v_type_id_prop  CODE;\\012BEGIN\\012   if NEW.mate_prop_id IS NOT NULL then\\012\\011\\011\\011-- find material type id of the property type \\012\\011\\011\\011select pt.maty_prop_id into v_type_id_prop \\012\\011\\011\\011  from sample_type_property_types etpt, property_types pt \\012\\011\\011\\011 where NEW.stpt_id = etpt.id AND etpt.prty_id = pt.id;\\012\\011\\011\\012\\011\\011\\011if v_type_id_prop IS NOT NULL then\\012\\011\\011\\011\\011-- find material type id of the material which consists the entity's property value\\012\\011\\011\\011\\011select entity.maty_id into v_type_id \\012\\011\\011\\011\\011  from materials entity\\012\\011\\011\\011\\011 where NEW.mate_prop_id = entity.id;\\012\\011\\011\\011\\011if v_type_id != v_type_id_prop then\\012\\011\\011\\011\\011\\011RAISE EXCEPTION 'Insert/Update of property value referencing material (id: %) failed, as referenced material type is different than expected (id %, expected id: %).', \\012\\011\\011\\011\\011\\011\\011\\011\\011\\011\\011\\011\\011 NEW.mate_prop_id, v_type_id, v_type_id_prop;\\012\\011\\011\\011\\011end if;\\012\\011\\011\\011end if;\\012   end if;\\012   RETURN NEW;\\012END;\\012$$ LANGUAGE 'plpgsql';\\012\\012CREATE TRIGGER SAMPLE_PROPERTY_WITH_MATERIAL_DATA_TYPE_CHECK BEFORE INSERT OR UPDATE ON sample_properties\\012    FOR EACH ROW EXECUTE PROCEDURE SAMPLE_PROPERTY_WITH_MATERIAL_DATA_TYPE_CHECK();\\012    \\012CREATE OR REPLACE FUNCTION EXPERIMENT_PROPERTY_WITH_MATERIAL_DATA_TYPE_CHECK() RETURNS trigger AS $$\\012DECLARE\\012   v_type_id  CODE;\\012   v_type_id_prop  CODE;\\012BEGIN\\012   if NEW.mate_prop_id IS NOT NULL then\\012\\011\\011\\011-- find material type id of the property type \\012\\011\\011\\011select pt.maty_prop_id into v_type_id_prop \\012\\011\\011\\011  from experiment_type_property_types etpt, property_types pt \\012\\011\\011\\011 where NEW.etpt_id = etpt.id AND etpt.prty_id = pt.id;\\012\\011\\011\\012\\011\\011\\011if v_type_id_prop IS NOT NULL then\\012\\011\\011\\011\\011-- find material type id of the material which consists the entity's property value\\012\\011\\011\\011\\011select entity.maty_id into v_type_id \\012\\011\\011\\011\\011  from materials entity\\012\\011\\011\\011\\011 where NEW.mate_prop_id = entity.id;\\012\\011\\011\\011\\011if v_type_id != v_type_id_prop then\\012\\011\\011\\011\\011\\011RAISE EXCEPTION 'Insert/Update of property value referencing material (id: %) failed, as referenced material type is different than expected (id %, expected id: %).', \\012\\011\\011\\011\\011\\011\\011\\011\\011\\011\\011\\011\\011 NEW.mate_prop_id, v_type_id, v_type_id_prop;\\012\\011\\011\\011\\011end if;\\012\\011\\011\\011end if;\\012   end if;\\012   RETURN NEW;\\012END;\\012$$ LANGUAGE 'plpgsql';\\012\\012CREATE TRIGGER EXPERIMENT_PROPERTY_WITH_MATERIAL_DATA_TYPE_CHECK BEFORE INSERT OR UPDATE ON experiment_properties\\012    FOR EACH ROW EXECUTE PROCEDURE EXPERIMENT_PROPERTY_WITH_MATERIAL_DATA_TYPE_CHECK();\\012       \\012-- -------\\012-- remove the reminescents of the OBSERVABLE_TYPE\\012-- -------\\012\\012ALTER TABLE data\\012\\011DROP CONSTRAINT data_obty_fk;\\012\\012ALTER TABLE data_set_types\\012\\011DROP CONSTRAINT obty_pk;\\012\\012ALTER TABLE data_set_types\\012\\011ADD CONSTRAINT dsty_pk PRIMARY KEY (id);\\012\\012ALTER TABLE data\\012\\011ADD CONSTRAINT data_dsty_fk FOREIGN KEY (dsty_id) REFERENCES data_set_types(id);\\012\\012ALTER TABLE data_set_types\\012\\011DROP CONSTRAINT obty_bk_uk;\\012\\012ALTER TABLE data_set_types\\012\\011DROP CONSTRAINT obty_dbin_fk;\\012\\012ALTER TABLE data_set_types\\012\\011ADD CONSTRAINT dsty_bk_uk UNIQUE (code, dbin_id);\\012\\012ALTER TABLE data_set_types\\012\\011ADD CONSTRAINT dsty_dbin_fk FOREIGN KEY (dbin_id) REFERENCES database_instances(id);\\012\\012DROP INDEX data_obty_fk_i;\\012\\012CREATE INDEX data_dsty_fk_i ON data(dsty_id);\\012	\N
+./sourceTest/sql/postgresql/041/.svn/text-base/017=database_version_logs.tsv.svn-base:030	source/sql/postgresql/migration/migration-029-030.sql	SUCCESS	2009-03-23 15:34:44.72	-- -------\\012-- add modification_timestamp field to allow edition with Hibernate\\012-- -------\\012ALTER TABLE data\\012\\011ADD COLUMN modification_timestamp TIME_STAMP DEFAULT CURRENT_TIMESTAMP;\\012ALTER TABLE experiment_types\\012\\011ADD COLUMN modification_timestamp TIME_STAMP DEFAULT CURRENT_TIMESTAMP;\\012ALTER TABLE sample_types\\012\\011ADD COLUMN modification_timestamp TIME_STAMP DEFAULT CURRENT_TIMESTAMP;\\012ALTER TABLE material_types\\012\\011ADD COLUMN modification_timestamp TIME_STAMP DEFAULT CURRENT_TIMESTAMP;\\012ALTER TABLE data_set_types\\012\\011ADD COLUMN modification_timestamp TIME_STAMP DEFAULT CURRENT_TIMESTAMP;\\012ALTER TABLE controlled_vocabularies\\012\\011ADD COLUMN modification_timestamp TIME_STAMP DEFAULT CURRENT_TIMESTAMP;\\012-- -------\\012-- add properties to data sets\\012-- -------\\012CREATE TABLE DATA_SET_PROPERTIES (ID TECH_ID NOT NULL,DS_ID TECH_ID NOT NULL,DSTPT_ID TECH_ID NOT NULL,VALUE GENERIC_VALUE,CVTE_ID TECH_ID, MATE_PROP_ID TECH_ID, PERS_ID_REGISTERER TECH_ID NOT NULL,REGISTRATION_TIMESTAMP TIME_STAMP_DFL NOT NULL DEFAULT CURRENT_TIMESTAMP, MODIFICATION_TIMESTAMP TIME_STAMP DEFAULT CURRENT_TIMESTAMP);\\012CREATE TABLE DATA_SET_TYPE_PROPERTY_TYPES (ID TECH_ID NOT NULL,DSTY_ID TECH_ID NOT NULL,PRTY_ID TECH_ID NOT NULL,IS_MANDATORY BOOLEAN_CHAR NOT NULL DEFAULT 'F',IS_MANAGED_INTERNALLY BOOLEAN_CHAR NOT NULL DEFAULT 'F',PERS_ID_REGISTERER TECH_ID NOT NULL,REGISTRATION_TIMESTAMP TIME_STAMP_DFL NOT NULL DEFAULT CURRENT_TIMESTAMP);\\012\\012CREATE SEQUENCE DATA_SET_PROPERTY_ID_SEQ;\\012CREATE SEQUENCE DSTPT_ID_SEQ;\\012\\012ALTER TABLE DATA_SET_TYPE_PROPERTY_TYPES ADD CONSTRAINT DSTPT_PK PRIMARY KEY(ID);\\012ALTER TABLE DATA_SET_PROPERTIES ADD CONSTRAINT DSPR_PK PRIMARY KEY(ID);\\012\\012ALTER TABLE DATA_SET_TYPE_PROPERTY_TYPES ADD CONSTRAINT DSTPT_BK_UK UNIQUE(DSTY_ID,PRTY_ID);\\012ALTER TABLE DATA_SET_PROPERTIES ADD CONSTRAINT DSPR_BK_UK UNIQUE(DS_ID,DSTPT_ID);\\012\\012\\012ALTER TABLE DATA_SET_TYPE_PROPERTY_TYPES ADD CONSTRAINT DSTPT_DSTY_FK FOREIGN KEY (DSTY_ID) REFERENCES DATA_SET_TYPES(ID);\\012ALTER TABLE DATA_SET_TYPE_PROPERTY_TYPES ADD CONSTRAINT DSTPT_PERS_FK FOREIGN KEY (PERS_ID_REGISTERER) REFERENCES PERSONS(ID);\\012ALTER TABLE DATA_SET_TYPE_PROPERTY_TYPES ADD CONSTRAINT DSTPT_PRTY_FK FOREIGN KEY (PRTY_ID) REFERENCES PROPERTY_TYPES(ID);\\012ALTER TABLE DATA_SET_PROPERTIES ADD CONSTRAINT DSPR_CVTE_FK FOREIGN KEY (CVTE_ID) REFERENCES CONTROLLED_VOCABULARY_TERMS(ID);\\012ALTER TABLE DATA_SET_PROPERTIES ADD CONSTRAINT DSPR_DSTPT_FK FOREIGN KEY (DSTPT_ID) REFERENCES DATA_SET_TYPE_PROPERTY_TYPES(ID) ON DELETE CASCADE;\\012ALTER TABLE DATA_SET_PROPERTIES ADD CONSTRAINT DSPR_DS_FK FOREIGN KEY (DS_ID) REFERENCES DATA(ID);\\012ALTER TABLE DATA_SET_PROPERTIES ADD CONSTRAINT DSPR_PERS_FK FOREIGN KEY (PERS_ID_REGISTERER) REFERENCES PERSONS(ID);\\012ALTER TABLE DATA_SET_PROPERTIES ADD CONSTRAINT DSPR_MAPR_FK FOREIGN KEY (MATE_PROP_ID) REFERENCES MATERIALS(ID);\\012\\012ALTER TABLE DATA_SET_PROPERTIES ADD CONSTRAINT DSPR_CK CHECK \\012\\011((VALUE IS NOT NULL AND CVTE_ID IS NULL AND MATE_PROP_ID IS NULL) OR \\012\\011 (VALUE IS NULL AND CVTE_ID IS NOT NULL AND MATE_PROP_ID IS NULL) OR\\012\\011 (VALUE IS NULL AND CVTE_ID IS NULL AND MATE_PROP_ID IS NOT NULL)\\012\\011);\\012\\012CREATE INDEX DSPR_CVTE_FK_I ON DATA_SET_PROPERTIES (CVTE_ID);\\012CREATE INDEX DSPR_DSTPT_FK_I ON DATA_SET_PROPERTIES (DSTPT_ID);\\012CREATE INDEX DSPR_DS_FK_I ON DATA_SET_PROPERTIES (DS_ID);\\012CREATE INDEX DSPR_PERS_FK_I ON DATA_SET_PROPERTIES (PERS_ID_REGISTERER);\\012CREATE INDEX DSTPT_DSTY_FK_I ON DATA_SET_TYPE_PROPERTY_TYPES (DSTY_ID);\\012CREATE INDEX DSTPT_PERS_FK_I ON DATA_SET_TYPE_PROPERTY_TYPES (PERS_ID_REGISTERER);\\012CREATE INDEX DSTPT_PRTY_FK_I ON DATA_SET_TYPE_PROPERTY_TYPES (PRTY_ID);\\012\\012CREATE OR REPLACE FUNCTION DATA_SET_PROPERTY_WITH_MATERIAL_DATA_TYPE_CHECK() RETURNS trigger AS $$\\012DECLARE\\012   v_type_id  CODE;\\012   v_type_id_prop  CODE;\\012BEGIN\\012   if NEW.mate_prop_id IS NOT NULL then\\012\\011\\011\\011-- find material type id of the property type \\012\\011\\011\\011select pt.maty_prop_id into v_type_id_prop \\012\\011\\011\\011  from data_set_type_property_types dstpt, property_types pt \\012\\011\\011\\011 where NEW.dstpt_id = dstpt.id AND dstpt.prty_id = pt.id;\\012\\011\\011\\012\\011\\011\\011if v_type_id_prop IS NOT NULL then\\012\\011\\011\\011\\011-- find material type id of the material which consists the entity's property value\\012\\011\\011\\011\\011select entity.maty_id into v_type_id \\012\\011\\011\\011\\011  from materials entity\\012\\011\\011\\011\\011 where NEW.mate_prop_id = entity.id;\\012\\011\\011\\011\\011if v_type_id != v_type_id_prop then\\012\\011\\011\\011\\011\\011RAISE EXCEPTION 'Insert/Update of property value referencing material (id: %) failed, as referenced material type is different than expected (id %, expected id: %).', \\012\\011\\011\\011\\011\\011\\011\\011\\011\\011\\011\\011\\011 NEW.mate_prop_id, v_type_id, v_type_id_prop;\\012\\011\\011\\011\\011end if;\\012\\011\\011\\011end if;\\012   end if;\\012   RETURN NEW;\\012END;\\012$$ LANGUAGE 'plpgsql';\\012\\012CREATE TRIGGER DATA_SET_PROPERTY_WITH_MATERIAL_DATA_TYPE_CHECK BEFORE INSERT OR UPDATE ON data_set_properties\\012    FOR EACH ROW EXECUTE PROCEDURE DATA_SET_PROPERTY_WITH_MATERIAL_DATA_TYPE_CHECK();   \\012	\N
+./sourceTest/sql/postgresql/041/.svn/text-base/017=database_version_logs.tsv.svn-base:032	source/sql/postgresql/migration/migration-031-032.sql	SUCCESS	2009-04-09 09:36:36.20	-- -------\\012-- Modify MATERIAL_BATCHES\\012-- -------\\012\\012ALTER TABLE material_batches\\012    DROP COLUMN proc_id;\\012\\012-- -------\\012-- Modify SAMPLES\\012-- -------\\012\\012ALTER TABLE samples\\012    ADD COLUMN expe_id tech_id;\\012\\012ALTER TABLE samples\\012    ADD CONSTRAINT samp_expe_fk FOREIGN KEY (expe_id) REFERENCES experiments(id);\\012\\012CREATE INDEX samp_expe_fk_i ON samples USING btree (expe_id);\\012\\012-- relink samples directly to experiments\\012\\012UPDATE samples\\012SET expe_id = (SELECT e.id FROM experiments e, procedures p, sample_inputs si \\012               WHERE si.samp_id = samples.id AND si.proc_id = p.id AND p.expe_id = e.id AND e.inva_id IS NULL);\\012\\012\\012-- -------\\012-- Modify DATA\\012-- -------\\012\\012ALTER TABLE data\\012    ADD COLUMN expe_id tech_id;\\012\\012ALTER TABLE data\\012    ADD CONSTRAINT data_expe_fk FOREIGN KEY (expe_id) REFERENCES experiments(id);\\012\\012CREATE INDEX data_expe_fk_i ON data USING btree (expe_id);\\012\\012UPDATE data\\012SET expe_id = (SELECT e.id FROM experiments e, procedures p \\012               WHERE data.proc_id_produced_by = p.id AND p.expe_id = e.id);\\012\\012ALTER TABLE data\\012    ALTER COLUMN expe_id SET NOT NULL;\\012\\012ALTER TABLE data\\012    DROP COLUMN proc_id_produced_by;\\012\\012-- -------\\012-- Drop PROCEDURES, PROCEDURE_TYPES, and SAMPLE_INPUTS\\012-- -------\\012\\012DROP TABLE sample_inputs;\\012DROP TABLE procedures;\\012DROP TABLE procedure_types;\\012\\012DROP SEQUENCE procedure_id_seq;\\012DROP SEQUENCE procedure_type_id_seq;\\012\\012-- -------\\012-- Add CODE_SEQ\\012-- -------\\012\\012CREATE SEQUENCE CODE_SEQ;\\012\\012-- -------\\012-- Add new columns to DATA_STORES\\012-- -------\\012\\012ALTER TABLE data_stores\\012    ADD COLUMN remote_url character varying(250),\\012    ADD COLUMN session_token character varying(50),\\012    ADD COLUMN modification_timestamp time_stamp DEFAULT now();\\012\\012UPDATE data_stores\\012SET remote_url = '', session_token='';\\012\\012ALTER TABLE data_stores\\012    ALTER COLUMN remote_url SET NOT NULL,\\012    ALTER COLUMN session_token SET NOT NULL;\\012\\012-- -------\\012-- Drop foreign keys onto DATA_STORES\\012-- -------\\012\\012ALTER TABLE database_instances\\012    DROP COLUMN dast_id;\\012\\012ALTER TABLE groups\\012    DROP COLUMN dast_id;\\012\\012ALTER TABLE projects\\012    DROP COLUMN dast_id;\\012\\012ALTER TABLE experiments\\012    DROP COLUMN dast_id;\\012\\012-- -------\\012-- Add foreign key from DATA onto DATA_STORES\\012-- -------\\012\\012ALTER TABLE data\\012    ADD COLUMN dast_id tech_id;\\012\\012ALTER TABLE data\\012    ADD CONSTRAINT data_dast_fk FOREIGN KEY (dast_id) REFERENCES data_stores(id);\\012\\012UPDATE data\\012SET dast_id = (select id from data_stores where code = 'STANDARD');\\012\\012ALTER TABLE data\\012    ALTER COLUMN dast_id SET NOT NULL;\\012\\012\\012------------------------------------------------------------------------------------\\012--  Purpose:  Replace trigger SAMPLE_CODE_UNIQUENESS_CHECK \\012------------------------------------------------------------------------------------\\012\\012CREATE OR REPLACE FUNCTION SAMPLE_CODE_UNIQUENESS_CHECK() RETURNS trigger AS $$\\012DECLARE\\012   counter  INTEGER;\\012BEGIN\\012    LOCK TABLE samples IN EXCLUSIVE MODE;\\012    IF (NEW.samp_id_part_of is NULL) THEN\\012        IF (NEW.dbin_id is not NULL) THEN\\012            SELECT count(*) into counter FROM samples \\012                where id != NEW.id and code = NEW.code and samp_id_part_of is NULL and dbin_id = NEW.dbin_id;\\012            IF (counter > 0) THEN\\012                RAISE EXCEPTION 'Insert/Update of Sample (Code: %) failed because database instance sample with the same code already exists.', NEW.code;\\012            END IF;\\012        ELSIF (NEW.grou_id is not NULL) THEN\\012            SELECT count(*) into counter FROM samples \\012                where id != NEW.id and code = NEW.code and samp_id_part_of is NULL and grou_id = NEW.grou_id;\\012            IF (counter > 0) THEN\\012                RAISE EXCEPTION 'Insert/Update of Sample (Code: %) failed because group sample with the same code already exists.', NEW.code;\\012            END IF;\\012        END IF;\\012        ELSE\\012        IF (NEW.dbin_id is not NULL) THEN\\012            SELECT count(*) into counter FROM samples \\012                where id != NEW.id and code = NEW.code and samp_id_part_of = NEW.samp_id_part_of and dbin_id = NEW.dbin_id;\\012            IF (counter > 0) THEN\\012                RAISE EXCEPTION 'Insert/Update of Sample (Code: %) failed because database instance sample with the same code and being the part of the same parent already exists.', NEW.code;\\012            END IF;\\012        ELSIF (NEW.grou_id is not NULL) THEN\\012            SELECT count(*) into counter FROM samples \\012                where id != NEW.id and code = NEW.code and samp_id_part_of = NEW.samp_id_part_of and grou_id = NEW.grou_id;\\012            IF (counter > 0) THEN\\012                RAISE EXCEPTION 'Insert/Update of Sample (Code: %) failed because group sample with the same code and being the part of the same parent already exists.', NEW.code;\\012            END IF;\\012        END IF;\\012        END IF;   \\012   RETURN NEW;\\012END;\\012$$ LANGUAGE 'plpgsql';\\012\\012\\012\\012	\N
+./sourceTest/sql/postgresql/041/.svn/text-base/017=database_version_logs.tsv.svn-base:034	source/sql/postgresql/migration/migration-033-034.sql	SUCCESS	2009-05-26 08:32:49.935	------------------------------------------------------------------------------------\\012-- Create sequence for generating permanent identifiers starting with nextval of existing dataset sequence.\\012------------------------------------------------------------------------------------\\012CREATE FUNCTION CREATE_SEQUENCE(EXISTING_SEQUENCE VARCHAR, NEW_SEQUENCE VARCHAR) RETURNS VOID AS $$\\012DECLARE\\012  CURR_SEQ_VAL   INTEGER;\\012BEGIN\\012  SELECT INTO CURR_SEQ_VAL NEXTVAL(EXISTING_SEQUENCE);\\012  EXECUTE 'CREATE SEQUENCE ' || NEW_SEQUENCE || ' START WITH ' || CURR_SEQ_VAL;\\012  RETURN;\\012END;\\012$$ LANGUAGE 'plpgsql';\\012\\012SELECT CREATE_SEQUENCE('DATA_ID_SEQ', 'PERM_ID_SEQ');\\012DROP FUNCTION CREATE_SEQUENCE(VARCHAR, VARCHAR);\\012\\012------------------------------------------------------------------------------------\\012-- Add perm_id columns to samples and experiments.\\012------------------------------------------------------------------------------------\\012ALTER TABLE SAMPLES ADD COLUMN PERM_ID CODE;\\012ALTER TABLE EXPERIMENTS ADD COLUMN PERM_ID CODE;\\012\\012UPDATE SAMPLES SET PERM_ID = to_char(registration_timestamp,'YYYYMMDDHHSSMS') || '-' || NEXTVAL('PERM_ID_SEQ');\\012UPDATE EXPERIMENTS SET PERM_ID = to_char(registration_timestamp,'YYYYMMDDHHSSMS') || '-' || NEXTVAL('PERM_ID_SEQ');\\012ALTER TABLE SAMPLES ALTER COLUMN PERM_ID SET NOT NULL;\\012ALTER TABLE EXPERIMENTS ALTER COLUMN PERM_ID SET NOT NULL;\\012ALTER TABLE SAMPLES ADD CONSTRAINT SAMP_PI_UK UNIQUE(PERM_ID);\\012ALTER TABLE EXPERIMENTS ADD CONSTRAINT EXPE_PI_UK UNIQUE(PERM_ID);\\012\\012\\012------------------------------------------------------------------------------------\\012-- Add column is_chosen_from_list to controlled_vocabularies.\\012------------------------------------------------------------------------------------\\012ALTER TABLE controlled_vocabularies ADD COLUMN is_chosen_from_list BOOLEAN_CHAR NOT NULL DEFAULT TRUE;\\012ALTER TABLE controlled_vocabularies ADD COLUMN source_uri CHARACTER VARYING(250);\\012------------------------------------------------------------------------------------\\012-- Modify Data table - remove arc connection between Sample and Data table, use a flag instead\\012------------------------------------------------------------------------------------\\012\\012-- add new columns\\012\\012ALTER TABLE data\\012    ADD COLUMN is_derived boolean_char;\\012ALTER TABLE data\\012    ADD COLUMN samp_id tech_id;\\012\\012-- update values in new columns\\012\\012UPDATE data\\012    SET is_derived = (samp_id_derived_from IS NOT NULL); \\012UPDATE data\\012    SET samp_id = samp_id_derived_from \\012    WHERE is_derived = 'TRUE';\\012UPDATE data\\012    SET samp_id = samp_id_acquired_from \\012    WHERE is_derived = 'FALSE';\\012\\012-- add constraints and indexes to new columns\\012\\012ALTER TABLE data\\012    ALTER COLUMN is_derived SET NOT NULL;\\012ALTER TABLE data\\012    ALTER COLUMN samp_id SET NOT NULL;   \\012ALTER TABLE data\\012    ADD CONSTRAINT data_samp_fk FOREIGN KEY (samp_id) REFERENCES samples (id);\\012CREATE INDEX data_samp_fk_i ON data USING btree (samp_id);\\012\\012-- remove old columns\\012\\012ALTER TABLE data\\012    DROP COLUMN samp_id_acquired_from;\\012ALTER TABLE data\\012    DROP COLUMN samp_id_derived_from;\\012    \\012------------------------------------------------------------------------------------\\012-- Granting SELECT privilege to group openbis_readonly\\012------------------------------------------------------------------------------------\\012\\012GRANT SELECT ON SEQUENCE attachment_content_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE attachment_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE code_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE controlled_vocabulary_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE cvte_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE data_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE data_set_property_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE data_set_relationship_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE data_set_type_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE data_store_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE data_type_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE database_instance_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE dstpt_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE etpt_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE event_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE experiment_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE experiment_property_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE experiment_type_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE file_format_type_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE group_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE invalidation_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE locator_type_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE material_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE material_property_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE material_type_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE mtpt_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE perm_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE person_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE project_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE property_type_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE role_assignment_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE sample_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE sample_property_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE sample_type_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE stpt_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE attachment_contents TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE attachments TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE controlled_vocabularies TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE controlled_vocabulary_terms TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE data TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE data_set_properties TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE data_set_relationships TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE data_set_type_property_types TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE data_set_types TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE data_stores TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE data_types TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE database_instances TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE database_version_logs TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE events TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE experiment_properties TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE experiment_type_property_types TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE experiment_types TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE experiments TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE external_data TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE file_format_types TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE groups TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE invalidations TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE locator_types TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE material_properties TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE material_type_property_types TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE material_types TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE materials TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE persons TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE projects TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE property_types TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE role_assignments TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE sample_properties TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE sample_type_property_types TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE sample_types TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE samples TO GROUP OPENBIS_READONLY;\\012\\012------------------------------------------------------------------------------------\\012-- Delete MATERIAL_BATCHES table\\012------------------------------------------------------------------------------------\\012\\012-- WARNING: Potential data lost!!!\\012-- WARNING: Potential data lost!!!\\012-- WARNING: Potential data lost!!!\\012\\012DROP TABLE SAMPLE_MATERIAL_BATCHES;\\012DROP TABLE MATERIAL_BATCHES;\\012DROP SEQUENCE MATERIAL_BATCH_ID_SEQ;\\012\\012------------------------------------------------------------------------------------\\012-- Delete MATE_ID_INHIBITOR_OF from table MATERIALS\\012------------------------------------------------------------------------------------\\012\\012-- WARNING: Potential data lost!!!\\012-- WARNING: Potential data lost!!!\\012-- WARNING: Potential data lost!!!\\012\\012ALTER TABLE MATERIALS DROP COLUMN MATE_ID_INHIBITOR_OF;\\012	\N
+./sourceTest/sql/postgresql/041/.svn/text-base/017=database_version_logs.tsv.svn-base:041	source/sql/postgresql/migration/migration-040-041.sql	SUCCESS	2009-09-14 13:48:57.539	-- Create FILTERS table\\012\\012CREATE TABLE FILTERS (ID TECH_ID NOT NULL, DBIN_ID TECH_ID NOT NULL, NAME VARCHAR(200) NOT NULL, DESCRIPTION DESCRIPTION_1000,REGISTRATION_TIMESTAMP TIME_STAMP_DFL NOT NULL DEFAULT CURRENT_TIMESTAMP, PERS_ID_REGISTERER TECH_ID NOT NULL, MODIFICATION_TIMESTAMP TIME_STAMP DEFAULT CURRENT_TIMESTAMP, EXPRESSION VARCHAR(2000) NOT NULL, IS_PUBLIC BOOLEAN NOT NULL, GRID_ID VARCHAR(200) NOT NULL);\\012CREATE SEQUENCE FILTER_ID_SEQ;\\012ALTER TABLE FILTERS ADD CONSTRAINT FILT_PK PRIMARY KEY(ID);\\012ALTER TABLE FILTERS ADD CONSTRAINT FILT_BK_UK UNIQUE(NAME, DBIN_ID, GRID_ID);\\012ALTER TABLE FILTERS ADD CONSTRAINT FILT_PERS_FK FOREIGN KEY (PERS_ID_REGISTERER) REFERENCES PERSONS(ID);\\012ALTER TABLE FILTERS ADD CONSTRAINT FILT_DBIN_FK FOREIGN KEY (DBIN_ID) REFERENCES DATABASE_INSTANCES(ID);\\012CREATE INDEX FILT_PERS_FK_I ON FILTERS (PERS_ID_REGISTERER);\\012CREATE INDEX FILT_DBIN_FK_I ON FILTERS (DBIN_ID);\\012GRANT SELECT ON SEQUENCE filter_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE filters TO GROUP OPENBIS_READONLY;\\012\\012-- Add missing foreign key to role assignments authorization group\\012ALTER TABLE ROLE_ASSIGNMENTS ADD CONSTRAINT ROAS_AG_FK_GRANTEE FOREIGN KEY (AG_ID_GRANTEE) REFERENCES AUTHORIZATION_GROUPS(ID);\\012\\012--------------------------------------------------------------------------------------------------\\012-- Modify dataset connections:\\012-- 1. connection with sample shouldn't be mandatory any more\\012-- 2. introduce an arc condition that dataset cannot be connected with a sample and a parent dataset at the same time\\012--------------------------------------------------------------------------------------------------\\012\\012-- Weaken data-sample connection constraint - allow dataset to have no connection with sample\\012ALTER TABLE data ALTER COLUMN samp_id DROP NOT NULL;\\012\\012-- Remove data-sample connection for datasets that have a parent\\012\\012UPDATE data \\012   SET samp_id = NULL \\012 WHERE id IN (SELECT DISTINCT data_id_child FROM data_set_relationships);\\012\\012-- With PostgreSQL 8.4 one can check that before migration there were no cycles in dataset relationships:\\012--\\012-- WITH RECURSIVE data_set_parents(id, parent_ids, cycle) AS (\\012--         SELECT  r.data_id_child AS id, \\012--                 ARRAY[CAST (r.data_id_parent AS bigint)] AS parent_ids, \\012--                 false AS cycle \\012--         FROM data_set_relationships r\\012--     UNION ALL\\012--         SELECT  r.data_id_child,\\012--                 CAST (r.data_id_parent AS bigint) || p.parent_ids,\\012--                 r.data_id_child = ANY(p.parent_ids)\\012--         FROM data_set_relationships r, data_set_parents p\\012--         WHERE r.data_id_parent = p.id AND NOT cycle\\012-- )\\012-- SELECT count(*) AS cycles FROM data_set_parents WHERE cycle = true;\\012\\012---------------------------------------------------------------------------------------------------\\012--  Purpose:  Create DEFERRED triggers:\\012--            * check_dataset_relationships_on_data_table_modification,\\012--            * check_dataset_relationships_on_relationships_table_modification.\\012--            They check that after all modifications of database (just before commit) \\012--            if 'data'/'data_set_relationships' tables are among modified tables \\012--            dataset is not connected with a sample and a parent dataset at the same time.\\012--            This connections are held in two different tables so simple immediate trigger \\012--            with arc check cannot be used and we need two deferred triggers.\\012----------------------------------------------------------------------------------------------------\\012\\012-- trigger for 'data' table\\012\\012CREATE OR REPLACE FUNCTION check_dataset_relationships_on_data_table_modification() RETURNS trigger AS $$\\012DECLARE\\012\\011counter\\011INTEGER;\\012BEGIN\\012\\011-- if there is a connection with a Sample there should not be any connection with a parent Data Set\\012\\011IF (NEW.samp_id IS NOT NULL) THEN\\012\\011\\011-- count number of parents\\012\\011\\011SELECT count(*) INTO counter \\012\\011\\011\\011FROM data_set_relationships \\012\\011\\011\\011WHERE data_id_child = OLD.id;\\012\\011\\011IF (counter > 0) THEN\\012\\011\\011\\011RAISE EXCEPTION 'Insert/Update of Data Set (Code: %) failed because it cannot be connected with a Sample and a parent Data Set at the same time.', OLD.code;\\012\\011\\011END IF;\\012\\011END IF;\\012  RETURN NEW;\\012END;\\012$$ LANGUAGE 'plpgsql';\\012\\012CREATE CONSTRAINT TRIGGER check_dataset_relationships_on_data_table_modification \\012  AFTER INSERT OR UPDATE ON data\\012\\011DEFERRABLE INITIALLY DEFERRED\\012\\011FOR EACH ROW \\012\\011EXECUTE PROCEDURE check_dataset_relationships_on_data_table_modification();\\012\\012-- trigger for 'data_set_relationships'\\012\\012CREATE OR REPLACE FUNCTION check_dataset_relationships_on_relationships_table_modification() RETURNS trigger AS $$\\012DECLARE\\012\\011counter\\011INTEGER;\\012\\011sample_id\\011TECH_ID;\\012\\011data_code\\011CODE;\\012BEGIN\\012\\011-- child will have a parent added so it should not be connected with any sample\\012\\011SELECT samp_id, code INTO sample_id, data_code \\012\\011\\011FROM data \\012\\011\\011WHERE id = NEW.data_id_child;\\012\\011IF (sample_id IS NOT NULL) THEN\\012\\011\\011RAISE EXCEPTION 'Insert/Update of Data Set (Code: %) failed because it cannot be connected to a Sample and to a parent Data Set at the same time.', data_code;\\012\\011END IF;\\012\\011RETURN NEW;\\012END;\\012$$ LANGUAGE 'plpgsql';\\012  \\012CREATE CONSTRAINT TRIGGER check_dataset_relationships_on_relationships_table_modification \\012  AFTER INSERT OR UPDATE ON data_set_relationships\\012\\011DEFERRABLE INITIALLY DEFERRED\\012\\011FOR EACH ROW \\012\\011EXECUTE PROCEDURE check_dataset_relationships_on_relationships_table_modification();\\012	\N
+./sourceTest/sql/postgresql/041/.svn/text-base/schema-041.sql.svn-base:    LANGUAGE plpgsql;
+./sourceTest/sql/postgresql/041/.svn/text-base/schema-041.sql.svn-base:    LANGUAGE plpgsql;
+./sourceTest/sql/postgresql/041/.svn/text-base/schema-041.sql.svn-base:    LANGUAGE plpgsql;
+./sourceTest/sql/postgresql/041/.svn/text-base/schema-041.sql.svn-base:    LANGUAGE plpgsql;
+./sourceTest/sql/postgresql/041/.svn/text-base/schema-041.sql.svn-base:    LANGUAGE plpgsql;
+./sourceTest/sql/postgresql/041/.svn/text-base/schema-041.sql.svn-base:    LANGUAGE plpgsql;
+./sourceTest/sql/postgresql/041/.svn/text-base/schema-041.sql.svn-base:    LANGUAGE plpgsql;
+./sourceTest/sql/postgresql/041/.svn/text-base/schema-041.sql.svn-base:    LANGUAGE plpgsql;
+./sourceTest/sql/postgresql/041/.svn/text-base/schema-041.sql.svn-base:    LANGUAGE plpgsql;
+./sourceTest/sql/postgresql/041/.svn/text-base/schema-041.sql.svn-base:    LANGUAGE plpgsql;
+./sourceTest/sql/postgresql/041/017=database_version_logs.tsv:027	D:\\User\\felmer\\dev-workspace\\openbis/source/sql/postgresql/027/function-027.sql	SUCCESS	2008-11-05 09:18:00.403	-- Creating Functions\\012\\012------------------------------------------------------------------------------------\\012--  Purpose:  Create function RENAME_SEQUENCE() that is required for renaming the sequences belonging to tables\\012------------------------------------------------------------------------------------\\012CREATE FUNCTION RENAME_SEQUENCE(OLD_NAME VARCHAR, NEW_NAME VARCHAR) RETURNS INTEGER AS $$\\012DECLARE\\012  CURR_SEQ_VAL   INTEGER;\\012BEGIN\\012  SELECT INTO CURR_SEQ_VAL NEXTVAL(OLD_NAME);\\012  EXECUTE 'CREATE SEQUENCE ' || NEW_NAME || ' START WITH ' || CURR_SEQ_VAL;\\012  EXECUTE 'DROP SEQUENCE ' || OLD_NAME;\\012  RETURN CURR_SEQ_VAL;\\012END;\\012$$ LANGUAGE 'plpgsql';\\012\\012\\012------------------------------------------------------------------------------------\\012--  Purpose:  Create trigger CONTROLLED_VOCABULARY_CHECK \\012------------------------------------------------------------------------------------\\012\\012CREATE OR REPLACE FUNCTION CONTROLLED_VOCABULARY_CHECK() RETURNS trigger AS $$\\012DECLARE\\012   v_code  CODE;\\012BEGIN\\012\\012   select code into v_code from data_types where id = NEW.daty_id;\\012\\012   -- Check if the data is of type "CONTROLLEDVOCABULARY"\\012   if v_code = 'CONTROLLEDVOCABULARY' then\\012      if NEW.covo_id IS NULL then\\012         RAISE EXCEPTION 'Insert/Update of Property Type (Code: %) failed, as its Data Type is CONTROLLEDVOCABULARY, but it is not linked to a Controlled Vocabulary.', NEW.code;\\012      end if;\\012   end if;\\012\\012   RETURN NEW;\\012\\012END;\\012$$ LANGUAGE 'plpgsql';\\012\\012CREATE TRIGGER CONTROLLED_VOCABULARY_CHECK BEFORE INSERT OR UPDATE ON PROPERTY_TYPES\\012    FOR EACH ROW EXECUTE PROCEDURE CONTROLLED_VOCABULARY_CHECK();\\012\\012\\012------------------------------------------------------------------------------------\\012--  Purpose:  Create trigger EXTERNAL_DATA_STORAGE_FORMAT_CHECK \\012------------------------------------------------------------------------------------\\012\\012CREATE OR REPLACE FUNCTION EXTERNAL_DATA_STORAGE_FORMAT_CHECK() RETURNS trigger AS $$\\012DECLARE\\012   v_covo_code  CODE;\\012   data_code CODE;\\012BEGIN\\012\\012   select code into v_covo_code from controlled_vocabularies\\012      where is_internal_namespace = true and \\012         id = (select covo_id from controlled_vocabulary_terms where id = NEW.cvte_id_stor_fmt);\\012   -- Check if the data storage format is a term of the controlled vocabulary "STORAGE_FORMAT"\\012   if v_covo_code != 'STORAGE_FORMAT' then\\012      select code into data_code from data where id = NEW.data_id; \\012      RAISE EXCEPTION 'Insert/Update of Data (Code: %) failed, as its Storage Format is %, but is required to be STORAGE_FORMAT.', data_code, v_covo_code;\\012   end if;\\012\\012   RETURN NEW;\\012\\012END;\\012$$ LANGUAGE 'plpgsql';\\012\\012CREATE TRIGGER EXTERNAL_DATA_STORAGE_FORMAT_CHECK BEFORE INSERT OR UPDATE ON EXTERNAL_DATA\\012    FOR EACH ROW EXECUTE PROCEDURE EXTERNAL_DATA_STORAGE_FORMAT_CHECK();\\012\\012------------------------------------------------------------------------------------\\012--  Purpose:  Create trigger SAMPLE_CODE_UNIQUENESS_CHECK \\012------------------------------------------------------------------------------------\\012\\012CREATE OR REPLACE FUNCTION SAMPLE_CODE_UNIQUENESS_CHECK() RETURNS trigger AS $$\\012DECLARE\\012   counter  INTEGER;\\012BEGIN\\012\\011IF (NEW.samp_id_part_of is NULL) THEN\\012\\011\\011IF (NEW.dbin_id is not NULL) THEN\\012\\011\\011\\011SELECT count(*) into counter FROM samples \\012\\011\\011\\011\\011where id != NEW.id and code = NEW.code and samp_id_part_of is NULL and dbin_id = NEW.dbin_id;\\012\\011\\011\\011IF (counter > 0) THEN\\012\\011\\011\\011\\011RAISE EXCEPTION 'Insert/Update of Sample (Code: %) failed because database instance sample with the same code already exists.', NEW.code;\\012\\011\\011\\011END IF;\\012\\011\\011ELSIF (NEW.grou_id is not NULL) THEN\\012\\011\\011\\011SELECT count(*) into counter FROM samples \\012\\011\\011\\011\\011where id != NEW.id and code = NEW.code and samp_id_part_of is NULL and grou_id = NEW.grou_id;\\012\\011\\011\\011IF (counter > 0) THEN\\012\\011\\011\\011\\011RAISE EXCEPTION 'Insert/Update of Sample (Code: %) failed because group sample with the same code already exists.', NEW.code;\\012\\011\\011\\011END IF;\\012\\011\\011END IF;\\012        ELSE\\012\\011\\011IF (NEW.dbin_id is not NULL) THEN\\012\\011\\011\\011SELECT count(*) into counter FROM samples \\012\\011\\011\\011\\011where id != NEW.id and code = NEW.code and samp_id_part_of = NEW.samp_id_part_of and dbin_id = NEW.dbin_id;\\012\\011\\011\\011IF (counter > 0) THEN\\012\\011\\011\\011\\011RAISE EXCEPTION 'Insert/Update of Sample (Code: %) failed because database instance sample with the same code and being the part of the same parent already exists.', NEW.code;\\012\\011\\011\\011END IF;\\012\\011\\011ELSIF (NEW.grou_id is not NULL) THEN\\012\\011\\011\\011SELECT count(*) into counter FROM samples \\012\\011\\011\\011\\011where id != NEW.id and code = NEW.code and samp_id_part_of = NEW.samp_id_part_of and grou_id = NEW.grou_id;\\012\\011\\011\\011IF (counter > 0) THEN\\012\\011\\011\\011\\011RAISE EXCEPTION 'Insert/Update of Sample (Code: %) failed because group sample with the same code and being the part of the same parent already exists.', NEW.code;\\012\\011\\011\\011END IF;\\012\\011\\011END IF;\\012        END IF;   \\012   RETURN NEW;\\012END;\\012$$ LANGUAGE 'plpgsql';\\012\\012CREATE TRIGGER SAMPLE_CODE_UNIQUENESS_CHECK BEFORE INSERT OR UPDATE ON SAMPLES\\012    FOR EACH ROW EXECUTE PROCEDURE SAMPLE_CODE_UNIQUENESS_CHECK();\\012	\N
+./sourceTest/sql/postgresql/041/017=database_version_logs.tsv:028	source/sql/postgresql/migration/migration-027-028.sql	SUCCESS	2008-11-18 13:24:17.508	-- Create EXPERIMENT_ATTACHMENT_CONTENTS.\\012CREATE TABLE EXPERIMENT_ATTACHMENT_CONTENTS (ID TECH_ID NOT NULL,VALUE FILE NOT NULL);\\012CREATE SEQUENCE EXPERIMENT_ATTACHMENT_CONTENT_ID_SEQ;\\012ALTER TABLE EXPERIMENT_ATTACHMENT_CONTENTS ADD CONSTRAINT EXAC_PK PRIMARY KEY(ID);\\012\\012-- Alter EXPERIMENT_ATTACHMENTS by adding the new column which has a NULL constraint.\\012-- The NOT NULL constraint is added later on.\\012ALTER TABLE EXPERIMENT_ATTACHMENTS ADD COLUMN EXAC_ID TECH_ID;\\012\\012-- Does the VALUE migration between EXPERIMENT_ATTACHMENTS to EXPERIMENT_ATTACHMENT_CONTENTS.\\012CREATE OR REPLACE FUNCTION move_exp_att_content() RETURNS integer AS $$\\012DECLARE\\012    rec RECORD;\\012    seq BIGINT;\\012BEGIN\\012  FOR rec IN SELECT id, value FROM EXPERIMENT_ATTACHMENTS LOOP\\012  \\011seq := nextval('EXPERIMENT_ATTACHMENT_CONTENT_ID_SEQ');\\012    INSERT INTO EXPERIMENT_ATTACHMENT_CONTENTS (id, value) VALUES (seq, rec.value);\\012    UPDATE EXPERIMENT_ATTACHMENTS SET exac_id = seq WHERE id = rec.id;\\012  END LOOP;\\012  RETURN 1;\\012END;\\012$$ LANGUAGE 'plpgsql';\\012\\012-- Call the function.\\012SELECT move_exp_att_content();\\012DROP FUNCTION move_exp_att_content();\\012\\012\\012-- Finish EXPERIMENT_ATTACHMENTS changes.\\012ALTER TABLE EXPERIMENT_ATTACHMENTS ADD CONSTRAINT EXAT_CONT_FK FOREIGN KEY (EXAC_ID) REFERENCES EXPERIMENT_ATTACHMENT_CONTENTS(ID);\\012ALTER TABLE EXPERIMENT_ATTACHMENTS DROP COLUMN VALUE;\\012ALTER TABLE EXPERIMENT_ATTACHMENTS ALTER COLUMN EXAC_ID SET NOT NULL;\\012	\N
+./sourceTest/sql/postgresql/041/017=database_version_logs.tsv:029	source/sql/postgresql/migration/migration-028-029.sql	SUCCESS	2009-03-18 10:50:20.105	-- -------\\012-- add modification_timestamp field to allow edition with Hibernate\\012-- -------\\012\\012ALTER TABLE samples\\012\\011ADD COLUMN modification_timestamp TIME_STAMP DEFAULT CURRENT_TIMESTAMP;\\012\\012ALTER TABLE experiments\\012\\011ADD COLUMN modification_timestamp TIME_STAMP DEFAULT CURRENT_TIMESTAMP;\\012\\012ALTER TABLE materials\\012\\011ADD COLUMN modification_timestamp TIME_STAMP DEFAULT CURRENT_TIMESTAMP;\\012\\012ALTER TABLE experiment_properties\\012\\011ADD COLUMN modification_timestamp TIME_STAMP DEFAULT CURRENT_TIMESTAMP;\\012\\012ALTER TABLE material_properties\\012\\011ADD COLUMN modification_timestamp TIME_STAMP DEFAULT CURRENT_TIMESTAMP;\\012\\012ALTER TABLE sample_properties\\012\\011ADD COLUMN modification_timestamp TIME_STAMP DEFAULT CURRENT_TIMESTAMP;\\012\\012-- -------\\012-- add property data type which references materials\\012-- -------\\012\\012ALTER TABLE property_types\\012\\011ADD COLUMN maty_prop_id tech_id;\\012\\012ALTER TABLE property_types\\012\\011ADD CONSTRAINT prty_maty_fk FOREIGN KEY (maty_prop_id) REFERENCES material_types(id);\\012\\012ALTER TABLE experiment_properties\\012\\011ADD COLUMN mate_prop_id tech_id;\\012\\012ALTER TABLE material_properties\\012\\011ADD COLUMN mate_prop_id tech_id;\\012\\012ALTER TABLE sample_properties\\012\\011ADD COLUMN mate_prop_id tech_id;\\012\\012ALTER TABLE experiment_properties\\012\\011ADD CONSTRAINT expr_mapr_fk FOREIGN KEY (mate_prop_id) REFERENCES materials(id);\\012\\012ALTER TABLE material_properties\\012\\011ADD CONSTRAINT mapr_mapr_fk FOREIGN KEY (mate_prop_id) REFERENCES materials(id);\\012\\012ALTER TABLE sample_properties\\012\\011ADD CONSTRAINT sapr_mapr_fk FOREIGN KEY (mate_prop_id) REFERENCES materials(id);\\012\\012insert into data_types\\012(id\\012 ,code\\012 ,description)\\012 values \\012 (nextval('DATA_TYPE_ID_SEQ')\\012 ,'MATERIAL'\\012 ,'Reference to a material'\\012);\\012\\012ALTER TABLE MATERIAL_PROPERTIES DROP CONSTRAINT MAPR_CK;\\012ALTER TABLE MATERIAL_PROPERTIES ADD CONSTRAINT MAPR_CK CHECK \\012\\011((VALUE IS NOT NULL AND CVTE_ID IS NULL AND MATE_PROP_ID IS NULL) OR \\012\\011 (VALUE IS NULL AND CVTE_ID IS NOT NULL AND MATE_PROP_ID IS NULL) OR\\012\\011 (VALUE IS NULL AND CVTE_ID IS NULL AND MATE_PROP_ID IS NOT NULL)\\012\\011);\\012\\012ALTER TABLE EXPERIMENT_PROPERTIES DROP CONSTRAINT EXPR_CK;\\012ALTER TABLE EXPERIMENT_PROPERTIES ADD CONSTRAINT EXPR_CK CHECK \\012\\011((VALUE IS NOT NULL AND CVTE_ID IS NULL AND MATE_PROP_ID IS NULL) OR \\012\\011 (VALUE IS NULL AND CVTE_ID IS NOT NULL AND MATE_PROP_ID IS NULL) OR\\012\\011 (VALUE IS NULL AND CVTE_ID IS NULL AND MATE_PROP_ID IS NOT NULL)\\012\\011);\\012\\012ALTER TABLE SAMPLE_PROPERTIES DROP CONSTRAINT SAPR_CK;\\012ALTER TABLE SAMPLE_PROPERTIES ADD CONSTRAINT SAPR_CK CHECK \\012\\011((VALUE IS NOT NULL AND CVTE_ID IS NULL AND MATE_PROP_ID IS NULL) OR \\012\\011 (VALUE IS NULL AND CVTE_ID IS NOT NULL AND MATE_PROP_ID IS NULL) OR\\012\\011 (VALUE IS NULL AND CVTE_ID IS NULL AND MATE_PROP_ID IS NOT NULL)\\012\\011);\\012\\012------------------------------------------------------------------------------------\\012--  Purpose:  Create trigger MATERIAL/SAMPLE/EXPERIMENT _PROPERTY_WITH_MATERIAL_DATA_TYPE_CHECK\\012--            It checks that if material property value is assigned to the entity,\\012--\\011\\011\\011\\011\\011\\011then the material type is equal to the one described by property type.\\012------------------------------------------------------------------------------------\\012\\012CREATE OR REPLACE FUNCTION MATERIAL_PROPERTY_WITH_MATERIAL_DATA_TYPE_CHECK() RETURNS trigger AS $$\\012DECLARE\\012   v_type_id  CODE;\\012   v_type_id_prop  CODE;\\012BEGIN\\012   if NEW.mate_prop_id IS NOT NULL then\\012\\011\\011\\011-- find material type id of the property type \\012\\011\\011\\011select pt.maty_prop_id into v_type_id_prop \\012\\011\\011\\011  from material_type_property_types etpt, property_types pt \\012\\011\\011\\011 where NEW.mtpt_id = etpt.id AND etpt.prty_id = pt.id;\\012\\011\\011\\012\\011\\011\\011if v_type_id_prop IS NOT NULL then\\012\\011\\011\\011\\011-- find material type id of the material which consists the entity's property value\\012\\011\\011\\011\\011select entity.maty_id into v_type_id \\012\\011\\011\\011\\011  from materials entity\\012\\011\\011\\011\\011 where NEW.mate_prop_id = entity.id;\\012\\011\\011\\011\\011if v_type_id != v_type_id_prop then\\012\\011\\011\\011\\011\\011RAISE EXCEPTION 'Insert/Update of property value referencing material (id: %) failed, as referenced material type is different than expected (id %, expected id: %).', \\012\\011\\011\\011\\011\\011\\011\\011 NEW.mate_prop_id, v_type_id, v_type_id_prop;\\012\\011\\011\\011\\011end if;\\012\\011\\011\\011end if;\\012   end if;\\012   RETURN NEW;\\012END;\\012$$ LANGUAGE 'plpgsql';\\012\\012CREATE TRIGGER MATERIAL_PROPERTY_WITH_MATERIAL_DATA_TYPE_CHECK BEFORE INSERT OR UPDATE ON material_properties\\012    FOR EACH ROW EXECUTE PROCEDURE MATERIAL_PROPERTY_WITH_MATERIAL_DATA_TYPE_CHECK();\\012    \\012CREATE OR REPLACE FUNCTION SAMPLE_PROPERTY_WITH_MATERIAL_DATA_TYPE_CHECK() RETURNS trigger AS $$\\012DECLARE\\012   v_type_id  CODE;\\012   v_type_id_prop  CODE;\\012BEGIN\\012   if NEW.mate_prop_id IS NOT NULL then\\012\\011\\011\\011-- find material type id of the property type \\012\\011\\011\\011select pt.maty_prop_id into v_type_id_prop \\012\\011\\011\\011  from sample_type_property_types etpt, property_types pt \\012\\011\\011\\011 where NEW.stpt_id = etpt.id AND etpt.prty_id = pt.id;\\012\\011\\011\\012\\011\\011\\011if v_type_id_prop IS NOT NULL then\\012\\011\\011\\011\\011-- find material type id of the material which consists the entity's property value\\012\\011\\011\\011\\011select entity.maty_id into v_type_id \\012\\011\\011\\011\\011  from materials entity\\012\\011\\011\\011\\011 where NEW.mate_prop_id = entity.id;\\012\\011\\011\\011\\011if v_type_id != v_type_id_prop then\\012\\011\\011\\011\\011\\011RAISE EXCEPTION 'Insert/Update of property value referencing material (id: %) failed, as referenced material type is different than expected (id %, expected id: %).', \\012\\011\\011\\011\\011\\011\\011\\011\\011\\011\\011\\011\\011 NEW.mate_prop_id, v_type_id, v_type_id_prop;\\012\\011\\011\\011\\011end if;\\012\\011\\011\\011end if;\\012   end if;\\012   RETURN NEW;\\012END;\\012$$ LANGUAGE 'plpgsql';\\012\\012CREATE TRIGGER SAMPLE_PROPERTY_WITH_MATERIAL_DATA_TYPE_CHECK BEFORE INSERT OR UPDATE ON sample_properties\\012    FOR EACH ROW EXECUTE PROCEDURE SAMPLE_PROPERTY_WITH_MATERIAL_DATA_TYPE_CHECK();\\012    \\012CREATE OR REPLACE FUNCTION EXPERIMENT_PROPERTY_WITH_MATERIAL_DATA_TYPE_CHECK() RETURNS trigger AS $$\\012DECLARE\\012   v_type_id  CODE;\\012   v_type_id_prop  CODE;\\012BEGIN\\012   if NEW.mate_prop_id IS NOT NULL then\\012\\011\\011\\011-- find material type id of the property type \\012\\011\\011\\011select pt.maty_prop_id into v_type_id_prop \\012\\011\\011\\011  from experiment_type_property_types etpt, property_types pt \\012\\011\\011\\011 where NEW.etpt_id = etpt.id AND etpt.prty_id = pt.id;\\012\\011\\011\\012\\011\\011\\011if v_type_id_prop IS NOT NULL then\\012\\011\\011\\011\\011-- find material type id of the material which consists the entity's property value\\012\\011\\011\\011\\011select entity.maty_id into v_type_id \\012\\011\\011\\011\\011  from materials entity\\012\\011\\011\\011\\011 where NEW.mate_prop_id = entity.id;\\012\\011\\011\\011\\011if v_type_id != v_type_id_prop then\\012\\011\\011\\011\\011\\011RAISE EXCEPTION 'Insert/Update of property value referencing material (id: %) failed, as referenced material type is different than expected (id %, expected id: %).', \\012\\011\\011\\011\\011\\011\\011\\011\\011\\011\\011\\011\\011 NEW.mate_prop_id, v_type_id, v_type_id_prop;\\012\\011\\011\\011\\011end if;\\012\\011\\011\\011end if;\\012   end if;\\012   RETURN NEW;\\012END;\\012$$ LANGUAGE 'plpgsql';\\012\\012CREATE TRIGGER EXPERIMENT_PROPERTY_WITH_MATERIAL_DATA_TYPE_CHECK BEFORE INSERT OR UPDATE ON experiment_properties\\012    FOR EACH ROW EXECUTE PROCEDURE EXPERIMENT_PROPERTY_WITH_MATERIAL_DATA_TYPE_CHECK();\\012       \\012-- -------\\012-- remove the reminescents of the OBSERVABLE_TYPE\\012-- -------\\012\\012ALTER TABLE data\\012\\011DROP CONSTRAINT data_obty_fk;\\012\\012ALTER TABLE data_set_types\\012\\011DROP CONSTRAINT obty_pk;\\012\\012ALTER TABLE data_set_types\\012\\011ADD CONSTRAINT dsty_pk PRIMARY KEY (id);\\012\\012ALTER TABLE data\\012\\011ADD CONSTRAINT data_dsty_fk FOREIGN KEY (dsty_id) REFERENCES data_set_types(id);\\012\\012ALTER TABLE data_set_types\\012\\011DROP CONSTRAINT obty_bk_uk;\\012\\012ALTER TABLE data_set_types\\012\\011DROP CONSTRAINT obty_dbin_fk;\\012\\012ALTER TABLE data_set_types\\012\\011ADD CONSTRAINT dsty_bk_uk UNIQUE (code, dbin_id);\\012\\012ALTER TABLE data_set_types\\012\\011ADD CONSTRAINT dsty_dbin_fk FOREIGN KEY (dbin_id) REFERENCES database_instances(id);\\012\\012DROP INDEX data_obty_fk_i;\\012\\012CREATE INDEX data_dsty_fk_i ON data(dsty_id);\\012	\N
+./sourceTest/sql/postgresql/041/017=database_version_logs.tsv:030	source/sql/postgresql/migration/migration-029-030.sql	SUCCESS	2009-03-23 15:34:44.72	-- -------\\012-- add modification_timestamp field to allow edition with Hibernate\\012-- -------\\012ALTER TABLE data\\012\\011ADD COLUMN modification_timestamp TIME_STAMP DEFAULT CURRENT_TIMESTAMP;\\012ALTER TABLE experiment_types\\012\\011ADD COLUMN modification_timestamp TIME_STAMP DEFAULT CURRENT_TIMESTAMP;\\012ALTER TABLE sample_types\\012\\011ADD COLUMN modification_timestamp TIME_STAMP DEFAULT CURRENT_TIMESTAMP;\\012ALTER TABLE material_types\\012\\011ADD COLUMN modification_timestamp TIME_STAMP DEFAULT CURRENT_TIMESTAMP;\\012ALTER TABLE data_set_types\\012\\011ADD COLUMN modification_timestamp TIME_STAMP DEFAULT CURRENT_TIMESTAMP;\\012ALTER TABLE controlled_vocabularies\\012\\011ADD COLUMN modification_timestamp TIME_STAMP DEFAULT CURRENT_TIMESTAMP;\\012-- -------\\012-- add properties to data sets\\012-- -------\\012CREATE TABLE DATA_SET_PROPERTIES (ID TECH_ID NOT NULL,DS_ID TECH_ID NOT NULL,DSTPT_ID TECH_ID NOT NULL,VALUE GENERIC_VALUE,CVTE_ID TECH_ID, MATE_PROP_ID TECH_ID, PERS_ID_REGISTERER TECH_ID NOT NULL,REGISTRATION_TIMESTAMP TIME_STAMP_DFL NOT NULL DEFAULT CURRENT_TIMESTAMP, MODIFICATION_TIMESTAMP TIME_STAMP DEFAULT CURRENT_TIMESTAMP);\\012CREATE TABLE DATA_SET_TYPE_PROPERTY_TYPES (ID TECH_ID NOT NULL,DSTY_ID TECH_ID NOT NULL,PRTY_ID TECH_ID NOT NULL,IS_MANDATORY BOOLEAN_CHAR NOT NULL DEFAULT 'F',IS_MANAGED_INTERNALLY BOOLEAN_CHAR NOT NULL DEFAULT 'F',PERS_ID_REGISTERER TECH_ID NOT NULL,REGISTRATION_TIMESTAMP TIME_STAMP_DFL NOT NULL DEFAULT CURRENT_TIMESTAMP);\\012\\012CREATE SEQUENCE DATA_SET_PROPERTY_ID_SEQ;\\012CREATE SEQUENCE DSTPT_ID_SEQ;\\012\\012ALTER TABLE DATA_SET_TYPE_PROPERTY_TYPES ADD CONSTRAINT DSTPT_PK PRIMARY KEY(ID);\\012ALTER TABLE DATA_SET_PROPERTIES ADD CONSTRAINT DSPR_PK PRIMARY KEY(ID);\\012\\012ALTER TABLE DATA_SET_TYPE_PROPERTY_TYPES ADD CONSTRAINT DSTPT_BK_UK UNIQUE(DSTY_ID,PRTY_ID);\\012ALTER TABLE DATA_SET_PROPERTIES ADD CONSTRAINT DSPR_BK_UK UNIQUE(DS_ID,DSTPT_ID);\\012\\012\\012ALTER TABLE DATA_SET_TYPE_PROPERTY_TYPES ADD CONSTRAINT DSTPT_DSTY_FK FOREIGN KEY (DSTY_ID) REFERENCES DATA_SET_TYPES(ID);\\012ALTER TABLE DATA_SET_TYPE_PROPERTY_TYPES ADD CONSTRAINT DSTPT_PERS_FK FOREIGN KEY (PERS_ID_REGISTERER) REFERENCES PERSONS(ID);\\012ALTER TABLE DATA_SET_TYPE_PROPERTY_TYPES ADD CONSTRAINT DSTPT_PRTY_FK FOREIGN KEY (PRTY_ID) REFERENCES PROPERTY_TYPES(ID);\\012ALTER TABLE DATA_SET_PROPERTIES ADD CONSTRAINT DSPR_CVTE_FK FOREIGN KEY (CVTE_ID) REFERENCES CONTROLLED_VOCABULARY_TERMS(ID);\\012ALTER TABLE DATA_SET_PROPERTIES ADD CONSTRAINT DSPR_DSTPT_FK FOREIGN KEY (DSTPT_ID) REFERENCES DATA_SET_TYPE_PROPERTY_TYPES(ID) ON DELETE CASCADE;\\012ALTER TABLE DATA_SET_PROPERTIES ADD CONSTRAINT DSPR_DS_FK FOREIGN KEY (DS_ID) REFERENCES DATA(ID);\\012ALTER TABLE DATA_SET_PROPERTIES ADD CONSTRAINT DSPR_PERS_FK FOREIGN KEY (PERS_ID_REGISTERER) REFERENCES PERSONS(ID);\\012ALTER TABLE DATA_SET_PROPERTIES ADD CONSTRAINT DSPR_MAPR_FK FOREIGN KEY (MATE_PROP_ID) REFERENCES MATERIALS(ID);\\012\\012ALTER TABLE DATA_SET_PROPERTIES ADD CONSTRAINT DSPR_CK CHECK \\012\\011((VALUE IS NOT NULL AND CVTE_ID IS NULL AND MATE_PROP_ID IS NULL) OR \\012\\011 (VALUE IS NULL AND CVTE_ID IS NOT NULL AND MATE_PROP_ID IS NULL) OR\\012\\011 (VALUE IS NULL AND CVTE_ID IS NULL AND MATE_PROP_ID IS NOT NULL)\\012\\011);\\012\\012CREATE INDEX DSPR_CVTE_FK_I ON DATA_SET_PROPERTIES (CVTE_ID);\\012CREATE INDEX DSPR_DSTPT_FK_I ON DATA_SET_PROPERTIES (DSTPT_ID);\\012CREATE INDEX DSPR_DS_FK_I ON DATA_SET_PROPERTIES (DS_ID);\\012CREATE INDEX DSPR_PERS_FK_I ON DATA_SET_PROPERTIES (PERS_ID_REGISTERER);\\012CREATE INDEX DSTPT_DSTY_FK_I ON DATA_SET_TYPE_PROPERTY_TYPES (DSTY_ID);\\012CREATE INDEX DSTPT_PERS_FK_I ON DATA_SET_TYPE_PROPERTY_TYPES (PERS_ID_REGISTERER);\\012CREATE INDEX DSTPT_PRTY_FK_I ON DATA_SET_TYPE_PROPERTY_TYPES (PRTY_ID);\\012\\012CREATE OR REPLACE FUNCTION DATA_SET_PROPERTY_WITH_MATERIAL_DATA_TYPE_CHECK() RETURNS trigger AS $$\\012DECLARE\\012   v_type_id  CODE;\\012   v_type_id_prop  CODE;\\012BEGIN\\012   if NEW.mate_prop_id IS NOT NULL then\\012\\011\\011\\011-- find material type id of the property type \\012\\011\\011\\011select pt.maty_prop_id into v_type_id_prop \\012\\011\\011\\011  from data_set_type_property_types dstpt, property_types pt \\012\\011\\011\\011 where NEW.dstpt_id = dstpt.id AND dstpt.prty_id = pt.id;\\012\\011\\011\\012\\011\\011\\011if v_type_id_prop IS NOT NULL then\\012\\011\\011\\011\\011-- find material type id of the material which consists the entity's property value\\012\\011\\011\\011\\011select entity.maty_id into v_type_id \\012\\011\\011\\011\\011  from materials entity\\012\\011\\011\\011\\011 where NEW.mate_prop_id = entity.id;\\012\\011\\011\\011\\011if v_type_id != v_type_id_prop then\\012\\011\\011\\011\\011\\011RAISE EXCEPTION 'Insert/Update of property value referencing material (id: %) failed, as referenced material type is different than expected (id %, expected id: %).', \\012\\011\\011\\011\\011\\011\\011\\011\\011\\011\\011\\011\\011 NEW.mate_prop_id, v_type_id, v_type_id_prop;\\012\\011\\011\\011\\011end if;\\012\\011\\011\\011end if;\\012   end if;\\012   RETURN NEW;\\012END;\\012$$ LANGUAGE 'plpgsql';\\012\\012CREATE TRIGGER DATA_SET_PROPERTY_WITH_MATERIAL_DATA_TYPE_CHECK BEFORE INSERT OR UPDATE ON data_set_properties\\012    FOR EACH ROW EXECUTE PROCEDURE DATA_SET_PROPERTY_WITH_MATERIAL_DATA_TYPE_CHECK();   \\012	\N
+./sourceTest/sql/postgresql/041/017=database_version_logs.tsv:032	source/sql/postgresql/migration/migration-031-032.sql	SUCCESS	2009-04-09 09:36:36.20	-- -------\\012-- Modify MATERIAL_BATCHES\\012-- -------\\012\\012ALTER TABLE material_batches\\012    DROP COLUMN proc_id;\\012\\012-- -------\\012-- Modify SAMPLES\\012-- -------\\012\\012ALTER TABLE samples\\012    ADD COLUMN expe_id tech_id;\\012\\012ALTER TABLE samples\\012    ADD CONSTRAINT samp_expe_fk FOREIGN KEY (expe_id) REFERENCES experiments(id);\\012\\012CREATE INDEX samp_expe_fk_i ON samples USING btree (expe_id);\\012\\012-- relink samples directly to experiments\\012\\012UPDATE samples\\012SET expe_id = (SELECT e.id FROM experiments e, procedures p, sample_inputs si \\012               WHERE si.samp_id = samples.id AND si.proc_id = p.id AND p.expe_id = e.id AND e.inva_id IS NULL);\\012\\012\\012-- -------\\012-- Modify DATA\\012-- -------\\012\\012ALTER TABLE data\\012    ADD COLUMN expe_id tech_id;\\012\\012ALTER TABLE data\\012    ADD CONSTRAINT data_expe_fk FOREIGN KEY (expe_id) REFERENCES experiments(id);\\012\\012CREATE INDEX data_expe_fk_i ON data USING btree (expe_id);\\012\\012UPDATE data\\012SET expe_id = (SELECT e.id FROM experiments e, procedures p \\012               WHERE data.proc_id_produced_by = p.id AND p.expe_id = e.id);\\012\\012ALTER TABLE data\\012    ALTER COLUMN expe_id SET NOT NULL;\\012\\012ALTER TABLE data\\012    DROP COLUMN proc_id_produced_by;\\012\\012-- -------\\012-- Drop PROCEDURES, PROCEDURE_TYPES, and SAMPLE_INPUTS\\012-- -------\\012\\012DROP TABLE sample_inputs;\\012DROP TABLE procedures;\\012DROP TABLE procedure_types;\\012\\012DROP SEQUENCE procedure_id_seq;\\012DROP SEQUENCE procedure_type_id_seq;\\012\\012-- -------\\012-- Add CODE_SEQ\\012-- -------\\012\\012CREATE SEQUENCE CODE_SEQ;\\012\\012-- -------\\012-- Add new columns to DATA_STORES\\012-- -------\\012\\012ALTER TABLE data_stores\\012    ADD COLUMN remote_url character varying(250),\\012    ADD COLUMN session_token character varying(50),\\012    ADD COLUMN modification_timestamp time_stamp DEFAULT now();\\012\\012UPDATE data_stores\\012SET remote_url = '', session_token='';\\012\\012ALTER TABLE data_stores\\012    ALTER COLUMN remote_url SET NOT NULL,\\012    ALTER COLUMN session_token SET NOT NULL;\\012\\012-- -------\\012-- Drop foreign keys onto DATA_STORES\\012-- -------\\012\\012ALTER TABLE database_instances\\012    DROP COLUMN dast_id;\\012\\012ALTER TABLE groups\\012    DROP COLUMN dast_id;\\012\\012ALTER TABLE projects\\012    DROP COLUMN dast_id;\\012\\012ALTER TABLE experiments\\012    DROP COLUMN dast_id;\\012\\012-- -------\\012-- Add foreign key from DATA onto DATA_STORES\\012-- -------\\012\\012ALTER TABLE data\\012    ADD COLUMN dast_id tech_id;\\012\\012ALTER TABLE data\\012    ADD CONSTRAINT data_dast_fk FOREIGN KEY (dast_id) REFERENCES data_stores(id);\\012\\012UPDATE data\\012SET dast_id = (select id from data_stores where code = 'STANDARD');\\012\\012ALTER TABLE data\\012    ALTER COLUMN dast_id SET NOT NULL;\\012\\012\\012------------------------------------------------------------------------------------\\012--  Purpose:  Replace trigger SAMPLE_CODE_UNIQUENESS_CHECK \\012------------------------------------------------------------------------------------\\012\\012CREATE OR REPLACE FUNCTION SAMPLE_CODE_UNIQUENESS_CHECK() RETURNS trigger AS $$\\012DECLARE\\012   counter  INTEGER;\\012BEGIN\\012    LOCK TABLE samples IN EXCLUSIVE MODE;\\012    IF (NEW.samp_id_part_of is NULL) THEN\\012        IF (NEW.dbin_id is not NULL) THEN\\012            SELECT count(*) into counter FROM samples \\012                where id != NEW.id and code = NEW.code and samp_id_part_of is NULL and dbin_id = NEW.dbin_id;\\012            IF (counter > 0) THEN\\012                RAISE EXCEPTION 'Insert/Update of Sample (Code: %) failed because database instance sample with the same code already exists.', NEW.code;\\012            END IF;\\012        ELSIF (NEW.grou_id is not NULL) THEN\\012            SELECT count(*) into counter FROM samples \\012                where id != NEW.id and code = NEW.code and samp_id_part_of is NULL and grou_id = NEW.grou_id;\\012            IF (counter > 0) THEN\\012                RAISE EXCEPTION 'Insert/Update of Sample (Code: %) failed because group sample with the same code already exists.', NEW.code;\\012            END IF;\\012        END IF;\\012        ELSE\\012        IF (NEW.dbin_id is not NULL) THEN\\012            SELECT count(*) into counter FROM samples \\012                where id != NEW.id and code = NEW.code and samp_id_part_of = NEW.samp_id_part_of and dbin_id = NEW.dbin_id;\\012            IF (counter > 0) THEN\\012                RAISE EXCEPTION 'Insert/Update of Sample (Code: %) failed because database instance sample with the same code and being the part of the same parent already exists.', NEW.code;\\012            END IF;\\012        ELSIF (NEW.grou_id is not NULL) THEN\\012            SELECT count(*) into counter FROM samples \\012                where id != NEW.id and code = NEW.code and samp_id_part_of = NEW.samp_id_part_of and grou_id = NEW.grou_id;\\012            IF (counter > 0) THEN\\012                RAISE EXCEPTION 'Insert/Update of Sample (Code: %) failed because group sample with the same code and being the part of the same parent already exists.', NEW.code;\\012            END IF;\\012        END IF;\\012        END IF;   \\012   RETURN NEW;\\012END;\\012$$ LANGUAGE 'plpgsql';\\012\\012\\012\\012	\N
+./sourceTest/sql/postgresql/041/017=database_version_logs.tsv:034	source/sql/postgresql/migration/migration-033-034.sql	SUCCESS	2009-05-26 08:32:49.935	------------------------------------------------------------------------------------\\012-- Create sequence for generating permanent identifiers starting with nextval of existing dataset sequence.\\012------------------------------------------------------------------------------------\\012CREATE FUNCTION CREATE_SEQUENCE(EXISTING_SEQUENCE VARCHAR, NEW_SEQUENCE VARCHAR) RETURNS VOID AS $$\\012DECLARE\\012  CURR_SEQ_VAL   INTEGER;\\012BEGIN\\012  SELECT INTO CURR_SEQ_VAL NEXTVAL(EXISTING_SEQUENCE);\\012  EXECUTE 'CREATE SEQUENCE ' || NEW_SEQUENCE || ' START WITH ' || CURR_SEQ_VAL;\\012  RETURN;\\012END;\\012$$ LANGUAGE 'plpgsql';\\012\\012SELECT CREATE_SEQUENCE('DATA_ID_SEQ', 'PERM_ID_SEQ');\\012DROP FUNCTION CREATE_SEQUENCE(VARCHAR, VARCHAR);\\012\\012------------------------------------------------------------------------------------\\012-- Add perm_id columns to samples and experiments.\\012------------------------------------------------------------------------------------\\012ALTER TABLE SAMPLES ADD COLUMN PERM_ID CODE;\\012ALTER TABLE EXPERIMENTS ADD COLUMN PERM_ID CODE;\\012\\012UPDATE SAMPLES SET PERM_ID = to_char(registration_timestamp,'YYYYMMDDHHSSMS') || '-' || NEXTVAL('PERM_ID_SEQ');\\012UPDATE EXPERIMENTS SET PERM_ID = to_char(registration_timestamp,'YYYYMMDDHHSSMS') || '-' || NEXTVAL('PERM_ID_SEQ');\\012ALTER TABLE SAMPLES ALTER COLUMN PERM_ID SET NOT NULL;\\012ALTER TABLE EXPERIMENTS ALTER COLUMN PERM_ID SET NOT NULL;\\012ALTER TABLE SAMPLES ADD CONSTRAINT SAMP_PI_UK UNIQUE(PERM_ID);\\012ALTER TABLE EXPERIMENTS ADD CONSTRAINT EXPE_PI_UK UNIQUE(PERM_ID);\\012\\012\\012------------------------------------------------------------------------------------\\012-- Add column is_chosen_from_list to controlled_vocabularies.\\012------------------------------------------------------------------------------------\\012ALTER TABLE controlled_vocabularies ADD COLUMN is_chosen_from_list BOOLEAN_CHAR NOT NULL DEFAULT TRUE;\\012ALTER TABLE controlled_vocabularies ADD COLUMN source_uri CHARACTER VARYING(250);\\012------------------------------------------------------------------------------------\\012-- Modify Data table - remove arc connection between Sample and Data table, use a flag instead\\012------------------------------------------------------------------------------------\\012\\012-- add new columns\\012\\012ALTER TABLE data\\012    ADD COLUMN is_derived boolean_char;\\012ALTER TABLE data\\012    ADD COLUMN samp_id tech_id;\\012\\012-- update values in new columns\\012\\012UPDATE data\\012    SET is_derived = (samp_id_derived_from IS NOT NULL); \\012UPDATE data\\012    SET samp_id = samp_id_derived_from \\012    WHERE is_derived = 'TRUE';\\012UPDATE data\\012    SET samp_id = samp_id_acquired_from \\012    WHERE is_derived = 'FALSE';\\012\\012-- add constraints and indexes to new columns\\012\\012ALTER TABLE data\\012    ALTER COLUMN is_derived SET NOT NULL;\\012ALTER TABLE data\\012    ALTER COLUMN samp_id SET NOT NULL;   \\012ALTER TABLE data\\012    ADD CONSTRAINT data_samp_fk FOREIGN KEY (samp_id) REFERENCES samples (id);\\012CREATE INDEX data_samp_fk_i ON data USING btree (samp_id);\\012\\012-- remove old columns\\012\\012ALTER TABLE data\\012    DROP COLUMN samp_id_acquired_from;\\012ALTER TABLE data\\012    DROP COLUMN samp_id_derived_from;\\012    \\012------------------------------------------------------------------------------------\\012-- Granting SELECT privilege to group openbis_readonly\\012------------------------------------------------------------------------------------\\012\\012GRANT SELECT ON SEQUENCE attachment_content_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE attachment_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE code_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE controlled_vocabulary_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE cvte_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE data_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE data_set_property_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE data_set_relationship_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE data_set_type_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE data_store_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE data_type_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE database_instance_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE dstpt_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE etpt_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE event_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE experiment_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE experiment_property_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE experiment_type_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE file_format_type_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE group_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE invalidation_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE locator_type_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE material_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE material_property_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE material_type_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE mtpt_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE perm_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE person_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE project_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE property_type_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE role_assignment_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE sample_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE sample_property_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE sample_type_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE stpt_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE attachment_contents TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE attachments TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE controlled_vocabularies TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE controlled_vocabulary_terms TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE data TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE data_set_properties TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE data_set_relationships TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE data_set_type_property_types TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE data_set_types TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE data_stores TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE data_types TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE database_instances TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE database_version_logs TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE events TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE experiment_properties TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE experiment_type_property_types TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE experiment_types TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE experiments TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE external_data TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE file_format_types TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE groups TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE invalidations TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE locator_types TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE material_properties TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE material_type_property_types TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE material_types TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE materials TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE persons TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE projects TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE property_types TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE role_assignments TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE sample_properties TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE sample_type_property_types TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE sample_types TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE samples TO GROUP OPENBIS_READONLY;\\012\\012------------------------------------------------------------------------------------\\012-- Delete MATERIAL_BATCHES table\\012------------------------------------------------------------------------------------\\012\\012-- WARNING: Potential data lost!!!\\012-- WARNING: Potential data lost!!!\\012-- WARNING: Potential data lost!!!\\012\\012DROP TABLE SAMPLE_MATERIAL_BATCHES;\\012DROP TABLE MATERIAL_BATCHES;\\012DROP SEQUENCE MATERIAL_BATCH_ID_SEQ;\\012\\012------------------------------------------------------------------------------------\\012-- Delete MATE_ID_INHIBITOR_OF from table MATERIALS\\012------------------------------------------------------------------------------------\\012\\012-- WARNING: Potential data lost!!!\\012-- WARNING: Potential data lost!!!\\012-- WARNING: Potential data lost!!!\\012\\012ALTER TABLE MATERIALS DROP COLUMN MATE_ID_INHIBITOR_OF;\\012	\N
+./sourceTest/sql/postgresql/041/017=database_version_logs.tsv:041	source/sql/postgresql/migration/migration-040-041.sql	SUCCESS	2009-09-14 13:48:57.539	-- Create FILTERS table\\012\\012CREATE TABLE FILTERS (ID TECH_ID NOT NULL, DBIN_ID TECH_ID NOT NULL, NAME VARCHAR(200) NOT NULL, DESCRIPTION DESCRIPTION_1000,REGISTRATION_TIMESTAMP TIME_STAMP_DFL NOT NULL DEFAULT CURRENT_TIMESTAMP, PERS_ID_REGISTERER TECH_ID NOT NULL, MODIFICATION_TIMESTAMP TIME_STAMP DEFAULT CURRENT_TIMESTAMP, EXPRESSION VARCHAR(2000) NOT NULL, IS_PUBLIC BOOLEAN NOT NULL, GRID_ID VARCHAR(200) NOT NULL);\\012CREATE SEQUENCE FILTER_ID_SEQ;\\012ALTER TABLE FILTERS ADD CONSTRAINT FILT_PK PRIMARY KEY(ID);\\012ALTER TABLE FILTERS ADD CONSTRAINT FILT_BK_UK UNIQUE(NAME, DBIN_ID, GRID_ID);\\012ALTER TABLE FILTERS ADD CONSTRAINT FILT_PERS_FK FOREIGN KEY (PERS_ID_REGISTERER) REFERENCES PERSONS(ID);\\012ALTER TABLE FILTERS ADD CONSTRAINT FILT_DBIN_FK FOREIGN KEY (DBIN_ID) REFERENCES DATABASE_INSTANCES(ID);\\012CREATE INDEX FILT_PERS_FK_I ON FILTERS (PERS_ID_REGISTERER);\\012CREATE INDEX FILT_DBIN_FK_I ON FILTERS (DBIN_ID);\\012GRANT SELECT ON SEQUENCE filter_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE filters TO GROUP OPENBIS_READONLY;\\012\\012-- Add missing foreign key to role assignments authorization group\\012ALTER TABLE ROLE_ASSIGNMENTS ADD CONSTRAINT ROAS_AG_FK_GRANTEE FOREIGN KEY (AG_ID_GRANTEE) REFERENCES AUTHORIZATION_GROUPS(ID);\\012\\012--------------------------------------------------------------------------------------------------\\012-- Modify dataset connections:\\012-- 1. connection with sample shouldn't be mandatory any more\\012-- 2. introduce an arc condition that dataset cannot be connected with a sample and a parent dataset at the same time\\012--------------------------------------------------------------------------------------------------\\012\\012-- Weaken data-sample connection constraint - allow dataset to have no connection with sample\\012ALTER TABLE data ALTER COLUMN samp_id DROP NOT NULL;\\012\\012-- Remove data-sample connection for datasets that have a parent\\012\\012UPDATE data \\012   SET samp_id = NULL \\012 WHERE id IN (SELECT DISTINCT data_id_child FROM data_set_relationships);\\012\\012-- With PostgreSQL 8.4 one can check that before migration there were no cycles in dataset relationships:\\012--\\012-- WITH RECURSIVE data_set_parents(id, parent_ids, cycle) AS (\\012--         SELECT  r.data_id_child AS id, \\012--                 ARRAY[CAST (r.data_id_parent AS bigint)] AS parent_ids, \\012--                 false AS cycle \\012--         FROM data_set_relationships r\\012--     UNION ALL\\012--         SELECT  r.data_id_child,\\012--                 CAST (r.data_id_parent AS bigint) || p.parent_ids,\\012--                 r.data_id_child = ANY(p.parent_ids)\\012--         FROM data_set_relationships r, data_set_parents p\\012--         WHERE r.data_id_parent = p.id AND NOT cycle\\012-- )\\012-- SELECT count(*) AS cycles FROM data_set_parents WHERE cycle = true;\\012\\012---------------------------------------------------------------------------------------------------\\012--  Purpose:  Create DEFERRED triggers:\\012--            * check_dataset_relationships_on_data_table_modification,\\012--            * check_dataset_relationships_on_relationships_table_modification.\\012--            They check that after all modifications of database (just before commit) \\012--            if 'data'/'data_set_relationships' tables are among modified tables \\012--            dataset is not connected with a sample and a parent dataset at the same time.\\012--            This connections are held in two different tables so simple immediate trigger \\012--            with arc check cannot be used and we need two deferred triggers.\\012----------------------------------------------------------------------------------------------------\\012\\012-- trigger for 'data' table\\012\\012CREATE OR REPLACE FUNCTION check_dataset_relationships_on_data_table_modification() RETURNS trigger AS $$\\012DECLARE\\012\\011counter\\011INTEGER;\\012BEGIN\\012\\011-- if there is a connection with a Sample there should not be any connection with a parent Data Set\\012\\011IF (NEW.samp_id IS NOT NULL) THEN\\012\\011\\011-- count number of parents\\012\\011\\011SELECT count(*) INTO counter \\012\\011\\011\\011FROM data_set_relationships \\012\\011\\011\\011WHERE data_id_child = OLD.id;\\012\\011\\011IF (counter > 0) THEN\\012\\011\\011\\011RAISE EXCEPTION 'Insert/Update of Data Set (Code: %) failed because it cannot be connected with a Sample and a parent Data Set at the same time.', OLD.code;\\012\\011\\011END IF;\\012\\011END IF;\\012  RETURN NEW;\\012END;\\012$$ LANGUAGE 'plpgsql';\\012\\012CREATE CONSTRAINT TRIGGER check_dataset_relationships_on_data_table_modification \\012  AFTER INSERT OR UPDATE ON data\\012\\011DEFERRABLE INITIALLY DEFERRED\\012\\011FOR EACH ROW \\012\\011EXECUTE PROCEDURE check_dataset_relationships_on_data_table_modification();\\012\\012-- trigger for 'data_set_relationships'\\012\\012CREATE OR REPLACE FUNCTION check_dataset_relationships_on_relationships_table_modification() RETURNS trigger AS $$\\012DECLARE\\012\\011counter\\011INTEGER;\\012\\011sample_id\\011TECH_ID;\\012\\011data_code\\011CODE;\\012BEGIN\\012\\011-- child will have a parent added so it should not be connected with any sample\\012\\011SELECT samp_id, code INTO sample_id, data_code \\012\\011\\011FROM data \\012\\011\\011WHERE id = NEW.data_id_child;\\012\\011IF (sample_id IS NOT NULL) THEN\\012\\011\\011RAISE EXCEPTION 'Insert/Update of Data Set (Code: %) failed because it cannot be connected to a Sample and to a parent Data Set at the same time.', data_code;\\012\\011END IF;\\012\\011RETURN NEW;\\012END;\\012$$ LANGUAGE 'plpgsql';\\012  \\012CREATE CONSTRAINT TRIGGER check_dataset_relationships_on_relationships_table_modification \\012  AFTER INSERT OR UPDATE ON data_set_relationships\\012\\011DEFERRABLE INITIALLY DEFERRED\\012\\011FOR EACH ROW \\012\\011EXECUTE PROCEDURE check_dataset_relationships_on_relationships_table_modification();\\012	\N
+./sourceTest/sql/postgresql/041/schema-041.sql:    LANGUAGE plpgsql;
+./sourceTest/sql/postgresql/041/schema-041.sql:    LANGUAGE plpgsql;
+./sourceTest/sql/postgresql/041/schema-041.sql:    LANGUAGE plpgsql;
+./sourceTest/sql/postgresql/041/schema-041.sql:    LANGUAGE plpgsql;
+./sourceTest/sql/postgresql/041/schema-041.sql:    LANGUAGE plpgsql;
+./sourceTest/sql/postgresql/041/schema-041.sql:    LANGUAGE plpgsql;
+./sourceTest/sql/postgresql/041/schema-041.sql:    LANGUAGE plpgsql;
+./sourceTest/sql/postgresql/041/schema-041.sql:    LANGUAGE plpgsql;
+./sourceTest/sql/postgresql/041/schema-041.sql:    LANGUAGE plpgsql;
+./sourceTest/sql/postgresql/041/schema-041.sql:    LANGUAGE plpgsql;
+./sourceTest/sql/postgresql/042/.svn/text-base/017=database_version_logs.tsv.svn-base:027	D:\\User\\felmer\\dev-workspace\\openbis/source/sql/postgresql/027/function-027.sql	SUCCESS	2008-11-05 09:18:00.403	-- Creating Functions\\012\\012------------------------------------------------------------------------------------\\012--  Purpose:  Create function RENAME_SEQUENCE() that is required for renaming the sequences belonging to tables\\012------------------------------------------------------------------------------------\\012CREATE FUNCTION RENAME_SEQUENCE(OLD_NAME VARCHAR, NEW_NAME VARCHAR) RETURNS INTEGER AS $$\\012DECLARE\\012  CURR_SEQ_VAL   INTEGER;\\012BEGIN\\012  SELECT INTO CURR_SEQ_VAL NEXTVAL(OLD_NAME);\\012  EXECUTE 'CREATE SEQUENCE ' || NEW_NAME || ' START WITH ' || CURR_SEQ_VAL;\\012  EXECUTE 'DROP SEQUENCE ' || OLD_NAME;\\012  RETURN CURR_SEQ_VAL;\\012END;\\012$$ LANGUAGE 'plpgsql';\\012\\012\\012------------------------------------------------------------------------------------\\012--  Purpose:  Create trigger CONTROLLED_VOCABULARY_CHECK \\012------------------------------------------------------------------------------------\\012\\012CREATE OR REPLACE FUNCTION CONTROLLED_VOCABULARY_CHECK() RETURNS trigger AS $$\\012DECLARE\\012   v_code  CODE;\\012BEGIN\\012\\012   select code into v_code from data_types where id = NEW.daty_id;\\012\\012   -- Check if the data is of type "CONTROLLEDVOCABULARY"\\012   if v_code = 'CONTROLLEDVOCABULARY' then\\012      if NEW.covo_id IS NULL then\\012         RAISE EXCEPTION 'Insert/Update of Property Type (Code: %) failed, as its Data Type is CONTROLLEDVOCABULARY, but it is not linked to a Controlled Vocabulary.', NEW.code;\\012      end if;\\012   end if;\\012\\012   RETURN NEW;\\012\\012END;\\012$$ LANGUAGE 'plpgsql';\\012\\012CREATE TRIGGER CONTROLLED_VOCABULARY_CHECK BEFORE INSERT OR UPDATE ON PROPERTY_TYPES\\012    FOR EACH ROW EXECUTE PROCEDURE CONTROLLED_VOCABULARY_CHECK();\\012\\012\\012------------------------------------------------------------------------------------\\012--  Purpose:  Create trigger EXTERNAL_DATA_STORAGE_FORMAT_CHECK \\012------------------------------------------------------------------------------------\\012\\012CREATE OR REPLACE FUNCTION EXTERNAL_DATA_STORAGE_FORMAT_CHECK() RETURNS trigger AS $$\\012DECLARE\\012   v_covo_code  CODE;\\012   data_code CODE;\\012BEGIN\\012\\012   select code into v_covo_code from controlled_vocabularies\\012      where is_internal_namespace = true and \\012         id = (select covo_id from controlled_vocabulary_terms where id = NEW.cvte_id_stor_fmt);\\012   -- Check if the data storage format is a term of the controlled vocabulary "STORAGE_FORMAT"\\012   if v_covo_code != 'STORAGE_FORMAT' then\\012      select code into data_code from data where id = NEW.data_id; \\012      RAISE EXCEPTION 'Insert/Update of Data (Code: %) failed, as its Storage Format is %, but is required to be STORAGE_FORMAT.', data_code, v_covo_code;\\012   end if;\\012\\012   RETURN NEW;\\012\\012END;\\012$$ LANGUAGE 'plpgsql';\\012\\012CREATE TRIGGER EXTERNAL_DATA_STORAGE_FORMAT_CHECK BEFORE INSERT OR UPDATE ON EXTERNAL_DATA\\012    FOR EACH ROW EXECUTE PROCEDURE EXTERNAL_DATA_STORAGE_FORMAT_CHECK();\\012\\012------------------------------------------------------------------------------------\\012--  Purpose:  Create trigger SAMPLE_CODE_UNIQUENESS_CHECK \\012------------------------------------------------------------------------------------\\012\\012CREATE OR REPLACE FUNCTION SAMPLE_CODE_UNIQUENESS_CHECK() RETURNS trigger AS $$\\012DECLARE\\012   counter  INTEGER;\\012BEGIN\\012\\011IF (NEW.samp_id_part_of is NULL) THEN\\012\\011\\011IF (NEW.dbin_id is not NULL) THEN\\012\\011\\011\\011SELECT count(*) into counter FROM samples \\012\\011\\011\\011\\011where id != NEW.id and code = NEW.code and samp_id_part_of is NULL and dbin_id = NEW.dbin_id;\\012\\011\\011\\011IF (counter > 0) THEN\\012\\011\\011\\011\\011RAISE EXCEPTION 'Insert/Update of Sample (Code: %) failed because database instance sample with the same code already exists.', NEW.code;\\012\\011\\011\\011END IF;\\012\\011\\011ELSIF (NEW.grou_id is not NULL) THEN\\012\\011\\011\\011SELECT count(*) into counter FROM samples \\012\\011\\011\\011\\011where id != NEW.id and code = NEW.code and samp_id_part_of is NULL and grou_id = NEW.grou_id;\\012\\011\\011\\011IF (counter > 0) THEN\\012\\011\\011\\011\\011RAISE EXCEPTION 'Insert/Update of Sample (Code: %) failed because group sample with the same code already exists.', NEW.code;\\012\\011\\011\\011END IF;\\012\\011\\011END IF;\\012        ELSE\\012\\011\\011IF (NEW.dbin_id is not NULL) THEN\\012\\011\\011\\011SELECT count(*) into counter FROM samples \\012\\011\\011\\011\\011where id != NEW.id and code = NEW.code and samp_id_part_of = NEW.samp_id_part_of and dbin_id = NEW.dbin_id;\\012\\011\\011\\011IF (counter > 0) THEN\\012\\011\\011\\011\\011RAISE EXCEPTION 'Insert/Update of Sample (Code: %) failed because database instance sample with the same code and being the part of the same parent already exists.', NEW.code;\\012\\011\\011\\011END IF;\\012\\011\\011ELSIF (NEW.grou_id is not NULL) THEN\\012\\011\\011\\011SELECT count(*) into counter FROM samples \\012\\011\\011\\011\\011where id != NEW.id and code = NEW.code and samp_id_part_of = NEW.samp_id_part_of and grou_id = NEW.grou_id;\\012\\011\\011\\011IF (counter > 0) THEN\\012\\011\\011\\011\\011RAISE EXCEPTION 'Insert/Update of Sample (Code: %) failed because group sample with the same code and being the part of the same parent already exists.', NEW.code;\\012\\011\\011\\011END IF;\\012\\011\\011END IF;\\012        END IF;   \\012   RETURN NEW;\\012END;\\012$$ LANGUAGE 'plpgsql';\\012\\012CREATE TRIGGER SAMPLE_CODE_UNIQUENESS_CHECK BEFORE INSERT OR UPDATE ON SAMPLES\\012    FOR EACH ROW EXECUTE PROCEDURE SAMPLE_CODE_UNIQUENESS_CHECK();\\012	\N
+./sourceTest/sql/postgresql/042/.svn/text-base/017=database_version_logs.tsv.svn-base:028	source/sql/postgresql/migration/migration-027-028.sql	SUCCESS	2008-11-18 13:24:17.508	-- Create EXPERIMENT_ATTACHMENT_CONTENTS.\\012CREATE TABLE EXPERIMENT_ATTACHMENT_CONTENTS (ID TECH_ID NOT NULL,VALUE FILE NOT NULL);\\012CREATE SEQUENCE EXPERIMENT_ATTACHMENT_CONTENT_ID_SEQ;\\012ALTER TABLE EXPERIMENT_ATTACHMENT_CONTENTS ADD CONSTRAINT EXAC_PK PRIMARY KEY(ID);\\012\\012-- Alter EXPERIMENT_ATTACHMENTS by adding the new column which has a NULL constraint.\\012-- The NOT NULL constraint is added later on.\\012ALTER TABLE EXPERIMENT_ATTACHMENTS ADD COLUMN EXAC_ID TECH_ID;\\012\\012-- Does the VALUE migration between EXPERIMENT_ATTACHMENTS to EXPERIMENT_ATTACHMENT_CONTENTS.\\012CREATE OR REPLACE FUNCTION move_exp_att_content() RETURNS integer AS $$\\012DECLARE\\012    rec RECORD;\\012    seq BIGINT;\\012BEGIN\\012  FOR rec IN SELECT id, value FROM EXPERIMENT_ATTACHMENTS LOOP\\012  \\011seq := nextval('EXPERIMENT_ATTACHMENT_CONTENT_ID_SEQ');\\012    INSERT INTO EXPERIMENT_ATTACHMENT_CONTENTS (id, value) VALUES (seq, rec.value);\\012    UPDATE EXPERIMENT_ATTACHMENTS SET exac_id = seq WHERE id = rec.id;\\012  END LOOP;\\012  RETURN 1;\\012END;\\012$$ LANGUAGE 'plpgsql';\\012\\012-- Call the function.\\012SELECT move_exp_att_content();\\012DROP FUNCTION move_exp_att_content();\\012\\012\\012-- Finish EXPERIMENT_ATTACHMENTS changes.\\012ALTER TABLE EXPERIMENT_ATTACHMENTS ADD CONSTRAINT EXAT_CONT_FK FOREIGN KEY (EXAC_ID) REFERENCES EXPERIMENT_ATTACHMENT_CONTENTS(ID);\\012ALTER TABLE EXPERIMENT_ATTACHMENTS DROP COLUMN VALUE;\\012ALTER TABLE EXPERIMENT_ATTACHMENTS ALTER COLUMN EXAC_ID SET NOT NULL;\\012	\N
+./sourceTest/sql/postgresql/042/.svn/text-base/017=database_version_logs.tsv.svn-base:029	source/sql/postgresql/migration/migration-028-029.sql	SUCCESS	2009-03-18 10:50:20.105	-- -------\\012-- add modification_timestamp field to allow edition with Hibernate\\012-- -------\\012\\012ALTER TABLE samples\\012\\011ADD COLUMN modification_timestamp TIME_STAMP DEFAULT CURRENT_TIMESTAMP;\\012\\012ALTER TABLE experiments\\012\\011ADD COLUMN modification_timestamp TIME_STAMP DEFAULT CURRENT_TIMESTAMP;\\012\\012ALTER TABLE materials\\012\\011ADD COLUMN modification_timestamp TIME_STAMP DEFAULT CURRENT_TIMESTAMP;\\012\\012ALTER TABLE experiment_properties\\012\\011ADD COLUMN modification_timestamp TIME_STAMP DEFAULT CURRENT_TIMESTAMP;\\012\\012ALTER TABLE material_properties\\012\\011ADD COLUMN modification_timestamp TIME_STAMP DEFAULT CURRENT_TIMESTAMP;\\012\\012ALTER TABLE sample_properties\\012\\011ADD COLUMN modification_timestamp TIME_STAMP DEFAULT CURRENT_TIMESTAMP;\\012\\012-- -------\\012-- add property data type which references materials\\012-- -------\\012\\012ALTER TABLE property_types\\012\\011ADD COLUMN maty_prop_id tech_id;\\012\\012ALTER TABLE property_types\\012\\011ADD CONSTRAINT prty_maty_fk FOREIGN KEY (maty_prop_id) REFERENCES material_types(id);\\012\\012ALTER TABLE experiment_properties\\012\\011ADD COLUMN mate_prop_id tech_id;\\012\\012ALTER TABLE material_properties\\012\\011ADD COLUMN mate_prop_id tech_id;\\012\\012ALTER TABLE sample_properties\\012\\011ADD COLUMN mate_prop_id tech_id;\\012\\012ALTER TABLE experiment_properties\\012\\011ADD CONSTRAINT expr_mapr_fk FOREIGN KEY (mate_prop_id) REFERENCES materials(id);\\012\\012ALTER TABLE material_properties\\012\\011ADD CONSTRAINT mapr_mapr_fk FOREIGN KEY (mate_prop_id) REFERENCES materials(id);\\012\\012ALTER TABLE sample_properties\\012\\011ADD CONSTRAINT sapr_mapr_fk FOREIGN KEY (mate_prop_id) REFERENCES materials(id);\\012\\012insert into data_types\\012(id\\012 ,code\\012 ,description)\\012 values \\012 (nextval('DATA_TYPE_ID_SEQ')\\012 ,'MATERIAL'\\012 ,'Reference to a material'\\012);\\012\\012ALTER TABLE MATERIAL_PROPERTIES DROP CONSTRAINT MAPR_CK;\\012ALTER TABLE MATERIAL_PROPERTIES ADD CONSTRAINT MAPR_CK CHECK \\012\\011((VALUE IS NOT NULL AND CVTE_ID IS NULL AND MATE_PROP_ID IS NULL) OR \\012\\011 (VALUE IS NULL AND CVTE_ID IS NOT NULL AND MATE_PROP_ID IS NULL) OR\\012\\011 (VALUE IS NULL AND CVTE_ID IS NULL AND MATE_PROP_ID IS NOT NULL)\\012\\011);\\012\\012ALTER TABLE EXPERIMENT_PROPERTIES DROP CONSTRAINT EXPR_CK;\\012ALTER TABLE EXPERIMENT_PROPERTIES ADD CONSTRAINT EXPR_CK CHECK \\012\\011((VALUE IS NOT NULL AND CVTE_ID IS NULL AND MATE_PROP_ID IS NULL) OR \\012\\011 (VALUE IS NULL AND CVTE_ID IS NOT NULL AND MATE_PROP_ID IS NULL) OR\\012\\011 (VALUE IS NULL AND CVTE_ID IS NULL AND MATE_PROP_ID IS NOT NULL)\\012\\011);\\012\\012ALTER TABLE SAMPLE_PROPERTIES DROP CONSTRAINT SAPR_CK;\\012ALTER TABLE SAMPLE_PROPERTIES ADD CONSTRAINT SAPR_CK CHECK \\012\\011((VALUE IS NOT NULL AND CVTE_ID IS NULL AND MATE_PROP_ID IS NULL) OR \\012\\011 (VALUE IS NULL AND CVTE_ID IS NOT NULL AND MATE_PROP_ID IS NULL) OR\\012\\011 (VALUE IS NULL AND CVTE_ID IS NULL AND MATE_PROP_ID IS NOT NULL)\\012\\011);\\012\\012------------------------------------------------------------------------------------\\012--  Purpose:  Create trigger MATERIAL/SAMPLE/EXPERIMENT _PROPERTY_WITH_MATERIAL_DATA_TYPE_CHECK\\012--            It checks that if material property value is assigned to the entity,\\012--\\011\\011\\011\\011\\011\\011then the material type is equal to the one described by property type.\\012------------------------------------------------------------------------------------\\012\\012CREATE OR REPLACE FUNCTION MATERIAL_PROPERTY_WITH_MATERIAL_DATA_TYPE_CHECK() RETURNS trigger AS $$\\012DECLARE\\012   v_type_id  CODE;\\012   v_type_id_prop  CODE;\\012BEGIN\\012   if NEW.mate_prop_id IS NOT NULL then\\012\\011\\011\\011-- find material type id of the property type \\012\\011\\011\\011select pt.maty_prop_id into v_type_id_prop \\012\\011\\011\\011  from material_type_property_types etpt, property_types pt \\012\\011\\011\\011 where NEW.mtpt_id = etpt.id AND etpt.prty_id = pt.id;\\012\\011\\011\\012\\011\\011\\011if v_type_id_prop IS NOT NULL then\\012\\011\\011\\011\\011-- find material type id of the material which consists the entity's property value\\012\\011\\011\\011\\011select entity.maty_id into v_type_id \\012\\011\\011\\011\\011  from materials entity\\012\\011\\011\\011\\011 where NEW.mate_prop_id = entity.id;\\012\\011\\011\\011\\011if v_type_id != v_type_id_prop then\\012\\011\\011\\011\\011\\011RAISE EXCEPTION 'Insert/Update of property value referencing material (id: %) failed, as referenced material type is different than expected (id %, expected id: %).', \\012\\011\\011\\011\\011\\011\\011\\011 NEW.mate_prop_id, v_type_id, v_type_id_prop;\\012\\011\\011\\011\\011end if;\\012\\011\\011\\011end if;\\012   end if;\\012   RETURN NEW;\\012END;\\012$$ LANGUAGE 'plpgsql';\\012\\012CREATE TRIGGER MATERIAL_PROPERTY_WITH_MATERIAL_DATA_TYPE_CHECK BEFORE INSERT OR UPDATE ON material_properties\\012    FOR EACH ROW EXECUTE PROCEDURE MATERIAL_PROPERTY_WITH_MATERIAL_DATA_TYPE_CHECK();\\012    \\012CREATE OR REPLACE FUNCTION SAMPLE_PROPERTY_WITH_MATERIAL_DATA_TYPE_CHECK() RETURNS trigger AS $$\\012DECLARE\\012   v_type_id  CODE;\\012   v_type_id_prop  CODE;\\012BEGIN\\012   if NEW.mate_prop_id IS NOT NULL then\\012\\011\\011\\011-- find material type id of the property type \\012\\011\\011\\011select pt.maty_prop_id into v_type_id_prop \\012\\011\\011\\011  from sample_type_property_types etpt, property_types pt \\012\\011\\011\\011 where NEW.stpt_id = etpt.id AND etpt.prty_id = pt.id;\\012\\011\\011\\012\\011\\011\\011if v_type_id_prop IS NOT NULL then\\012\\011\\011\\011\\011-- find material type id of the material which consists the entity's property value\\012\\011\\011\\011\\011select entity.maty_id into v_type_id \\012\\011\\011\\011\\011  from materials entity\\012\\011\\011\\011\\011 where NEW.mate_prop_id = entity.id;\\012\\011\\011\\011\\011if v_type_id != v_type_id_prop then\\012\\011\\011\\011\\011\\011RAISE EXCEPTION 'Insert/Update of property value referencing material (id: %) failed, as referenced material type is different than expected (id %, expected id: %).', \\012\\011\\011\\011\\011\\011\\011\\011\\011\\011\\011\\011\\011 NEW.mate_prop_id, v_type_id, v_type_id_prop;\\012\\011\\011\\011\\011end if;\\012\\011\\011\\011end if;\\012   end if;\\012   RETURN NEW;\\012END;\\012$$ LANGUAGE 'plpgsql';\\012\\012CREATE TRIGGER SAMPLE_PROPERTY_WITH_MATERIAL_DATA_TYPE_CHECK BEFORE INSERT OR UPDATE ON sample_properties\\012    FOR EACH ROW EXECUTE PROCEDURE SAMPLE_PROPERTY_WITH_MATERIAL_DATA_TYPE_CHECK();\\012    \\012CREATE OR REPLACE FUNCTION EXPERIMENT_PROPERTY_WITH_MATERIAL_DATA_TYPE_CHECK() RETURNS trigger AS $$\\012DECLARE\\012   v_type_id  CODE;\\012   v_type_id_prop  CODE;\\012BEGIN\\012   if NEW.mate_prop_id IS NOT NULL then\\012\\011\\011\\011-- find material type id of the property type \\012\\011\\011\\011select pt.maty_prop_id into v_type_id_prop \\012\\011\\011\\011  from experiment_type_property_types etpt, property_types pt \\012\\011\\011\\011 where NEW.etpt_id = etpt.id AND etpt.prty_id = pt.id;\\012\\011\\011\\012\\011\\011\\011if v_type_id_prop IS NOT NULL then\\012\\011\\011\\011\\011-- find material type id of the material which consists the entity's property value\\012\\011\\011\\011\\011select entity.maty_id into v_type_id \\012\\011\\011\\011\\011  from materials entity\\012\\011\\011\\011\\011 where NEW.mate_prop_id = entity.id;\\012\\011\\011\\011\\011if v_type_id != v_type_id_prop then\\012\\011\\011\\011\\011\\011RAISE EXCEPTION 'Insert/Update of property value referencing material (id: %) failed, as referenced material type is different than expected (id %, expected id: %).', \\012\\011\\011\\011\\011\\011\\011\\011\\011\\011\\011\\011\\011 NEW.mate_prop_id, v_type_id, v_type_id_prop;\\012\\011\\011\\011\\011end if;\\012\\011\\011\\011end if;\\012   end if;\\012   RETURN NEW;\\012END;\\012$$ LANGUAGE 'plpgsql';\\012\\012CREATE TRIGGER EXPERIMENT_PROPERTY_WITH_MATERIAL_DATA_TYPE_CHECK BEFORE INSERT OR UPDATE ON experiment_properties\\012    FOR EACH ROW EXECUTE PROCEDURE EXPERIMENT_PROPERTY_WITH_MATERIAL_DATA_TYPE_CHECK();\\012       \\012-- -------\\012-- remove the reminescents of the OBSERVABLE_TYPE\\012-- -------\\012\\012ALTER TABLE data\\012\\011DROP CONSTRAINT data_obty_fk;\\012\\012ALTER TABLE data_set_types\\012\\011DROP CONSTRAINT obty_pk;\\012\\012ALTER TABLE data_set_types\\012\\011ADD CONSTRAINT dsty_pk PRIMARY KEY (id);\\012\\012ALTER TABLE data\\012\\011ADD CONSTRAINT data_dsty_fk FOREIGN KEY (dsty_id) REFERENCES data_set_types(id);\\012\\012ALTER TABLE data_set_types\\012\\011DROP CONSTRAINT obty_bk_uk;\\012\\012ALTER TABLE data_set_types\\012\\011DROP CONSTRAINT obty_dbin_fk;\\012\\012ALTER TABLE data_set_types\\012\\011ADD CONSTRAINT dsty_bk_uk UNIQUE (code, dbin_id);\\012\\012ALTER TABLE data_set_types\\012\\011ADD CONSTRAINT dsty_dbin_fk FOREIGN KEY (dbin_id) REFERENCES database_instances(id);\\012\\012DROP INDEX data_obty_fk_i;\\012\\012CREATE INDEX data_dsty_fk_i ON data(dsty_id);\\012	\N
+./sourceTest/sql/postgresql/042/.svn/text-base/017=database_version_logs.tsv.svn-base:030	source/sql/postgresql/migration/migration-029-030.sql	SUCCESS	2009-03-23 15:34:44.72	-- -------\\012-- add modification_timestamp field to allow edition with Hibernate\\012-- -------\\012ALTER TABLE data\\012\\011ADD COLUMN modification_timestamp TIME_STAMP DEFAULT CURRENT_TIMESTAMP;\\012ALTER TABLE experiment_types\\012\\011ADD COLUMN modification_timestamp TIME_STAMP DEFAULT CURRENT_TIMESTAMP;\\012ALTER TABLE sample_types\\012\\011ADD COLUMN modification_timestamp TIME_STAMP DEFAULT CURRENT_TIMESTAMP;\\012ALTER TABLE material_types\\012\\011ADD COLUMN modification_timestamp TIME_STAMP DEFAULT CURRENT_TIMESTAMP;\\012ALTER TABLE data_set_types\\012\\011ADD COLUMN modification_timestamp TIME_STAMP DEFAULT CURRENT_TIMESTAMP;\\012ALTER TABLE controlled_vocabularies\\012\\011ADD COLUMN modification_timestamp TIME_STAMP DEFAULT CURRENT_TIMESTAMP;\\012-- -------\\012-- add properties to data sets\\012-- -------\\012CREATE TABLE DATA_SET_PROPERTIES (ID TECH_ID NOT NULL,DS_ID TECH_ID NOT NULL,DSTPT_ID TECH_ID NOT NULL,VALUE GENERIC_VALUE,CVTE_ID TECH_ID, MATE_PROP_ID TECH_ID, PERS_ID_REGISTERER TECH_ID NOT NULL,REGISTRATION_TIMESTAMP TIME_STAMP_DFL NOT NULL DEFAULT CURRENT_TIMESTAMP, MODIFICATION_TIMESTAMP TIME_STAMP DEFAULT CURRENT_TIMESTAMP);\\012CREATE TABLE DATA_SET_TYPE_PROPERTY_TYPES (ID TECH_ID NOT NULL,DSTY_ID TECH_ID NOT NULL,PRTY_ID TECH_ID NOT NULL,IS_MANDATORY BOOLEAN_CHAR NOT NULL DEFAULT 'F',IS_MANAGED_INTERNALLY BOOLEAN_CHAR NOT NULL DEFAULT 'F',PERS_ID_REGISTERER TECH_ID NOT NULL,REGISTRATION_TIMESTAMP TIME_STAMP_DFL NOT NULL DEFAULT CURRENT_TIMESTAMP);\\012\\012CREATE SEQUENCE DATA_SET_PROPERTY_ID_SEQ;\\012CREATE SEQUENCE DSTPT_ID_SEQ;\\012\\012ALTER TABLE DATA_SET_TYPE_PROPERTY_TYPES ADD CONSTRAINT DSTPT_PK PRIMARY KEY(ID);\\012ALTER TABLE DATA_SET_PROPERTIES ADD CONSTRAINT DSPR_PK PRIMARY KEY(ID);\\012\\012ALTER TABLE DATA_SET_TYPE_PROPERTY_TYPES ADD CONSTRAINT DSTPT_BK_UK UNIQUE(DSTY_ID,PRTY_ID);\\012ALTER TABLE DATA_SET_PROPERTIES ADD CONSTRAINT DSPR_BK_UK UNIQUE(DS_ID,DSTPT_ID);\\012\\012\\012ALTER TABLE DATA_SET_TYPE_PROPERTY_TYPES ADD CONSTRAINT DSTPT_DSTY_FK FOREIGN KEY (DSTY_ID) REFERENCES DATA_SET_TYPES(ID);\\012ALTER TABLE DATA_SET_TYPE_PROPERTY_TYPES ADD CONSTRAINT DSTPT_PERS_FK FOREIGN KEY (PERS_ID_REGISTERER) REFERENCES PERSONS(ID);\\012ALTER TABLE DATA_SET_TYPE_PROPERTY_TYPES ADD CONSTRAINT DSTPT_PRTY_FK FOREIGN KEY (PRTY_ID) REFERENCES PROPERTY_TYPES(ID);\\012ALTER TABLE DATA_SET_PROPERTIES ADD CONSTRAINT DSPR_CVTE_FK FOREIGN KEY (CVTE_ID) REFERENCES CONTROLLED_VOCABULARY_TERMS(ID);\\012ALTER TABLE DATA_SET_PROPERTIES ADD CONSTRAINT DSPR_DSTPT_FK FOREIGN KEY (DSTPT_ID) REFERENCES DATA_SET_TYPE_PROPERTY_TYPES(ID) ON DELETE CASCADE;\\012ALTER TABLE DATA_SET_PROPERTIES ADD CONSTRAINT DSPR_DS_FK FOREIGN KEY (DS_ID) REFERENCES DATA(ID);\\012ALTER TABLE DATA_SET_PROPERTIES ADD CONSTRAINT DSPR_PERS_FK FOREIGN KEY (PERS_ID_REGISTERER) REFERENCES PERSONS(ID);\\012ALTER TABLE DATA_SET_PROPERTIES ADD CONSTRAINT DSPR_MAPR_FK FOREIGN KEY (MATE_PROP_ID) REFERENCES MATERIALS(ID);\\012\\012ALTER TABLE DATA_SET_PROPERTIES ADD CONSTRAINT DSPR_CK CHECK \\012\\011((VALUE IS NOT NULL AND CVTE_ID IS NULL AND MATE_PROP_ID IS NULL) OR \\012\\011 (VALUE IS NULL AND CVTE_ID IS NOT NULL AND MATE_PROP_ID IS NULL) OR\\012\\011 (VALUE IS NULL AND CVTE_ID IS NULL AND MATE_PROP_ID IS NOT NULL)\\012\\011);\\012\\012CREATE INDEX DSPR_CVTE_FK_I ON DATA_SET_PROPERTIES (CVTE_ID);\\012CREATE INDEX DSPR_DSTPT_FK_I ON DATA_SET_PROPERTIES (DSTPT_ID);\\012CREATE INDEX DSPR_DS_FK_I ON DATA_SET_PROPERTIES (DS_ID);\\012CREATE INDEX DSPR_PERS_FK_I ON DATA_SET_PROPERTIES (PERS_ID_REGISTERER);\\012CREATE INDEX DSTPT_DSTY_FK_I ON DATA_SET_TYPE_PROPERTY_TYPES (DSTY_ID);\\012CREATE INDEX DSTPT_PERS_FK_I ON DATA_SET_TYPE_PROPERTY_TYPES (PERS_ID_REGISTERER);\\012CREATE INDEX DSTPT_PRTY_FK_I ON DATA_SET_TYPE_PROPERTY_TYPES (PRTY_ID);\\012\\012CREATE OR REPLACE FUNCTION DATA_SET_PROPERTY_WITH_MATERIAL_DATA_TYPE_CHECK() RETURNS trigger AS $$\\012DECLARE\\012   v_type_id  CODE;\\012   v_type_id_prop  CODE;\\012BEGIN\\012   if NEW.mate_prop_id IS NOT NULL then\\012\\011\\011\\011-- find material type id of the property type \\012\\011\\011\\011select pt.maty_prop_id into v_type_id_prop \\012\\011\\011\\011  from data_set_type_property_types dstpt, property_types pt \\012\\011\\011\\011 where NEW.dstpt_id = dstpt.id AND dstpt.prty_id = pt.id;\\012\\011\\011\\012\\011\\011\\011if v_type_id_prop IS NOT NULL then\\012\\011\\011\\011\\011-- find material type id of the material which consists the entity's property value\\012\\011\\011\\011\\011select entity.maty_id into v_type_id \\012\\011\\011\\011\\011  from materials entity\\012\\011\\011\\011\\011 where NEW.mate_prop_id = entity.id;\\012\\011\\011\\011\\011if v_type_id != v_type_id_prop then\\012\\011\\011\\011\\011\\011RAISE EXCEPTION 'Insert/Update of property value referencing material (id: %) failed, as referenced material type is different than expected (id %, expected id: %).', \\012\\011\\011\\011\\011\\011\\011\\011\\011\\011\\011\\011\\011 NEW.mate_prop_id, v_type_id, v_type_id_prop;\\012\\011\\011\\011\\011end if;\\012\\011\\011\\011end if;\\012   end if;\\012   RETURN NEW;\\012END;\\012$$ LANGUAGE 'plpgsql';\\012\\012CREATE TRIGGER DATA_SET_PROPERTY_WITH_MATERIAL_DATA_TYPE_CHECK BEFORE INSERT OR UPDATE ON data_set_properties\\012    FOR EACH ROW EXECUTE PROCEDURE DATA_SET_PROPERTY_WITH_MATERIAL_DATA_TYPE_CHECK();   \\012	\N
+./sourceTest/sql/postgresql/042/.svn/text-base/017=database_version_logs.tsv.svn-base:032	source/sql/postgresql/migration/migration-031-032.sql	SUCCESS	2009-04-09 09:36:36.20	-- -------\\012-- Modify MATERIAL_BATCHES\\012-- -------\\012\\012ALTER TABLE material_batches\\012    DROP COLUMN proc_id;\\012\\012-- -------\\012-- Modify SAMPLES\\012-- -------\\012\\012ALTER TABLE samples\\012    ADD COLUMN expe_id tech_id;\\012\\012ALTER TABLE samples\\012    ADD CONSTRAINT samp_expe_fk FOREIGN KEY (expe_id) REFERENCES experiments(id);\\012\\012CREATE INDEX samp_expe_fk_i ON samples USING btree (expe_id);\\012\\012-- relink samples directly to experiments\\012\\012UPDATE samples\\012SET expe_id = (SELECT e.id FROM experiments e, procedures p, sample_inputs si \\012               WHERE si.samp_id = samples.id AND si.proc_id = p.id AND p.expe_id = e.id AND e.inva_id IS NULL);\\012\\012\\012-- -------\\012-- Modify DATA\\012-- -------\\012\\012ALTER TABLE data\\012    ADD COLUMN expe_id tech_id;\\012\\012ALTER TABLE data\\012    ADD CONSTRAINT data_expe_fk FOREIGN KEY (expe_id) REFERENCES experiments(id);\\012\\012CREATE INDEX data_expe_fk_i ON data USING btree (expe_id);\\012\\012UPDATE data\\012SET expe_id = (SELECT e.id FROM experiments e, procedures p \\012               WHERE data.proc_id_produced_by = p.id AND p.expe_id = e.id);\\012\\012ALTER TABLE data\\012    ALTER COLUMN expe_id SET NOT NULL;\\012\\012ALTER TABLE data\\012    DROP COLUMN proc_id_produced_by;\\012\\012-- -------\\012-- Drop PROCEDURES, PROCEDURE_TYPES, and SAMPLE_INPUTS\\012-- -------\\012\\012DROP TABLE sample_inputs;\\012DROP TABLE procedures;\\012DROP TABLE procedure_types;\\012\\012DROP SEQUENCE procedure_id_seq;\\012DROP SEQUENCE procedure_type_id_seq;\\012\\012-- -------\\012-- Add CODE_SEQ\\012-- -------\\012\\012CREATE SEQUENCE CODE_SEQ;\\012\\012-- -------\\012-- Add new columns to DATA_STORES\\012-- -------\\012\\012ALTER TABLE data_stores\\012    ADD COLUMN remote_url character varying(250),\\012    ADD COLUMN session_token character varying(50),\\012    ADD COLUMN modification_timestamp time_stamp DEFAULT now();\\012\\012UPDATE data_stores\\012SET remote_url = '', session_token='';\\012\\012ALTER TABLE data_stores\\012    ALTER COLUMN remote_url SET NOT NULL,\\012    ALTER COLUMN session_token SET NOT NULL;\\012\\012-- -------\\012-- Drop foreign keys onto DATA_STORES\\012-- -------\\012\\012ALTER TABLE database_instances\\012    DROP COLUMN dast_id;\\012\\012ALTER TABLE groups\\012    DROP COLUMN dast_id;\\012\\012ALTER TABLE projects\\012    DROP COLUMN dast_id;\\012\\012ALTER TABLE experiments\\012    DROP COLUMN dast_id;\\012\\012-- -------\\012-- Add foreign key from DATA onto DATA_STORES\\012-- -------\\012\\012ALTER TABLE data\\012    ADD COLUMN dast_id tech_id;\\012\\012ALTER TABLE data\\012    ADD CONSTRAINT data_dast_fk FOREIGN KEY (dast_id) REFERENCES data_stores(id);\\012\\012UPDATE data\\012SET dast_id = (select id from data_stores where code = 'STANDARD');\\012\\012ALTER TABLE data\\012    ALTER COLUMN dast_id SET NOT NULL;\\012\\012\\012------------------------------------------------------------------------------------\\012--  Purpose:  Replace trigger SAMPLE_CODE_UNIQUENESS_CHECK \\012------------------------------------------------------------------------------------\\012\\012CREATE OR REPLACE FUNCTION SAMPLE_CODE_UNIQUENESS_CHECK() RETURNS trigger AS $$\\012DECLARE\\012   counter  INTEGER;\\012BEGIN\\012    LOCK TABLE samples IN EXCLUSIVE MODE;\\012    IF (NEW.samp_id_part_of is NULL) THEN\\012        IF (NEW.dbin_id is not NULL) THEN\\012            SELECT count(*) into counter FROM samples \\012                where id != NEW.id and code = NEW.code and samp_id_part_of is NULL and dbin_id = NEW.dbin_id;\\012            IF (counter > 0) THEN\\012                RAISE EXCEPTION 'Insert/Update of Sample (Code: %) failed because database instance sample with the same code already exists.', NEW.code;\\012            END IF;\\012        ELSIF (NEW.grou_id is not NULL) THEN\\012            SELECT count(*) into counter FROM samples \\012                where id != NEW.id and code = NEW.code and samp_id_part_of is NULL and grou_id = NEW.grou_id;\\012            IF (counter > 0) THEN\\012                RAISE EXCEPTION 'Insert/Update of Sample (Code: %) failed because group sample with the same code already exists.', NEW.code;\\012            END IF;\\012        END IF;\\012        ELSE\\012        IF (NEW.dbin_id is not NULL) THEN\\012            SELECT count(*) into counter FROM samples \\012                where id != NEW.id and code = NEW.code and samp_id_part_of = NEW.samp_id_part_of and dbin_id = NEW.dbin_id;\\012            IF (counter > 0) THEN\\012                RAISE EXCEPTION 'Insert/Update of Sample (Code: %) failed because database instance sample with the same code and being the part of the same parent already exists.', NEW.code;\\012            END IF;\\012        ELSIF (NEW.grou_id is not NULL) THEN\\012            SELECT count(*) into counter FROM samples \\012                where id != NEW.id and code = NEW.code and samp_id_part_of = NEW.samp_id_part_of and grou_id = NEW.grou_id;\\012            IF (counter > 0) THEN\\012                RAISE EXCEPTION 'Insert/Update of Sample (Code: %) failed because group sample with the same code and being the part of the same parent already exists.', NEW.code;\\012            END IF;\\012        END IF;\\012        END IF;   \\012   RETURN NEW;\\012END;\\012$$ LANGUAGE 'plpgsql';\\012\\012\\012\\012	\N
+./sourceTest/sql/postgresql/042/.svn/text-base/017=database_version_logs.tsv.svn-base:034	source/sql/postgresql/migration/migration-033-034.sql	SUCCESS	2009-05-26 08:32:49.935	------------------------------------------------------------------------------------\\012-- Create sequence for generating permanent identifiers starting with nextval of existing dataset sequence.\\012------------------------------------------------------------------------------------\\012CREATE FUNCTION CREATE_SEQUENCE(EXISTING_SEQUENCE VARCHAR, NEW_SEQUENCE VARCHAR) RETURNS VOID AS $$\\012DECLARE\\012  CURR_SEQ_VAL   INTEGER;\\012BEGIN\\012  SELECT INTO CURR_SEQ_VAL NEXTVAL(EXISTING_SEQUENCE);\\012  EXECUTE 'CREATE SEQUENCE ' || NEW_SEQUENCE || ' START WITH ' || CURR_SEQ_VAL;\\012  RETURN;\\012END;\\012$$ LANGUAGE 'plpgsql';\\012\\012SELECT CREATE_SEQUENCE('DATA_ID_SEQ', 'PERM_ID_SEQ');\\012DROP FUNCTION CREATE_SEQUENCE(VARCHAR, VARCHAR);\\012\\012------------------------------------------------------------------------------------\\012-- Add perm_id columns to samples and experiments.\\012------------------------------------------------------------------------------------\\012ALTER TABLE SAMPLES ADD COLUMN PERM_ID CODE;\\012ALTER TABLE EXPERIMENTS ADD COLUMN PERM_ID CODE;\\012\\012UPDATE SAMPLES SET PERM_ID = to_char(registration_timestamp,'YYYYMMDDHHSSMS') || '-' || NEXTVAL('PERM_ID_SEQ');\\012UPDATE EXPERIMENTS SET PERM_ID = to_char(registration_timestamp,'YYYYMMDDHHSSMS') || '-' || NEXTVAL('PERM_ID_SEQ');\\012ALTER TABLE SAMPLES ALTER COLUMN PERM_ID SET NOT NULL;\\012ALTER TABLE EXPERIMENTS ALTER COLUMN PERM_ID SET NOT NULL;\\012ALTER TABLE SAMPLES ADD CONSTRAINT SAMP_PI_UK UNIQUE(PERM_ID);\\012ALTER TABLE EXPERIMENTS ADD CONSTRAINT EXPE_PI_UK UNIQUE(PERM_ID);\\012\\012\\012------------------------------------------------------------------------------------\\012-- Add column is_chosen_from_list to controlled_vocabularies.\\012------------------------------------------------------------------------------------\\012ALTER TABLE controlled_vocabularies ADD COLUMN is_chosen_from_list BOOLEAN_CHAR NOT NULL DEFAULT TRUE;\\012ALTER TABLE controlled_vocabularies ADD COLUMN source_uri CHARACTER VARYING(250);\\012------------------------------------------------------------------------------------\\012-- Modify Data table - remove arc connection between Sample and Data table, use a flag instead\\012------------------------------------------------------------------------------------\\012\\012-- add new columns\\012\\012ALTER TABLE data\\012    ADD COLUMN is_derived boolean_char;\\012ALTER TABLE data\\012    ADD COLUMN samp_id tech_id;\\012\\012-- update values in new columns\\012\\012UPDATE data\\012    SET is_derived = (samp_id_derived_from IS NOT NULL); \\012UPDATE data\\012    SET samp_id = samp_id_derived_from \\012    WHERE is_derived = 'TRUE';\\012UPDATE data\\012    SET samp_id = samp_id_acquired_from \\012    WHERE is_derived = 'FALSE';\\012\\012-- add constraints and indexes to new columns\\012\\012ALTER TABLE data\\012    ALTER COLUMN is_derived SET NOT NULL;\\012ALTER TABLE data\\012    ALTER COLUMN samp_id SET NOT NULL;   \\012ALTER TABLE data\\012    ADD CONSTRAINT data_samp_fk FOREIGN KEY (samp_id) REFERENCES samples (id);\\012CREATE INDEX data_samp_fk_i ON data USING btree (samp_id);\\012\\012-- remove old columns\\012\\012ALTER TABLE data\\012    DROP COLUMN samp_id_acquired_from;\\012ALTER TABLE data\\012    DROP COLUMN samp_id_derived_from;\\012    \\012------------------------------------------------------------------------------------\\012-- Granting SELECT privilege to group openbis_readonly\\012------------------------------------------------------------------------------------\\012\\012GRANT SELECT ON SEQUENCE attachment_content_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE attachment_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE code_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE controlled_vocabulary_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE cvte_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE data_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE data_set_property_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE data_set_relationship_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE data_set_type_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE data_store_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE data_type_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE database_instance_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE dstpt_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE etpt_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE event_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE experiment_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE experiment_property_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE experiment_type_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE file_format_type_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE group_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE invalidation_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE locator_type_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE material_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE material_property_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE material_type_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE mtpt_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE perm_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE person_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE project_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE property_type_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE role_assignment_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE sample_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE sample_property_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE sample_type_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE stpt_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE attachment_contents TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE attachments TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE controlled_vocabularies TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE controlled_vocabulary_terms TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE data TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE data_set_properties TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE data_set_relationships TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE data_set_type_property_types TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE data_set_types TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE data_stores TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE data_types TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE database_instances TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE database_version_logs TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE events TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE experiment_properties TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE experiment_type_property_types TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE experiment_types TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE experiments TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE external_data TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE file_format_types TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE groups TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE invalidations TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE locator_types TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE material_properties TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE material_type_property_types TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE material_types TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE materials TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE persons TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE projects TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE property_types TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE role_assignments TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE sample_properties TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE sample_type_property_types TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE sample_types TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE samples TO GROUP OPENBIS_READONLY;\\012\\012------------------------------------------------------------------------------------\\012-- Delete MATERIAL_BATCHES table\\012------------------------------------------------------------------------------------\\012\\012-- WARNING: Potential data lost!!!\\012-- WARNING: Potential data lost!!!\\012-- WARNING: Potential data lost!!!\\012\\012DROP TABLE SAMPLE_MATERIAL_BATCHES;\\012DROP TABLE MATERIAL_BATCHES;\\012DROP SEQUENCE MATERIAL_BATCH_ID_SEQ;\\012\\012------------------------------------------------------------------------------------\\012-- Delete MATE_ID_INHIBITOR_OF from table MATERIALS\\012------------------------------------------------------------------------------------\\012\\012-- WARNING: Potential data lost!!!\\012-- WARNING: Potential data lost!!!\\012-- WARNING: Potential data lost!!!\\012\\012ALTER TABLE MATERIALS DROP COLUMN MATE_ID_INHIBITOR_OF;\\012	\N
+./sourceTest/sql/postgresql/042/.svn/text-base/017=database_version_logs.tsv.svn-base:041	source/sql/postgresql/migration/migration-040-041.sql	SUCCESS	2009-09-14 13:48:57.539	-- Create FILTERS table\\012\\012CREATE TABLE FILTERS (ID TECH_ID NOT NULL, DBIN_ID TECH_ID NOT NULL, NAME VARCHAR(200) NOT NULL, DESCRIPTION DESCRIPTION_1000,REGISTRATION_TIMESTAMP TIME_STAMP_DFL NOT NULL DEFAULT CURRENT_TIMESTAMP, PERS_ID_REGISTERER TECH_ID NOT NULL, MODIFICATION_TIMESTAMP TIME_STAMP DEFAULT CURRENT_TIMESTAMP, EXPRESSION VARCHAR(2000) NOT NULL, IS_PUBLIC BOOLEAN NOT NULL, GRID_ID VARCHAR(200) NOT NULL);\\012CREATE SEQUENCE FILTER_ID_SEQ;\\012ALTER TABLE FILTERS ADD CONSTRAINT FILT_PK PRIMARY KEY(ID);\\012ALTER TABLE FILTERS ADD CONSTRAINT FILT_BK_UK UNIQUE(NAME, DBIN_ID, GRID_ID);\\012ALTER TABLE FILTERS ADD CONSTRAINT FILT_PERS_FK FOREIGN KEY (PERS_ID_REGISTERER) REFERENCES PERSONS(ID);\\012ALTER TABLE FILTERS ADD CONSTRAINT FILT_DBIN_FK FOREIGN KEY (DBIN_ID) REFERENCES DATABASE_INSTANCES(ID);\\012CREATE INDEX FILT_PERS_FK_I ON FILTERS (PERS_ID_REGISTERER);\\012CREATE INDEX FILT_DBIN_FK_I ON FILTERS (DBIN_ID);\\012GRANT SELECT ON SEQUENCE filter_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE filters TO GROUP OPENBIS_READONLY;\\012\\012-- Add missing foreign key to role assignments authorization group\\012ALTER TABLE ROLE_ASSIGNMENTS ADD CONSTRAINT ROAS_AG_FK_GRANTEE FOREIGN KEY (AG_ID_GRANTEE) REFERENCES AUTHORIZATION_GROUPS(ID);\\012\\012--------------------------------------------------------------------------------------------------\\012-- Modify dataset connections:\\012-- 1. connection with sample shouldn't be mandatory any more\\012-- 2. introduce an arc condition that dataset cannot be connected with a sample and a parent dataset at the same time\\012--------------------------------------------------------------------------------------------------\\012\\012-- Weaken data-sample connection constraint - allow dataset to have no connection with sample\\012ALTER TABLE data ALTER COLUMN samp_id DROP NOT NULL;\\012\\012-- Remove data-sample connection for datasets that have a parent\\012\\012UPDATE data \\012   SET samp_id = NULL \\012 WHERE id IN (SELECT DISTINCT data_id_child FROM data_set_relationships);\\012\\012-- With PostgreSQL 8.4 one can check that before migration there were no cycles in dataset relationships:\\012--\\012-- WITH RECURSIVE data_set_parents(id, parent_ids, cycle) AS (\\012--         SELECT  r.data_id_child AS id, \\012--                 ARRAY[CAST (r.data_id_parent AS bigint)] AS parent_ids, \\012--                 false AS cycle \\012--         FROM data_set_relationships r\\012--     UNION ALL\\012--         SELECT  r.data_id_child,\\012--                 CAST (r.data_id_parent AS bigint) || p.parent_ids,\\012--                 r.data_id_child = ANY(p.parent_ids)\\012--         FROM data_set_relationships r, data_set_parents p\\012--         WHERE r.data_id_parent = p.id AND NOT cycle\\012-- )\\012-- SELECT count(*) AS cycles FROM data_set_parents WHERE cycle = true;\\012\\012---------------------------------------------------------------------------------------------------\\012--  Purpose:  Create DEFERRED triggers:\\012--            * check_dataset_relationships_on_data_table_modification,\\012--            * check_dataset_relationships_on_relationships_table_modification.\\012--            They check that after all modifications of database (just before commit) \\012--            if 'data'/'data_set_relationships' tables are among modified tables \\012--            dataset is not connected with a sample and a parent dataset at the same time.\\012--            This connections are held in two different tables so simple immediate trigger \\012--            with arc check cannot be used and we need two deferred triggers.\\012----------------------------------------------------------------------------------------------------\\012\\012-- trigger for 'data' table\\012\\012CREATE OR REPLACE FUNCTION check_dataset_relationships_on_data_table_modification() RETURNS trigger AS $$\\012DECLARE\\012\\011counter\\011INTEGER;\\012BEGIN\\012\\011-- if there is a connection with a Sample there should not be any connection with a parent Data Set\\012\\011IF (NEW.samp_id IS NOT NULL) THEN\\012\\011\\011-- count number of parents\\012\\011\\011SELECT count(*) INTO counter \\012\\011\\011\\011FROM data_set_relationships \\012\\011\\011\\011WHERE data_id_child = OLD.id;\\012\\011\\011IF (counter > 0) THEN\\012\\011\\011\\011RAISE EXCEPTION 'Insert/Update of Data Set (Code: %) failed because it cannot be connected with a Sample and a parent Data Set at the same time.', OLD.code;\\012\\011\\011END IF;\\012\\011END IF;\\012  RETURN NEW;\\012END;\\012$$ LANGUAGE 'plpgsql';\\012\\012CREATE CONSTRAINT TRIGGER check_dataset_relationships_on_data_table_modification \\012  AFTER INSERT OR UPDATE ON data\\012\\011DEFERRABLE INITIALLY DEFERRED\\012\\011FOR EACH ROW \\012\\011EXECUTE PROCEDURE check_dataset_relationships_on_data_table_modification();\\012\\012-- trigger for 'data_set_relationships'\\012\\012CREATE OR REPLACE FUNCTION check_dataset_relationships_on_relationships_table_modification() RETURNS trigger AS $$\\012DECLARE\\012\\011counter\\011INTEGER;\\012\\011sample_id\\011TECH_ID;\\012\\011data_code\\011CODE;\\012BEGIN\\012\\011-- child will have a parent added so it should not be connected with any sample\\012\\011SELECT samp_id, code INTO sample_id, data_code \\012\\011\\011FROM data \\012\\011\\011WHERE id = NEW.data_id_child;\\012\\011IF (sample_id IS NOT NULL) THEN\\012\\011\\011RAISE EXCEPTION 'Insert/Update of Data Set (Code: %) failed because it cannot be connected to a Sample and to a parent Data Set at the same time.', data_code;\\012\\011END IF;\\012\\011RETURN NEW;\\012END;\\012$$ LANGUAGE 'plpgsql';\\012  \\012CREATE CONSTRAINT TRIGGER check_dataset_relationships_on_relationships_table_modification \\012  AFTER INSERT OR UPDATE ON data_set_relationships\\012\\011DEFERRABLE INITIALLY DEFERRED\\012\\011FOR EACH ROW \\012\\011EXECUTE PROCEDURE check_dataset_relationships_on_relationships_table_modification();\\012	\N
+./sourceTest/sql/postgresql/042/.svn/text-base/schema-042.sql.svn-base:    LANGUAGE plpgsql;
+./sourceTest/sql/postgresql/042/.svn/text-base/schema-042.sql.svn-base:    LANGUAGE plpgsql;
+./sourceTest/sql/postgresql/042/.svn/text-base/schema-042.sql.svn-base:    LANGUAGE plpgsql;
+./sourceTest/sql/postgresql/042/.svn/text-base/schema-042.sql.svn-base:    LANGUAGE plpgsql;
+./sourceTest/sql/postgresql/042/.svn/text-base/schema-042.sql.svn-base:    LANGUAGE plpgsql;
+./sourceTest/sql/postgresql/042/.svn/text-base/schema-042.sql.svn-base:    LANGUAGE plpgsql;
+./sourceTest/sql/postgresql/042/.svn/text-base/schema-042.sql.svn-base:    LANGUAGE plpgsql;
+./sourceTest/sql/postgresql/042/.svn/text-base/schema-042.sql.svn-base:    LANGUAGE plpgsql;
+./sourceTest/sql/postgresql/042/.svn/text-base/schema-042.sql.svn-base:    LANGUAGE plpgsql;
+./sourceTest/sql/postgresql/042/.svn/text-base/schema-042.sql.svn-base:    LANGUAGE plpgsql;
+./sourceTest/sql/postgresql/042/017=database_version_logs.tsv:027	D:\\User\\felmer\\dev-workspace\\openbis/source/sql/postgresql/027/function-027.sql	SUCCESS	2008-11-05 09:18:00.403	-- Creating Functions\\012\\012------------------------------------------------------------------------------------\\012--  Purpose:  Create function RENAME_SEQUENCE() that is required for renaming the sequences belonging to tables\\012------------------------------------------------------------------------------------\\012CREATE FUNCTION RENAME_SEQUENCE(OLD_NAME VARCHAR, NEW_NAME VARCHAR) RETURNS INTEGER AS $$\\012DECLARE\\012  CURR_SEQ_VAL   INTEGER;\\012BEGIN\\012  SELECT INTO CURR_SEQ_VAL NEXTVAL(OLD_NAME);\\012  EXECUTE 'CREATE SEQUENCE ' || NEW_NAME || ' START WITH ' || CURR_SEQ_VAL;\\012  EXECUTE 'DROP SEQUENCE ' || OLD_NAME;\\012  RETURN CURR_SEQ_VAL;\\012END;\\012$$ LANGUAGE 'plpgsql';\\012\\012\\012------------------------------------------------------------------------------------\\012--  Purpose:  Create trigger CONTROLLED_VOCABULARY_CHECK \\012------------------------------------------------------------------------------------\\012\\012CREATE OR REPLACE FUNCTION CONTROLLED_VOCABULARY_CHECK() RETURNS trigger AS $$\\012DECLARE\\012   v_code  CODE;\\012BEGIN\\012\\012   select code into v_code from data_types where id = NEW.daty_id;\\012\\012   -- Check if the data is of type "CONTROLLEDVOCABULARY"\\012   if v_code = 'CONTROLLEDVOCABULARY' then\\012      if NEW.covo_id IS NULL then\\012         RAISE EXCEPTION 'Insert/Update of Property Type (Code: %) failed, as its Data Type is CONTROLLEDVOCABULARY, but it is not linked to a Controlled Vocabulary.', NEW.code;\\012      end if;\\012   end if;\\012\\012   RETURN NEW;\\012\\012END;\\012$$ LANGUAGE 'plpgsql';\\012\\012CREATE TRIGGER CONTROLLED_VOCABULARY_CHECK BEFORE INSERT OR UPDATE ON PROPERTY_TYPES\\012    FOR EACH ROW EXECUTE PROCEDURE CONTROLLED_VOCABULARY_CHECK();\\012\\012\\012------------------------------------------------------------------------------------\\012--  Purpose:  Create trigger EXTERNAL_DATA_STORAGE_FORMAT_CHECK \\012------------------------------------------------------------------------------------\\012\\012CREATE OR REPLACE FUNCTION EXTERNAL_DATA_STORAGE_FORMAT_CHECK() RETURNS trigger AS $$\\012DECLARE\\012   v_covo_code  CODE;\\012   data_code CODE;\\012BEGIN\\012\\012   select code into v_covo_code from controlled_vocabularies\\012      where is_internal_namespace = true and \\012         id = (select covo_id from controlled_vocabulary_terms where id = NEW.cvte_id_stor_fmt);\\012   -- Check if the data storage format is a term of the controlled vocabulary "STORAGE_FORMAT"\\012   if v_covo_code != 'STORAGE_FORMAT' then\\012      select code into data_code from data where id = NEW.data_id; \\012      RAISE EXCEPTION 'Insert/Update of Data (Code: %) failed, as its Storage Format is %, but is required to be STORAGE_FORMAT.', data_code, v_covo_code;\\012   end if;\\012\\012   RETURN NEW;\\012\\012END;\\012$$ LANGUAGE 'plpgsql';\\012\\012CREATE TRIGGER EXTERNAL_DATA_STORAGE_FORMAT_CHECK BEFORE INSERT OR UPDATE ON EXTERNAL_DATA\\012    FOR EACH ROW EXECUTE PROCEDURE EXTERNAL_DATA_STORAGE_FORMAT_CHECK();\\012\\012------------------------------------------------------------------------------------\\012--  Purpose:  Create trigger SAMPLE_CODE_UNIQUENESS_CHECK \\012------------------------------------------------------------------------------------\\012\\012CREATE OR REPLACE FUNCTION SAMPLE_CODE_UNIQUENESS_CHECK() RETURNS trigger AS $$\\012DECLARE\\012   counter  INTEGER;\\012BEGIN\\012\\011IF (NEW.samp_id_part_of is NULL) THEN\\012\\011\\011IF (NEW.dbin_id is not NULL) THEN\\012\\011\\011\\011SELECT count(*) into counter FROM samples \\012\\011\\011\\011\\011where id != NEW.id and code = NEW.code and samp_id_part_of is NULL and dbin_id = NEW.dbin_id;\\012\\011\\011\\011IF (counter > 0) THEN\\012\\011\\011\\011\\011RAISE EXCEPTION 'Insert/Update of Sample (Code: %) failed because database instance sample with the same code already exists.', NEW.code;\\012\\011\\011\\011END IF;\\012\\011\\011ELSIF (NEW.grou_id is not NULL) THEN\\012\\011\\011\\011SELECT count(*) into counter FROM samples \\012\\011\\011\\011\\011where id != NEW.id and code = NEW.code and samp_id_part_of is NULL and grou_id = NEW.grou_id;\\012\\011\\011\\011IF (counter > 0) THEN\\012\\011\\011\\011\\011RAISE EXCEPTION 'Insert/Update of Sample (Code: %) failed because group sample with the same code already exists.', NEW.code;\\012\\011\\011\\011END IF;\\012\\011\\011END IF;\\012        ELSE\\012\\011\\011IF (NEW.dbin_id is not NULL) THEN\\012\\011\\011\\011SELECT count(*) into counter FROM samples \\012\\011\\011\\011\\011where id != NEW.id and code = NEW.code and samp_id_part_of = NEW.samp_id_part_of and dbin_id = NEW.dbin_id;\\012\\011\\011\\011IF (counter > 0) THEN\\012\\011\\011\\011\\011RAISE EXCEPTION 'Insert/Update of Sample (Code: %) failed because database instance sample with the same code and being the part of the same parent already exists.', NEW.code;\\012\\011\\011\\011END IF;\\012\\011\\011ELSIF (NEW.grou_id is not NULL) THEN\\012\\011\\011\\011SELECT count(*) into counter FROM samples \\012\\011\\011\\011\\011where id != NEW.id and code = NEW.code and samp_id_part_of = NEW.samp_id_part_of and grou_id = NEW.grou_id;\\012\\011\\011\\011IF (counter > 0) THEN\\012\\011\\011\\011\\011RAISE EXCEPTION 'Insert/Update of Sample (Code: %) failed because group sample with the same code and being the part of the same parent already exists.', NEW.code;\\012\\011\\011\\011END IF;\\012\\011\\011END IF;\\012        END IF;   \\012   RETURN NEW;\\012END;\\012$$ LANGUAGE 'plpgsql';\\012\\012CREATE TRIGGER SAMPLE_CODE_UNIQUENESS_CHECK BEFORE INSERT OR UPDATE ON SAMPLES\\012    FOR EACH ROW EXECUTE PROCEDURE SAMPLE_CODE_UNIQUENESS_CHECK();\\012	\N
+./sourceTest/sql/postgresql/042/017=database_version_logs.tsv:028	source/sql/postgresql/migration/migration-027-028.sql	SUCCESS	2008-11-18 13:24:17.508	-- Create EXPERIMENT_ATTACHMENT_CONTENTS.\\012CREATE TABLE EXPERIMENT_ATTACHMENT_CONTENTS (ID TECH_ID NOT NULL,VALUE FILE NOT NULL);\\012CREATE SEQUENCE EXPERIMENT_ATTACHMENT_CONTENT_ID_SEQ;\\012ALTER TABLE EXPERIMENT_ATTACHMENT_CONTENTS ADD CONSTRAINT EXAC_PK PRIMARY KEY(ID);\\012\\012-- Alter EXPERIMENT_ATTACHMENTS by adding the new column which has a NULL constraint.\\012-- The NOT NULL constraint is added later on.\\012ALTER TABLE EXPERIMENT_ATTACHMENTS ADD COLUMN EXAC_ID TECH_ID;\\012\\012-- Does the VALUE migration between EXPERIMENT_ATTACHMENTS to EXPERIMENT_ATTACHMENT_CONTENTS.\\012CREATE OR REPLACE FUNCTION move_exp_att_content() RETURNS integer AS $$\\012DECLARE\\012    rec RECORD;\\012    seq BIGINT;\\012BEGIN\\012  FOR rec IN SELECT id, value FROM EXPERIMENT_ATTACHMENTS LOOP\\012  \\011seq := nextval('EXPERIMENT_ATTACHMENT_CONTENT_ID_SEQ');\\012    INSERT INTO EXPERIMENT_ATTACHMENT_CONTENTS (id, value) VALUES (seq, rec.value);\\012    UPDATE EXPERIMENT_ATTACHMENTS SET exac_id = seq WHERE id = rec.id;\\012  END LOOP;\\012  RETURN 1;\\012END;\\012$$ LANGUAGE 'plpgsql';\\012\\012-- Call the function.\\012SELECT move_exp_att_content();\\012DROP FUNCTION move_exp_att_content();\\012\\012\\012-- Finish EXPERIMENT_ATTACHMENTS changes.\\012ALTER TABLE EXPERIMENT_ATTACHMENTS ADD CONSTRAINT EXAT_CONT_FK FOREIGN KEY (EXAC_ID) REFERENCES EXPERIMENT_ATTACHMENT_CONTENTS(ID);\\012ALTER TABLE EXPERIMENT_ATTACHMENTS DROP COLUMN VALUE;\\012ALTER TABLE EXPERIMENT_ATTACHMENTS ALTER COLUMN EXAC_ID SET NOT NULL;\\012	\N
+./sourceTest/sql/postgresql/042/017=database_version_logs.tsv:029	source/sql/postgresql/migration/migration-028-029.sql	SUCCESS	2009-03-18 10:50:20.105	-- -------\\012-- add modification_timestamp field to allow edition with Hibernate\\012-- -------\\012\\012ALTER TABLE samples\\012\\011ADD COLUMN modification_timestamp TIME_STAMP DEFAULT CURRENT_TIMESTAMP;\\012\\012ALTER TABLE experiments\\012\\011ADD COLUMN modification_timestamp TIME_STAMP DEFAULT CURRENT_TIMESTAMP;\\012\\012ALTER TABLE materials\\012\\011ADD COLUMN modification_timestamp TIME_STAMP DEFAULT CURRENT_TIMESTAMP;\\012\\012ALTER TABLE experiment_properties\\012\\011ADD COLUMN modification_timestamp TIME_STAMP DEFAULT CURRENT_TIMESTAMP;\\012\\012ALTER TABLE material_properties\\012\\011ADD COLUMN modification_timestamp TIME_STAMP DEFAULT CURRENT_TIMESTAMP;\\012\\012ALTER TABLE sample_properties\\012\\011ADD COLUMN modification_timestamp TIME_STAMP DEFAULT CURRENT_TIMESTAMP;\\012\\012-- -------\\012-- add property data type which references materials\\012-- -------\\012\\012ALTER TABLE property_types\\012\\011ADD COLUMN maty_prop_id tech_id;\\012\\012ALTER TABLE property_types\\012\\011ADD CONSTRAINT prty_maty_fk FOREIGN KEY (maty_prop_id) REFERENCES material_types(id);\\012\\012ALTER TABLE experiment_properties\\012\\011ADD COLUMN mate_prop_id tech_id;\\012\\012ALTER TABLE material_properties\\012\\011ADD COLUMN mate_prop_id tech_id;\\012\\012ALTER TABLE sample_properties\\012\\011ADD COLUMN mate_prop_id tech_id;\\012\\012ALTER TABLE experiment_properties\\012\\011ADD CONSTRAINT expr_mapr_fk FOREIGN KEY (mate_prop_id) REFERENCES materials(id);\\012\\012ALTER TABLE material_properties\\012\\011ADD CONSTRAINT mapr_mapr_fk FOREIGN KEY (mate_prop_id) REFERENCES materials(id);\\012\\012ALTER TABLE sample_properties\\012\\011ADD CONSTRAINT sapr_mapr_fk FOREIGN KEY (mate_prop_id) REFERENCES materials(id);\\012\\012insert into data_types\\012(id\\012 ,code\\012 ,description)\\012 values \\012 (nextval('DATA_TYPE_ID_SEQ')\\012 ,'MATERIAL'\\012 ,'Reference to a material'\\012);\\012\\012ALTER TABLE MATERIAL_PROPERTIES DROP CONSTRAINT MAPR_CK;\\012ALTER TABLE MATERIAL_PROPERTIES ADD CONSTRAINT MAPR_CK CHECK \\012\\011((VALUE IS NOT NULL AND CVTE_ID IS NULL AND MATE_PROP_ID IS NULL) OR \\012\\011 (VALUE IS NULL AND CVTE_ID IS NOT NULL AND MATE_PROP_ID IS NULL) OR\\012\\011 (VALUE IS NULL AND CVTE_ID IS NULL AND MATE_PROP_ID IS NOT NULL)\\012\\011);\\012\\012ALTER TABLE EXPERIMENT_PROPERTIES DROP CONSTRAINT EXPR_CK;\\012ALTER TABLE EXPERIMENT_PROPERTIES ADD CONSTRAINT EXPR_CK CHECK \\012\\011((VALUE IS NOT NULL AND CVTE_ID IS NULL AND MATE_PROP_ID IS NULL) OR \\012\\011 (VALUE IS NULL AND CVTE_ID IS NOT NULL AND MATE_PROP_ID IS NULL) OR\\012\\011 (VALUE IS NULL AND CVTE_ID IS NULL AND MATE_PROP_ID IS NOT NULL)\\012\\011);\\012\\012ALTER TABLE SAMPLE_PROPERTIES DROP CONSTRAINT SAPR_CK;\\012ALTER TABLE SAMPLE_PROPERTIES ADD CONSTRAINT SAPR_CK CHECK \\012\\011((VALUE IS NOT NULL AND CVTE_ID IS NULL AND MATE_PROP_ID IS NULL) OR \\012\\011 (VALUE IS NULL AND CVTE_ID IS NOT NULL AND MATE_PROP_ID IS NULL) OR\\012\\011 (VALUE IS NULL AND CVTE_ID IS NULL AND MATE_PROP_ID IS NOT NULL)\\012\\011);\\012\\012------------------------------------------------------------------------------------\\012--  Purpose:  Create trigger MATERIAL/SAMPLE/EXPERIMENT _PROPERTY_WITH_MATERIAL_DATA_TYPE_CHECK\\012--            It checks that if material property value is assigned to the entity,\\012--\\011\\011\\011\\011\\011\\011then the material type is equal to the one described by property type.\\012------------------------------------------------------------------------------------\\012\\012CREATE OR REPLACE FUNCTION MATERIAL_PROPERTY_WITH_MATERIAL_DATA_TYPE_CHECK() RETURNS trigger AS $$\\012DECLARE\\012   v_type_id  CODE;\\012   v_type_id_prop  CODE;\\012BEGIN\\012   if NEW.mate_prop_id IS NOT NULL then\\012\\011\\011\\011-- find material type id of the property type \\012\\011\\011\\011select pt.maty_prop_id into v_type_id_prop \\012\\011\\011\\011  from material_type_property_types etpt, property_types pt \\012\\011\\011\\011 where NEW.mtpt_id = etpt.id AND etpt.prty_id = pt.id;\\012\\011\\011\\012\\011\\011\\011if v_type_id_prop IS NOT NULL then\\012\\011\\011\\011\\011-- find material type id of the material which consists the entity's property value\\012\\011\\011\\011\\011select entity.maty_id into v_type_id \\012\\011\\011\\011\\011  from materials entity\\012\\011\\011\\011\\011 where NEW.mate_prop_id = entity.id;\\012\\011\\011\\011\\011if v_type_id != v_type_id_prop then\\012\\011\\011\\011\\011\\011RAISE EXCEPTION 'Insert/Update of property value referencing material (id: %) failed, as referenced material type is different than expected (id %, expected id: %).', \\012\\011\\011\\011\\011\\011\\011\\011 NEW.mate_prop_id, v_type_id, v_type_id_prop;\\012\\011\\011\\011\\011end if;\\012\\011\\011\\011end if;\\012   end if;\\012   RETURN NEW;\\012END;\\012$$ LANGUAGE 'plpgsql';\\012\\012CREATE TRIGGER MATERIAL_PROPERTY_WITH_MATERIAL_DATA_TYPE_CHECK BEFORE INSERT OR UPDATE ON material_properties\\012    FOR EACH ROW EXECUTE PROCEDURE MATERIAL_PROPERTY_WITH_MATERIAL_DATA_TYPE_CHECK();\\012    \\012CREATE OR REPLACE FUNCTION SAMPLE_PROPERTY_WITH_MATERIAL_DATA_TYPE_CHECK() RETURNS trigger AS $$\\012DECLARE\\012   v_type_id  CODE;\\012   v_type_id_prop  CODE;\\012BEGIN\\012   if NEW.mate_prop_id IS NOT NULL then\\012\\011\\011\\011-- find material type id of the property type \\012\\011\\011\\011select pt.maty_prop_id into v_type_id_prop \\012\\011\\011\\011  from sample_type_property_types etpt, property_types pt \\012\\011\\011\\011 where NEW.stpt_id = etpt.id AND etpt.prty_id = pt.id;\\012\\011\\011\\012\\011\\011\\011if v_type_id_prop IS NOT NULL then\\012\\011\\011\\011\\011-- find material type id of the material which consists the entity's property value\\012\\011\\011\\011\\011select entity.maty_id into v_type_id \\012\\011\\011\\011\\011  from materials entity\\012\\011\\011\\011\\011 where NEW.mate_prop_id = entity.id;\\012\\011\\011\\011\\011if v_type_id != v_type_id_prop then\\012\\011\\011\\011\\011\\011RAISE EXCEPTION 'Insert/Update of property value referencing material (id: %) failed, as referenced material type is different than expected (id %, expected id: %).', \\012\\011\\011\\011\\011\\011\\011\\011\\011\\011\\011\\011\\011 NEW.mate_prop_id, v_type_id, v_type_id_prop;\\012\\011\\011\\011\\011end if;\\012\\011\\011\\011end if;\\012   end if;\\012   RETURN NEW;\\012END;\\012$$ LANGUAGE 'plpgsql';\\012\\012CREATE TRIGGER SAMPLE_PROPERTY_WITH_MATERIAL_DATA_TYPE_CHECK BEFORE INSERT OR UPDATE ON sample_properties\\012    FOR EACH ROW EXECUTE PROCEDURE SAMPLE_PROPERTY_WITH_MATERIAL_DATA_TYPE_CHECK();\\012    \\012CREATE OR REPLACE FUNCTION EXPERIMENT_PROPERTY_WITH_MATERIAL_DATA_TYPE_CHECK() RETURNS trigger AS $$\\012DECLARE\\012   v_type_id  CODE;\\012   v_type_id_prop  CODE;\\012BEGIN\\012   if NEW.mate_prop_id IS NOT NULL then\\012\\011\\011\\011-- find material type id of the property type \\012\\011\\011\\011select pt.maty_prop_id into v_type_id_prop \\012\\011\\011\\011  from experiment_type_property_types etpt, property_types pt \\012\\011\\011\\011 where NEW.etpt_id = etpt.id AND etpt.prty_id = pt.id;\\012\\011\\011\\012\\011\\011\\011if v_type_id_prop IS NOT NULL then\\012\\011\\011\\011\\011-- find material type id of the material which consists the entity's property value\\012\\011\\011\\011\\011select entity.maty_id into v_type_id \\012\\011\\011\\011\\011  from materials entity\\012\\011\\011\\011\\011 where NEW.mate_prop_id = entity.id;\\012\\011\\011\\011\\011if v_type_id != v_type_id_prop then\\012\\011\\011\\011\\011\\011RAISE EXCEPTION 'Insert/Update of property value referencing material (id: %) failed, as referenced material type is different than expected (id %, expected id: %).', \\012\\011\\011\\011\\011\\011\\011\\011\\011\\011\\011\\011\\011 NEW.mate_prop_id, v_type_id, v_type_id_prop;\\012\\011\\011\\011\\011end if;\\012\\011\\011\\011end if;\\012   end if;\\012   RETURN NEW;\\012END;\\012$$ LANGUAGE 'plpgsql';\\012\\012CREATE TRIGGER EXPERIMENT_PROPERTY_WITH_MATERIAL_DATA_TYPE_CHECK BEFORE INSERT OR UPDATE ON experiment_properties\\012    FOR EACH ROW EXECUTE PROCEDURE EXPERIMENT_PROPERTY_WITH_MATERIAL_DATA_TYPE_CHECK();\\012       \\012-- -------\\012-- remove the reminescents of the OBSERVABLE_TYPE\\012-- -------\\012\\012ALTER TABLE data\\012\\011DROP CONSTRAINT data_obty_fk;\\012\\012ALTER TABLE data_set_types\\012\\011DROP CONSTRAINT obty_pk;\\012\\012ALTER TABLE data_set_types\\012\\011ADD CONSTRAINT dsty_pk PRIMARY KEY (id);\\012\\012ALTER TABLE data\\012\\011ADD CONSTRAINT data_dsty_fk FOREIGN KEY (dsty_id) REFERENCES data_set_types(id);\\012\\012ALTER TABLE data_set_types\\012\\011DROP CONSTRAINT obty_bk_uk;\\012\\012ALTER TABLE data_set_types\\012\\011DROP CONSTRAINT obty_dbin_fk;\\012\\012ALTER TABLE data_set_types\\012\\011ADD CONSTRAINT dsty_bk_uk UNIQUE (code, dbin_id);\\012\\012ALTER TABLE data_set_types\\012\\011ADD CONSTRAINT dsty_dbin_fk FOREIGN KEY (dbin_id) REFERENCES database_instances(id);\\012\\012DROP INDEX data_obty_fk_i;\\012\\012CREATE INDEX data_dsty_fk_i ON data(dsty_id);\\012	\N
+./sourceTest/sql/postgresql/042/017=database_version_logs.tsv:030	source/sql/postgresql/migration/migration-029-030.sql	SUCCESS	2009-03-23 15:34:44.72	-- -------\\012-- add modification_timestamp field to allow edition with Hibernate\\012-- -------\\012ALTER TABLE data\\012\\011ADD COLUMN modification_timestamp TIME_STAMP DEFAULT CURRENT_TIMESTAMP;\\012ALTER TABLE experiment_types\\012\\011ADD COLUMN modification_timestamp TIME_STAMP DEFAULT CURRENT_TIMESTAMP;\\012ALTER TABLE sample_types\\012\\011ADD COLUMN modification_timestamp TIME_STAMP DEFAULT CURRENT_TIMESTAMP;\\012ALTER TABLE material_types\\012\\011ADD COLUMN modification_timestamp TIME_STAMP DEFAULT CURRENT_TIMESTAMP;\\012ALTER TABLE data_set_types\\012\\011ADD COLUMN modification_timestamp TIME_STAMP DEFAULT CURRENT_TIMESTAMP;\\012ALTER TABLE controlled_vocabularies\\012\\011ADD COLUMN modification_timestamp TIME_STAMP DEFAULT CURRENT_TIMESTAMP;\\012-- -------\\012-- add properties to data sets\\012-- -------\\012CREATE TABLE DATA_SET_PROPERTIES (ID TECH_ID NOT NULL,DS_ID TECH_ID NOT NULL,DSTPT_ID TECH_ID NOT NULL,VALUE GENERIC_VALUE,CVTE_ID TECH_ID, MATE_PROP_ID TECH_ID, PERS_ID_REGISTERER TECH_ID NOT NULL,REGISTRATION_TIMESTAMP TIME_STAMP_DFL NOT NULL DEFAULT CURRENT_TIMESTAMP, MODIFICATION_TIMESTAMP TIME_STAMP DEFAULT CURRENT_TIMESTAMP);\\012CREATE TABLE DATA_SET_TYPE_PROPERTY_TYPES (ID TECH_ID NOT NULL,DSTY_ID TECH_ID NOT NULL,PRTY_ID TECH_ID NOT NULL,IS_MANDATORY BOOLEAN_CHAR NOT NULL DEFAULT 'F',IS_MANAGED_INTERNALLY BOOLEAN_CHAR NOT NULL DEFAULT 'F',PERS_ID_REGISTERER TECH_ID NOT NULL,REGISTRATION_TIMESTAMP TIME_STAMP_DFL NOT NULL DEFAULT CURRENT_TIMESTAMP);\\012\\012CREATE SEQUENCE DATA_SET_PROPERTY_ID_SEQ;\\012CREATE SEQUENCE DSTPT_ID_SEQ;\\012\\012ALTER TABLE DATA_SET_TYPE_PROPERTY_TYPES ADD CONSTRAINT DSTPT_PK PRIMARY KEY(ID);\\012ALTER TABLE DATA_SET_PROPERTIES ADD CONSTRAINT DSPR_PK PRIMARY KEY(ID);\\012\\012ALTER TABLE DATA_SET_TYPE_PROPERTY_TYPES ADD CONSTRAINT DSTPT_BK_UK UNIQUE(DSTY_ID,PRTY_ID);\\012ALTER TABLE DATA_SET_PROPERTIES ADD CONSTRAINT DSPR_BK_UK UNIQUE(DS_ID,DSTPT_ID);\\012\\012\\012ALTER TABLE DATA_SET_TYPE_PROPERTY_TYPES ADD CONSTRAINT DSTPT_DSTY_FK FOREIGN KEY (DSTY_ID) REFERENCES DATA_SET_TYPES(ID);\\012ALTER TABLE DATA_SET_TYPE_PROPERTY_TYPES ADD CONSTRAINT DSTPT_PERS_FK FOREIGN KEY (PERS_ID_REGISTERER) REFERENCES PERSONS(ID);\\012ALTER TABLE DATA_SET_TYPE_PROPERTY_TYPES ADD CONSTRAINT DSTPT_PRTY_FK FOREIGN KEY (PRTY_ID) REFERENCES PROPERTY_TYPES(ID);\\012ALTER TABLE DATA_SET_PROPERTIES ADD CONSTRAINT DSPR_CVTE_FK FOREIGN KEY (CVTE_ID) REFERENCES CONTROLLED_VOCABULARY_TERMS(ID);\\012ALTER TABLE DATA_SET_PROPERTIES ADD CONSTRAINT DSPR_DSTPT_FK FOREIGN KEY (DSTPT_ID) REFERENCES DATA_SET_TYPE_PROPERTY_TYPES(ID) ON DELETE CASCADE;\\012ALTER TABLE DATA_SET_PROPERTIES ADD CONSTRAINT DSPR_DS_FK FOREIGN KEY (DS_ID) REFERENCES DATA(ID);\\012ALTER TABLE DATA_SET_PROPERTIES ADD CONSTRAINT DSPR_PERS_FK FOREIGN KEY (PERS_ID_REGISTERER) REFERENCES PERSONS(ID);\\012ALTER TABLE DATA_SET_PROPERTIES ADD CONSTRAINT DSPR_MAPR_FK FOREIGN KEY (MATE_PROP_ID) REFERENCES MATERIALS(ID);\\012\\012ALTER TABLE DATA_SET_PROPERTIES ADD CONSTRAINT DSPR_CK CHECK \\012\\011((VALUE IS NOT NULL AND CVTE_ID IS NULL AND MATE_PROP_ID IS NULL) OR \\012\\011 (VALUE IS NULL AND CVTE_ID IS NOT NULL AND MATE_PROP_ID IS NULL) OR\\012\\011 (VALUE IS NULL AND CVTE_ID IS NULL AND MATE_PROP_ID IS NOT NULL)\\012\\011);\\012\\012CREATE INDEX DSPR_CVTE_FK_I ON DATA_SET_PROPERTIES (CVTE_ID);\\012CREATE INDEX DSPR_DSTPT_FK_I ON DATA_SET_PROPERTIES (DSTPT_ID);\\012CREATE INDEX DSPR_DS_FK_I ON DATA_SET_PROPERTIES (DS_ID);\\012CREATE INDEX DSPR_PERS_FK_I ON DATA_SET_PROPERTIES (PERS_ID_REGISTERER);\\012CREATE INDEX DSTPT_DSTY_FK_I ON DATA_SET_TYPE_PROPERTY_TYPES (DSTY_ID);\\012CREATE INDEX DSTPT_PERS_FK_I ON DATA_SET_TYPE_PROPERTY_TYPES (PERS_ID_REGISTERER);\\012CREATE INDEX DSTPT_PRTY_FK_I ON DATA_SET_TYPE_PROPERTY_TYPES (PRTY_ID);\\012\\012CREATE OR REPLACE FUNCTION DATA_SET_PROPERTY_WITH_MATERIAL_DATA_TYPE_CHECK() RETURNS trigger AS $$\\012DECLARE\\012   v_type_id  CODE;\\012   v_type_id_prop  CODE;\\012BEGIN\\012   if NEW.mate_prop_id IS NOT NULL then\\012\\011\\011\\011-- find material type id of the property type \\012\\011\\011\\011select pt.maty_prop_id into v_type_id_prop \\012\\011\\011\\011  from data_set_type_property_types dstpt, property_types pt \\012\\011\\011\\011 where NEW.dstpt_id = dstpt.id AND dstpt.prty_id = pt.id;\\012\\011\\011\\012\\011\\011\\011if v_type_id_prop IS NOT NULL then\\012\\011\\011\\011\\011-- find material type id of the material which consists the entity's property value\\012\\011\\011\\011\\011select entity.maty_id into v_type_id \\012\\011\\011\\011\\011  from materials entity\\012\\011\\011\\011\\011 where NEW.mate_prop_id = entity.id;\\012\\011\\011\\011\\011if v_type_id != v_type_id_prop then\\012\\011\\011\\011\\011\\011RAISE EXCEPTION 'Insert/Update of property value referencing material (id: %) failed, as referenced material type is different than expected (id %, expected id: %).', \\012\\011\\011\\011\\011\\011\\011\\011\\011\\011\\011\\011\\011 NEW.mate_prop_id, v_type_id, v_type_id_prop;\\012\\011\\011\\011\\011end if;\\012\\011\\011\\011end if;\\012   end if;\\012   RETURN NEW;\\012END;\\012$$ LANGUAGE 'plpgsql';\\012\\012CREATE TRIGGER DATA_SET_PROPERTY_WITH_MATERIAL_DATA_TYPE_CHECK BEFORE INSERT OR UPDATE ON data_set_properties\\012    FOR EACH ROW EXECUTE PROCEDURE DATA_SET_PROPERTY_WITH_MATERIAL_DATA_TYPE_CHECK();   \\012	\N
+./sourceTest/sql/postgresql/042/017=database_version_logs.tsv:032	source/sql/postgresql/migration/migration-031-032.sql	SUCCESS	2009-04-09 09:36:36.20	-- -------\\012-- Modify MATERIAL_BATCHES\\012-- -------\\012\\012ALTER TABLE material_batches\\012    DROP COLUMN proc_id;\\012\\012-- -------\\012-- Modify SAMPLES\\012-- -------\\012\\012ALTER TABLE samples\\012    ADD COLUMN expe_id tech_id;\\012\\012ALTER TABLE samples\\012    ADD CONSTRAINT samp_expe_fk FOREIGN KEY (expe_id) REFERENCES experiments(id);\\012\\012CREATE INDEX samp_expe_fk_i ON samples USING btree (expe_id);\\012\\012-- relink samples directly to experiments\\012\\012UPDATE samples\\012SET expe_id = (SELECT e.id FROM experiments e, procedures p, sample_inputs si \\012               WHERE si.samp_id = samples.id AND si.proc_id = p.id AND p.expe_id = e.id AND e.inva_id IS NULL);\\012\\012\\012-- -------\\012-- Modify DATA\\012-- -------\\012\\012ALTER TABLE data\\012    ADD COLUMN expe_id tech_id;\\012\\012ALTER TABLE data\\012    ADD CONSTRAINT data_expe_fk FOREIGN KEY (expe_id) REFERENCES experiments(id);\\012\\012CREATE INDEX data_expe_fk_i ON data USING btree (expe_id);\\012\\012UPDATE data\\012SET expe_id = (SELECT e.id FROM experiments e, procedures p \\012               WHERE data.proc_id_produced_by = p.id AND p.expe_id = e.id);\\012\\012ALTER TABLE data\\012    ALTER COLUMN expe_id SET NOT NULL;\\012\\012ALTER TABLE data\\012    DROP COLUMN proc_id_produced_by;\\012\\012-- -------\\012-- Drop PROCEDURES, PROCEDURE_TYPES, and SAMPLE_INPUTS\\012-- -------\\012\\012DROP TABLE sample_inputs;\\012DROP TABLE procedures;\\012DROP TABLE procedure_types;\\012\\012DROP SEQUENCE procedure_id_seq;\\012DROP SEQUENCE procedure_type_id_seq;\\012\\012-- -------\\012-- Add CODE_SEQ\\012-- -------\\012\\012CREATE SEQUENCE CODE_SEQ;\\012\\012-- -------\\012-- Add new columns to DATA_STORES\\012-- -------\\012\\012ALTER TABLE data_stores\\012    ADD COLUMN remote_url character varying(250),\\012    ADD COLUMN session_token character varying(50),\\012    ADD COLUMN modification_timestamp time_stamp DEFAULT now();\\012\\012UPDATE data_stores\\012SET remote_url = '', session_token='';\\012\\012ALTER TABLE data_stores\\012    ALTER COLUMN remote_url SET NOT NULL,\\012    ALTER COLUMN session_token SET NOT NULL;\\012\\012-- -------\\012-- Drop foreign keys onto DATA_STORES\\012-- -------\\012\\012ALTER TABLE database_instances\\012    DROP COLUMN dast_id;\\012\\012ALTER TABLE groups\\012    DROP COLUMN dast_id;\\012\\012ALTER TABLE projects\\012    DROP COLUMN dast_id;\\012\\012ALTER TABLE experiments\\012    DROP COLUMN dast_id;\\012\\012-- -------\\012-- Add foreign key from DATA onto DATA_STORES\\012-- -------\\012\\012ALTER TABLE data\\012    ADD COLUMN dast_id tech_id;\\012\\012ALTER TABLE data\\012    ADD CONSTRAINT data_dast_fk FOREIGN KEY (dast_id) REFERENCES data_stores(id);\\012\\012UPDATE data\\012SET dast_id = (select id from data_stores where code = 'STANDARD');\\012\\012ALTER TABLE data\\012    ALTER COLUMN dast_id SET NOT NULL;\\012\\012\\012------------------------------------------------------------------------------------\\012--  Purpose:  Replace trigger SAMPLE_CODE_UNIQUENESS_CHECK \\012------------------------------------------------------------------------------------\\012\\012CREATE OR REPLACE FUNCTION SAMPLE_CODE_UNIQUENESS_CHECK() RETURNS trigger AS $$\\012DECLARE\\012   counter  INTEGER;\\012BEGIN\\012    LOCK TABLE samples IN EXCLUSIVE MODE;\\012    IF (NEW.samp_id_part_of is NULL) THEN\\012        IF (NEW.dbin_id is not NULL) THEN\\012            SELECT count(*) into counter FROM samples \\012                where id != NEW.id and code = NEW.code and samp_id_part_of is NULL and dbin_id = NEW.dbin_id;\\012            IF (counter > 0) THEN\\012                RAISE EXCEPTION 'Insert/Update of Sample (Code: %) failed because database instance sample with the same code already exists.', NEW.code;\\012            END IF;\\012        ELSIF (NEW.grou_id is not NULL) THEN\\012            SELECT count(*) into counter FROM samples \\012                where id != NEW.id and code = NEW.code and samp_id_part_of is NULL and grou_id = NEW.grou_id;\\012            IF (counter > 0) THEN\\012                RAISE EXCEPTION 'Insert/Update of Sample (Code: %) failed because group sample with the same code already exists.', NEW.code;\\012            END IF;\\012        END IF;\\012        ELSE\\012        IF (NEW.dbin_id is not NULL) THEN\\012            SELECT count(*) into counter FROM samples \\012                where id != NEW.id and code = NEW.code and samp_id_part_of = NEW.samp_id_part_of and dbin_id = NEW.dbin_id;\\012            IF (counter > 0) THEN\\012                RAISE EXCEPTION 'Insert/Update of Sample (Code: %) failed because database instance sample with the same code and being the part of the same parent already exists.', NEW.code;\\012            END IF;\\012        ELSIF (NEW.grou_id is not NULL) THEN\\012            SELECT count(*) into counter FROM samples \\012                where id != NEW.id and code = NEW.code and samp_id_part_of = NEW.samp_id_part_of and grou_id = NEW.grou_id;\\012            IF (counter > 0) THEN\\012                RAISE EXCEPTION 'Insert/Update of Sample (Code: %) failed because group sample with the same code and being the part of the same parent already exists.', NEW.code;\\012            END IF;\\012        END IF;\\012        END IF;   \\012   RETURN NEW;\\012END;\\012$$ LANGUAGE 'plpgsql';\\012\\012\\012\\012	\N
+./sourceTest/sql/postgresql/042/017=database_version_logs.tsv:034	source/sql/postgresql/migration/migration-033-034.sql	SUCCESS	2009-05-26 08:32:49.935	------------------------------------------------------------------------------------\\012-- Create sequence for generating permanent identifiers starting with nextval of existing dataset sequence.\\012------------------------------------------------------------------------------------\\012CREATE FUNCTION CREATE_SEQUENCE(EXISTING_SEQUENCE VARCHAR, NEW_SEQUENCE VARCHAR) RETURNS VOID AS $$\\012DECLARE\\012  CURR_SEQ_VAL   INTEGER;\\012BEGIN\\012  SELECT INTO CURR_SEQ_VAL NEXTVAL(EXISTING_SEQUENCE);\\012  EXECUTE 'CREATE SEQUENCE ' || NEW_SEQUENCE || ' START WITH ' || CURR_SEQ_VAL;\\012  RETURN;\\012END;\\012$$ LANGUAGE 'plpgsql';\\012\\012SELECT CREATE_SEQUENCE('DATA_ID_SEQ', 'PERM_ID_SEQ');\\012DROP FUNCTION CREATE_SEQUENCE(VARCHAR, VARCHAR);\\012\\012------------------------------------------------------------------------------------\\012-- Add perm_id columns to samples and experiments.\\012------------------------------------------------------------------------------------\\012ALTER TABLE SAMPLES ADD COLUMN PERM_ID CODE;\\012ALTER TABLE EXPERIMENTS ADD COLUMN PERM_ID CODE;\\012\\012UPDATE SAMPLES SET PERM_ID = to_char(registration_timestamp,'YYYYMMDDHHSSMS') || '-' || NEXTVAL('PERM_ID_SEQ');\\012UPDATE EXPERIMENTS SET PERM_ID = to_char(registration_timestamp,'YYYYMMDDHHSSMS') || '-' || NEXTVAL('PERM_ID_SEQ');\\012ALTER TABLE SAMPLES ALTER COLUMN PERM_ID SET NOT NULL;\\012ALTER TABLE EXPERIMENTS ALTER COLUMN PERM_ID SET NOT NULL;\\012ALTER TABLE SAMPLES ADD CONSTRAINT SAMP_PI_UK UNIQUE(PERM_ID);\\012ALTER TABLE EXPERIMENTS ADD CONSTRAINT EXPE_PI_UK UNIQUE(PERM_ID);\\012\\012\\012------------------------------------------------------------------------------------\\012-- Add column is_chosen_from_list to controlled_vocabularies.\\012------------------------------------------------------------------------------------\\012ALTER TABLE controlled_vocabularies ADD COLUMN is_chosen_from_list BOOLEAN_CHAR NOT NULL DEFAULT TRUE;\\012ALTER TABLE controlled_vocabularies ADD COLUMN source_uri CHARACTER VARYING(250);\\012------------------------------------------------------------------------------------\\012-- Modify Data table - remove arc connection between Sample and Data table, use a flag instead\\012------------------------------------------------------------------------------------\\012\\012-- add new columns\\012\\012ALTER TABLE data\\012    ADD COLUMN is_derived boolean_char;\\012ALTER TABLE data\\012    ADD COLUMN samp_id tech_id;\\012\\012-- update values in new columns\\012\\012UPDATE data\\012    SET is_derived = (samp_id_derived_from IS NOT NULL); \\012UPDATE data\\012    SET samp_id = samp_id_derived_from \\012    WHERE is_derived = 'TRUE';\\012UPDATE data\\012    SET samp_id = samp_id_acquired_from \\012    WHERE is_derived = 'FALSE';\\012\\012-- add constraints and indexes to new columns\\012\\012ALTER TABLE data\\012    ALTER COLUMN is_derived SET NOT NULL;\\012ALTER TABLE data\\012    ALTER COLUMN samp_id SET NOT NULL;   \\012ALTER TABLE data\\012    ADD CONSTRAINT data_samp_fk FOREIGN KEY (samp_id) REFERENCES samples (id);\\012CREATE INDEX data_samp_fk_i ON data USING btree (samp_id);\\012\\012-- remove old columns\\012\\012ALTER TABLE data\\012    DROP COLUMN samp_id_acquired_from;\\012ALTER TABLE data\\012    DROP COLUMN samp_id_derived_from;\\012    \\012------------------------------------------------------------------------------------\\012-- Granting SELECT privilege to group openbis_readonly\\012------------------------------------------------------------------------------------\\012\\012GRANT SELECT ON SEQUENCE attachment_content_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE attachment_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE code_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE controlled_vocabulary_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE cvte_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE data_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE data_set_property_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE data_set_relationship_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE data_set_type_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE data_store_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE data_type_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE database_instance_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE dstpt_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE etpt_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE event_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE experiment_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE experiment_property_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE experiment_type_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE file_format_type_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE group_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE invalidation_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE locator_type_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE material_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE material_property_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE material_type_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE mtpt_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE perm_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE person_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE project_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE property_type_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE role_assignment_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE sample_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE sample_property_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE sample_type_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE stpt_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE attachment_contents TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE attachments TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE controlled_vocabularies TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE controlled_vocabulary_terms TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE data TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE data_set_properties TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE data_set_relationships TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE data_set_type_property_types TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE data_set_types TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE data_stores TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE data_types TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE database_instances TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE database_version_logs TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE events TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE experiment_properties TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE experiment_type_property_types TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE experiment_types TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE experiments TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE external_data TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE file_format_types TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE groups TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE invalidations TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE locator_types TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE material_properties TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE material_type_property_types TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE material_types TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE materials TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE persons TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE projects TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE property_types TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE role_assignments TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE sample_properties TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE sample_type_property_types TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE sample_types TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE samples TO GROUP OPENBIS_READONLY;\\012\\012------------------------------------------------------------------------------------\\012-- Delete MATERIAL_BATCHES table\\012------------------------------------------------------------------------------------\\012\\012-- WARNING: Potential data lost!!!\\012-- WARNING: Potential data lost!!!\\012-- WARNING: Potential data lost!!!\\012\\012DROP TABLE SAMPLE_MATERIAL_BATCHES;\\012DROP TABLE MATERIAL_BATCHES;\\012DROP SEQUENCE MATERIAL_BATCH_ID_SEQ;\\012\\012------------------------------------------------------------------------------------\\012-- Delete MATE_ID_INHIBITOR_OF from table MATERIALS\\012------------------------------------------------------------------------------------\\012\\012-- WARNING: Potential data lost!!!\\012-- WARNING: Potential data lost!!!\\012-- WARNING: Potential data lost!!!\\012\\012ALTER TABLE MATERIALS DROP COLUMN MATE_ID_INHIBITOR_OF;\\012	\N
+./sourceTest/sql/postgresql/042/017=database_version_logs.tsv:041	source/sql/postgresql/migration/migration-040-041.sql	SUCCESS	2009-09-14 13:48:57.539	-- Create FILTERS table\\012\\012CREATE TABLE FILTERS (ID TECH_ID NOT NULL, DBIN_ID TECH_ID NOT NULL, NAME VARCHAR(200) NOT NULL, DESCRIPTION DESCRIPTION_1000,REGISTRATION_TIMESTAMP TIME_STAMP_DFL NOT NULL DEFAULT CURRENT_TIMESTAMP, PERS_ID_REGISTERER TECH_ID NOT NULL, MODIFICATION_TIMESTAMP TIME_STAMP DEFAULT CURRENT_TIMESTAMP, EXPRESSION VARCHAR(2000) NOT NULL, IS_PUBLIC BOOLEAN NOT NULL, GRID_ID VARCHAR(200) NOT NULL);\\012CREATE SEQUENCE FILTER_ID_SEQ;\\012ALTER TABLE FILTERS ADD CONSTRAINT FILT_PK PRIMARY KEY(ID);\\012ALTER TABLE FILTERS ADD CONSTRAINT FILT_BK_UK UNIQUE(NAME, DBIN_ID, GRID_ID);\\012ALTER TABLE FILTERS ADD CONSTRAINT FILT_PERS_FK FOREIGN KEY (PERS_ID_REGISTERER) REFERENCES PERSONS(ID);\\012ALTER TABLE FILTERS ADD CONSTRAINT FILT_DBIN_FK FOREIGN KEY (DBIN_ID) REFERENCES DATABASE_INSTANCES(ID);\\012CREATE INDEX FILT_PERS_FK_I ON FILTERS (PERS_ID_REGISTERER);\\012CREATE INDEX FILT_DBIN_FK_I ON FILTERS (DBIN_ID);\\012GRANT SELECT ON SEQUENCE filter_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE filters TO GROUP OPENBIS_READONLY;\\012\\012-- Add missing foreign key to role assignments authorization group\\012ALTER TABLE ROLE_ASSIGNMENTS ADD CONSTRAINT ROAS_AG_FK_GRANTEE FOREIGN KEY (AG_ID_GRANTEE) REFERENCES AUTHORIZATION_GROUPS(ID);\\012\\012--------------------------------------------------------------------------------------------------\\012-- Modify dataset connections:\\012-- 1. connection with sample shouldn't be mandatory any more\\012-- 2. introduce an arc condition that dataset cannot be connected with a sample and a parent dataset at the same time\\012--------------------------------------------------------------------------------------------------\\012\\012-- Weaken data-sample connection constraint - allow dataset to have no connection with sample\\012ALTER TABLE data ALTER COLUMN samp_id DROP NOT NULL;\\012\\012-- Remove data-sample connection for datasets that have a parent\\012\\012UPDATE data \\012   SET samp_id = NULL \\012 WHERE id IN (SELECT DISTINCT data_id_child FROM data_set_relationships);\\012\\012-- With PostgreSQL 8.4 one can check that before migration there were no cycles in dataset relationships:\\012--\\012-- WITH RECURSIVE data_set_parents(id, parent_ids, cycle) AS (\\012--         SELECT  r.data_id_child AS id, \\012--                 ARRAY[CAST (r.data_id_parent AS bigint)] AS parent_ids, \\012--                 false AS cycle \\012--         FROM data_set_relationships r\\012--     UNION ALL\\012--         SELECT  r.data_id_child,\\012--                 CAST (r.data_id_parent AS bigint) || p.parent_ids,\\012--                 r.data_id_child = ANY(p.parent_ids)\\012--         FROM data_set_relationships r, data_set_parents p\\012--         WHERE r.data_id_parent = p.id AND NOT cycle\\012-- )\\012-- SELECT count(*) AS cycles FROM data_set_parents WHERE cycle = true;\\012\\012---------------------------------------------------------------------------------------------------\\012--  Purpose:  Create DEFERRED triggers:\\012--            * check_dataset_relationships_on_data_table_modification,\\012--            * check_dataset_relationships_on_relationships_table_modification.\\012--            They check that after all modifications of database (just before commit) \\012--            if 'data'/'data_set_relationships' tables are among modified tables \\012--            dataset is not connected with a sample and a parent dataset at the same time.\\012--            This connections are held in two different tables so simple immediate trigger \\012--            with arc check cannot be used and we need two deferred triggers.\\012----------------------------------------------------------------------------------------------------\\012\\012-- trigger for 'data' table\\012\\012CREATE OR REPLACE FUNCTION check_dataset_relationships_on_data_table_modification() RETURNS trigger AS $$\\012DECLARE\\012\\011counter\\011INTEGER;\\012BEGIN\\012\\011-- if there is a connection with a Sample there should not be any connection with a parent Data Set\\012\\011IF (NEW.samp_id IS NOT NULL) THEN\\012\\011\\011-- count number of parents\\012\\011\\011SELECT count(*) INTO counter \\012\\011\\011\\011FROM data_set_relationships \\012\\011\\011\\011WHERE data_id_child = OLD.id;\\012\\011\\011IF (counter > 0) THEN\\012\\011\\011\\011RAISE EXCEPTION 'Insert/Update of Data Set (Code: %) failed because it cannot be connected with a Sample and a parent Data Set at the same time.', OLD.code;\\012\\011\\011END IF;\\012\\011END IF;\\012  RETURN NEW;\\012END;\\012$$ LANGUAGE 'plpgsql';\\012\\012CREATE CONSTRAINT TRIGGER check_dataset_relationships_on_data_table_modification \\012  AFTER INSERT OR UPDATE ON data\\012\\011DEFERRABLE INITIALLY DEFERRED\\012\\011FOR EACH ROW \\012\\011EXECUTE PROCEDURE check_dataset_relationships_on_data_table_modification();\\012\\012-- trigger for 'data_set_relationships'\\012\\012CREATE OR REPLACE FUNCTION check_dataset_relationships_on_relationships_table_modification() RETURNS trigger AS $$\\012DECLARE\\012\\011counter\\011INTEGER;\\012\\011sample_id\\011TECH_ID;\\012\\011data_code\\011CODE;\\012BEGIN\\012\\011-- child will have a parent added so it should not be connected with any sample\\012\\011SELECT samp_id, code INTO sample_id, data_code \\012\\011\\011FROM data \\012\\011\\011WHERE id = NEW.data_id_child;\\012\\011IF (sample_id IS NOT NULL) THEN\\012\\011\\011RAISE EXCEPTION 'Insert/Update of Data Set (Code: %) failed because it cannot be connected to a Sample and to a parent Data Set at the same time.', data_code;\\012\\011END IF;\\012\\011RETURN NEW;\\012END;\\012$$ LANGUAGE 'plpgsql';\\012  \\012CREATE CONSTRAINT TRIGGER check_dataset_relationships_on_relationships_table_modification \\012  AFTER INSERT OR UPDATE ON data_set_relationships\\012\\011DEFERRABLE INITIALLY DEFERRED\\012\\011FOR EACH ROW \\012\\011EXECUTE PROCEDURE check_dataset_relationships_on_relationships_table_modification();\\012	\N
+./sourceTest/sql/postgresql/042/schema-042.sql:    LANGUAGE plpgsql;
+./sourceTest/sql/postgresql/042/schema-042.sql:    LANGUAGE plpgsql;
+./sourceTest/sql/postgresql/042/schema-042.sql:    LANGUAGE plpgsql;
+./sourceTest/sql/postgresql/042/schema-042.sql:    LANGUAGE plpgsql;
+./sourceTest/sql/postgresql/042/schema-042.sql:    LANGUAGE plpgsql;
+./sourceTest/sql/postgresql/042/schema-042.sql:    LANGUAGE plpgsql;
+./sourceTest/sql/postgresql/042/schema-042.sql:    LANGUAGE plpgsql;
+./sourceTest/sql/postgresql/042/schema-042.sql:    LANGUAGE plpgsql;
+./sourceTest/sql/postgresql/042/schema-042.sql:    LANGUAGE plpgsql;
+./sourceTest/sql/postgresql/042/schema-042.sql:    LANGUAGE plpgsql;
+./sourceTest/sql/postgresql/043/.svn/text-base/017=database_version_logs.tsv.svn-base:027	D:\\User\\felmer\\dev-workspace\\openbis/source/sql/postgresql/027/function-027.sql	SUCCESS	2008-11-05 09:18:00.403	-- Creating Functions\\012\\012------------------------------------------------------------------------------------\\012--  Purpose:  Create function RENAME_SEQUENCE() that is required for renaming the sequences belonging to tables\\012------------------------------------------------------------------------------------\\012CREATE FUNCTION RENAME_SEQUENCE(OLD_NAME VARCHAR, NEW_NAME VARCHAR) RETURNS INTEGER AS $$\\012DECLARE\\012  CURR_SEQ_VAL   INTEGER;\\012BEGIN\\012  SELECT INTO CURR_SEQ_VAL NEXTVAL(OLD_NAME);\\012  EXECUTE 'CREATE SEQUENCE ' || NEW_NAME || ' START WITH ' || CURR_SEQ_VAL;\\012  EXECUTE 'DROP SEQUENCE ' || OLD_NAME;\\012  RETURN CURR_SEQ_VAL;\\012END;\\012$$ LANGUAGE 'plpgsql';\\012\\012\\012------------------------------------------------------------------------------------\\012--  Purpose:  Create trigger CONTROLLED_VOCABULARY_CHECK \\012------------------------------------------------------------------------------------\\012\\012CREATE OR REPLACE FUNCTION CONTROLLED_VOCABULARY_CHECK() RETURNS trigger AS $$\\012DECLARE\\012   v_code  CODE;\\012BEGIN\\012\\012   select code into v_code from data_types where id = NEW.daty_id;\\012\\012   -- Check if the data is of type "CONTROLLEDVOCABULARY"\\012   if v_code = 'CONTROLLEDVOCABULARY' then\\012      if NEW.covo_id IS NULL then\\012         RAISE EXCEPTION 'Insert/Update of Property Type (Code: %) failed, as its Data Type is CONTROLLEDVOCABULARY, but it is not linked to a Controlled Vocabulary.', NEW.code;\\012      end if;\\012   end if;\\012\\012   RETURN NEW;\\012\\012END;\\012$$ LANGUAGE 'plpgsql';\\012\\012CREATE TRIGGER CONTROLLED_VOCABULARY_CHECK BEFORE INSERT OR UPDATE ON PROPERTY_TYPES\\012    FOR EACH ROW EXECUTE PROCEDURE CONTROLLED_VOCABULARY_CHECK();\\012\\012\\012------------------------------------------------------------------------------------\\012--  Purpose:  Create trigger EXTERNAL_DATA_STORAGE_FORMAT_CHECK \\012------------------------------------------------------------------------------------\\012\\012CREATE OR REPLACE FUNCTION EXTERNAL_DATA_STORAGE_FORMAT_CHECK() RETURNS trigger AS $$\\012DECLARE\\012   v_covo_code  CODE;\\012   data_code CODE;\\012BEGIN\\012\\012   select code into v_covo_code from controlled_vocabularies\\012      where is_internal_namespace = true and \\012         id = (select covo_id from controlled_vocabulary_terms where id = NEW.cvte_id_stor_fmt);\\012   -- Check if the data storage format is a term of the controlled vocabulary "STORAGE_FORMAT"\\012   if v_covo_code != 'STORAGE_FORMAT' then\\012      select code into data_code from data where id = NEW.data_id; \\012      RAISE EXCEPTION 'Insert/Update of Data (Code: %) failed, as its Storage Format is %, but is required to be STORAGE_FORMAT.', data_code, v_covo_code;\\012   end if;\\012\\012   RETURN NEW;\\012\\012END;\\012$$ LANGUAGE 'plpgsql';\\012\\012CREATE TRIGGER EXTERNAL_DATA_STORAGE_FORMAT_CHECK BEFORE INSERT OR UPDATE ON EXTERNAL_DATA\\012    FOR EACH ROW EXECUTE PROCEDURE EXTERNAL_DATA_STORAGE_FORMAT_CHECK();\\012\\012------------------------------------------------------------------------------------\\012--  Purpose:  Create trigger SAMPLE_CODE_UNIQUENESS_CHECK \\012------------------------------------------------------------------------------------\\012\\012CREATE OR REPLACE FUNCTION SAMPLE_CODE_UNIQUENESS_CHECK() RETURNS trigger AS $$\\012DECLARE\\012   counter  INTEGER;\\012BEGIN\\012\\011IF (NEW.samp_id_part_of is NULL) THEN\\012\\011\\011IF (NEW.dbin_id is not NULL) THEN\\012\\011\\011\\011SELECT count(*) into counter FROM samples \\012\\011\\011\\011\\011where id != NEW.id and code = NEW.code and samp_id_part_of is NULL and dbin_id = NEW.dbin_id;\\012\\011\\011\\011IF (counter > 0) THEN\\012\\011\\011\\011\\011RAISE EXCEPTION 'Insert/Update of Sample (Code: %) failed because database instance sample with the same code already exists.', NEW.code;\\012\\011\\011\\011END IF;\\012\\011\\011ELSIF (NEW.grou_id is not NULL) THEN\\012\\011\\011\\011SELECT count(*) into counter FROM samples \\012\\011\\011\\011\\011where id != NEW.id and code = NEW.code and samp_id_part_of is NULL and grou_id = NEW.grou_id;\\012\\011\\011\\011IF (counter > 0) THEN\\012\\011\\011\\011\\011RAISE EXCEPTION 'Insert/Update of Sample (Code: %) failed because group sample with the same code already exists.', NEW.code;\\012\\011\\011\\011END IF;\\012\\011\\011END IF;\\012        ELSE\\012\\011\\011IF (NEW.dbin_id is not NULL) THEN\\012\\011\\011\\011SELECT count(*) into counter FROM samples \\012\\011\\011\\011\\011where id != NEW.id and code = NEW.code and samp_id_part_of = NEW.samp_id_part_of and dbin_id = NEW.dbin_id;\\012\\011\\011\\011IF (counter > 0) THEN\\012\\011\\011\\011\\011RAISE EXCEPTION 'Insert/Update of Sample (Code: %) failed because database instance sample with the same code and being the part of the same parent already exists.', NEW.code;\\012\\011\\011\\011END IF;\\012\\011\\011ELSIF (NEW.grou_id is not NULL) THEN\\012\\011\\011\\011SELECT count(*) into counter FROM samples \\012\\011\\011\\011\\011where id != NEW.id and code = NEW.code and samp_id_part_of = NEW.samp_id_part_of and grou_id = NEW.grou_id;\\012\\011\\011\\011IF (counter > 0) THEN\\012\\011\\011\\011\\011RAISE EXCEPTION 'Insert/Update of Sample (Code: %) failed because group sample with the same code and being the part of the same parent already exists.', NEW.code;\\012\\011\\011\\011END IF;\\012\\011\\011END IF;\\012        END IF;   \\012   RETURN NEW;\\012END;\\012$$ LANGUAGE 'plpgsql';\\012\\012CREATE TRIGGER SAMPLE_CODE_UNIQUENESS_CHECK BEFORE INSERT OR UPDATE ON SAMPLES\\012    FOR EACH ROW EXECUTE PROCEDURE SAMPLE_CODE_UNIQUENESS_CHECK();\\012	\N
+./sourceTest/sql/postgresql/043/.svn/text-base/017=database_version_logs.tsv.svn-base:028	source/sql/postgresql/migration/migration-027-028.sql	SUCCESS	2008-11-18 13:24:17.508	-- Create EXPERIMENT_ATTACHMENT_CONTENTS.\\012CREATE TABLE EXPERIMENT_ATTACHMENT_CONTENTS (ID TECH_ID NOT NULL,VALUE FILE NOT NULL);\\012CREATE SEQUENCE EXPERIMENT_ATTACHMENT_CONTENT_ID_SEQ;\\012ALTER TABLE EXPERIMENT_ATTACHMENT_CONTENTS ADD CONSTRAINT EXAC_PK PRIMARY KEY(ID);\\012\\012-- Alter EXPERIMENT_ATTACHMENTS by adding the new column which has a NULL constraint.\\012-- The NOT NULL constraint is added later on.\\012ALTER TABLE EXPERIMENT_ATTACHMENTS ADD COLUMN EXAC_ID TECH_ID;\\012\\012-- Does the VALUE migration between EXPERIMENT_ATTACHMENTS to EXPERIMENT_ATTACHMENT_CONTENTS.\\012CREATE OR REPLACE FUNCTION move_exp_att_content() RETURNS integer AS $$\\012DECLARE\\012    rec RECORD;\\012    seq BIGINT;\\012BEGIN\\012  FOR rec IN SELECT id, value FROM EXPERIMENT_ATTACHMENTS LOOP\\012  \\011seq := nextval('EXPERIMENT_ATTACHMENT_CONTENT_ID_SEQ');\\012    INSERT INTO EXPERIMENT_ATTACHMENT_CONTENTS (id, value) VALUES (seq, rec.value);\\012    UPDATE EXPERIMENT_ATTACHMENTS SET exac_id = seq WHERE id = rec.id;\\012  END LOOP;\\012  RETURN 1;\\012END;\\012$$ LANGUAGE 'plpgsql';\\012\\012-- Call the function.\\012SELECT move_exp_att_content();\\012DROP FUNCTION move_exp_att_content();\\012\\012\\012-- Finish EXPERIMENT_ATTACHMENTS changes.\\012ALTER TABLE EXPERIMENT_ATTACHMENTS ADD CONSTRAINT EXAT_CONT_FK FOREIGN KEY (EXAC_ID) REFERENCES EXPERIMENT_ATTACHMENT_CONTENTS(ID);\\012ALTER TABLE EXPERIMENT_ATTACHMENTS DROP COLUMN VALUE;\\012ALTER TABLE EXPERIMENT_ATTACHMENTS ALTER COLUMN EXAC_ID SET NOT NULL;\\012	\N
+./sourceTest/sql/postgresql/043/.svn/text-base/017=database_version_logs.tsv.svn-base:029	source/sql/postgresql/migration/migration-028-029.sql	SUCCESS	2009-03-18 10:50:20.105	-- -------\\012-- add modification_timestamp field to allow edition with Hibernate\\012-- -------\\012\\012ALTER TABLE samples\\012\\011ADD COLUMN modification_timestamp TIME_STAMP DEFAULT CURRENT_TIMESTAMP;\\012\\012ALTER TABLE experiments\\012\\011ADD COLUMN modification_timestamp TIME_STAMP DEFAULT CURRENT_TIMESTAMP;\\012\\012ALTER TABLE materials\\012\\011ADD COLUMN modification_timestamp TIME_STAMP DEFAULT CURRENT_TIMESTAMP;\\012\\012ALTER TABLE experiment_properties\\012\\011ADD COLUMN modification_timestamp TIME_STAMP DEFAULT CURRENT_TIMESTAMP;\\012\\012ALTER TABLE material_properties\\012\\011ADD COLUMN modification_timestamp TIME_STAMP DEFAULT CURRENT_TIMESTAMP;\\012\\012ALTER TABLE sample_properties\\012\\011ADD COLUMN modification_timestamp TIME_STAMP DEFAULT CURRENT_TIMESTAMP;\\012\\012-- -------\\012-- add property data type which references materials\\012-- -------\\012\\012ALTER TABLE property_types\\012\\011ADD COLUMN maty_prop_id tech_id;\\012\\012ALTER TABLE property_types\\012\\011ADD CONSTRAINT prty_maty_fk FOREIGN KEY (maty_prop_id) REFERENCES material_types(id);\\012\\012ALTER TABLE experiment_properties\\012\\011ADD COLUMN mate_prop_id tech_id;\\012\\012ALTER TABLE material_properties\\012\\011ADD COLUMN mate_prop_id tech_id;\\012\\012ALTER TABLE sample_properties\\012\\011ADD COLUMN mate_prop_id tech_id;\\012\\012ALTER TABLE experiment_properties\\012\\011ADD CONSTRAINT expr_mapr_fk FOREIGN KEY (mate_prop_id) REFERENCES materials(id);\\012\\012ALTER TABLE material_properties\\012\\011ADD CONSTRAINT mapr_mapr_fk FOREIGN KEY (mate_prop_id) REFERENCES materials(id);\\012\\012ALTER TABLE sample_properties\\012\\011ADD CONSTRAINT sapr_mapr_fk FOREIGN KEY (mate_prop_id) REFERENCES materials(id);\\012\\012insert into data_types\\012(id\\012 ,code\\012 ,description)\\012 values \\012 (nextval('DATA_TYPE_ID_SEQ')\\012 ,'MATERIAL'\\012 ,'Reference to a material'\\012);\\012\\012ALTER TABLE MATERIAL_PROPERTIES DROP CONSTRAINT MAPR_CK;\\012ALTER TABLE MATERIAL_PROPERTIES ADD CONSTRAINT MAPR_CK CHECK \\012\\011((VALUE IS NOT NULL AND CVTE_ID IS NULL AND MATE_PROP_ID IS NULL) OR \\012\\011 (VALUE IS NULL AND CVTE_ID IS NOT NULL AND MATE_PROP_ID IS NULL) OR\\012\\011 (VALUE IS NULL AND CVTE_ID IS NULL AND MATE_PROP_ID IS NOT NULL)\\012\\011);\\012\\012ALTER TABLE EXPERIMENT_PROPERTIES DROP CONSTRAINT EXPR_CK;\\012ALTER TABLE EXPERIMENT_PROPERTIES ADD CONSTRAINT EXPR_CK CHECK \\012\\011((VALUE IS NOT NULL AND CVTE_ID IS NULL AND MATE_PROP_ID IS NULL) OR \\012\\011 (VALUE IS NULL AND CVTE_ID IS NOT NULL AND MATE_PROP_ID IS NULL) OR\\012\\011 (VALUE IS NULL AND CVTE_ID IS NULL AND MATE_PROP_ID IS NOT NULL)\\012\\011);\\012\\012ALTER TABLE SAMPLE_PROPERTIES DROP CONSTRAINT SAPR_CK;\\012ALTER TABLE SAMPLE_PROPERTIES ADD CONSTRAINT SAPR_CK CHECK \\012\\011((VALUE IS NOT NULL AND CVTE_ID IS NULL AND MATE_PROP_ID IS NULL) OR \\012\\011 (VALUE IS NULL AND CVTE_ID IS NOT NULL AND MATE_PROP_ID IS NULL) OR\\012\\011 (VALUE IS NULL AND CVTE_ID IS NULL AND MATE_PROP_ID IS NOT NULL)\\012\\011);\\012\\012------------------------------------------------------------------------------------\\012--  Purpose:  Create trigger MATERIAL/SAMPLE/EXPERIMENT _PROPERTY_WITH_MATERIAL_DATA_TYPE_CHECK\\012--            It checks that if material property value is assigned to the entity,\\012--\\011\\011\\011\\011\\011\\011then the material type is equal to the one described by property type.\\012------------------------------------------------------------------------------------\\012\\012CREATE OR REPLACE FUNCTION MATERIAL_PROPERTY_WITH_MATERIAL_DATA_TYPE_CHECK() RETURNS trigger AS $$\\012DECLARE\\012   v_type_id  CODE;\\012   v_type_id_prop  CODE;\\012BEGIN\\012   if NEW.mate_prop_id IS NOT NULL then\\012\\011\\011\\011-- find material type id of the property type \\012\\011\\011\\011select pt.maty_prop_id into v_type_id_prop \\012\\011\\011\\011  from material_type_property_types etpt, property_types pt \\012\\011\\011\\011 where NEW.mtpt_id = etpt.id AND etpt.prty_id = pt.id;\\012\\011\\011\\012\\011\\011\\011if v_type_id_prop IS NOT NULL then\\012\\011\\011\\011\\011-- find material type id of the material which consists the entity's property value\\012\\011\\011\\011\\011select entity.maty_id into v_type_id \\012\\011\\011\\011\\011  from materials entity\\012\\011\\011\\011\\011 where NEW.mate_prop_id = entity.id;\\012\\011\\011\\011\\011if v_type_id != v_type_id_prop then\\012\\011\\011\\011\\011\\011RAISE EXCEPTION 'Insert/Update of property value referencing material (id: %) failed, as referenced material type is different than expected (id %, expected id: %).', \\012\\011\\011\\011\\011\\011\\011\\011 NEW.mate_prop_id, v_type_id, v_type_id_prop;\\012\\011\\011\\011\\011end if;\\012\\011\\011\\011end if;\\012   end if;\\012   RETURN NEW;\\012END;\\012$$ LANGUAGE 'plpgsql';\\012\\012CREATE TRIGGER MATERIAL_PROPERTY_WITH_MATERIAL_DATA_TYPE_CHECK BEFORE INSERT OR UPDATE ON material_properties\\012    FOR EACH ROW EXECUTE PROCEDURE MATERIAL_PROPERTY_WITH_MATERIAL_DATA_TYPE_CHECK();\\012    \\012CREATE OR REPLACE FUNCTION SAMPLE_PROPERTY_WITH_MATERIAL_DATA_TYPE_CHECK() RETURNS trigger AS $$\\012DECLARE\\012   v_type_id  CODE;\\012   v_type_id_prop  CODE;\\012BEGIN\\012   if NEW.mate_prop_id IS NOT NULL then\\012\\011\\011\\011-- find material type id of the property type \\012\\011\\011\\011select pt.maty_prop_id into v_type_id_prop \\012\\011\\011\\011  from sample_type_property_types etpt, property_types pt \\012\\011\\011\\011 where NEW.stpt_id = etpt.id AND etpt.prty_id = pt.id;\\012\\011\\011\\012\\011\\011\\011if v_type_id_prop IS NOT NULL then\\012\\011\\011\\011\\011-- find material type id of the material which consists the entity's property value\\012\\011\\011\\011\\011select entity.maty_id into v_type_id \\012\\011\\011\\011\\011  from materials entity\\012\\011\\011\\011\\011 where NEW.mate_prop_id = entity.id;\\012\\011\\011\\011\\011if v_type_id != v_type_id_prop then\\012\\011\\011\\011\\011\\011RAISE EXCEPTION 'Insert/Update of property value referencing material (id: %) failed, as referenced material type is different than expected (id %, expected id: %).', \\012\\011\\011\\011\\011\\011\\011\\011\\011\\011\\011\\011\\011 NEW.mate_prop_id, v_type_id, v_type_id_prop;\\012\\011\\011\\011\\011end if;\\012\\011\\011\\011end if;\\012   end if;\\012   RETURN NEW;\\012END;\\012$$ LANGUAGE 'plpgsql';\\012\\012CREATE TRIGGER SAMPLE_PROPERTY_WITH_MATERIAL_DATA_TYPE_CHECK BEFORE INSERT OR UPDATE ON sample_properties\\012    FOR EACH ROW EXECUTE PROCEDURE SAMPLE_PROPERTY_WITH_MATERIAL_DATA_TYPE_CHECK();\\012    \\012CREATE OR REPLACE FUNCTION EXPERIMENT_PROPERTY_WITH_MATERIAL_DATA_TYPE_CHECK() RETURNS trigger AS $$\\012DECLARE\\012   v_type_id  CODE;\\012   v_type_id_prop  CODE;\\012BEGIN\\012   if NEW.mate_prop_id IS NOT NULL then\\012\\011\\011\\011-- find material type id of the property type \\012\\011\\011\\011select pt.maty_prop_id into v_type_id_prop \\012\\011\\011\\011  from experiment_type_property_types etpt, property_types pt \\012\\011\\011\\011 where NEW.etpt_id = etpt.id AND etpt.prty_id = pt.id;\\012\\011\\011\\012\\011\\011\\011if v_type_id_prop IS NOT NULL then\\012\\011\\011\\011\\011-- find material type id of the material which consists the entity's property value\\012\\011\\011\\011\\011select entity.maty_id into v_type_id \\012\\011\\011\\011\\011  from materials entity\\012\\011\\011\\011\\011 where NEW.mate_prop_id = entity.id;\\012\\011\\011\\011\\011if v_type_id != v_type_id_prop then\\012\\011\\011\\011\\011\\011RAISE EXCEPTION 'Insert/Update of property value referencing material (id: %) failed, as referenced material type is different than expected (id %, expected id: %).', \\012\\011\\011\\011\\011\\011\\011\\011\\011\\011\\011\\011\\011 NEW.mate_prop_id, v_type_id, v_type_id_prop;\\012\\011\\011\\011\\011end if;\\012\\011\\011\\011end if;\\012   end if;\\012   RETURN NEW;\\012END;\\012$$ LANGUAGE 'plpgsql';\\012\\012CREATE TRIGGER EXPERIMENT_PROPERTY_WITH_MATERIAL_DATA_TYPE_CHECK BEFORE INSERT OR UPDATE ON experiment_properties\\012    FOR EACH ROW EXECUTE PROCEDURE EXPERIMENT_PROPERTY_WITH_MATERIAL_DATA_TYPE_CHECK();\\012       \\012-- -------\\012-- remove the reminescents of the OBSERVABLE_TYPE\\012-- -------\\012\\012ALTER TABLE data\\012\\011DROP CONSTRAINT data_obty_fk;\\012\\012ALTER TABLE data_set_types\\012\\011DROP CONSTRAINT obty_pk;\\012\\012ALTER TABLE data_set_types\\012\\011ADD CONSTRAINT dsty_pk PRIMARY KEY (id);\\012\\012ALTER TABLE data\\012\\011ADD CONSTRAINT data_dsty_fk FOREIGN KEY (dsty_id) REFERENCES data_set_types(id);\\012\\012ALTER TABLE data_set_types\\012\\011DROP CONSTRAINT obty_bk_uk;\\012\\012ALTER TABLE data_set_types\\012\\011DROP CONSTRAINT obty_dbin_fk;\\012\\012ALTER TABLE data_set_types\\012\\011ADD CONSTRAINT dsty_bk_uk UNIQUE (code, dbin_id);\\012\\012ALTER TABLE data_set_types\\012\\011ADD CONSTRAINT dsty_dbin_fk FOREIGN KEY (dbin_id) REFERENCES database_instances(id);\\012\\012DROP INDEX data_obty_fk_i;\\012\\012CREATE INDEX data_dsty_fk_i ON data(dsty_id);\\012	\N
+./sourceTest/sql/postgresql/043/.svn/text-base/017=database_version_logs.tsv.svn-base:030	source/sql/postgresql/migration/migration-029-030.sql	SUCCESS	2009-03-23 15:34:44.72	-- -------\\012-- add modification_timestamp field to allow edition with Hibernate\\012-- -------\\012ALTER TABLE data\\012\\011ADD COLUMN modification_timestamp TIME_STAMP DEFAULT CURRENT_TIMESTAMP;\\012ALTER TABLE experiment_types\\012\\011ADD COLUMN modification_timestamp TIME_STAMP DEFAULT CURRENT_TIMESTAMP;\\012ALTER TABLE sample_types\\012\\011ADD COLUMN modification_timestamp TIME_STAMP DEFAULT CURRENT_TIMESTAMP;\\012ALTER TABLE material_types\\012\\011ADD COLUMN modification_timestamp TIME_STAMP DEFAULT CURRENT_TIMESTAMP;\\012ALTER TABLE data_set_types\\012\\011ADD COLUMN modification_timestamp TIME_STAMP DEFAULT CURRENT_TIMESTAMP;\\012ALTER TABLE controlled_vocabularies\\012\\011ADD COLUMN modification_timestamp TIME_STAMP DEFAULT CURRENT_TIMESTAMP;\\012-- -------\\012-- add properties to data sets\\012-- -------\\012CREATE TABLE DATA_SET_PROPERTIES (ID TECH_ID NOT NULL,DS_ID TECH_ID NOT NULL,DSTPT_ID TECH_ID NOT NULL,VALUE GENERIC_VALUE,CVTE_ID TECH_ID, MATE_PROP_ID TECH_ID, PERS_ID_REGISTERER TECH_ID NOT NULL,REGISTRATION_TIMESTAMP TIME_STAMP_DFL NOT NULL DEFAULT CURRENT_TIMESTAMP, MODIFICATION_TIMESTAMP TIME_STAMP DEFAULT CURRENT_TIMESTAMP);\\012CREATE TABLE DATA_SET_TYPE_PROPERTY_TYPES (ID TECH_ID NOT NULL,DSTY_ID TECH_ID NOT NULL,PRTY_ID TECH_ID NOT NULL,IS_MANDATORY BOOLEAN_CHAR NOT NULL DEFAULT 'F',IS_MANAGED_INTERNALLY BOOLEAN_CHAR NOT NULL DEFAULT 'F',PERS_ID_REGISTERER TECH_ID NOT NULL,REGISTRATION_TIMESTAMP TIME_STAMP_DFL NOT NULL DEFAULT CURRENT_TIMESTAMP);\\012\\012CREATE SEQUENCE DATA_SET_PROPERTY_ID_SEQ;\\012CREATE SEQUENCE DSTPT_ID_SEQ;\\012\\012ALTER TABLE DATA_SET_TYPE_PROPERTY_TYPES ADD CONSTRAINT DSTPT_PK PRIMARY KEY(ID);\\012ALTER TABLE DATA_SET_PROPERTIES ADD CONSTRAINT DSPR_PK PRIMARY KEY(ID);\\012\\012ALTER TABLE DATA_SET_TYPE_PROPERTY_TYPES ADD CONSTRAINT DSTPT_BK_UK UNIQUE(DSTY_ID,PRTY_ID);\\012ALTER TABLE DATA_SET_PROPERTIES ADD CONSTRAINT DSPR_BK_UK UNIQUE(DS_ID,DSTPT_ID);\\012\\012\\012ALTER TABLE DATA_SET_TYPE_PROPERTY_TYPES ADD CONSTRAINT DSTPT_DSTY_FK FOREIGN KEY (DSTY_ID) REFERENCES DATA_SET_TYPES(ID);\\012ALTER TABLE DATA_SET_TYPE_PROPERTY_TYPES ADD CONSTRAINT DSTPT_PERS_FK FOREIGN KEY (PERS_ID_REGISTERER) REFERENCES PERSONS(ID);\\012ALTER TABLE DATA_SET_TYPE_PROPERTY_TYPES ADD CONSTRAINT DSTPT_PRTY_FK FOREIGN KEY (PRTY_ID) REFERENCES PROPERTY_TYPES(ID);\\012ALTER TABLE DATA_SET_PROPERTIES ADD CONSTRAINT DSPR_CVTE_FK FOREIGN KEY (CVTE_ID) REFERENCES CONTROLLED_VOCABULARY_TERMS(ID);\\012ALTER TABLE DATA_SET_PROPERTIES ADD CONSTRAINT DSPR_DSTPT_FK FOREIGN KEY (DSTPT_ID) REFERENCES DATA_SET_TYPE_PROPERTY_TYPES(ID) ON DELETE CASCADE;\\012ALTER TABLE DATA_SET_PROPERTIES ADD CONSTRAINT DSPR_DS_FK FOREIGN KEY (DS_ID) REFERENCES DATA(ID);\\012ALTER TABLE DATA_SET_PROPERTIES ADD CONSTRAINT DSPR_PERS_FK FOREIGN KEY (PERS_ID_REGISTERER) REFERENCES PERSONS(ID);\\012ALTER TABLE DATA_SET_PROPERTIES ADD CONSTRAINT DSPR_MAPR_FK FOREIGN KEY (MATE_PROP_ID) REFERENCES MATERIALS(ID);\\012\\012ALTER TABLE DATA_SET_PROPERTIES ADD CONSTRAINT DSPR_CK CHECK \\012\\011((VALUE IS NOT NULL AND CVTE_ID IS NULL AND MATE_PROP_ID IS NULL) OR \\012\\011 (VALUE IS NULL AND CVTE_ID IS NOT NULL AND MATE_PROP_ID IS NULL) OR\\012\\011 (VALUE IS NULL AND CVTE_ID IS NULL AND MATE_PROP_ID IS NOT NULL)\\012\\011);\\012\\012CREATE INDEX DSPR_CVTE_FK_I ON DATA_SET_PROPERTIES (CVTE_ID);\\012CREATE INDEX DSPR_DSTPT_FK_I ON DATA_SET_PROPERTIES (DSTPT_ID);\\012CREATE INDEX DSPR_DS_FK_I ON DATA_SET_PROPERTIES (DS_ID);\\012CREATE INDEX DSPR_PERS_FK_I ON DATA_SET_PROPERTIES (PERS_ID_REGISTERER);\\012CREATE INDEX DSTPT_DSTY_FK_I ON DATA_SET_TYPE_PROPERTY_TYPES (DSTY_ID);\\012CREATE INDEX DSTPT_PERS_FK_I ON DATA_SET_TYPE_PROPERTY_TYPES (PERS_ID_REGISTERER);\\012CREATE INDEX DSTPT_PRTY_FK_I ON DATA_SET_TYPE_PROPERTY_TYPES (PRTY_ID);\\012\\012CREATE OR REPLACE FUNCTION DATA_SET_PROPERTY_WITH_MATERIAL_DATA_TYPE_CHECK() RETURNS trigger AS $$\\012DECLARE\\012   v_type_id  CODE;\\012   v_type_id_prop  CODE;\\012BEGIN\\012   if NEW.mate_prop_id IS NOT NULL then\\012\\011\\011\\011-- find material type id of the property type \\012\\011\\011\\011select pt.maty_prop_id into v_type_id_prop \\012\\011\\011\\011  from data_set_type_property_types dstpt, property_types pt \\012\\011\\011\\011 where NEW.dstpt_id = dstpt.id AND dstpt.prty_id = pt.id;\\012\\011\\011\\012\\011\\011\\011if v_type_id_prop IS NOT NULL then\\012\\011\\011\\011\\011-- find material type id of the material which consists the entity's property value\\012\\011\\011\\011\\011select entity.maty_id into v_type_id \\012\\011\\011\\011\\011  from materials entity\\012\\011\\011\\011\\011 where NEW.mate_prop_id = entity.id;\\012\\011\\011\\011\\011if v_type_id != v_type_id_prop then\\012\\011\\011\\011\\011\\011RAISE EXCEPTION 'Insert/Update of property value referencing material (id: %) failed, as referenced material type is different than expected (id %, expected id: %).', \\012\\011\\011\\011\\011\\011\\011\\011\\011\\011\\011\\011\\011 NEW.mate_prop_id, v_type_id, v_type_id_prop;\\012\\011\\011\\011\\011end if;\\012\\011\\011\\011end if;\\012   end if;\\012   RETURN NEW;\\012END;\\012$$ LANGUAGE 'plpgsql';\\012\\012CREATE TRIGGER DATA_SET_PROPERTY_WITH_MATERIAL_DATA_TYPE_CHECK BEFORE INSERT OR UPDATE ON data_set_properties\\012    FOR EACH ROW EXECUTE PROCEDURE DATA_SET_PROPERTY_WITH_MATERIAL_DATA_TYPE_CHECK();   \\012	\N
+./sourceTest/sql/postgresql/043/.svn/text-base/017=database_version_logs.tsv.svn-base:032	source/sql/postgresql/migration/migration-031-032.sql	SUCCESS	2009-04-09 09:36:36.20	-- -------\\012-- Modify MATERIAL_BATCHES\\012-- -------\\012\\012ALTER TABLE material_batches\\012    DROP COLUMN proc_id;\\012\\012-- -------\\012-- Modify SAMPLES\\012-- -------\\012\\012ALTER TABLE samples\\012    ADD COLUMN expe_id tech_id;\\012\\012ALTER TABLE samples\\012    ADD CONSTRAINT samp_expe_fk FOREIGN KEY (expe_id) REFERENCES experiments(id);\\012\\012CREATE INDEX samp_expe_fk_i ON samples USING btree (expe_id);\\012\\012-- relink samples directly to experiments\\012\\012UPDATE samples\\012SET expe_id = (SELECT e.id FROM experiments e, procedures p, sample_inputs si \\012               WHERE si.samp_id = samples.id AND si.proc_id = p.id AND p.expe_id = e.id AND e.inva_id IS NULL);\\012\\012\\012-- -------\\012-- Modify DATA\\012-- -------\\012\\012ALTER TABLE data\\012    ADD COLUMN expe_id tech_id;\\012\\012ALTER TABLE data\\012    ADD CONSTRAINT data_expe_fk FOREIGN KEY (expe_id) REFERENCES experiments(id);\\012\\012CREATE INDEX data_expe_fk_i ON data USING btree (expe_id);\\012\\012UPDATE data\\012SET expe_id = (SELECT e.id FROM experiments e, procedures p \\012               WHERE data.proc_id_produced_by = p.id AND p.expe_id = e.id);\\012\\012ALTER TABLE data\\012    ALTER COLUMN expe_id SET NOT NULL;\\012\\012ALTER TABLE data\\012    DROP COLUMN proc_id_produced_by;\\012\\012-- -------\\012-- Drop PROCEDURES, PROCEDURE_TYPES, and SAMPLE_INPUTS\\012-- -------\\012\\012DROP TABLE sample_inputs;\\012DROP TABLE procedures;\\012DROP TABLE procedure_types;\\012\\012DROP SEQUENCE procedure_id_seq;\\012DROP SEQUENCE procedure_type_id_seq;\\012\\012-- -------\\012-- Add CODE_SEQ\\012-- -------\\012\\012CREATE SEQUENCE CODE_SEQ;\\012\\012-- -------\\012-- Add new columns to DATA_STORES\\012-- -------\\012\\012ALTER TABLE data_stores\\012    ADD COLUMN remote_url character varying(250),\\012    ADD COLUMN session_token character varying(50),\\012    ADD COLUMN modification_timestamp time_stamp DEFAULT now();\\012\\012UPDATE data_stores\\012SET remote_url = '', session_token='';\\012\\012ALTER TABLE data_stores\\012    ALTER COLUMN remote_url SET NOT NULL,\\012    ALTER COLUMN session_token SET NOT NULL;\\012\\012-- -------\\012-- Drop foreign keys onto DATA_STORES\\012-- -------\\012\\012ALTER TABLE database_instances\\012    DROP COLUMN dast_id;\\012\\012ALTER TABLE groups\\012    DROP COLUMN dast_id;\\012\\012ALTER TABLE projects\\012    DROP COLUMN dast_id;\\012\\012ALTER TABLE experiments\\012    DROP COLUMN dast_id;\\012\\012-- -------\\012-- Add foreign key from DATA onto DATA_STORES\\012-- -------\\012\\012ALTER TABLE data\\012    ADD COLUMN dast_id tech_id;\\012\\012ALTER TABLE data\\012    ADD CONSTRAINT data_dast_fk FOREIGN KEY (dast_id) REFERENCES data_stores(id);\\012\\012UPDATE data\\012SET dast_id = (select id from data_stores where code = 'STANDARD');\\012\\012ALTER TABLE data\\012    ALTER COLUMN dast_id SET NOT NULL;\\012\\012\\012------------------------------------------------------------------------------------\\012--  Purpose:  Replace trigger SAMPLE_CODE_UNIQUENESS_CHECK \\012------------------------------------------------------------------------------------\\012\\012CREATE OR REPLACE FUNCTION SAMPLE_CODE_UNIQUENESS_CHECK() RETURNS trigger AS $$\\012DECLARE\\012   counter  INTEGER;\\012BEGIN\\012    LOCK TABLE samples IN EXCLUSIVE MODE;\\012    IF (NEW.samp_id_part_of is NULL) THEN\\012        IF (NEW.dbin_id is not NULL) THEN\\012            SELECT count(*) into counter FROM samples \\012                where id != NEW.id and code = NEW.code and samp_id_part_of is NULL and dbin_id = NEW.dbin_id;\\012            IF (counter > 0) THEN\\012                RAISE EXCEPTION 'Insert/Update of Sample (Code: %) failed because database instance sample with the same code already exists.', NEW.code;\\012            END IF;\\012        ELSIF (NEW.grou_id is not NULL) THEN\\012            SELECT count(*) into counter FROM samples \\012                where id != NEW.id and code = NEW.code and samp_id_part_of is NULL and grou_id = NEW.grou_id;\\012            IF (counter > 0) THEN\\012                RAISE EXCEPTION 'Insert/Update of Sample (Code: %) failed because group sample with the same code already exists.', NEW.code;\\012            END IF;\\012        END IF;\\012        ELSE\\012        IF (NEW.dbin_id is not NULL) THEN\\012            SELECT count(*) into counter FROM samples \\012                where id != NEW.id and code = NEW.code and samp_id_part_of = NEW.samp_id_part_of and dbin_id = NEW.dbin_id;\\012            IF (counter > 0) THEN\\012                RAISE EXCEPTION 'Insert/Update of Sample (Code: %) failed because database instance sample with the same code and being the part of the same parent already exists.', NEW.code;\\012            END IF;\\012        ELSIF (NEW.grou_id is not NULL) THEN\\012            SELECT count(*) into counter FROM samples \\012                where id != NEW.id and code = NEW.code and samp_id_part_of = NEW.samp_id_part_of and grou_id = NEW.grou_id;\\012            IF (counter > 0) THEN\\012                RAISE EXCEPTION 'Insert/Update of Sample (Code: %) failed because group sample with the same code and being the part of the same parent already exists.', NEW.code;\\012            END IF;\\012        END IF;\\012        END IF;   \\012   RETURN NEW;\\012END;\\012$$ LANGUAGE 'plpgsql';\\012\\012\\012\\012	\N
+./sourceTest/sql/postgresql/043/.svn/text-base/017=database_version_logs.tsv.svn-base:034	source/sql/postgresql/migration/migration-033-034.sql	SUCCESS	2009-05-26 08:32:49.935	------------------------------------------------------------------------------------\\012-- Create sequence for generating permanent identifiers starting with nextval of existing dataset sequence.\\012------------------------------------------------------------------------------------\\012CREATE FUNCTION CREATE_SEQUENCE(EXISTING_SEQUENCE VARCHAR, NEW_SEQUENCE VARCHAR) RETURNS VOID AS $$\\012DECLARE\\012  CURR_SEQ_VAL   INTEGER;\\012BEGIN\\012  SELECT INTO CURR_SEQ_VAL NEXTVAL(EXISTING_SEQUENCE);\\012  EXECUTE 'CREATE SEQUENCE ' || NEW_SEQUENCE || ' START WITH ' || CURR_SEQ_VAL;\\012  RETURN;\\012END;\\012$$ LANGUAGE 'plpgsql';\\012\\012SELECT CREATE_SEQUENCE('DATA_ID_SEQ', 'PERM_ID_SEQ');\\012DROP FUNCTION CREATE_SEQUENCE(VARCHAR, VARCHAR);\\012\\012------------------------------------------------------------------------------------\\012-- Add perm_id columns to samples and experiments.\\012------------------------------------------------------------------------------------\\012ALTER TABLE SAMPLES ADD COLUMN PERM_ID CODE;\\012ALTER TABLE EXPERIMENTS ADD COLUMN PERM_ID CODE;\\012\\012UPDATE SAMPLES SET PERM_ID = to_char(registration_timestamp,'YYYYMMDDHHSSMS') || '-' || NEXTVAL('PERM_ID_SEQ');\\012UPDATE EXPERIMENTS SET PERM_ID = to_char(registration_timestamp,'YYYYMMDDHHSSMS') || '-' || NEXTVAL('PERM_ID_SEQ');\\012ALTER TABLE SAMPLES ALTER COLUMN PERM_ID SET NOT NULL;\\012ALTER TABLE EXPERIMENTS ALTER COLUMN PERM_ID SET NOT NULL;\\012ALTER TABLE SAMPLES ADD CONSTRAINT SAMP_PI_UK UNIQUE(PERM_ID);\\012ALTER TABLE EXPERIMENTS ADD CONSTRAINT EXPE_PI_UK UNIQUE(PERM_ID);\\012\\012\\012------------------------------------------------------------------------------------\\012-- Add column is_chosen_from_list to controlled_vocabularies.\\012------------------------------------------------------------------------------------\\012ALTER TABLE controlled_vocabularies ADD COLUMN is_chosen_from_list BOOLEAN_CHAR NOT NULL DEFAULT TRUE;\\012ALTER TABLE controlled_vocabularies ADD COLUMN source_uri CHARACTER VARYING(250);\\012------------------------------------------------------------------------------------\\012-- Modify Data table - remove arc connection between Sample and Data table, use a flag instead\\012------------------------------------------------------------------------------------\\012\\012-- add new columns\\012\\012ALTER TABLE data\\012    ADD COLUMN is_derived boolean_char;\\012ALTER TABLE data\\012    ADD COLUMN samp_id tech_id;\\012\\012-- update values in new columns\\012\\012UPDATE data\\012    SET is_derived = (samp_id_derived_from IS NOT NULL); \\012UPDATE data\\012    SET samp_id = samp_id_derived_from \\012    WHERE is_derived = 'TRUE';\\012UPDATE data\\012    SET samp_id = samp_id_acquired_from \\012    WHERE is_derived = 'FALSE';\\012\\012-- add constraints and indexes to new columns\\012\\012ALTER TABLE data\\012    ALTER COLUMN is_derived SET NOT NULL;\\012ALTER TABLE data\\012    ALTER COLUMN samp_id SET NOT NULL;   \\012ALTER TABLE data\\012    ADD CONSTRAINT data_samp_fk FOREIGN KEY (samp_id) REFERENCES samples (id);\\012CREATE INDEX data_samp_fk_i ON data USING btree (samp_id);\\012\\012-- remove old columns\\012\\012ALTER TABLE data\\012    DROP COLUMN samp_id_acquired_from;\\012ALTER TABLE data\\012    DROP COLUMN samp_id_derived_from;\\012    \\012------------------------------------------------------------------------------------\\012-- Granting SELECT privilege to group openbis_readonly\\012------------------------------------------------------------------------------------\\012\\012GRANT SELECT ON SEQUENCE attachment_content_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE attachment_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE code_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE controlled_vocabulary_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE cvte_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE data_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE data_set_property_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE data_set_relationship_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE data_set_type_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE data_store_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE data_type_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE database_instance_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE dstpt_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE etpt_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE event_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE experiment_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE experiment_property_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE experiment_type_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE file_format_type_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE group_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE invalidation_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE locator_type_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE material_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE material_property_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE material_type_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE mtpt_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE perm_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE person_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE project_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE property_type_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE role_assignment_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE sample_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE sample_property_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE sample_type_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE stpt_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE attachment_contents TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE attachments TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE controlled_vocabularies TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE controlled_vocabulary_terms TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE data TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE data_set_properties TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE data_set_relationships TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE data_set_type_property_types TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE data_set_types TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE data_stores TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE data_types TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE database_instances TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE database_version_logs TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE events TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE experiment_properties TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE experiment_type_property_types TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE experiment_types TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE experiments TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE external_data TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE file_format_types TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE groups TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE invalidations TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE locator_types TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE material_properties TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE material_type_property_types TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE material_types TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE materials TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE persons TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE projects TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE property_types TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE role_assignments TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE sample_properties TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE sample_type_property_types TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE sample_types TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE samples TO GROUP OPENBIS_READONLY;\\012\\012------------------------------------------------------------------------------------\\012-- Delete MATERIAL_BATCHES table\\012------------------------------------------------------------------------------------\\012\\012-- WARNING: Potential data lost!!!\\012-- WARNING: Potential data lost!!!\\012-- WARNING: Potential data lost!!!\\012\\012DROP TABLE SAMPLE_MATERIAL_BATCHES;\\012DROP TABLE MATERIAL_BATCHES;\\012DROP SEQUENCE MATERIAL_BATCH_ID_SEQ;\\012\\012------------------------------------------------------------------------------------\\012-- Delete MATE_ID_INHIBITOR_OF from table MATERIALS\\012------------------------------------------------------------------------------------\\012\\012-- WARNING: Potential data lost!!!\\012-- WARNING: Potential data lost!!!\\012-- WARNING: Potential data lost!!!\\012\\012ALTER TABLE MATERIALS DROP COLUMN MATE_ID_INHIBITOR_OF;\\012	\N
+./sourceTest/sql/postgresql/043/.svn/text-base/017=database_version_logs.tsv.svn-base:041	source/sql/postgresql/migration/migration-040-041.sql	SUCCESS	2009-09-14 13:48:57.539	-- Create FILTERS table\\012\\012CREATE TABLE FILTERS (ID TECH_ID NOT NULL, DBIN_ID TECH_ID NOT NULL, NAME VARCHAR(200) NOT NULL, DESCRIPTION DESCRIPTION_1000,REGISTRATION_TIMESTAMP TIME_STAMP_DFL NOT NULL DEFAULT CURRENT_TIMESTAMP, PERS_ID_REGISTERER TECH_ID NOT NULL, MODIFICATION_TIMESTAMP TIME_STAMP DEFAULT CURRENT_TIMESTAMP, EXPRESSION VARCHAR(2000) NOT NULL, IS_PUBLIC BOOLEAN NOT NULL, GRID_ID VARCHAR(200) NOT NULL);\\012CREATE SEQUENCE FILTER_ID_SEQ;\\012ALTER TABLE FILTERS ADD CONSTRAINT FILT_PK PRIMARY KEY(ID);\\012ALTER TABLE FILTERS ADD CONSTRAINT FILT_BK_UK UNIQUE(NAME, DBIN_ID, GRID_ID);\\012ALTER TABLE FILTERS ADD CONSTRAINT FILT_PERS_FK FOREIGN KEY (PERS_ID_REGISTERER) REFERENCES PERSONS(ID);\\012ALTER TABLE FILTERS ADD CONSTRAINT FILT_DBIN_FK FOREIGN KEY (DBIN_ID) REFERENCES DATABASE_INSTANCES(ID);\\012CREATE INDEX FILT_PERS_FK_I ON FILTERS (PERS_ID_REGISTERER);\\012CREATE INDEX FILT_DBIN_FK_I ON FILTERS (DBIN_ID);\\012GRANT SELECT ON SEQUENCE filter_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE filters TO GROUP OPENBIS_READONLY;\\012\\012-- Add missing foreign key to role assignments authorization group\\012ALTER TABLE ROLE_ASSIGNMENTS ADD CONSTRAINT ROAS_AG_FK_GRANTEE FOREIGN KEY (AG_ID_GRANTEE) REFERENCES AUTHORIZATION_GROUPS(ID);\\012\\012--------------------------------------------------------------------------------------------------\\012-- Modify dataset connections:\\012-- 1. connection with sample shouldn't be mandatory any more\\012-- 2. introduce an arc condition that dataset cannot be connected with a sample and a parent dataset at the same time\\012--------------------------------------------------------------------------------------------------\\012\\012-- Weaken data-sample connection constraint - allow dataset to have no connection with sample\\012ALTER TABLE data ALTER COLUMN samp_id DROP NOT NULL;\\012\\012-- Remove data-sample connection for datasets that have a parent\\012\\012UPDATE data \\012   SET samp_id = NULL \\012 WHERE id IN (SELECT DISTINCT data_id_child FROM data_set_relationships);\\012\\012-- With PostgreSQL 8.4 one can check that before migration there were no cycles in dataset relationships:\\012--\\012-- WITH RECURSIVE data_set_parents(id, parent_ids, cycle) AS (\\012--         SELECT  r.data_id_child AS id, \\012--                 ARRAY[CAST (r.data_id_parent AS bigint)] AS parent_ids, \\012--                 false AS cycle \\012--         FROM data_set_relationships r\\012--     UNION ALL\\012--         SELECT  r.data_id_child,\\012--                 CAST (r.data_id_parent AS bigint) || p.parent_ids,\\012--                 r.data_id_child = ANY(p.parent_ids)\\012--         FROM data_set_relationships r, data_set_parents p\\012--         WHERE r.data_id_parent = p.id AND NOT cycle\\012-- )\\012-- SELECT count(*) AS cycles FROM data_set_parents WHERE cycle = true;\\012\\012---------------------------------------------------------------------------------------------------\\012--  Purpose:  Create DEFERRED triggers:\\012--            * check_dataset_relationships_on_data_table_modification,\\012--            * check_dataset_relationships_on_relationships_table_modification.\\012--            They check that after all modifications of database (just before commit) \\012--            if 'data'/'data_set_relationships' tables are among modified tables \\012--            dataset is not connected with a sample and a parent dataset at the same time.\\012--            This connections are held in two different tables so simple immediate trigger \\012--            with arc check cannot be used and we need two deferred triggers.\\012----------------------------------------------------------------------------------------------------\\012\\012-- trigger for 'data' table\\012\\012CREATE OR REPLACE FUNCTION check_dataset_relationships_on_data_table_modification() RETURNS trigger AS $$\\012DECLARE\\012\\011counter\\011INTEGER;\\012BEGIN\\012\\011-- if there is a connection with a Sample there should not be any connection with a parent Data Set\\012\\011IF (NEW.samp_id IS NOT NULL) THEN\\012\\011\\011-- count number of parents\\012\\011\\011SELECT count(*) INTO counter \\012\\011\\011\\011FROM data_set_relationships \\012\\011\\011\\011WHERE data_id_child = OLD.id;\\012\\011\\011IF (counter > 0) THEN\\012\\011\\011\\011RAISE EXCEPTION 'Insert/Update of Data Set (Code: %) failed because it cannot be connected with a Sample and a parent Data Set at the same time.', OLD.code;\\012\\011\\011END IF;\\012\\011END IF;\\012  RETURN NEW;\\012END;\\012$$ LANGUAGE 'plpgsql';\\012\\012CREATE CONSTRAINT TRIGGER check_dataset_relationships_on_data_table_modification \\012  AFTER INSERT OR UPDATE ON data\\012\\011DEFERRABLE INITIALLY DEFERRED\\012\\011FOR EACH ROW \\012\\011EXECUTE PROCEDURE check_dataset_relationships_on_data_table_modification();\\012\\012-- trigger for 'data_set_relationships'\\012\\012CREATE OR REPLACE FUNCTION check_dataset_relationships_on_relationships_table_modification() RETURNS trigger AS $$\\012DECLARE\\012\\011counter\\011INTEGER;\\012\\011sample_id\\011TECH_ID;\\012\\011data_code\\011CODE;\\012BEGIN\\012\\011-- child will have a parent added so it should not be connected with any sample\\012\\011SELECT samp_id, code INTO sample_id, data_code \\012\\011\\011FROM data \\012\\011\\011WHERE id = NEW.data_id_child;\\012\\011IF (sample_id IS NOT NULL) THEN\\012\\011\\011RAISE EXCEPTION 'Insert/Update of Data Set (Code: %) failed because it cannot be connected to a Sample and to a parent Data Set at the same time.', data_code;\\012\\011END IF;\\012\\011RETURN NEW;\\012END;\\012$$ LANGUAGE 'plpgsql';\\012  \\012CREATE CONSTRAINT TRIGGER check_dataset_relationships_on_relationships_table_modification \\012  AFTER INSERT OR UPDATE ON data_set_relationships\\012\\011DEFERRABLE INITIALLY DEFERRED\\012\\011FOR EACH ROW \\012\\011EXECUTE PROCEDURE check_dataset_relationships_on_relationships_table_modification();\\012	\N
+./sourceTest/sql/postgresql/043/.svn/text-base/schema-043.sql.svn-base:    LANGUAGE plpgsql;
+./sourceTest/sql/postgresql/043/.svn/text-base/schema-043.sql.svn-base:    LANGUAGE plpgsql;
+./sourceTest/sql/postgresql/043/.svn/text-base/schema-043.sql.svn-base:    LANGUAGE plpgsql;
+./sourceTest/sql/postgresql/043/.svn/text-base/schema-043.sql.svn-base:    LANGUAGE plpgsql;
+./sourceTest/sql/postgresql/043/.svn/text-base/schema-043.sql.svn-base:    LANGUAGE plpgsql;
+./sourceTest/sql/postgresql/043/.svn/text-base/schema-043.sql.svn-base:    LANGUAGE plpgsql;
+./sourceTest/sql/postgresql/043/.svn/text-base/schema-043.sql.svn-base:    LANGUAGE plpgsql;
+./sourceTest/sql/postgresql/043/.svn/text-base/schema-043.sql.svn-base:    LANGUAGE plpgsql;
+./sourceTest/sql/postgresql/043/.svn/text-base/schema-043.sql.svn-base:    LANGUAGE plpgsql;
+./sourceTest/sql/postgresql/043/.svn/text-base/schema-043.sql.svn-base:    LANGUAGE plpgsql;
+./sourceTest/sql/postgresql/043/017=database_version_logs.tsv:027	D:\\User\\felmer\\dev-workspace\\openbis/source/sql/postgresql/027/function-027.sql	SUCCESS	2008-11-05 09:18:00.403	-- Creating Functions\\012\\012------------------------------------------------------------------------------------\\012--  Purpose:  Create function RENAME_SEQUENCE() that is required for renaming the sequences belonging to tables\\012------------------------------------------------------------------------------------\\012CREATE FUNCTION RENAME_SEQUENCE(OLD_NAME VARCHAR, NEW_NAME VARCHAR) RETURNS INTEGER AS $$\\012DECLARE\\012  CURR_SEQ_VAL   INTEGER;\\012BEGIN\\012  SELECT INTO CURR_SEQ_VAL NEXTVAL(OLD_NAME);\\012  EXECUTE 'CREATE SEQUENCE ' || NEW_NAME || ' START WITH ' || CURR_SEQ_VAL;\\012  EXECUTE 'DROP SEQUENCE ' || OLD_NAME;\\012  RETURN CURR_SEQ_VAL;\\012END;\\012$$ LANGUAGE 'plpgsql';\\012\\012\\012------------------------------------------------------------------------------------\\012--  Purpose:  Create trigger CONTROLLED_VOCABULARY_CHECK \\012------------------------------------------------------------------------------------\\012\\012CREATE OR REPLACE FUNCTION CONTROLLED_VOCABULARY_CHECK() RETURNS trigger AS $$\\012DECLARE\\012   v_code  CODE;\\012BEGIN\\012\\012   select code into v_code from data_types where id = NEW.daty_id;\\012\\012   -- Check if the data is of type "CONTROLLEDVOCABULARY"\\012   if v_code = 'CONTROLLEDVOCABULARY' then\\012      if NEW.covo_id IS NULL then\\012         RAISE EXCEPTION 'Insert/Update of Property Type (Code: %) failed, as its Data Type is CONTROLLEDVOCABULARY, but it is not linked to a Controlled Vocabulary.', NEW.code;\\012      end if;\\012   end if;\\012\\012   RETURN NEW;\\012\\012END;\\012$$ LANGUAGE 'plpgsql';\\012\\012CREATE TRIGGER CONTROLLED_VOCABULARY_CHECK BEFORE INSERT OR UPDATE ON PROPERTY_TYPES\\012    FOR EACH ROW EXECUTE PROCEDURE CONTROLLED_VOCABULARY_CHECK();\\012\\012\\012------------------------------------------------------------------------------------\\012--  Purpose:  Create trigger EXTERNAL_DATA_STORAGE_FORMAT_CHECK \\012------------------------------------------------------------------------------------\\012\\012CREATE OR REPLACE FUNCTION EXTERNAL_DATA_STORAGE_FORMAT_CHECK() RETURNS trigger AS $$\\012DECLARE\\012   v_covo_code  CODE;\\012   data_code CODE;\\012BEGIN\\012\\012   select code into v_covo_code from controlled_vocabularies\\012      where is_internal_namespace = true and \\012         id = (select covo_id from controlled_vocabulary_terms where id = NEW.cvte_id_stor_fmt);\\012   -- Check if the data storage format is a term of the controlled vocabulary "STORAGE_FORMAT"\\012   if v_covo_code != 'STORAGE_FORMAT' then\\012      select code into data_code from data where id = NEW.data_id; \\012      RAISE EXCEPTION 'Insert/Update of Data (Code: %) failed, as its Storage Format is %, but is required to be STORAGE_FORMAT.', data_code, v_covo_code;\\012   end if;\\012\\012   RETURN NEW;\\012\\012END;\\012$$ LANGUAGE 'plpgsql';\\012\\012CREATE TRIGGER EXTERNAL_DATA_STORAGE_FORMAT_CHECK BEFORE INSERT OR UPDATE ON EXTERNAL_DATA\\012    FOR EACH ROW EXECUTE PROCEDURE EXTERNAL_DATA_STORAGE_FORMAT_CHECK();\\012\\012------------------------------------------------------------------------------------\\012--  Purpose:  Create trigger SAMPLE_CODE_UNIQUENESS_CHECK \\012------------------------------------------------------------------------------------\\012\\012CREATE OR REPLACE FUNCTION SAMPLE_CODE_UNIQUENESS_CHECK() RETURNS trigger AS $$\\012DECLARE\\012   counter  INTEGER;\\012BEGIN\\012\\011IF (NEW.samp_id_part_of is NULL) THEN\\012\\011\\011IF (NEW.dbin_id is not NULL) THEN\\012\\011\\011\\011SELECT count(*) into counter FROM samples \\012\\011\\011\\011\\011where id != NEW.id and code = NEW.code and samp_id_part_of is NULL and dbin_id = NEW.dbin_id;\\012\\011\\011\\011IF (counter > 0) THEN\\012\\011\\011\\011\\011RAISE EXCEPTION 'Insert/Update of Sample (Code: %) failed because database instance sample with the same code already exists.', NEW.code;\\012\\011\\011\\011END IF;\\012\\011\\011ELSIF (NEW.grou_id is not NULL) THEN\\012\\011\\011\\011SELECT count(*) into counter FROM samples \\012\\011\\011\\011\\011where id != NEW.id and code = NEW.code and samp_id_part_of is NULL and grou_id = NEW.grou_id;\\012\\011\\011\\011IF (counter > 0) THEN\\012\\011\\011\\011\\011RAISE EXCEPTION 'Insert/Update of Sample (Code: %) failed because group sample with the same code already exists.', NEW.code;\\012\\011\\011\\011END IF;\\012\\011\\011END IF;\\012        ELSE\\012\\011\\011IF (NEW.dbin_id is not NULL) THEN\\012\\011\\011\\011SELECT count(*) into counter FROM samples \\012\\011\\011\\011\\011where id != NEW.id and code = NEW.code and samp_id_part_of = NEW.samp_id_part_of and dbin_id = NEW.dbin_id;\\012\\011\\011\\011IF (counter > 0) THEN\\012\\011\\011\\011\\011RAISE EXCEPTION 'Insert/Update of Sample (Code: %) failed because database instance sample with the same code and being the part of the same parent already exists.', NEW.code;\\012\\011\\011\\011END IF;\\012\\011\\011ELSIF (NEW.grou_id is not NULL) THEN\\012\\011\\011\\011SELECT count(*) into counter FROM samples \\012\\011\\011\\011\\011where id != NEW.id and code = NEW.code and samp_id_part_of = NEW.samp_id_part_of and grou_id = NEW.grou_id;\\012\\011\\011\\011IF (counter > 0) THEN\\012\\011\\011\\011\\011RAISE EXCEPTION 'Insert/Update of Sample (Code: %) failed because group sample with the same code and being the part of the same parent already exists.', NEW.code;\\012\\011\\011\\011END IF;\\012\\011\\011END IF;\\012        END IF;   \\012   RETURN NEW;\\012END;\\012$$ LANGUAGE 'plpgsql';\\012\\012CREATE TRIGGER SAMPLE_CODE_UNIQUENESS_CHECK BEFORE INSERT OR UPDATE ON SAMPLES\\012    FOR EACH ROW EXECUTE PROCEDURE SAMPLE_CODE_UNIQUENESS_CHECK();\\012	\N
+./sourceTest/sql/postgresql/043/017=database_version_logs.tsv:028	source/sql/postgresql/migration/migration-027-028.sql	SUCCESS	2008-11-18 13:24:17.508	-- Create EXPERIMENT_ATTACHMENT_CONTENTS.\\012CREATE TABLE EXPERIMENT_ATTACHMENT_CONTENTS (ID TECH_ID NOT NULL,VALUE FILE NOT NULL);\\012CREATE SEQUENCE EXPERIMENT_ATTACHMENT_CONTENT_ID_SEQ;\\012ALTER TABLE EXPERIMENT_ATTACHMENT_CONTENTS ADD CONSTRAINT EXAC_PK PRIMARY KEY(ID);\\012\\012-- Alter EXPERIMENT_ATTACHMENTS by adding the new column which has a NULL constraint.\\012-- The NOT NULL constraint is added later on.\\012ALTER TABLE EXPERIMENT_ATTACHMENTS ADD COLUMN EXAC_ID TECH_ID;\\012\\012-- Does the VALUE migration between EXPERIMENT_ATTACHMENTS to EXPERIMENT_ATTACHMENT_CONTENTS.\\012CREATE OR REPLACE FUNCTION move_exp_att_content() RETURNS integer AS $$\\012DECLARE\\012    rec RECORD;\\012    seq BIGINT;\\012BEGIN\\012  FOR rec IN SELECT id, value FROM EXPERIMENT_ATTACHMENTS LOOP\\012  \\011seq := nextval('EXPERIMENT_ATTACHMENT_CONTENT_ID_SEQ');\\012    INSERT INTO EXPERIMENT_ATTACHMENT_CONTENTS (id, value) VALUES (seq, rec.value);\\012    UPDATE EXPERIMENT_ATTACHMENTS SET exac_id = seq WHERE id = rec.id;\\012  END LOOP;\\012  RETURN 1;\\012END;\\012$$ LANGUAGE 'plpgsql';\\012\\012-- Call the function.\\012SELECT move_exp_att_content();\\012DROP FUNCTION move_exp_att_content();\\012\\012\\012-- Finish EXPERIMENT_ATTACHMENTS changes.\\012ALTER TABLE EXPERIMENT_ATTACHMENTS ADD CONSTRAINT EXAT_CONT_FK FOREIGN KEY (EXAC_ID) REFERENCES EXPERIMENT_ATTACHMENT_CONTENTS(ID);\\012ALTER TABLE EXPERIMENT_ATTACHMENTS DROP COLUMN VALUE;\\012ALTER TABLE EXPERIMENT_ATTACHMENTS ALTER COLUMN EXAC_ID SET NOT NULL;\\012	\N
+./sourceTest/sql/postgresql/043/017=database_version_logs.tsv:029	source/sql/postgresql/migration/migration-028-029.sql	SUCCESS	2009-03-18 10:50:20.105	-- -------\\012-- add modification_timestamp field to allow edition with Hibernate\\012-- -------\\012\\012ALTER TABLE samples\\012\\011ADD COLUMN modification_timestamp TIME_STAMP DEFAULT CURRENT_TIMESTAMP;\\012\\012ALTER TABLE experiments\\012\\011ADD COLUMN modification_timestamp TIME_STAMP DEFAULT CURRENT_TIMESTAMP;\\012\\012ALTER TABLE materials\\012\\011ADD COLUMN modification_timestamp TIME_STAMP DEFAULT CURRENT_TIMESTAMP;\\012\\012ALTER TABLE experiment_properties\\012\\011ADD COLUMN modification_timestamp TIME_STAMP DEFAULT CURRENT_TIMESTAMP;\\012\\012ALTER TABLE material_properties\\012\\011ADD COLUMN modification_timestamp TIME_STAMP DEFAULT CURRENT_TIMESTAMP;\\012\\012ALTER TABLE sample_properties\\012\\011ADD COLUMN modification_timestamp TIME_STAMP DEFAULT CURRENT_TIMESTAMP;\\012\\012-- -------\\012-- add property data type which references materials\\012-- -------\\012\\012ALTER TABLE property_types\\012\\011ADD COLUMN maty_prop_id tech_id;\\012\\012ALTER TABLE property_types\\012\\011ADD CONSTRAINT prty_maty_fk FOREIGN KEY (maty_prop_id) REFERENCES material_types(id);\\012\\012ALTER TABLE experiment_properties\\012\\011ADD COLUMN mate_prop_id tech_id;\\012\\012ALTER TABLE material_properties\\012\\011ADD COLUMN mate_prop_id tech_id;\\012\\012ALTER TABLE sample_properties\\012\\011ADD COLUMN mate_prop_id tech_id;\\012\\012ALTER TABLE experiment_properties\\012\\011ADD CONSTRAINT expr_mapr_fk FOREIGN KEY (mate_prop_id) REFERENCES materials(id);\\012\\012ALTER TABLE material_properties\\012\\011ADD CONSTRAINT mapr_mapr_fk FOREIGN KEY (mate_prop_id) REFERENCES materials(id);\\012\\012ALTER TABLE sample_properties\\012\\011ADD CONSTRAINT sapr_mapr_fk FOREIGN KEY (mate_prop_id) REFERENCES materials(id);\\012\\012insert into data_types\\012(id\\012 ,code\\012 ,description)\\012 values \\012 (nextval('DATA_TYPE_ID_SEQ')\\012 ,'MATERIAL'\\012 ,'Reference to a material'\\012);\\012\\012ALTER TABLE MATERIAL_PROPERTIES DROP CONSTRAINT MAPR_CK;\\012ALTER TABLE MATERIAL_PROPERTIES ADD CONSTRAINT MAPR_CK CHECK \\012\\011((VALUE IS NOT NULL AND CVTE_ID IS NULL AND MATE_PROP_ID IS NULL) OR \\012\\011 (VALUE IS NULL AND CVTE_ID IS NOT NULL AND MATE_PROP_ID IS NULL) OR\\012\\011 (VALUE IS NULL AND CVTE_ID IS NULL AND MATE_PROP_ID IS NOT NULL)\\012\\011);\\012\\012ALTER TABLE EXPERIMENT_PROPERTIES DROP CONSTRAINT EXPR_CK;\\012ALTER TABLE EXPERIMENT_PROPERTIES ADD CONSTRAINT EXPR_CK CHECK \\012\\011((VALUE IS NOT NULL AND CVTE_ID IS NULL AND MATE_PROP_ID IS NULL) OR \\012\\011 (VALUE IS NULL AND CVTE_ID IS NOT NULL AND MATE_PROP_ID IS NULL) OR\\012\\011 (VALUE IS NULL AND CVTE_ID IS NULL AND MATE_PROP_ID IS NOT NULL)\\012\\011);\\012\\012ALTER TABLE SAMPLE_PROPERTIES DROP CONSTRAINT SAPR_CK;\\012ALTER TABLE SAMPLE_PROPERTIES ADD CONSTRAINT SAPR_CK CHECK \\012\\011((VALUE IS NOT NULL AND CVTE_ID IS NULL AND MATE_PROP_ID IS NULL) OR \\012\\011 (VALUE IS NULL AND CVTE_ID IS NOT NULL AND MATE_PROP_ID IS NULL) OR\\012\\011 (VALUE IS NULL AND CVTE_ID IS NULL AND MATE_PROP_ID IS NOT NULL)\\012\\011);\\012\\012------------------------------------------------------------------------------------\\012--  Purpose:  Create trigger MATERIAL/SAMPLE/EXPERIMENT _PROPERTY_WITH_MATERIAL_DATA_TYPE_CHECK\\012--            It checks that if material property value is assigned to the entity,\\012--\\011\\011\\011\\011\\011\\011then the material type is equal to the one described by property type.\\012------------------------------------------------------------------------------------\\012\\012CREATE OR REPLACE FUNCTION MATERIAL_PROPERTY_WITH_MATERIAL_DATA_TYPE_CHECK() RETURNS trigger AS $$\\012DECLARE\\012   v_type_id  CODE;\\012   v_type_id_prop  CODE;\\012BEGIN\\012   if NEW.mate_prop_id IS NOT NULL then\\012\\011\\011\\011-- find material type id of the property type \\012\\011\\011\\011select pt.maty_prop_id into v_type_id_prop \\012\\011\\011\\011  from material_type_property_types etpt, property_types pt \\012\\011\\011\\011 where NEW.mtpt_id = etpt.id AND etpt.prty_id = pt.id;\\012\\011\\011\\012\\011\\011\\011if v_type_id_prop IS NOT NULL then\\012\\011\\011\\011\\011-- find material type id of the material which consists the entity's property value\\012\\011\\011\\011\\011select entity.maty_id into v_type_id \\012\\011\\011\\011\\011  from materials entity\\012\\011\\011\\011\\011 where NEW.mate_prop_id = entity.id;\\012\\011\\011\\011\\011if v_type_id != v_type_id_prop then\\012\\011\\011\\011\\011\\011RAISE EXCEPTION 'Insert/Update of property value referencing material (id: %) failed, as referenced material type is different than expected (id %, expected id: %).', \\012\\011\\011\\011\\011\\011\\011\\011 NEW.mate_prop_id, v_type_id, v_type_id_prop;\\012\\011\\011\\011\\011end if;\\012\\011\\011\\011end if;\\012   end if;\\012   RETURN NEW;\\012END;\\012$$ LANGUAGE 'plpgsql';\\012\\012CREATE TRIGGER MATERIAL_PROPERTY_WITH_MATERIAL_DATA_TYPE_CHECK BEFORE INSERT OR UPDATE ON material_properties\\012    FOR EACH ROW EXECUTE PROCEDURE MATERIAL_PROPERTY_WITH_MATERIAL_DATA_TYPE_CHECK();\\012    \\012CREATE OR REPLACE FUNCTION SAMPLE_PROPERTY_WITH_MATERIAL_DATA_TYPE_CHECK() RETURNS trigger AS $$\\012DECLARE\\012   v_type_id  CODE;\\012   v_type_id_prop  CODE;\\012BEGIN\\012   if NEW.mate_prop_id IS NOT NULL then\\012\\011\\011\\011-- find material type id of the property type \\012\\011\\011\\011select pt.maty_prop_id into v_type_id_prop \\012\\011\\011\\011  from sample_type_property_types etpt, property_types pt \\012\\011\\011\\011 where NEW.stpt_id = etpt.id AND etpt.prty_id = pt.id;\\012\\011\\011\\012\\011\\011\\011if v_type_id_prop IS NOT NULL then\\012\\011\\011\\011\\011-- find material type id of the material which consists the entity's property value\\012\\011\\011\\011\\011select entity.maty_id into v_type_id \\012\\011\\011\\011\\011  from materials entity\\012\\011\\011\\011\\011 where NEW.mate_prop_id = entity.id;\\012\\011\\011\\011\\011if v_type_id != v_type_id_prop then\\012\\011\\011\\011\\011\\011RAISE EXCEPTION 'Insert/Update of property value referencing material (id: %) failed, as referenced material type is different than expected (id %, expected id: %).', \\012\\011\\011\\011\\011\\011\\011\\011\\011\\011\\011\\011\\011 NEW.mate_prop_id, v_type_id, v_type_id_prop;\\012\\011\\011\\011\\011end if;\\012\\011\\011\\011end if;\\012   end if;\\012   RETURN NEW;\\012END;\\012$$ LANGUAGE 'plpgsql';\\012\\012CREATE TRIGGER SAMPLE_PROPERTY_WITH_MATERIAL_DATA_TYPE_CHECK BEFORE INSERT OR UPDATE ON sample_properties\\012    FOR EACH ROW EXECUTE PROCEDURE SAMPLE_PROPERTY_WITH_MATERIAL_DATA_TYPE_CHECK();\\012    \\012CREATE OR REPLACE FUNCTION EXPERIMENT_PROPERTY_WITH_MATERIAL_DATA_TYPE_CHECK() RETURNS trigger AS $$\\012DECLARE\\012   v_type_id  CODE;\\012   v_type_id_prop  CODE;\\012BEGIN\\012   if NEW.mate_prop_id IS NOT NULL then\\012\\011\\011\\011-- find material type id of the property type \\012\\011\\011\\011select pt.maty_prop_id into v_type_id_prop \\012\\011\\011\\011  from experiment_type_property_types etpt, property_types pt \\012\\011\\011\\011 where NEW.etpt_id = etpt.id AND etpt.prty_id = pt.id;\\012\\011\\011\\012\\011\\011\\011if v_type_id_prop IS NOT NULL then\\012\\011\\011\\011\\011-- find material type id of the material which consists the entity's property value\\012\\011\\011\\011\\011select entity.maty_id into v_type_id \\012\\011\\011\\011\\011  from materials entity\\012\\011\\011\\011\\011 where NEW.mate_prop_id = entity.id;\\012\\011\\011\\011\\011if v_type_id != v_type_id_prop then\\012\\011\\011\\011\\011\\011RAISE EXCEPTION 'Insert/Update of property value referencing material (id: %) failed, as referenced material type is different than expected (id %, expected id: %).', \\012\\011\\011\\011\\011\\011\\011\\011\\011\\011\\011\\011\\011 NEW.mate_prop_id, v_type_id, v_type_id_prop;\\012\\011\\011\\011\\011end if;\\012\\011\\011\\011end if;\\012   end if;\\012   RETURN NEW;\\012END;\\012$$ LANGUAGE 'plpgsql';\\012\\012CREATE TRIGGER EXPERIMENT_PROPERTY_WITH_MATERIAL_DATA_TYPE_CHECK BEFORE INSERT OR UPDATE ON experiment_properties\\012    FOR EACH ROW EXECUTE PROCEDURE EXPERIMENT_PROPERTY_WITH_MATERIAL_DATA_TYPE_CHECK();\\012       \\012-- -------\\012-- remove the reminescents of the OBSERVABLE_TYPE\\012-- -------\\012\\012ALTER TABLE data\\012\\011DROP CONSTRAINT data_obty_fk;\\012\\012ALTER TABLE data_set_types\\012\\011DROP CONSTRAINT obty_pk;\\012\\012ALTER TABLE data_set_types\\012\\011ADD CONSTRAINT dsty_pk PRIMARY KEY (id);\\012\\012ALTER TABLE data\\012\\011ADD CONSTRAINT data_dsty_fk FOREIGN KEY (dsty_id) REFERENCES data_set_types(id);\\012\\012ALTER TABLE data_set_types\\012\\011DROP CONSTRAINT obty_bk_uk;\\012\\012ALTER TABLE data_set_types\\012\\011DROP CONSTRAINT obty_dbin_fk;\\012\\012ALTER TABLE data_set_types\\012\\011ADD CONSTRAINT dsty_bk_uk UNIQUE (code, dbin_id);\\012\\012ALTER TABLE data_set_types\\012\\011ADD CONSTRAINT dsty_dbin_fk FOREIGN KEY (dbin_id) REFERENCES database_instances(id);\\012\\012DROP INDEX data_obty_fk_i;\\012\\012CREATE INDEX data_dsty_fk_i ON data(dsty_id);\\012	\N
+./sourceTest/sql/postgresql/043/017=database_version_logs.tsv:030	source/sql/postgresql/migration/migration-029-030.sql	SUCCESS	2009-03-23 15:34:44.72	-- -------\\012-- add modification_timestamp field to allow edition with Hibernate\\012-- -------\\012ALTER TABLE data\\012\\011ADD COLUMN modification_timestamp TIME_STAMP DEFAULT CURRENT_TIMESTAMP;\\012ALTER TABLE experiment_types\\012\\011ADD COLUMN modification_timestamp TIME_STAMP DEFAULT CURRENT_TIMESTAMP;\\012ALTER TABLE sample_types\\012\\011ADD COLUMN modification_timestamp TIME_STAMP DEFAULT CURRENT_TIMESTAMP;\\012ALTER TABLE material_types\\012\\011ADD COLUMN modification_timestamp TIME_STAMP DEFAULT CURRENT_TIMESTAMP;\\012ALTER TABLE data_set_types\\012\\011ADD COLUMN modification_timestamp TIME_STAMP DEFAULT CURRENT_TIMESTAMP;\\012ALTER TABLE controlled_vocabularies\\012\\011ADD COLUMN modification_timestamp TIME_STAMP DEFAULT CURRENT_TIMESTAMP;\\012-- -------\\012-- add properties to data sets\\012-- -------\\012CREATE TABLE DATA_SET_PROPERTIES (ID TECH_ID NOT NULL,DS_ID TECH_ID NOT NULL,DSTPT_ID TECH_ID NOT NULL,VALUE GENERIC_VALUE,CVTE_ID TECH_ID, MATE_PROP_ID TECH_ID, PERS_ID_REGISTERER TECH_ID NOT NULL,REGISTRATION_TIMESTAMP TIME_STAMP_DFL NOT NULL DEFAULT CURRENT_TIMESTAMP, MODIFICATION_TIMESTAMP TIME_STAMP DEFAULT CURRENT_TIMESTAMP);\\012CREATE TABLE DATA_SET_TYPE_PROPERTY_TYPES (ID TECH_ID NOT NULL,DSTY_ID TECH_ID NOT NULL,PRTY_ID TECH_ID NOT NULL,IS_MANDATORY BOOLEAN_CHAR NOT NULL DEFAULT 'F',IS_MANAGED_INTERNALLY BOOLEAN_CHAR NOT NULL DEFAULT 'F',PERS_ID_REGISTERER TECH_ID NOT NULL,REGISTRATION_TIMESTAMP TIME_STAMP_DFL NOT NULL DEFAULT CURRENT_TIMESTAMP);\\012\\012CREATE SEQUENCE DATA_SET_PROPERTY_ID_SEQ;\\012CREATE SEQUENCE DSTPT_ID_SEQ;\\012\\012ALTER TABLE DATA_SET_TYPE_PROPERTY_TYPES ADD CONSTRAINT DSTPT_PK PRIMARY KEY(ID);\\012ALTER TABLE DATA_SET_PROPERTIES ADD CONSTRAINT DSPR_PK PRIMARY KEY(ID);\\012\\012ALTER TABLE DATA_SET_TYPE_PROPERTY_TYPES ADD CONSTRAINT DSTPT_BK_UK UNIQUE(DSTY_ID,PRTY_ID);\\012ALTER TABLE DATA_SET_PROPERTIES ADD CONSTRAINT DSPR_BK_UK UNIQUE(DS_ID,DSTPT_ID);\\012\\012\\012ALTER TABLE DATA_SET_TYPE_PROPERTY_TYPES ADD CONSTRAINT DSTPT_DSTY_FK FOREIGN KEY (DSTY_ID) REFERENCES DATA_SET_TYPES(ID);\\012ALTER TABLE DATA_SET_TYPE_PROPERTY_TYPES ADD CONSTRAINT DSTPT_PERS_FK FOREIGN KEY (PERS_ID_REGISTERER) REFERENCES PERSONS(ID);\\012ALTER TABLE DATA_SET_TYPE_PROPERTY_TYPES ADD CONSTRAINT DSTPT_PRTY_FK FOREIGN KEY (PRTY_ID) REFERENCES PROPERTY_TYPES(ID);\\012ALTER TABLE DATA_SET_PROPERTIES ADD CONSTRAINT DSPR_CVTE_FK FOREIGN KEY (CVTE_ID) REFERENCES CONTROLLED_VOCABULARY_TERMS(ID);\\012ALTER TABLE DATA_SET_PROPERTIES ADD CONSTRAINT DSPR_DSTPT_FK FOREIGN KEY (DSTPT_ID) REFERENCES DATA_SET_TYPE_PROPERTY_TYPES(ID) ON DELETE CASCADE;\\012ALTER TABLE DATA_SET_PROPERTIES ADD CONSTRAINT DSPR_DS_FK FOREIGN KEY (DS_ID) REFERENCES DATA(ID);\\012ALTER TABLE DATA_SET_PROPERTIES ADD CONSTRAINT DSPR_PERS_FK FOREIGN KEY (PERS_ID_REGISTERER) REFERENCES PERSONS(ID);\\012ALTER TABLE DATA_SET_PROPERTIES ADD CONSTRAINT DSPR_MAPR_FK FOREIGN KEY (MATE_PROP_ID) REFERENCES MATERIALS(ID);\\012\\012ALTER TABLE DATA_SET_PROPERTIES ADD CONSTRAINT DSPR_CK CHECK \\012\\011((VALUE IS NOT NULL AND CVTE_ID IS NULL AND MATE_PROP_ID IS NULL) OR \\012\\011 (VALUE IS NULL AND CVTE_ID IS NOT NULL AND MATE_PROP_ID IS NULL) OR\\012\\011 (VALUE IS NULL AND CVTE_ID IS NULL AND MATE_PROP_ID IS NOT NULL)\\012\\011);\\012\\012CREATE INDEX DSPR_CVTE_FK_I ON DATA_SET_PROPERTIES (CVTE_ID);\\012CREATE INDEX DSPR_DSTPT_FK_I ON DATA_SET_PROPERTIES (DSTPT_ID);\\012CREATE INDEX DSPR_DS_FK_I ON DATA_SET_PROPERTIES (DS_ID);\\012CREATE INDEX DSPR_PERS_FK_I ON DATA_SET_PROPERTIES (PERS_ID_REGISTERER);\\012CREATE INDEX DSTPT_DSTY_FK_I ON DATA_SET_TYPE_PROPERTY_TYPES (DSTY_ID);\\012CREATE INDEX DSTPT_PERS_FK_I ON DATA_SET_TYPE_PROPERTY_TYPES (PERS_ID_REGISTERER);\\012CREATE INDEX DSTPT_PRTY_FK_I ON DATA_SET_TYPE_PROPERTY_TYPES (PRTY_ID);\\012\\012CREATE OR REPLACE FUNCTION DATA_SET_PROPERTY_WITH_MATERIAL_DATA_TYPE_CHECK() RETURNS trigger AS $$\\012DECLARE\\012   v_type_id  CODE;\\012   v_type_id_prop  CODE;\\012BEGIN\\012   if NEW.mate_prop_id IS NOT NULL then\\012\\011\\011\\011-- find material type id of the property type \\012\\011\\011\\011select pt.maty_prop_id into v_type_id_prop \\012\\011\\011\\011  from data_set_type_property_types dstpt, property_types pt \\012\\011\\011\\011 where NEW.dstpt_id = dstpt.id AND dstpt.prty_id = pt.id;\\012\\011\\011\\012\\011\\011\\011if v_type_id_prop IS NOT NULL then\\012\\011\\011\\011\\011-- find material type id of the material which consists the entity's property value\\012\\011\\011\\011\\011select entity.maty_id into v_type_id \\012\\011\\011\\011\\011  from materials entity\\012\\011\\011\\011\\011 where NEW.mate_prop_id = entity.id;\\012\\011\\011\\011\\011if v_type_id != v_type_id_prop then\\012\\011\\011\\011\\011\\011RAISE EXCEPTION 'Insert/Update of property value referencing material (id: %) failed, as referenced material type is different than expected (id %, expected id: %).', \\012\\011\\011\\011\\011\\011\\011\\011\\011\\011\\011\\011\\011 NEW.mate_prop_id, v_type_id, v_type_id_prop;\\012\\011\\011\\011\\011end if;\\012\\011\\011\\011end if;\\012   end if;\\012   RETURN NEW;\\012END;\\012$$ LANGUAGE 'plpgsql';\\012\\012CREATE TRIGGER DATA_SET_PROPERTY_WITH_MATERIAL_DATA_TYPE_CHECK BEFORE INSERT OR UPDATE ON data_set_properties\\012    FOR EACH ROW EXECUTE PROCEDURE DATA_SET_PROPERTY_WITH_MATERIAL_DATA_TYPE_CHECK();   \\012	\N
+./sourceTest/sql/postgresql/043/017=database_version_logs.tsv:032	source/sql/postgresql/migration/migration-031-032.sql	SUCCESS	2009-04-09 09:36:36.20	-- -------\\012-- Modify MATERIAL_BATCHES\\012-- -------\\012\\012ALTER TABLE material_batches\\012    DROP COLUMN proc_id;\\012\\012-- -------\\012-- Modify SAMPLES\\012-- -------\\012\\012ALTER TABLE samples\\012    ADD COLUMN expe_id tech_id;\\012\\012ALTER TABLE samples\\012    ADD CONSTRAINT samp_expe_fk FOREIGN KEY (expe_id) REFERENCES experiments(id);\\012\\012CREATE INDEX samp_expe_fk_i ON samples USING btree (expe_id);\\012\\012-- relink samples directly to experiments\\012\\012UPDATE samples\\012SET expe_id = (SELECT e.id FROM experiments e, procedures p, sample_inputs si \\012               WHERE si.samp_id = samples.id AND si.proc_id = p.id AND p.expe_id = e.id AND e.inva_id IS NULL);\\012\\012\\012-- -------\\012-- Modify DATA\\012-- -------\\012\\012ALTER TABLE data\\012    ADD COLUMN expe_id tech_id;\\012\\012ALTER TABLE data\\012    ADD CONSTRAINT data_expe_fk FOREIGN KEY (expe_id) REFERENCES experiments(id);\\012\\012CREATE INDEX data_expe_fk_i ON data USING btree (expe_id);\\012\\012UPDATE data\\012SET expe_id = (SELECT e.id FROM experiments e, procedures p \\012               WHERE data.proc_id_produced_by = p.id AND p.expe_id = e.id);\\012\\012ALTER TABLE data\\012    ALTER COLUMN expe_id SET NOT NULL;\\012\\012ALTER TABLE data\\012    DROP COLUMN proc_id_produced_by;\\012\\012-- -------\\012-- Drop PROCEDURES, PROCEDURE_TYPES, and SAMPLE_INPUTS\\012-- -------\\012\\012DROP TABLE sample_inputs;\\012DROP TABLE procedures;\\012DROP TABLE procedure_types;\\012\\012DROP SEQUENCE procedure_id_seq;\\012DROP SEQUENCE procedure_type_id_seq;\\012\\012-- -------\\012-- Add CODE_SEQ\\012-- -------\\012\\012CREATE SEQUENCE CODE_SEQ;\\012\\012-- -------\\012-- Add new columns to DATA_STORES\\012-- -------\\012\\012ALTER TABLE data_stores\\012    ADD COLUMN remote_url character varying(250),\\012    ADD COLUMN session_token character varying(50),\\012    ADD COLUMN modification_timestamp time_stamp DEFAULT now();\\012\\012UPDATE data_stores\\012SET remote_url = '', session_token='';\\012\\012ALTER TABLE data_stores\\012    ALTER COLUMN remote_url SET NOT NULL,\\012    ALTER COLUMN session_token SET NOT NULL;\\012\\012-- -------\\012-- Drop foreign keys onto DATA_STORES\\012-- -------\\012\\012ALTER TABLE database_instances\\012    DROP COLUMN dast_id;\\012\\012ALTER TABLE groups\\012    DROP COLUMN dast_id;\\012\\012ALTER TABLE projects\\012    DROP COLUMN dast_id;\\012\\012ALTER TABLE experiments\\012    DROP COLUMN dast_id;\\012\\012-- -------\\012-- Add foreign key from DATA onto DATA_STORES\\012-- -------\\012\\012ALTER TABLE data\\012    ADD COLUMN dast_id tech_id;\\012\\012ALTER TABLE data\\012    ADD CONSTRAINT data_dast_fk FOREIGN KEY (dast_id) REFERENCES data_stores(id);\\012\\012UPDATE data\\012SET dast_id = (select id from data_stores where code = 'STANDARD');\\012\\012ALTER TABLE data\\012    ALTER COLUMN dast_id SET NOT NULL;\\012\\012\\012------------------------------------------------------------------------------------\\012--  Purpose:  Replace trigger SAMPLE_CODE_UNIQUENESS_CHECK \\012------------------------------------------------------------------------------------\\012\\012CREATE OR REPLACE FUNCTION SAMPLE_CODE_UNIQUENESS_CHECK() RETURNS trigger AS $$\\012DECLARE\\012   counter  INTEGER;\\012BEGIN\\012    LOCK TABLE samples IN EXCLUSIVE MODE;\\012    IF (NEW.samp_id_part_of is NULL) THEN\\012        IF (NEW.dbin_id is not NULL) THEN\\012            SELECT count(*) into counter FROM samples \\012                where id != NEW.id and code = NEW.code and samp_id_part_of is NULL and dbin_id = NEW.dbin_id;\\012            IF (counter > 0) THEN\\012                RAISE EXCEPTION 'Insert/Update of Sample (Code: %) failed because database instance sample with the same code already exists.', NEW.code;\\012            END IF;\\012        ELSIF (NEW.grou_id is not NULL) THEN\\012            SELECT count(*) into counter FROM samples \\012                where id != NEW.id and code = NEW.code and samp_id_part_of is NULL and grou_id = NEW.grou_id;\\012            IF (counter > 0) THEN\\012                RAISE EXCEPTION 'Insert/Update of Sample (Code: %) failed because group sample with the same code already exists.', NEW.code;\\012            END IF;\\012        END IF;\\012        ELSE\\012        IF (NEW.dbin_id is not NULL) THEN\\012            SELECT count(*) into counter FROM samples \\012                where id != NEW.id and code = NEW.code and samp_id_part_of = NEW.samp_id_part_of and dbin_id = NEW.dbin_id;\\012            IF (counter > 0) THEN\\012                RAISE EXCEPTION 'Insert/Update of Sample (Code: %) failed because database instance sample with the same code and being the part of the same parent already exists.', NEW.code;\\012            END IF;\\012        ELSIF (NEW.grou_id is not NULL) THEN\\012            SELECT count(*) into counter FROM samples \\012                where id != NEW.id and code = NEW.code and samp_id_part_of = NEW.samp_id_part_of and grou_id = NEW.grou_id;\\012            IF (counter > 0) THEN\\012                RAISE EXCEPTION 'Insert/Update of Sample (Code: %) failed because group sample with the same code and being the part of the same parent already exists.', NEW.code;\\012            END IF;\\012        END IF;\\012        END IF;   \\012   RETURN NEW;\\012END;\\012$$ LANGUAGE 'plpgsql';\\012\\012\\012\\012	\N
+./sourceTest/sql/postgresql/043/017=database_version_logs.tsv:034	source/sql/postgresql/migration/migration-033-034.sql	SUCCESS	2009-05-26 08:32:49.935	------------------------------------------------------------------------------------\\012-- Create sequence for generating permanent identifiers starting with nextval of existing dataset sequence.\\012------------------------------------------------------------------------------------\\012CREATE FUNCTION CREATE_SEQUENCE(EXISTING_SEQUENCE VARCHAR, NEW_SEQUENCE VARCHAR) RETURNS VOID AS $$\\012DECLARE\\012  CURR_SEQ_VAL   INTEGER;\\012BEGIN\\012  SELECT INTO CURR_SEQ_VAL NEXTVAL(EXISTING_SEQUENCE);\\012  EXECUTE 'CREATE SEQUENCE ' || NEW_SEQUENCE || ' START WITH ' || CURR_SEQ_VAL;\\012  RETURN;\\012END;\\012$$ LANGUAGE 'plpgsql';\\012\\012SELECT CREATE_SEQUENCE('DATA_ID_SEQ', 'PERM_ID_SEQ');\\012DROP FUNCTION CREATE_SEQUENCE(VARCHAR, VARCHAR);\\012\\012------------------------------------------------------------------------------------\\012-- Add perm_id columns to samples and experiments.\\012------------------------------------------------------------------------------------\\012ALTER TABLE SAMPLES ADD COLUMN PERM_ID CODE;\\012ALTER TABLE EXPERIMENTS ADD COLUMN PERM_ID CODE;\\012\\012UPDATE SAMPLES SET PERM_ID = to_char(registration_timestamp,'YYYYMMDDHHSSMS') || '-' || NEXTVAL('PERM_ID_SEQ');\\012UPDATE EXPERIMENTS SET PERM_ID = to_char(registration_timestamp,'YYYYMMDDHHSSMS') || '-' || NEXTVAL('PERM_ID_SEQ');\\012ALTER TABLE SAMPLES ALTER COLUMN PERM_ID SET NOT NULL;\\012ALTER TABLE EXPERIMENTS ALTER COLUMN PERM_ID SET NOT NULL;\\012ALTER TABLE SAMPLES ADD CONSTRAINT SAMP_PI_UK UNIQUE(PERM_ID);\\012ALTER TABLE EXPERIMENTS ADD CONSTRAINT EXPE_PI_UK UNIQUE(PERM_ID);\\012\\012\\012------------------------------------------------------------------------------------\\012-- Add column is_chosen_from_list to controlled_vocabularies.\\012------------------------------------------------------------------------------------\\012ALTER TABLE controlled_vocabularies ADD COLUMN is_chosen_from_list BOOLEAN_CHAR NOT NULL DEFAULT TRUE;\\012ALTER TABLE controlled_vocabularies ADD COLUMN source_uri CHARACTER VARYING(250);\\012------------------------------------------------------------------------------------\\012-- Modify Data table - remove arc connection between Sample and Data table, use a flag instead\\012------------------------------------------------------------------------------------\\012\\012-- add new columns\\012\\012ALTER TABLE data\\012    ADD COLUMN is_derived boolean_char;\\012ALTER TABLE data\\012    ADD COLUMN samp_id tech_id;\\012\\012-- update values in new columns\\012\\012UPDATE data\\012    SET is_derived = (samp_id_derived_from IS NOT NULL); \\012UPDATE data\\012    SET samp_id = samp_id_derived_from \\012    WHERE is_derived = 'TRUE';\\012UPDATE data\\012    SET samp_id = samp_id_acquired_from \\012    WHERE is_derived = 'FALSE';\\012\\012-- add constraints and indexes to new columns\\012\\012ALTER TABLE data\\012    ALTER COLUMN is_derived SET NOT NULL;\\012ALTER TABLE data\\012    ALTER COLUMN samp_id SET NOT NULL;   \\012ALTER TABLE data\\012    ADD CONSTRAINT data_samp_fk FOREIGN KEY (samp_id) REFERENCES samples (id);\\012CREATE INDEX data_samp_fk_i ON data USING btree (samp_id);\\012\\012-- remove old columns\\012\\012ALTER TABLE data\\012    DROP COLUMN samp_id_acquired_from;\\012ALTER TABLE data\\012    DROP COLUMN samp_id_derived_from;\\012    \\012------------------------------------------------------------------------------------\\012-- Granting SELECT privilege to group openbis_readonly\\012------------------------------------------------------------------------------------\\012\\012GRANT SELECT ON SEQUENCE attachment_content_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE attachment_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE code_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE controlled_vocabulary_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE cvte_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE data_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE data_set_property_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE data_set_relationship_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE data_set_type_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE data_store_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE data_type_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE database_instance_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE dstpt_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE etpt_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE event_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE experiment_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE experiment_property_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE experiment_type_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE file_format_type_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE group_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE invalidation_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE locator_type_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE material_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE material_property_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE material_type_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE mtpt_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE perm_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE person_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE project_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE property_type_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE role_assignment_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE sample_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE sample_property_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE sample_type_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE stpt_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE attachment_contents TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE attachments TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE controlled_vocabularies TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE controlled_vocabulary_terms TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE data TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE data_set_properties TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE data_set_relationships TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE data_set_type_property_types TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE data_set_types TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE data_stores TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE data_types TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE database_instances TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE database_version_logs TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE events TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE experiment_properties TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE experiment_type_property_types TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE experiment_types TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE experiments TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE external_data TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE file_format_types TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE groups TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE invalidations TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE locator_types TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE material_properties TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE material_type_property_types TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE material_types TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE materials TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE persons TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE projects TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE property_types TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE role_assignments TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE sample_properties TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE sample_type_property_types TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE sample_types TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE samples TO GROUP OPENBIS_READONLY;\\012\\012------------------------------------------------------------------------------------\\012-- Delete MATERIAL_BATCHES table\\012------------------------------------------------------------------------------------\\012\\012-- WARNING: Potential data lost!!!\\012-- WARNING: Potential data lost!!!\\012-- WARNING: Potential data lost!!!\\012\\012DROP TABLE SAMPLE_MATERIAL_BATCHES;\\012DROP TABLE MATERIAL_BATCHES;\\012DROP SEQUENCE MATERIAL_BATCH_ID_SEQ;\\012\\012------------------------------------------------------------------------------------\\012-- Delete MATE_ID_INHIBITOR_OF from table MATERIALS\\012------------------------------------------------------------------------------------\\012\\012-- WARNING: Potential data lost!!!\\012-- WARNING: Potential data lost!!!\\012-- WARNING: Potential data lost!!!\\012\\012ALTER TABLE MATERIALS DROP COLUMN MATE_ID_INHIBITOR_OF;\\012	\N
+./sourceTest/sql/postgresql/043/017=database_version_logs.tsv:041	source/sql/postgresql/migration/migration-040-041.sql	SUCCESS	2009-09-14 13:48:57.539	-- Create FILTERS table\\012\\012CREATE TABLE FILTERS (ID TECH_ID NOT NULL, DBIN_ID TECH_ID NOT NULL, NAME VARCHAR(200) NOT NULL, DESCRIPTION DESCRIPTION_1000,REGISTRATION_TIMESTAMP TIME_STAMP_DFL NOT NULL DEFAULT CURRENT_TIMESTAMP, PERS_ID_REGISTERER TECH_ID NOT NULL, MODIFICATION_TIMESTAMP TIME_STAMP DEFAULT CURRENT_TIMESTAMP, EXPRESSION VARCHAR(2000) NOT NULL, IS_PUBLIC BOOLEAN NOT NULL, GRID_ID VARCHAR(200) NOT NULL);\\012CREATE SEQUENCE FILTER_ID_SEQ;\\012ALTER TABLE FILTERS ADD CONSTRAINT FILT_PK PRIMARY KEY(ID);\\012ALTER TABLE FILTERS ADD CONSTRAINT FILT_BK_UK UNIQUE(NAME, DBIN_ID, GRID_ID);\\012ALTER TABLE FILTERS ADD CONSTRAINT FILT_PERS_FK FOREIGN KEY (PERS_ID_REGISTERER) REFERENCES PERSONS(ID);\\012ALTER TABLE FILTERS ADD CONSTRAINT FILT_DBIN_FK FOREIGN KEY (DBIN_ID) REFERENCES DATABASE_INSTANCES(ID);\\012CREATE INDEX FILT_PERS_FK_I ON FILTERS (PERS_ID_REGISTERER);\\012CREATE INDEX FILT_DBIN_FK_I ON FILTERS (DBIN_ID);\\012GRANT SELECT ON SEQUENCE filter_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE filters TO GROUP OPENBIS_READONLY;\\012\\012-- Add missing foreign key to role assignments authorization group\\012ALTER TABLE ROLE_ASSIGNMENTS ADD CONSTRAINT ROAS_AG_FK_GRANTEE FOREIGN KEY (AG_ID_GRANTEE) REFERENCES AUTHORIZATION_GROUPS(ID);\\012\\012--------------------------------------------------------------------------------------------------\\012-- Modify dataset connections:\\012-- 1. connection with sample shouldn't be mandatory any more\\012-- 2. introduce an arc condition that dataset cannot be connected with a sample and a parent dataset at the same time\\012--------------------------------------------------------------------------------------------------\\012\\012-- Weaken data-sample connection constraint - allow dataset to have no connection with sample\\012ALTER TABLE data ALTER COLUMN samp_id DROP NOT NULL;\\012\\012-- Remove data-sample connection for datasets that have a parent\\012\\012UPDATE data \\012   SET samp_id = NULL \\012 WHERE id IN (SELECT DISTINCT data_id_child FROM data_set_relationships);\\012\\012-- With PostgreSQL 8.4 one can check that before migration there were no cycles in dataset relationships:\\012--\\012-- WITH RECURSIVE data_set_parents(id, parent_ids, cycle) AS (\\012--         SELECT  r.data_id_child AS id, \\012--                 ARRAY[CAST (r.data_id_parent AS bigint)] AS parent_ids, \\012--                 false AS cycle \\012--         FROM data_set_relationships r\\012--     UNION ALL\\012--         SELECT  r.data_id_child,\\012--                 CAST (r.data_id_parent AS bigint) || p.parent_ids,\\012--                 r.data_id_child = ANY(p.parent_ids)\\012--         FROM data_set_relationships r, data_set_parents p\\012--         WHERE r.data_id_parent = p.id AND NOT cycle\\012-- )\\012-- SELECT count(*) AS cycles FROM data_set_parents WHERE cycle = true;\\012\\012---------------------------------------------------------------------------------------------------\\012--  Purpose:  Create DEFERRED triggers:\\012--            * check_dataset_relationships_on_data_table_modification,\\012--            * check_dataset_relationships_on_relationships_table_modification.\\012--            They check that after all modifications of database (just before commit) \\012--            if 'data'/'data_set_relationships' tables are among modified tables \\012--            dataset is not connected with a sample and a parent dataset at the same time.\\012--            This connections are held in two different tables so simple immediate trigger \\012--            with arc check cannot be used and we need two deferred triggers.\\012----------------------------------------------------------------------------------------------------\\012\\012-- trigger for 'data' table\\012\\012CREATE OR REPLACE FUNCTION check_dataset_relationships_on_data_table_modification() RETURNS trigger AS $$\\012DECLARE\\012\\011counter\\011INTEGER;\\012BEGIN\\012\\011-- if there is a connection with a Sample there should not be any connection with a parent Data Set\\012\\011IF (NEW.samp_id IS NOT NULL) THEN\\012\\011\\011-- count number of parents\\012\\011\\011SELECT count(*) INTO counter \\012\\011\\011\\011FROM data_set_relationships \\012\\011\\011\\011WHERE data_id_child = OLD.id;\\012\\011\\011IF (counter > 0) THEN\\012\\011\\011\\011RAISE EXCEPTION 'Insert/Update of Data Set (Code: %) failed because it cannot be connected with a Sample and a parent Data Set at the same time.', OLD.code;\\012\\011\\011END IF;\\012\\011END IF;\\012  RETURN NEW;\\012END;\\012$$ LANGUAGE 'plpgsql';\\012\\012CREATE CONSTRAINT TRIGGER check_dataset_relationships_on_data_table_modification \\012  AFTER INSERT OR UPDATE ON data\\012\\011DEFERRABLE INITIALLY DEFERRED\\012\\011FOR EACH ROW \\012\\011EXECUTE PROCEDURE check_dataset_relationships_on_data_table_modification();\\012\\012-- trigger for 'data_set_relationships'\\012\\012CREATE OR REPLACE FUNCTION check_dataset_relationships_on_relationships_table_modification() RETURNS trigger AS $$\\012DECLARE\\012\\011counter\\011INTEGER;\\012\\011sample_id\\011TECH_ID;\\012\\011data_code\\011CODE;\\012BEGIN\\012\\011-- child will have a parent added so it should not be connected with any sample\\012\\011SELECT samp_id, code INTO sample_id, data_code \\012\\011\\011FROM data \\012\\011\\011WHERE id = NEW.data_id_child;\\012\\011IF (sample_id IS NOT NULL) THEN\\012\\011\\011RAISE EXCEPTION 'Insert/Update of Data Set (Code: %) failed because it cannot be connected to a Sample and to a parent Data Set at the same time.', data_code;\\012\\011END IF;\\012\\011RETURN NEW;\\012END;\\012$$ LANGUAGE 'plpgsql';\\012  \\012CREATE CONSTRAINT TRIGGER check_dataset_relationships_on_relationships_table_modification \\012  AFTER INSERT OR UPDATE ON data_set_relationships\\012\\011DEFERRABLE INITIALLY DEFERRED\\012\\011FOR EACH ROW \\012\\011EXECUTE PROCEDURE check_dataset_relationships_on_relationships_table_modification();\\012	\N
+./sourceTest/sql/postgresql/043/schema-043.sql:    LANGUAGE plpgsql;
+./sourceTest/sql/postgresql/043/schema-043.sql:    LANGUAGE plpgsql;
+./sourceTest/sql/postgresql/043/schema-043.sql:    LANGUAGE plpgsql;
+./sourceTest/sql/postgresql/043/schema-043.sql:    LANGUAGE plpgsql;
+./sourceTest/sql/postgresql/043/schema-043.sql:    LANGUAGE plpgsql;
+./sourceTest/sql/postgresql/043/schema-043.sql:    LANGUAGE plpgsql;
+./sourceTest/sql/postgresql/043/schema-043.sql:    LANGUAGE plpgsql;
+./sourceTest/sql/postgresql/043/schema-043.sql:    LANGUAGE plpgsql;
+./sourceTest/sql/postgresql/043/schema-043.sql:    LANGUAGE plpgsql;
+./sourceTest/sql/postgresql/043/schema-043.sql:    LANGUAGE plpgsql;
+./sourceTest/sql/postgresql/044/.svn/text-base/017=database_version_logs.tsv.svn-base:027	D:\\User\\felmer\\dev-workspace\\openbis/source/sql/postgresql/027/function-027.sql	SUCCESS	2008-11-05 09:18:00.403	-- Creating Functions\\012\\012------------------------------------------------------------------------------------\\012--  Purpose:  Create function RENAME_SEQUENCE() that is required for renaming the sequences belonging to tables\\012------------------------------------------------------------------------------------\\012CREATE FUNCTION RENAME_SEQUENCE(OLD_NAME VARCHAR, NEW_NAME VARCHAR) RETURNS INTEGER AS $$\\012DECLARE\\012  CURR_SEQ_VAL   INTEGER;\\012BEGIN\\012  SELECT INTO CURR_SEQ_VAL NEXTVAL(OLD_NAME);\\012  EXECUTE 'CREATE SEQUENCE ' || NEW_NAME || ' START WITH ' || CURR_SEQ_VAL;\\012  EXECUTE 'DROP SEQUENCE ' || OLD_NAME;\\012  RETURN CURR_SEQ_VAL;\\012END;\\012$$ LANGUAGE 'plpgsql';\\012\\012\\012------------------------------------------------------------------------------------\\012--  Purpose:  Create trigger CONTROLLED_VOCABULARY_CHECK \\012------------------------------------------------------------------------------------\\012\\012CREATE OR REPLACE FUNCTION CONTROLLED_VOCABULARY_CHECK() RETURNS trigger AS $$\\012DECLARE\\012   v_code  CODE;\\012BEGIN\\012\\012   select code into v_code from data_types where id = NEW.daty_id;\\012\\012   -- Check if the data is of type "CONTROLLEDVOCABULARY"\\012   if v_code = 'CONTROLLEDVOCABULARY' then\\012      if NEW.covo_id IS NULL then\\012         RAISE EXCEPTION 'Insert/Update of Property Type (Code: %) failed, as its Data Type is CONTROLLEDVOCABULARY, but it is not linked to a Controlled Vocabulary.', NEW.code;\\012      end if;\\012   end if;\\012\\012   RETURN NEW;\\012\\012END;\\012$$ LANGUAGE 'plpgsql';\\012\\012CREATE TRIGGER CONTROLLED_VOCABULARY_CHECK BEFORE INSERT OR UPDATE ON PROPERTY_TYPES\\012    FOR EACH ROW EXECUTE PROCEDURE CONTROLLED_VOCABULARY_CHECK();\\012\\012\\012------------------------------------------------------------------------------------\\012--  Purpose:  Create trigger EXTERNAL_DATA_STORAGE_FORMAT_CHECK \\012------------------------------------------------------------------------------------\\012\\012CREATE OR REPLACE FUNCTION EXTERNAL_DATA_STORAGE_FORMAT_CHECK() RETURNS trigger AS $$\\012DECLARE\\012   v_covo_code  CODE;\\012   data_code CODE;\\012BEGIN\\012\\012   select code into v_covo_code from controlled_vocabularies\\012      where is_internal_namespace = true and \\012         id = (select covo_id from controlled_vocabulary_terms where id = NEW.cvte_id_stor_fmt);\\012   -- Check if the data storage format is a term of the controlled vocabulary "STORAGE_FORMAT"\\012   if v_covo_code != 'STORAGE_FORMAT' then\\012      select code into data_code from data where id = NEW.data_id; \\012      RAISE EXCEPTION 'Insert/Update of Data (Code: %) failed, as its Storage Format is %, but is required to be STORAGE_FORMAT.', data_code, v_covo_code;\\012   end if;\\012\\012   RETURN NEW;\\012\\012END;\\012$$ LANGUAGE 'plpgsql';\\012\\012CREATE TRIGGER EXTERNAL_DATA_STORAGE_FORMAT_CHECK BEFORE INSERT OR UPDATE ON EXTERNAL_DATA\\012    FOR EACH ROW EXECUTE PROCEDURE EXTERNAL_DATA_STORAGE_FORMAT_CHECK();\\012\\012------------------------------------------------------------------------------------\\012--  Purpose:  Create trigger SAMPLE_CODE_UNIQUENESS_CHECK \\012------------------------------------------------------------------------------------\\012\\012CREATE OR REPLACE FUNCTION SAMPLE_CODE_UNIQUENESS_CHECK() RETURNS trigger AS $$\\012DECLARE\\012   counter  INTEGER;\\012BEGIN\\012\\011IF (NEW.samp_id_part_of is NULL) THEN\\012\\011\\011IF (NEW.dbin_id is not NULL) THEN\\012\\011\\011\\011SELECT count(*) into counter FROM samples \\012\\011\\011\\011\\011where id != NEW.id and code = NEW.code and samp_id_part_of is NULL and dbin_id = NEW.dbin_id;\\012\\011\\011\\011IF (counter > 0) THEN\\012\\011\\011\\011\\011RAISE EXCEPTION 'Insert/Update of Sample (Code: %) failed because database instance sample with the same code already exists.', NEW.code;\\012\\011\\011\\011END IF;\\012\\011\\011ELSIF (NEW.grou_id is not NULL) THEN\\012\\011\\011\\011SELECT count(*) into counter FROM samples \\012\\011\\011\\011\\011where id != NEW.id and code = NEW.code and samp_id_part_of is NULL and grou_id = NEW.grou_id;\\012\\011\\011\\011IF (counter > 0) THEN\\012\\011\\011\\011\\011RAISE EXCEPTION 'Insert/Update of Sample (Code: %) failed because group sample with the same code already exists.', NEW.code;\\012\\011\\011\\011END IF;\\012\\011\\011END IF;\\012        ELSE\\012\\011\\011IF (NEW.dbin_id is not NULL) THEN\\012\\011\\011\\011SELECT count(*) into counter FROM samples \\012\\011\\011\\011\\011where id != NEW.id and code = NEW.code and samp_id_part_of = NEW.samp_id_part_of and dbin_id = NEW.dbin_id;\\012\\011\\011\\011IF (counter > 0) THEN\\012\\011\\011\\011\\011RAISE EXCEPTION 'Insert/Update of Sample (Code: %) failed because database instance sample with the same code and being the part of the same parent already exists.', NEW.code;\\012\\011\\011\\011END IF;\\012\\011\\011ELSIF (NEW.grou_id is not NULL) THEN\\012\\011\\011\\011SELECT count(*) into counter FROM samples \\012\\011\\011\\011\\011where id != NEW.id and code = NEW.code and samp_id_part_of = NEW.samp_id_part_of and grou_id = NEW.grou_id;\\012\\011\\011\\011IF (counter > 0) THEN\\012\\011\\011\\011\\011RAISE EXCEPTION 'Insert/Update of Sample (Code: %) failed because group sample with the same code and being the part of the same parent already exists.', NEW.code;\\012\\011\\011\\011END IF;\\012\\011\\011END IF;\\012        END IF;   \\012   RETURN NEW;\\012END;\\012$$ LANGUAGE 'plpgsql';\\012\\012CREATE TRIGGER SAMPLE_CODE_UNIQUENESS_CHECK BEFORE INSERT OR UPDATE ON SAMPLES\\012    FOR EACH ROW EXECUTE PROCEDURE SAMPLE_CODE_UNIQUENESS_CHECK();\\012	\N
+./sourceTest/sql/postgresql/044/.svn/text-base/017=database_version_logs.tsv.svn-base:028	source/sql/postgresql/migration/migration-027-028.sql	SUCCESS	2008-11-18 13:24:17.508	-- Create EXPERIMENT_ATTACHMENT_CONTENTS.\\012CREATE TABLE EXPERIMENT_ATTACHMENT_CONTENTS (ID TECH_ID NOT NULL,VALUE FILE NOT NULL);\\012CREATE SEQUENCE EXPERIMENT_ATTACHMENT_CONTENT_ID_SEQ;\\012ALTER TABLE EXPERIMENT_ATTACHMENT_CONTENTS ADD CONSTRAINT EXAC_PK PRIMARY KEY(ID);\\012\\012-- Alter EXPERIMENT_ATTACHMENTS by adding the new column which has a NULL constraint.\\012-- The NOT NULL constraint is added later on.\\012ALTER TABLE EXPERIMENT_ATTACHMENTS ADD COLUMN EXAC_ID TECH_ID;\\012\\012-- Does the VALUE migration between EXPERIMENT_ATTACHMENTS to EXPERIMENT_ATTACHMENT_CONTENTS.\\012CREATE OR REPLACE FUNCTION move_exp_att_content() RETURNS integer AS $$\\012DECLARE\\012    rec RECORD;\\012    seq BIGINT;\\012BEGIN\\012  FOR rec IN SELECT id, value FROM EXPERIMENT_ATTACHMENTS LOOP\\012  \\011seq := nextval('EXPERIMENT_ATTACHMENT_CONTENT_ID_SEQ');\\012    INSERT INTO EXPERIMENT_ATTACHMENT_CONTENTS (id, value) VALUES (seq, rec.value);\\012    UPDATE EXPERIMENT_ATTACHMENTS SET exac_id = seq WHERE id = rec.id;\\012  END LOOP;\\012  RETURN 1;\\012END;\\012$$ LANGUAGE 'plpgsql';\\012\\012-- Call the function.\\012SELECT move_exp_att_content();\\012DROP FUNCTION move_exp_att_content();\\012\\012\\012-- Finish EXPERIMENT_ATTACHMENTS changes.\\012ALTER TABLE EXPERIMENT_ATTACHMENTS ADD CONSTRAINT EXAT_CONT_FK FOREIGN KEY (EXAC_ID) REFERENCES EXPERIMENT_ATTACHMENT_CONTENTS(ID);\\012ALTER TABLE EXPERIMENT_ATTACHMENTS DROP COLUMN VALUE;\\012ALTER TABLE EXPERIMENT_ATTACHMENTS ALTER COLUMN EXAC_ID SET NOT NULL;\\012	\N
+./sourceTest/sql/postgresql/044/.svn/text-base/017=database_version_logs.tsv.svn-base:029	source/sql/postgresql/migration/migration-028-029.sql	SUCCESS	2009-03-18 10:50:20.105	-- -------\\012-- add modification_timestamp field to allow edition with Hibernate\\012-- -------\\012\\012ALTER TABLE samples\\012\\011ADD COLUMN modification_timestamp TIME_STAMP DEFAULT CURRENT_TIMESTAMP;\\012\\012ALTER TABLE experiments\\012\\011ADD COLUMN modification_timestamp TIME_STAMP DEFAULT CURRENT_TIMESTAMP;\\012\\012ALTER TABLE materials\\012\\011ADD COLUMN modification_timestamp TIME_STAMP DEFAULT CURRENT_TIMESTAMP;\\012\\012ALTER TABLE experiment_properties\\012\\011ADD COLUMN modification_timestamp TIME_STAMP DEFAULT CURRENT_TIMESTAMP;\\012\\012ALTER TABLE material_properties\\012\\011ADD COLUMN modification_timestamp TIME_STAMP DEFAULT CURRENT_TIMESTAMP;\\012\\012ALTER TABLE sample_properties\\012\\011ADD COLUMN modification_timestamp TIME_STAMP DEFAULT CURRENT_TIMESTAMP;\\012\\012-- -------\\012-- add property data type which references materials\\012-- -------\\012\\012ALTER TABLE property_types\\012\\011ADD COLUMN maty_prop_id tech_id;\\012\\012ALTER TABLE property_types\\012\\011ADD CONSTRAINT prty_maty_fk FOREIGN KEY (maty_prop_id) REFERENCES material_types(id);\\012\\012ALTER TABLE experiment_properties\\012\\011ADD COLUMN mate_prop_id tech_id;\\012\\012ALTER TABLE material_properties\\012\\011ADD COLUMN mate_prop_id tech_id;\\012\\012ALTER TABLE sample_properties\\012\\011ADD COLUMN mate_prop_id tech_id;\\012\\012ALTER TABLE experiment_properties\\012\\011ADD CONSTRAINT expr_mapr_fk FOREIGN KEY (mate_prop_id) REFERENCES materials(id);\\012\\012ALTER TABLE material_properties\\012\\011ADD CONSTRAINT mapr_mapr_fk FOREIGN KEY (mate_prop_id) REFERENCES materials(id);\\012\\012ALTER TABLE sample_properties\\012\\011ADD CONSTRAINT sapr_mapr_fk FOREIGN KEY (mate_prop_id) REFERENCES materials(id);\\012\\012insert into data_types\\012(id\\012 ,code\\012 ,description)\\012 values \\012 (nextval('DATA_TYPE_ID_SEQ')\\012 ,'MATERIAL'\\012 ,'Reference to a material'\\012);\\012\\012ALTER TABLE MATERIAL_PROPERTIES DROP CONSTRAINT MAPR_CK;\\012ALTER TABLE MATERIAL_PROPERTIES ADD CONSTRAINT MAPR_CK CHECK \\012\\011((VALUE IS NOT NULL AND CVTE_ID IS NULL AND MATE_PROP_ID IS NULL) OR \\012\\011 (VALUE IS NULL AND CVTE_ID IS NOT NULL AND MATE_PROP_ID IS NULL) OR\\012\\011 (VALUE IS NULL AND CVTE_ID IS NULL AND MATE_PROP_ID IS NOT NULL)\\012\\011);\\012\\012ALTER TABLE EXPERIMENT_PROPERTIES DROP CONSTRAINT EXPR_CK;\\012ALTER TABLE EXPERIMENT_PROPERTIES ADD CONSTRAINT EXPR_CK CHECK \\012\\011((VALUE IS NOT NULL AND CVTE_ID IS NULL AND MATE_PROP_ID IS NULL) OR \\012\\011 (VALUE IS NULL AND CVTE_ID IS NOT NULL AND MATE_PROP_ID IS NULL) OR\\012\\011 (VALUE IS NULL AND CVTE_ID IS NULL AND MATE_PROP_ID IS NOT NULL)\\012\\011);\\012\\012ALTER TABLE SAMPLE_PROPERTIES DROP CONSTRAINT SAPR_CK;\\012ALTER TABLE SAMPLE_PROPERTIES ADD CONSTRAINT SAPR_CK CHECK \\012\\011((VALUE IS NOT NULL AND CVTE_ID IS NULL AND MATE_PROP_ID IS NULL) OR \\012\\011 (VALUE IS NULL AND CVTE_ID IS NOT NULL AND MATE_PROP_ID IS NULL) OR\\012\\011 (VALUE IS NULL AND CVTE_ID IS NULL AND MATE_PROP_ID IS NOT NULL)\\012\\011);\\012\\012------------------------------------------------------------------------------------\\012--  Purpose:  Create trigger MATERIAL/SAMPLE/EXPERIMENT _PROPERTY_WITH_MATERIAL_DATA_TYPE_CHECK\\012--            It checks that if material property value is assigned to the entity,\\012--\\011\\011\\011\\011\\011\\011then the material type is equal to the one described by property type.\\012------------------------------------------------------------------------------------\\012\\012CREATE OR REPLACE FUNCTION MATERIAL_PROPERTY_WITH_MATERIAL_DATA_TYPE_CHECK() RETURNS trigger AS $$\\012DECLARE\\012   v_type_id  CODE;\\012   v_type_id_prop  CODE;\\012BEGIN\\012   if NEW.mate_prop_id IS NOT NULL then\\012\\011\\011\\011-- find material type id of the property type \\012\\011\\011\\011select pt.maty_prop_id into v_type_id_prop \\012\\011\\011\\011  from material_type_property_types etpt, property_types pt \\012\\011\\011\\011 where NEW.mtpt_id = etpt.id AND etpt.prty_id = pt.id;\\012\\011\\011\\012\\011\\011\\011if v_type_id_prop IS NOT NULL then\\012\\011\\011\\011\\011-- find material type id of the material which consists the entity's property value\\012\\011\\011\\011\\011select entity.maty_id into v_type_id \\012\\011\\011\\011\\011  from materials entity\\012\\011\\011\\011\\011 where NEW.mate_prop_id = entity.id;\\012\\011\\011\\011\\011if v_type_id != v_type_id_prop then\\012\\011\\011\\011\\011\\011RAISE EXCEPTION 'Insert/Update of property value referencing material (id: %) failed, as referenced material type is different than expected (id %, expected id: %).', \\012\\011\\011\\011\\011\\011\\011\\011 NEW.mate_prop_id, v_type_id, v_type_id_prop;\\012\\011\\011\\011\\011end if;\\012\\011\\011\\011end if;\\012   end if;\\012   RETURN NEW;\\012END;\\012$$ LANGUAGE 'plpgsql';\\012\\012CREATE TRIGGER MATERIAL_PROPERTY_WITH_MATERIAL_DATA_TYPE_CHECK BEFORE INSERT OR UPDATE ON material_properties\\012    FOR EACH ROW EXECUTE PROCEDURE MATERIAL_PROPERTY_WITH_MATERIAL_DATA_TYPE_CHECK();\\012    \\012CREATE OR REPLACE FUNCTION SAMPLE_PROPERTY_WITH_MATERIAL_DATA_TYPE_CHECK() RETURNS trigger AS $$\\012DECLARE\\012   v_type_id  CODE;\\012   v_type_id_prop  CODE;\\012BEGIN\\012   if NEW.mate_prop_id IS NOT NULL then\\012\\011\\011\\011-- find material type id of the property type \\012\\011\\011\\011select pt.maty_prop_id into v_type_id_prop \\012\\011\\011\\011  from sample_type_property_types etpt, property_types pt \\012\\011\\011\\011 where NEW.stpt_id = etpt.id AND etpt.prty_id = pt.id;\\012\\011\\011\\012\\011\\011\\011if v_type_id_prop IS NOT NULL then\\012\\011\\011\\011\\011-- find material type id of the material which consists the entity's property value\\012\\011\\011\\011\\011select entity.maty_id into v_type_id \\012\\011\\011\\011\\011  from materials entity\\012\\011\\011\\011\\011 where NEW.mate_prop_id = entity.id;\\012\\011\\011\\011\\011if v_type_id != v_type_id_prop then\\012\\011\\011\\011\\011\\011RAISE EXCEPTION 'Insert/Update of property value referencing material (id: %) failed, as referenced material type is different than expected (id %, expected id: %).', \\012\\011\\011\\011\\011\\011\\011\\011\\011\\011\\011\\011\\011 NEW.mate_prop_id, v_type_id, v_type_id_prop;\\012\\011\\011\\011\\011end if;\\012\\011\\011\\011end if;\\012   end if;\\012   RETURN NEW;\\012END;\\012$$ LANGUAGE 'plpgsql';\\012\\012CREATE TRIGGER SAMPLE_PROPERTY_WITH_MATERIAL_DATA_TYPE_CHECK BEFORE INSERT OR UPDATE ON sample_properties\\012    FOR EACH ROW EXECUTE PROCEDURE SAMPLE_PROPERTY_WITH_MATERIAL_DATA_TYPE_CHECK();\\012    \\012CREATE OR REPLACE FUNCTION EXPERIMENT_PROPERTY_WITH_MATERIAL_DATA_TYPE_CHECK() RETURNS trigger AS $$\\012DECLARE\\012   v_type_id  CODE;\\012   v_type_id_prop  CODE;\\012BEGIN\\012   if NEW.mate_prop_id IS NOT NULL then\\012\\011\\011\\011-- find material type id of the property type \\012\\011\\011\\011select pt.maty_prop_id into v_type_id_prop \\012\\011\\011\\011  from experiment_type_property_types etpt, property_types pt \\012\\011\\011\\011 where NEW.etpt_id = etpt.id AND etpt.prty_id = pt.id;\\012\\011\\011\\012\\011\\011\\011if v_type_id_prop IS NOT NULL then\\012\\011\\011\\011\\011-- find material type id of the material which consists the entity's property value\\012\\011\\011\\011\\011select entity.maty_id into v_type_id \\012\\011\\011\\011\\011  from materials entity\\012\\011\\011\\011\\011 where NEW.mate_prop_id = entity.id;\\012\\011\\011\\011\\011if v_type_id != v_type_id_prop then\\012\\011\\011\\011\\011\\011RAISE EXCEPTION 'Insert/Update of property value referencing material (id: %) failed, as referenced material type is different than expected (id %, expected id: %).', \\012\\011\\011\\011\\011\\011\\011\\011\\011\\011\\011\\011\\011 NEW.mate_prop_id, v_type_id, v_type_id_prop;\\012\\011\\011\\011\\011end if;\\012\\011\\011\\011end if;\\012   end if;\\012   RETURN NEW;\\012END;\\012$$ LANGUAGE 'plpgsql';\\012\\012CREATE TRIGGER EXPERIMENT_PROPERTY_WITH_MATERIAL_DATA_TYPE_CHECK BEFORE INSERT OR UPDATE ON experiment_properties\\012    FOR EACH ROW EXECUTE PROCEDURE EXPERIMENT_PROPERTY_WITH_MATERIAL_DATA_TYPE_CHECK();\\012       \\012-- -------\\012-- remove the reminescents of the OBSERVABLE_TYPE\\012-- -------\\012\\012ALTER TABLE data\\012\\011DROP CONSTRAINT data_obty_fk;\\012\\012ALTER TABLE data_set_types\\012\\011DROP CONSTRAINT obty_pk;\\012\\012ALTER TABLE data_set_types\\012\\011ADD CONSTRAINT dsty_pk PRIMARY KEY (id);\\012\\012ALTER TABLE data\\012\\011ADD CONSTRAINT data_dsty_fk FOREIGN KEY (dsty_id) REFERENCES data_set_types(id);\\012\\012ALTER TABLE data_set_types\\012\\011DROP CONSTRAINT obty_bk_uk;\\012\\012ALTER TABLE data_set_types\\012\\011DROP CONSTRAINT obty_dbin_fk;\\012\\012ALTER TABLE data_set_types\\012\\011ADD CONSTRAINT dsty_bk_uk UNIQUE (code, dbin_id);\\012\\012ALTER TABLE data_set_types\\012\\011ADD CONSTRAINT dsty_dbin_fk FOREIGN KEY (dbin_id) REFERENCES database_instances(id);\\012\\012DROP INDEX data_obty_fk_i;\\012\\012CREATE INDEX data_dsty_fk_i ON data(dsty_id);\\012	\N
+./sourceTest/sql/postgresql/044/.svn/text-base/017=database_version_logs.tsv.svn-base:030	source/sql/postgresql/migration/migration-029-030.sql	SUCCESS	2009-03-23 15:34:44.72	-- -------\\012-- add modification_timestamp field to allow edition with Hibernate\\012-- -------\\012ALTER TABLE data\\012\\011ADD COLUMN modification_timestamp TIME_STAMP DEFAULT CURRENT_TIMESTAMP;\\012ALTER TABLE experiment_types\\012\\011ADD COLUMN modification_timestamp TIME_STAMP DEFAULT CURRENT_TIMESTAMP;\\012ALTER TABLE sample_types\\012\\011ADD COLUMN modification_timestamp TIME_STAMP DEFAULT CURRENT_TIMESTAMP;\\012ALTER TABLE material_types\\012\\011ADD COLUMN modification_timestamp TIME_STAMP DEFAULT CURRENT_TIMESTAMP;\\012ALTER TABLE data_set_types\\012\\011ADD COLUMN modification_timestamp TIME_STAMP DEFAULT CURRENT_TIMESTAMP;\\012ALTER TABLE controlled_vocabularies\\012\\011ADD COLUMN modification_timestamp TIME_STAMP DEFAULT CURRENT_TIMESTAMP;\\012-- -------\\012-- add properties to data sets\\012-- -------\\012CREATE TABLE DATA_SET_PROPERTIES (ID TECH_ID NOT NULL,DS_ID TECH_ID NOT NULL,DSTPT_ID TECH_ID NOT NULL,VALUE GENERIC_VALUE,CVTE_ID TECH_ID, MATE_PROP_ID TECH_ID, PERS_ID_REGISTERER TECH_ID NOT NULL,REGISTRATION_TIMESTAMP TIME_STAMP_DFL NOT NULL DEFAULT CURRENT_TIMESTAMP, MODIFICATION_TIMESTAMP TIME_STAMP DEFAULT CURRENT_TIMESTAMP);\\012CREATE TABLE DATA_SET_TYPE_PROPERTY_TYPES (ID TECH_ID NOT NULL,DSTY_ID TECH_ID NOT NULL,PRTY_ID TECH_ID NOT NULL,IS_MANDATORY BOOLEAN_CHAR NOT NULL DEFAULT 'F',IS_MANAGED_INTERNALLY BOOLEAN_CHAR NOT NULL DEFAULT 'F',PERS_ID_REGISTERER TECH_ID NOT NULL,REGISTRATION_TIMESTAMP TIME_STAMP_DFL NOT NULL DEFAULT CURRENT_TIMESTAMP);\\012\\012CREATE SEQUENCE DATA_SET_PROPERTY_ID_SEQ;\\012CREATE SEQUENCE DSTPT_ID_SEQ;\\012\\012ALTER TABLE DATA_SET_TYPE_PROPERTY_TYPES ADD CONSTRAINT DSTPT_PK PRIMARY KEY(ID);\\012ALTER TABLE DATA_SET_PROPERTIES ADD CONSTRAINT DSPR_PK PRIMARY KEY(ID);\\012\\012ALTER TABLE DATA_SET_TYPE_PROPERTY_TYPES ADD CONSTRAINT DSTPT_BK_UK UNIQUE(DSTY_ID,PRTY_ID);\\012ALTER TABLE DATA_SET_PROPERTIES ADD CONSTRAINT DSPR_BK_UK UNIQUE(DS_ID,DSTPT_ID);\\012\\012\\012ALTER TABLE DATA_SET_TYPE_PROPERTY_TYPES ADD CONSTRAINT DSTPT_DSTY_FK FOREIGN KEY (DSTY_ID) REFERENCES DATA_SET_TYPES(ID);\\012ALTER TABLE DATA_SET_TYPE_PROPERTY_TYPES ADD CONSTRAINT DSTPT_PERS_FK FOREIGN KEY (PERS_ID_REGISTERER) REFERENCES PERSONS(ID);\\012ALTER TABLE DATA_SET_TYPE_PROPERTY_TYPES ADD CONSTRAINT DSTPT_PRTY_FK FOREIGN KEY (PRTY_ID) REFERENCES PROPERTY_TYPES(ID);\\012ALTER TABLE DATA_SET_PROPERTIES ADD CONSTRAINT DSPR_CVTE_FK FOREIGN KEY (CVTE_ID) REFERENCES CONTROLLED_VOCABULARY_TERMS(ID);\\012ALTER TABLE DATA_SET_PROPERTIES ADD CONSTRAINT DSPR_DSTPT_FK FOREIGN KEY (DSTPT_ID) REFERENCES DATA_SET_TYPE_PROPERTY_TYPES(ID) ON DELETE CASCADE;\\012ALTER TABLE DATA_SET_PROPERTIES ADD CONSTRAINT DSPR_DS_FK FOREIGN KEY (DS_ID) REFERENCES DATA(ID);\\012ALTER TABLE DATA_SET_PROPERTIES ADD CONSTRAINT DSPR_PERS_FK FOREIGN KEY (PERS_ID_REGISTERER) REFERENCES PERSONS(ID);\\012ALTER TABLE DATA_SET_PROPERTIES ADD CONSTRAINT DSPR_MAPR_FK FOREIGN KEY (MATE_PROP_ID) REFERENCES MATERIALS(ID);\\012\\012ALTER TABLE DATA_SET_PROPERTIES ADD CONSTRAINT DSPR_CK CHECK \\012\\011((VALUE IS NOT NULL AND CVTE_ID IS NULL AND MATE_PROP_ID IS NULL) OR \\012\\011 (VALUE IS NULL AND CVTE_ID IS NOT NULL AND MATE_PROP_ID IS NULL) OR\\012\\011 (VALUE IS NULL AND CVTE_ID IS NULL AND MATE_PROP_ID IS NOT NULL)\\012\\011);\\012\\012CREATE INDEX DSPR_CVTE_FK_I ON DATA_SET_PROPERTIES (CVTE_ID);\\012CREATE INDEX DSPR_DSTPT_FK_I ON DATA_SET_PROPERTIES (DSTPT_ID);\\012CREATE INDEX DSPR_DS_FK_I ON DATA_SET_PROPERTIES (DS_ID);\\012CREATE INDEX DSPR_PERS_FK_I ON DATA_SET_PROPERTIES (PERS_ID_REGISTERER);\\012CREATE INDEX DSTPT_DSTY_FK_I ON DATA_SET_TYPE_PROPERTY_TYPES (DSTY_ID);\\012CREATE INDEX DSTPT_PERS_FK_I ON DATA_SET_TYPE_PROPERTY_TYPES (PERS_ID_REGISTERER);\\012CREATE INDEX DSTPT_PRTY_FK_I ON DATA_SET_TYPE_PROPERTY_TYPES (PRTY_ID);\\012\\012CREATE OR REPLACE FUNCTION DATA_SET_PROPERTY_WITH_MATERIAL_DATA_TYPE_CHECK() RETURNS trigger AS $$\\012DECLARE\\012   v_type_id  CODE;\\012   v_type_id_prop  CODE;\\012BEGIN\\012   if NEW.mate_prop_id IS NOT NULL then\\012\\011\\011\\011-- find material type id of the property type \\012\\011\\011\\011select pt.maty_prop_id into v_type_id_prop \\012\\011\\011\\011  from data_set_type_property_types dstpt, property_types pt \\012\\011\\011\\011 where NEW.dstpt_id = dstpt.id AND dstpt.prty_id = pt.id;\\012\\011\\011\\012\\011\\011\\011if v_type_id_prop IS NOT NULL then\\012\\011\\011\\011\\011-- find material type id of the material which consists the entity's property value\\012\\011\\011\\011\\011select entity.maty_id into v_type_id \\012\\011\\011\\011\\011  from materials entity\\012\\011\\011\\011\\011 where NEW.mate_prop_id = entity.id;\\012\\011\\011\\011\\011if v_type_id != v_type_id_prop then\\012\\011\\011\\011\\011\\011RAISE EXCEPTION 'Insert/Update of property value referencing material (id: %) failed, as referenced material type is different than expected (id %, expected id: %).', \\012\\011\\011\\011\\011\\011\\011\\011\\011\\011\\011\\011\\011 NEW.mate_prop_id, v_type_id, v_type_id_prop;\\012\\011\\011\\011\\011end if;\\012\\011\\011\\011end if;\\012   end if;\\012   RETURN NEW;\\012END;\\012$$ LANGUAGE 'plpgsql';\\012\\012CREATE TRIGGER DATA_SET_PROPERTY_WITH_MATERIAL_DATA_TYPE_CHECK BEFORE INSERT OR UPDATE ON data_set_properties\\012    FOR EACH ROW EXECUTE PROCEDURE DATA_SET_PROPERTY_WITH_MATERIAL_DATA_TYPE_CHECK();   \\012	\N
+./sourceTest/sql/postgresql/044/.svn/text-base/017=database_version_logs.tsv.svn-base:032	source/sql/postgresql/migration/migration-031-032.sql	SUCCESS	2009-04-09 09:36:36.20	-- -------\\012-- Modify MATERIAL_BATCHES\\012-- -------\\012\\012ALTER TABLE material_batches\\012    DROP COLUMN proc_id;\\012\\012-- -------\\012-- Modify SAMPLES\\012-- -------\\012\\012ALTER TABLE samples\\012    ADD COLUMN expe_id tech_id;\\012\\012ALTER TABLE samples\\012    ADD CONSTRAINT samp_expe_fk FOREIGN KEY (expe_id) REFERENCES experiments(id);\\012\\012CREATE INDEX samp_expe_fk_i ON samples USING btree (expe_id);\\012\\012-- relink samples directly to experiments\\012\\012UPDATE samples\\012SET expe_id = (SELECT e.id FROM experiments e, procedures p, sample_inputs si \\012               WHERE si.samp_id = samples.id AND si.proc_id = p.id AND p.expe_id = e.id AND e.inva_id IS NULL);\\012\\012\\012-- -------\\012-- Modify DATA\\012-- -------\\012\\012ALTER TABLE data\\012    ADD COLUMN expe_id tech_id;\\012\\012ALTER TABLE data\\012    ADD CONSTRAINT data_expe_fk FOREIGN KEY (expe_id) REFERENCES experiments(id);\\012\\012CREATE INDEX data_expe_fk_i ON data USING btree (expe_id);\\012\\012UPDATE data\\012SET expe_id = (SELECT e.id FROM experiments e, procedures p \\012               WHERE data.proc_id_produced_by = p.id AND p.expe_id = e.id);\\012\\012ALTER TABLE data\\012    ALTER COLUMN expe_id SET NOT NULL;\\012\\012ALTER TABLE data\\012    DROP COLUMN proc_id_produced_by;\\012\\012-- -------\\012-- Drop PROCEDURES, PROCEDURE_TYPES, and SAMPLE_INPUTS\\012-- -------\\012\\012DROP TABLE sample_inputs;\\012DROP TABLE procedures;\\012DROP TABLE procedure_types;\\012\\012DROP SEQUENCE procedure_id_seq;\\012DROP SEQUENCE procedure_type_id_seq;\\012\\012-- -------\\012-- Add CODE_SEQ\\012-- -------\\012\\012CREATE SEQUENCE CODE_SEQ;\\012\\012-- -------\\012-- Add new columns to DATA_STORES\\012-- -------\\012\\012ALTER TABLE data_stores\\012    ADD COLUMN remote_url character varying(250),\\012    ADD COLUMN session_token character varying(50),\\012    ADD COLUMN modification_timestamp time_stamp DEFAULT now();\\012\\012UPDATE data_stores\\012SET remote_url = '', session_token='';\\012\\012ALTER TABLE data_stores\\012    ALTER COLUMN remote_url SET NOT NULL,\\012    ALTER COLUMN session_token SET NOT NULL;\\012\\012-- -------\\012-- Drop foreign keys onto DATA_STORES\\012-- -------\\012\\012ALTER TABLE database_instances\\012    DROP COLUMN dast_id;\\012\\012ALTER TABLE groups\\012    DROP COLUMN dast_id;\\012\\012ALTER TABLE projects\\012    DROP COLUMN dast_id;\\012\\012ALTER TABLE experiments\\012    DROP COLUMN dast_id;\\012\\012-- -------\\012-- Add foreign key from DATA onto DATA_STORES\\012-- -------\\012\\012ALTER TABLE data\\012    ADD COLUMN dast_id tech_id;\\012\\012ALTER TABLE data\\012    ADD CONSTRAINT data_dast_fk FOREIGN KEY (dast_id) REFERENCES data_stores(id);\\012\\012UPDATE data\\012SET dast_id = (select id from data_stores where code = 'STANDARD');\\012\\012ALTER TABLE data\\012    ALTER COLUMN dast_id SET NOT NULL;\\012\\012\\012------------------------------------------------------------------------------------\\012--  Purpose:  Replace trigger SAMPLE_CODE_UNIQUENESS_CHECK \\012------------------------------------------------------------------------------------\\012\\012CREATE OR REPLACE FUNCTION SAMPLE_CODE_UNIQUENESS_CHECK() RETURNS trigger AS $$\\012DECLARE\\012   counter  INTEGER;\\012BEGIN\\012    LOCK TABLE samples IN EXCLUSIVE MODE;\\012    IF (NEW.samp_id_part_of is NULL) THEN\\012        IF (NEW.dbin_id is not NULL) THEN\\012            SELECT count(*) into counter FROM samples \\012                where id != NEW.id and code = NEW.code and samp_id_part_of is NULL and dbin_id = NEW.dbin_id;\\012            IF (counter > 0) THEN\\012                RAISE EXCEPTION 'Insert/Update of Sample (Code: %) failed because database instance sample with the same code already exists.', NEW.code;\\012            END IF;\\012        ELSIF (NEW.grou_id is not NULL) THEN\\012            SELECT count(*) into counter FROM samples \\012                where id != NEW.id and code = NEW.code and samp_id_part_of is NULL and grou_id = NEW.grou_id;\\012            IF (counter > 0) THEN\\012                RAISE EXCEPTION 'Insert/Update of Sample (Code: %) failed because group sample with the same code already exists.', NEW.code;\\012            END IF;\\012        END IF;\\012        ELSE\\012        IF (NEW.dbin_id is not NULL) THEN\\012            SELECT count(*) into counter FROM samples \\012                where id != NEW.id and code = NEW.code and samp_id_part_of = NEW.samp_id_part_of and dbin_id = NEW.dbin_id;\\012            IF (counter > 0) THEN\\012                RAISE EXCEPTION 'Insert/Update of Sample (Code: %) failed because database instance sample with the same code and being the part of the same parent already exists.', NEW.code;\\012            END IF;\\012        ELSIF (NEW.grou_id is not NULL) THEN\\012            SELECT count(*) into counter FROM samples \\012                where id != NEW.id and code = NEW.code and samp_id_part_of = NEW.samp_id_part_of and grou_id = NEW.grou_id;\\012            IF (counter > 0) THEN\\012                RAISE EXCEPTION 'Insert/Update of Sample (Code: %) failed because group sample with the same code and being the part of the same parent already exists.', NEW.code;\\012            END IF;\\012        END IF;\\012        END IF;   \\012   RETURN NEW;\\012END;\\012$$ LANGUAGE 'plpgsql';\\012\\012\\012\\012	\N
+./sourceTest/sql/postgresql/044/.svn/text-base/017=database_version_logs.tsv.svn-base:034	source/sql/postgresql/migration/migration-033-034.sql	SUCCESS	2009-05-26 08:32:49.935	------------------------------------------------------------------------------------\\012-- Create sequence for generating permanent identifiers starting with nextval of existing dataset sequence.\\012------------------------------------------------------------------------------------\\012CREATE FUNCTION CREATE_SEQUENCE(EXISTING_SEQUENCE VARCHAR, NEW_SEQUENCE VARCHAR) RETURNS VOID AS $$\\012DECLARE\\012  CURR_SEQ_VAL   INTEGER;\\012BEGIN\\012  SELECT INTO CURR_SEQ_VAL NEXTVAL(EXISTING_SEQUENCE);\\012  EXECUTE 'CREATE SEQUENCE ' || NEW_SEQUENCE || ' START WITH ' || CURR_SEQ_VAL;\\012  RETURN;\\012END;\\012$$ LANGUAGE 'plpgsql';\\012\\012SELECT CREATE_SEQUENCE('DATA_ID_SEQ', 'PERM_ID_SEQ');\\012DROP FUNCTION CREATE_SEQUENCE(VARCHAR, VARCHAR);\\012\\012------------------------------------------------------------------------------------\\012-- Add perm_id columns to samples and experiments.\\012------------------------------------------------------------------------------------\\012ALTER TABLE SAMPLES ADD COLUMN PERM_ID CODE;\\012ALTER TABLE EXPERIMENTS ADD COLUMN PERM_ID CODE;\\012\\012UPDATE SAMPLES SET PERM_ID = to_char(registration_timestamp,'YYYYMMDDHHSSMS') || '-' || NEXTVAL('PERM_ID_SEQ');\\012UPDATE EXPERIMENTS SET PERM_ID = to_char(registration_timestamp,'YYYYMMDDHHSSMS') || '-' || NEXTVAL('PERM_ID_SEQ');\\012ALTER TABLE SAMPLES ALTER COLUMN PERM_ID SET NOT NULL;\\012ALTER TABLE EXPERIMENTS ALTER COLUMN PERM_ID SET NOT NULL;\\012ALTER TABLE SAMPLES ADD CONSTRAINT SAMP_PI_UK UNIQUE(PERM_ID);\\012ALTER TABLE EXPERIMENTS ADD CONSTRAINT EXPE_PI_UK UNIQUE(PERM_ID);\\012\\012\\012------------------------------------------------------------------------------------\\012-- Add column is_chosen_from_list to controlled_vocabularies.\\012------------------------------------------------------------------------------------\\012ALTER TABLE controlled_vocabularies ADD COLUMN is_chosen_from_list BOOLEAN_CHAR NOT NULL DEFAULT TRUE;\\012ALTER TABLE controlled_vocabularies ADD COLUMN source_uri CHARACTER VARYING(250);\\012------------------------------------------------------------------------------------\\012-- Modify Data table - remove arc connection between Sample and Data table, use a flag instead\\012------------------------------------------------------------------------------------\\012\\012-- add new columns\\012\\012ALTER TABLE data\\012    ADD COLUMN is_derived boolean_char;\\012ALTER TABLE data\\012    ADD COLUMN samp_id tech_id;\\012\\012-- update values in new columns\\012\\012UPDATE data\\012    SET is_derived = (samp_id_derived_from IS NOT NULL); \\012UPDATE data\\012    SET samp_id = samp_id_derived_from \\012    WHERE is_derived = 'TRUE';\\012UPDATE data\\012    SET samp_id = samp_id_acquired_from \\012    WHERE is_derived = 'FALSE';\\012\\012-- add constraints and indexes to new columns\\012\\012ALTER TABLE data\\012    ALTER COLUMN is_derived SET NOT NULL;\\012ALTER TABLE data\\012    ALTER COLUMN samp_id SET NOT NULL;   \\012ALTER TABLE data\\012    ADD CONSTRAINT data_samp_fk FOREIGN KEY (samp_id) REFERENCES samples (id);\\012CREATE INDEX data_samp_fk_i ON data USING btree (samp_id);\\012\\012-- remove old columns\\012\\012ALTER TABLE data\\012    DROP COLUMN samp_id_acquired_from;\\012ALTER TABLE data\\012    DROP COLUMN samp_id_derived_from;\\012    \\012------------------------------------------------------------------------------------\\012-- Granting SELECT privilege to group openbis_readonly\\012------------------------------------------------------------------------------------\\012\\012GRANT SELECT ON SEQUENCE attachment_content_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE attachment_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE code_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE controlled_vocabulary_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE cvte_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE data_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE data_set_property_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE data_set_relationship_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE data_set_type_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE data_store_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE data_type_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE database_instance_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE dstpt_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE etpt_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE event_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE experiment_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE experiment_property_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE experiment_type_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE file_format_type_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE group_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE invalidation_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE locator_type_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE material_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE material_property_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE material_type_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE mtpt_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE perm_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE person_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE project_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE property_type_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE role_assignment_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE sample_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE sample_property_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE sample_type_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE stpt_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE attachment_contents TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE attachments TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE controlled_vocabularies TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE controlled_vocabulary_terms TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE data TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE data_set_properties TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE data_set_relationships TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE data_set_type_property_types TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE data_set_types TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE data_stores TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE data_types TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE database_instances TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE database_version_logs TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE events TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE experiment_properties TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE experiment_type_property_types TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE experiment_types TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE experiments TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE external_data TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE file_format_types TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE groups TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE invalidations TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE locator_types TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE material_properties TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE material_type_property_types TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE material_types TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE materials TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE persons TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE projects TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE property_types TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE role_assignments TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE sample_properties TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE sample_type_property_types TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE sample_types TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE samples TO GROUP OPENBIS_READONLY;\\012\\012------------------------------------------------------------------------------------\\012-- Delete MATERIAL_BATCHES table\\012------------------------------------------------------------------------------------\\012\\012-- WARNING: Potential data lost!!!\\012-- WARNING: Potential data lost!!!\\012-- WARNING: Potential data lost!!!\\012\\012DROP TABLE SAMPLE_MATERIAL_BATCHES;\\012DROP TABLE MATERIAL_BATCHES;\\012DROP SEQUENCE MATERIAL_BATCH_ID_SEQ;\\012\\012------------------------------------------------------------------------------------\\012-- Delete MATE_ID_INHIBITOR_OF from table MATERIALS\\012------------------------------------------------------------------------------------\\012\\012-- WARNING: Potential data lost!!!\\012-- WARNING: Potential data lost!!!\\012-- WARNING: Potential data lost!!!\\012\\012ALTER TABLE MATERIALS DROP COLUMN MATE_ID_INHIBITOR_OF;\\012	\N
+./sourceTest/sql/postgresql/044/.svn/text-base/017=database_version_logs.tsv.svn-base:041	source/sql/postgresql/migration/migration-040-041.sql	SUCCESS	2009-09-14 13:48:57.539	-- Create FILTERS table\\012\\012CREATE TABLE FILTERS (ID TECH_ID NOT NULL, DBIN_ID TECH_ID NOT NULL, NAME VARCHAR(200) NOT NULL, DESCRIPTION DESCRIPTION_1000,REGISTRATION_TIMESTAMP TIME_STAMP_DFL NOT NULL DEFAULT CURRENT_TIMESTAMP, PERS_ID_REGISTERER TECH_ID NOT NULL, MODIFICATION_TIMESTAMP TIME_STAMP DEFAULT CURRENT_TIMESTAMP, EXPRESSION VARCHAR(2000) NOT NULL, IS_PUBLIC BOOLEAN NOT NULL, GRID_ID VARCHAR(200) NOT NULL);\\012CREATE SEQUENCE FILTER_ID_SEQ;\\012ALTER TABLE FILTERS ADD CONSTRAINT FILT_PK PRIMARY KEY(ID);\\012ALTER TABLE FILTERS ADD CONSTRAINT FILT_BK_UK UNIQUE(NAME, DBIN_ID, GRID_ID);\\012ALTER TABLE FILTERS ADD CONSTRAINT FILT_PERS_FK FOREIGN KEY (PERS_ID_REGISTERER) REFERENCES PERSONS(ID);\\012ALTER TABLE FILTERS ADD CONSTRAINT FILT_DBIN_FK FOREIGN KEY (DBIN_ID) REFERENCES DATABASE_INSTANCES(ID);\\012CREATE INDEX FILT_PERS_FK_I ON FILTERS (PERS_ID_REGISTERER);\\012CREATE INDEX FILT_DBIN_FK_I ON FILTERS (DBIN_ID);\\012GRANT SELECT ON SEQUENCE filter_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE filters TO GROUP OPENBIS_READONLY;\\012\\012-- Add missing foreign key to role assignments authorization group\\012ALTER TABLE ROLE_ASSIGNMENTS ADD CONSTRAINT ROAS_AG_FK_GRANTEE FOREIGN KEY (AG_ID_GRANTEE) REFERENCES AUTHORIZATION_GROUPS(ID);\\012\\012--------------------------------------------------------------------------------------------------\\012-- Modify dataset connections:\\012-- 1. connection with sample shouldn't be mandatory any more\\012-- 2. introduce an arc condition that dataset cannot be connected with a sample and a parent dataset at the same time\\012--------------------------------------------------------------------------------------------------\\012\\012-- Weaken data-sample connection constraint - allow dataset to have no connection with sample\\012ALTER TABLE data ALTER COLUMN samp_id DROP NOT NULL;\\012\\012-- Remove data-sample connection for datasets that have a parent\\012\\012UPDATE data \\012   SET samp_id = NULL \\012 WHERE id IN (SELECT DISTINCT data_id_child FROM data_set_relationships);\\012\\012-- With PostgreSQL 8.4 one can check that before migration there were no cycles in dataset relationships:\\012--\\012-- WITH RECURSIVE data_set_parents(id, parent_ids, cycle) AS (\\012--         SELECT  r.data_id_child AS id, \\012--                 ARRAY[CAST (r.data_id_parent AS bigint)] AS parent_ids, \\012--                 false AS cycle \\012--         FROM data_set_relationships r\\012--     UNION ALL\\012--         SELECT  r.data_id_child,\\012--                 CAST (r.data_id_parent AS bigint) || p.parent_ids,\\012--                 r.data_id_child = ANY(p.parent_ids)\\012--         FROM data_set_relationships r, data_set_parents p\\012--         WHERE r.data_id_parent = p.id AND NOT cycle\\012-- )\\012-- SELECT count(*) AS cycles FROM data_set_parents WHERE cycle = true;\\012\\012---------------------------------------------------------------------------------------------------\\012--  Purpose:  Create DEFERRED triggers:\\012--            * check_dataset_relationships_on_data_table_modification,\\012--            * check_dataset_relationships_on_relationships_table_modification.\\012--            They check that after all modifications of database (just before commit) \\012--            if 'data'/'data_set_relationships' tables are among modified tables \\012--            dataset is not connected with a sample and a parent dataset at the same time.\\012--            This connections are held in two different tables so simple immediate trigger \\012--            with arc check cannot be used and we need two deferred triggers.\\012----------------------------------------------------------------------------------------------------\\012\\012-- trigger for 'data' table\\012\\012CREATE OR REPLACE FUNCTION check_dataset_relationships_on_data_table_modification() RETURNS trigger AS $$\\012DECLARE\\012\\011counter\\011INTEGER;\\012BEGIN\\012\\011-- if there is a connection with a Sample there should not be any connection with a parent Data Set\\012\\011IF (NEW.samp_id IS NOT NULL) THEN\\012\\011\\011-- count number of parents\\012\\011\\011SELECT count(*) INTO counter \\012\\011\\011\\011FROM data_set_relationships \\012\\011\\011\\011WHERE data_id_child = OLD.id;\\012\\011\\011IF (counter > 0) THEN\\012\\011\\011\\011RAISE EXCEPTION 'Insert/Update of Data Set (Code: %) failed because it cannot be connected with a Sample and a parent Data Set at the same time.', OLD.code;\\012\\011\\011END IF;\\012\\011END IF;\\012  RETURN NEW;\\012END;\\012$$ LANGUAGE 'plpgsql';\\012\\012CREATE CONSTRAINT TRIGGER check_dataset_relationships_on_data_table_modification \\012  AFTER INSERT OR UPDATE ON data\\012\\011DEFERRABLE INITIALLY DEFERRED\\012\\011FOR EACH ROW \\012\\011EXECUTE PROCEDURE check_dataset_relationships_on_data_table_modification();\\012\\012-- trigger for 'data_set_relationships'\\012\\012CREATE OR REPLACE FUNCTION check_dataset_relationships_on_relationships_table_modification() RETURNS trigger AS $$\\012DECLARE\\012\\011counter\\011INTEGER;\\012\\011sample_id\\011TECH_ID;\\012\\011data_code\\011CODE;\\012BEGIN\\012\\011-- child will have a parent added so it should not be connected with any sample\\012\\011SELECT samp_id, code INTO sample_id, data_code \\012\\011\\011FROM data \\012\\011\\011WHERE id = NEW.data_id_child;\\012\\011IF (sample_id IS NOT NULL) THEN\\012\\011\\011RAISE EXCEPTION 'Insert/Update of Data Set (Code: %) failed because it cannot be connected to a Sample and to a parent Data Set at the same time.', data_code;\\012\\011END IF;\\012\\011RETURN NEW;\\012END;\\012$$ LANGUAGE 'plpgsql';\\012  \\012CREATE CONSTRAINT TRIGGER check_dataset_relationships_on_relationships_table_modification \\012  AFTER INSERT OR UPDATE ON data_set_relationships\\012\\011DEFERRABLE INITIALLY DEFERRED\\012\\011FOR EACH ROW \\012\\011EXECUTE PROCEDURE check_dataset_relationships_on_relationships_table_modification();\\012	\N
+./sourceTest/sql/postgresql/044/.svn/text-base/schema-044.sql.svn-base:    LANGUAGE plpgsql;
+./sourceTest/sql/postgresql/044/.svn/text-base/schema-044.sql.svn-base:    LANGUAGE plpgsql;
+./sourceTest/sql/postgresql/044/.svn/text-base/schema-044.sql.svn-base:    LANGUAGE plpgsql;
+./sourceTest/sql/postgresql/044/.svn/text-base/schema-044.sql.svn-base:    LANGUAGE plpgsql;
+./sourceTest/sql/postgresql/044/.svn/text-base/schema-044.sql.svn-base:    LANGUAGE plpgsql;
+./sourceTest/sql/postgresql/044/.svn/text-base/schema-044.sql.svn-base:    LANGUAGE plpgsql;
+./sourceTest/sql/postgresql/044/.svn/text-base/schema-044.sql.svn-base:    LANGUAGE plpgsql;
+./sourceTest/sql/postgresql/044/.svn/text-base/schema-044.sql.svn-base:    LANGUAGE plpgsql;
+./sourceTest/sql/postgresql/044/.svn/text-base/schema-044.sql.svn-base:    LANGUAGE plpgsql;
+./sourceTest/sql/postgresql/044/.svn/text-base/schema-044.sql.svn-base:    LANGUAGE plpgsql;
+./sourceTest/sql/postgresql/044/017=database_version_logs.tsv:027	D:\\User\\felmer\\dev-workspace\\openbis/source/sql/postgresql/027/function-027.sql	SUCCESS	2008-11-05 09:18:00.403	-- Creating Functions\\012\\012------------------------------------------------------------------------------------\\012--  Purpose:  Create function RENAME_SEQUENCE() that is required for renaming the sequences belonging to tables\\012------------------------------------------------------------------------------------\\012CREATE FUNCTION RENAME_SEQUENCE(OLD_NAME VARCHAR, NEW_NAME VARCHAR) RETURNS INTEGER AS $$\\012DECLARE\\012  CURR_SEQ_VAL   INTEGER;\\012BEGIN\\012  SELECT INTO CURR_SEQ_VAL NEXTVAL(OLD_NAME);\\012  EXECUTE 'CREATE SEQUENCE ' || NEW_NAME || ' START WITH ' || CURR_SEQ_VAL;\\012  EXECUTE 'DROP SEQUENCE ' || OLD_NAME;\\012  RETURN CURR_SEQ_VAL;\\012END;\\012$$ LANGUAGE 'plpgsql';\\012\\012\\012------------------------------------------------------------------------------------\\012--  Purpose:  Create trigger CONTROLLED_VOCABULARY_CHECK \\012------------------------------------------------------------------------------------\\012\\012CREATE OR REPLACE FUNCTION CONTROLLED_VOCABULARY_CHECK() RETURNS trigger AS $$\\012DECLARE\\012   v_code  CODE;\\012BEGIN\\012\\012   select code into v_code from data_types where id = NEW.daty_id;\\012\\012   -- Check if the data is of type "CONTROLLEDVOCABULARY"\\012   if v_code = 'CONTROLLEDVOCABULARY' then\\012      if NEW.covo_id IS NULL then\\012         RAISE EXCEPTION 'Insert/Update of Property Type (Code: %) failed, as its Data Type is CONTROLLEDVOCABULARY, but it is not linked to a Controlled Vocabulary.', NEW.code;\\012      end if;\\012   end if;\\012\\012   RETURN NEW;\\012\\012END;\\012$$ LANGUAGE 'plpgsql';\\012\\012CREATE TRIGGER CONTROLLED_VOCABULARY_CHECK BEFORE INSERT OR UPDATE ON PROPERTY_TYPES\\012    FOR EACH ROW EXECUTE PROCEDURE CONTROLLED_VOCABULARY_CHECK();\\012\\012\\012------------------------------------------------------------------------------------\\012--  Purpose:  Create trigger EXTERNAL_DATA_STORAGE_FORMAT_CHECK \\012------------------------------------------------------------------------------------\\012\\012CREATE OR REPLACE FUNCTION EXTERNAL_DATA_STORAGE_FORMAT_CHECK() RETURNS trigger AS $$\\012DECLARE\\012   v_covo_code  CODE;\\012   data_code CODE;\\012BEGIN\\012\\012   select code into v_covo_code from controlled_vocabularies\\012      where is_internal_namespace = true and \\012         id = (select covo_id from controlled_vocabulary_terms where id = NEW.cvte_id_stor_fmt);\\012   -- Check if the data storage format is a term of the controlled vocabulary "STORAGE_FORMAT"\\012   if v_covo_code != 'STORAGE_FORMAT' then\\012      select code into data_code from data where id = NEW.data_id; \\012      RAISE EXCEPTION 'Insert/Update of Data (Code: %) failed, as its Storage Format is %, but is required to be STORAGE_FORMAT.', data_code, v_covo_code;\\012   end if;\\012\\012   RETURN NEW;\\012\\012END;\\012$$ LANGUAGE 'plpgsql';\\012\\012CREATE TRIGGER EXTERNAL_DATA_STORAGE_FORMAT_CHECK BEFORE INSERT OR UPDATE ON EXTERNAL_DATA\\012    FOR EACH ROW EXECUTE PROCEDURE EXTERNAL_DATA_STORAGE_FORMAT_CHECK();\\012\\012------------------------------------------------------------------------------------\\012--  Purpose:  Create trigger SAMPLE_CODE_UNIQUENESS_CHECK \\012------------------------------------------------------------------------------------\\012\\012CREATE OR REPLACE FUNCTION SAMPLE_CODE_UNIQUENESS_CHECK() RETURNS trigger AS $$\\012DECLARE\\012   counter  INTEGER;\\012BEGIN\\012\\011IF (NEW.samp_id_part_of is NULL) THEN\\012\\011\\011IF (NEW.dbin_id is not NULL) THEN\\012\\011\\011\\011SELECT count(*) into counter FROM samples \\012\\011\\011\\011\\011where id != NEW.id and code = NEW.code and samp_id_part_of is NULL and dbin_id = NEW.dbin_id;\\012\\011\\011\\011IF (counter > 0) THEN\\012\\011\\011\\011\\011RAISE EXCEPTION 'Insert/Update of Sample (Code: %) failed because database instance sample with the same code already exists.', NEW.code;\\012\\011\\011\\011END IF;\\012\\011\\011ELSIF (NEW.grou_id is not NULL) THEN\\012\\011\\011\\011SELECT count(*) into counter FROM samples \\012\\011\\011\\011\\011where id != NEW.id and code = NEW.code and samp_id_part_of is NULL and grou_id = NEW.grou_id;\\012\\011\\011\\011IF (counter > 0) THEN\\012\\011\\011\\011\\011RAISE EXCEPTION 'Insert/Update of Sample (Code: %) failed because group sample with the same code already exists.', NEW.code;\\012\\011\\011\\011END IF;\\012\\011\\011END IF;\\012        ELSE\\012\\011\\011IF (NEW.dbin_id is not NULL) THEN\\012\\011\\011\\011SELECT count(*) into counter FROM samples \\012\\011\\011\\011\\011where id != NEW.id and code = NEW.code and samp_id_part_of = NEW.samp_id_part_of and dbin_id = NEW.dbin_id;\\012\\011\\011\\011IF (counter > 0) THEN\\012\\011\\011\\011\\011RAISE EXCEPTION 'Insert/Update of Sample (Code: %) failed because database instance sample with the same code and being the part of the same parent already exists.', NEW.code;\\012\\011\\011\\011END IF;\\012\\011\\011ELSIF (NEW.grou_id is not NULL) THEN\\012\\011\\011\\011SELECT count(*) into counter FROM samples \\012\\011\\011\\011\\011where id != NEW.id and code = NEW.code and samp_id_part_of = NEW.samp_id_part_of and grou_id = NEW.grou_id;\\012\\011\\011\\011IF (counter > 0) THEN\\012\\011\\011\\011\\011RAISE EXCEPTION 'Insert/Update of Sample (Code: %) failed because group sample with the same code and being the part of the same parent already exists.', NEW.code;\\012\\011\\011\\011END IF;\\012\\011\\011END IF;\\012        END IF;   \\012   RETURN NEW;\\012END;\\012$$ LANGUAGE 'plpgsql';\\012\\012CREATE TRIGGER SAMPLE_CODE_UNIQUENESS_CHECK BEFORE INSERT OR UPDATE ON SAMPLES\\012    FOR EACH ROW EXECUTE PROCEDURE SAMPLE_CODE_UNIQUENESS_CHECK();\\012	\N
+./sourceTest/sql/postgresql/044/017=database_version_logs.tsv:028	source/sql/postgresql/migration/migration-027-028.sql	SUCCESS	2008-11-18 13:24:17.508	-- Create EXPERIMENT_ATTACHMENT_CONTENTS.\\012CREATE TABLE EXPERIMENT_ATTACHMENT_CONTENTS (ID TECH_ID NOT NULL,VALUE FILE NOT NULL);\\012CREATE SEQUENCE EXPERIMENT_ATTACHMENT_CONTENT_ID_SEQ;\\012ALTER TABLE EXPERIMENT_ATTACHMENT_CONTENTS ADD CONSTRAINT EXAC_PK PRIMARY KEY(ID);\\012\\012-- Alter EXPERIMENT_ATTACHMENTS by adding the new column which has a NULL constraint.\\012-- The NOT NULL constraint is added later on.\\012ALTER TABLE EXPERIMENT_ATTACHMENTS ADD COLUMN EXAC_ID TECH_ID;\\012\\012-- Does the VALUE migration between EXPERIMENT_ATTACHMENTS to EXPERIMENT_ATTACHMENT_CONTENTS.\\012CREATE OR REPLACE FUNCTION move_exp_att_content() RETURNS integer AS $$\\012DECLARE\\012    rec RECORD;\\012    seq BIGINT;\\012BEGIN\\012  FOR rec IN SELECT id, value FROM EXPERIMENT_ATTACHMENTS LOOP\\012  \\011seq := nextval('EXPERIMENT_ATTACHMENT_CONTENT_ID_SEQ');\\012    INSERT INTO EXPERIMENT_ATTACHMENT_CONTENTS (id, value) VALUES (seq, rec.value);\\012    UPDATE EXPERIMENT_ATTACHMENTS SET exac_id = seq WHERE id = rec.id;\\012  END LOOP;\\012  RETURN 1;\\012END;\\012$$ LANGUAGE 'plpgsql';\\012\\012-- Call the function.\\012SELECT move_exp_att_content();\\012DROP FUNCTION move_exp_att_content();\\012\\012\\012-- Finish EXPERIMENT_ATTACHMENTS changes.\\012ALTER TABLE EXPERIMENT_ATTACHMENTS ADD CONSTRAINT EXAT_CONT_FK FOREIGN KEY (EXAC_ID) REFERENCES EXPERIMENT_ATTACHMENT_CONTENTS(ID);\\012ALTER TABLE EXPERIMENT_ATTACHMENTS DROP COLUMN VALUE;\\012ALTER TABLE EXPERIMENT_ATTACHMENTS ALTER COLUMN EXAC_ID SET NOT NULL;\\012	\N
+./sourceTest/sql/postgresql/044/017=database_version_logs.tsv:029	source/sql/postgresql/migration/migration-028-029.sql	SUCCESS	2009-03-18 10:50:20.105	-- -------\\012-- add modification_timestamp field to allow edition with Hibernate\\012-- -------\\012\\012ALTER TABLE samples\\012\\011ADD COLUMN modification_timestamp TIME_STAMP DEFAULT CURRENT_TIMESTAMP;\\012\\012ALTER TABLE experiments\\012\\011ADD COLUMN modification_timestamp TIME_STAMP DEFAULT CURRENT_TIMESTAMP;\\012\\012ALTER TABLE materials\\012\\011ADD COLUMN modification_timestamp TIME_STAMP DEFAULT CURRENT_TIMESTAMP;\\012\\012ALTER TABLE experiment_properties\\012\\011ADD COLUMN modification_timestamp TIME_STAMP DEFAULT CURRENT_TIMESTAMP;\\012\\012ALTER TABLE material_properties\\012\\011ADD COLUMN modification_timestamp TIME_STAMP DEFAULT CURRENT_TIMESTAMP;\\012\\012ALTER TABLE sample_properties\\012\\011ADD COLUMN modification_timestamp TIME_STAMP DEFAULT CURRENT_TIMESTAMP;\\012\\012-- -------\\012-- add property data type which references materials\\012-- -------\\012\\012ALTER TABLE property_types\\012\\011ADD COLUMN maty_prop_id tech_id;\\012\\012ALTER TABLE property_types\\012\\011ADD CONSTRAINT prty_maty_fk FOREIGN KEY (maty_prop_id) REFERENCES material_types(id);\\012\\012ALTER TABLE experiment_properties\\012\\011ADD COLUMN mate_prop_id tech_id;\\012\\012ALTER TABLE material_properties\\012\\011ADD COLUMN mate_prop_id tech_id;\\012\\012ALTER TABLE sample_properties\\012\\011ADD COLUMN mate_prop_id tech_id;\\012\\012ALTER TABLE experiment_properties\\012\\011ADD CONSTRAINT expr_mapr_fk FOREIGN KEY (mate_prop_id) REFERENCES materials(id);\\012\\012ALTER TABLE material_properties\\012\\011ADD CONSTRAINT mapr_mapr_fk FOREIGN KEY (mate_prop_id) REFERENCES materials(id);\\012\\012ALTER TABLE sample_properties\\012\\011ADD CONSTRAINT sapr_mapr_fk FOREIGN KEY (mate_prop_id) REFERENCES materials(id);\\012\\012insert into data_types\\012(id\\012 ,code\\012 ,description)\\012 values \\012 (nextval('DATA_TYPE_ID_SEQ')\\012 ,'MATERIAL'\\012 ,'Reference to a material'\\012);\\012\\012ALTER TABLE MATERIAL_PROPERTIES DROP CONSTRAINT MAPR_CK;\\012ALTER TABLE MATERIAL_PROPERTIES ADD CONSTRAINT MAPR_CK CHECK \\012\\011((VALUE IS NOT NULL AND CVTE_ID IS NULL AND MATE_PROP_ID IS NULL) OR \\012\\011 (VALUE IS NULL AND CVTE_ID IS NOT NULL AND MATE_PROP_ID IS NULL) OR\\012\\011 (VALUE IS NULL AND CVTE_ID IS NULL AND MATE_PROP_ID IS NOT NULL)\\012\\011);\\012\\012ALTER TABLE EXPERIMENT_PROPERTIES DROP CONSTRAINT EXPR_CK;\\012ALTER TABLE EXPERIMENT_PROPERTIES ADD CONSTRAINT EXPR_CK CHECK \\012\\011((VALUE IS NOT NULL AND CVTE_ID IS NULL AND MATE_PROP_ID IS NULL) OR \\012\\011 (VALUE IS NULL AND CVTE_ID IS NOT NULL AND MATE_PROP_ID IS NULL) OR\\012\\011 (VALUE IS NULL AND CVTE_ID IS NULL AND MATE_PROP_ID IS NOT NULL)\\012\\011);\\012\\012ALTER TABLE SAMPLE_PROPERTIES DROP CONSTRAINT SAPR_CK;\\012ALTER TABLE SAMPLE_PROPERTIES ADD CONSTRAINT SAPR_CK CHECK \\012\\011((VALUE IS NOT NULL AND CVTE_ID IS NULL AND MATE_PROP_ID IS NULL) OR \\012\\011 (VALUE IS NULL AND CVTE_ID IS NOT NULL AND MATE_PROP_ID IS NULL) OR\\012\\011 (VALUE IS NULL AND CVTE_ID IS NULL AND MATE_PROP_ID IS NOT NULL)\\012\\011);\\012\\012------------------------------------------------------------------------------------\\012--  Purpose:  Create trigger MATERIAL/SAMPLE/EXPERIMENT _PROPERTY_WITH_MATERIAL_DATA_TYPE_CHECK\\012--            It checks that if material property value is assigned to the entity,\\012--\\011\\011\\011\\011\\011\\011then the material type is equal to the one described by property type.\\012------------------------------------------------------------------------------------\\012\\012CREATE OR REPLACE FUNCTION MATERIAL_PROPERTY_WITH_MATERIAL_DATA_TYPE_CHECK() RETURNS trigger AS $$\\012DECLARE\\012   v_type_id  CODE;\\012   v_type_id_prop  CODE;\\012BEGIN\\012   if NEW.mate_prop_id IS NOT NULL then\\012\\011\\011\\011-- find material type id of the property type \\012\\011\\011\\011select pt.maty_prop_id into v_type_id_prop \\012\\011\\011\\011  from material_type_property_types etpt, property_types pt \\012\\011\\011\\011 where NEW.mtpt_id = etpt.id AND etpt.prty_id = pt.id;\\012\\011\\011\\012\\011\\011\\011if v_type_id_prop IS NOT NULL then\\012\\011\\011\\011\\011-- find material type id of the material which consists the entity's property value\\012\\011\\011\\011\\011select entity.maty_id into v_type_id \\012\\011\\011\\011\\011  from materials entity\\012\\011\\011\\011\\011 where NEW.mate_prop_id = entity.id;\\012\\011\\011\\011\\011if v_type_id != v_type_id_prop then\\012\\011\\011\\011\\011\\011RAISE EXCEPTION 'Insert/Update of property value referencing material (id: %) failed, as referenced material type is different than expected (id %, expected id: %).', \\012\\011\\011\\011\\011\\011\\011\\011 NEW.mate_prop_id, v_type_id, v_type_id_prop;\\012\\011\\011\\011\\011end if;\\012\\011\\011\\011end if;\\012   end if;\\012   RETURN NEW;\\012END;\\012$$ LANGUAGE 'plpgsql';\\012\\012CREATE TRIGGER MATERIAL_PROPERTY_WITH_MATERIAL_DATA_TYPE_CHECK BEFORE INSERT OR UPDATE ON material_properties\\012    FOR EACH ROW EXECUTE PROCEDURE MATERIAL_PROPERTY_WITH_MATERIAL_DATA_TYPE_CHECK();\\012    \\012CREATE OR REPLACE FUNCTION SAMPLE_PROPERTY_WITH_MATERIAL_DATA_TYPE_CHECK() RETURNS trigger AS $$\\012DECLARE\\012   v_type_id  CODE;\\012   v_type_id_prop  CODE;\\012BEGIN\\012   if NEW.mate_prop_id IS NOT NULL then\\012\\011\\011\\011-- find material type id of the property type \\012\\011\\011\\011select pt.maty_prop_id into v_type_id_prop \\012\\011\\011\\011  from sample_type_property_types etpt, property_types pt \\012\\011\\011\\011 where NEW.stpt_id = etpt.id AND etpt.prty_id = pt.id;\\012\\011\\011\\012\\011\\011\\011if v_type_id_prop IS NOT NULL then\\012\\011\\011\\011\\011-- find material type id of the material which consists the entity's property value\\012\\011\\011\\011\\011select entity.maty_id into v_type_id \\012\\011\\011\\011\\011  from materials entity\\012\\011\\011\\011\\011 where NEW.mate_prop_id = entity.id;\\012\\011\\011\\011\\011if v_type_id != v_type_id_prop then\\012\\011\\011\\011\\011\\011RAISE EXCEPTION 'Insert/Update of property value referencing material (id: %) failed, as referenced material type is different than expected (id %, expected id: %).', \\012\\011\\011\\011\\011\\011\\011\\011\\011\\011\\011\\011\\011 NEW.mate_prop_id, v_type_id, v_type_id_prop;\\012\\011\\011\\011\\011end if;\\012\\011\\011\\011end if;\\012   end if;\\012   RETURN NEW;\\012END;\\012$$ LANGUAGE 'plpgsql';\\012\\012CREATE TRIGGER SAMPLE_PROPERTY_WITH_MATERIAL_DATA_TYPE_CHECK BEFORE INSERT OR UPDATE ON sample_properties\\012    FOR EACH ROW EXECUTE PROCEDURE SAMPLE_PROPERTY_WITH_MATERIAL_DATA_TYPE_CHECK();\\012    \\012CREATE OR REPLACE FUNCTION EXPERIMENT_PROPERTY_WITH_MATERIAL_DATA_TYPE_CHECK() RETURNS trigger AS $$\\012DECLARE\\012   v_type_id  CODE;\\012   v_type_id_prop  CODE;\\012BEGIN\\012   if NEW.mate_prop_id IS NOT NULL then\\012\\011\\011\\011-- find material type id of the property type \\012\\011\\011\\011select pt.maty_prop_id into v_type_id_prop \\012\\011\\011\\011  from experiment_type_property_types etpt, property_types pt \\012\\011\\011\\011 where NEW.etpt_id = etpt.id AND etpt.prty_id = pt.id;\\012\\011\\011\\012\\011\\011\\011if v_type_id_prop IS NOT NULL then\\012\\011\\011\\011\\011-- find material type id of the material which consists the entity's property value\\012\\011\\011\\011\\011select entity.maty_id into v_type_id \\012\\011\\011\\011\\011  from materials entity\\012\\011\\011\\011\\011 where NEW.mate_prop_id = entity.id;\\012\\011\\011\\011\\011if v_type_id != v_type_id_prop then\\012\\011\\011\\011\\011\\011RAISE EXCEPTION 'Insert/Update of property value referencing material (id: %) failed, as referenced material type is different than expected (id %, expected id: %).', \\012\\011\\011\\011\\011\\011\\011\\011\\011\\011\\011\\011\\011 NEW.mate_prop_id, v_type_id, v_type_id_prop;\\012\\011\\011\\011\\011end if;\\012\\011\\011\\011end if;\\012   end if;\\012   RETURN NEW;\\012END;\\012$$ LANGUAGE 'plpgsql';\\012\\012CREATE TRIGGER EXPERIMENT_PROPERTY_WITH_MATERIAL_DATA_TYPE_CHECK BEFORE INSERT OR UPDATE ON experiment_properties\\012    FOR EACH ROW EXECUTE PROCEDURE EXPERIMENT_PROPERTY_WITH_MATERIAL_DATA_TYPE_CHECK();\\012       \\012-- -------\\012-- remove the reminescents of the OBSERVABLE_TYPE\\012-- -------\\012\\012ALTER TABLE data\\012\\011DROP CONSTRAINT data_obty_fk;\\012\\012ALTER TABLE data_set_types\\012\\011DROP CONSTRAINT obty_pk;\\012\\012ALTER TABLE data_set_types\\012\\011ADD CONSTRAINT dsty_pk PRIMARY KEY (id);\\012\\012ALTER TABLE data\\012\\011ADD CONSTRAINT data_dsty_fk FOREIGN KEY (dsty_id) REFERENCES data_set_types(id);\\012\\012ALTER TABLE data_set_types\\012\\011DROP CONSTRAINT obty_bk_uk;\\012\\012ALTER TABLE data_set_types\\012\\011DROP CONSTRAINT obty_dbin_fk;\\012\\012ALTER TABLE data_set_types\\012\\011ADD CONSTRAINT dsty_bk_uk UNIQUE (code, dbin_id);\\012\\012ALTER TABLE data_set_types\\012\\011ADD CONSTRAINT dsty_dbin_fk FOREIGN KEY (dbin_id) REFERENCES database_instances(id);\\012\\012DROP INDEX data_obty_fk_i;\\012\\012CREATE INDEX data_dsty_fk_i ON data(dsty_id);\\012	\N
+./sourceTest/sql/postgresql/044/017=database_version_logs.tsv:030	source/sql/postgresql/migration/migration-029-030.sql	SUCCESS	2009-03-23 15:34:44.72	-- -------\\012-- add modification_timestamp field to allow edition with Hibernate\\012-- -------\\012ALTER TABLE data\\012\\011ADD COLUMN modification_timestamp TIME_STAMP DEFAULT CURRENT_TIMESTAMP;\\012ALTER TABLE experiment_types\\012\\011ADD COLUMN modification_timestamp TIME_STAMP DEFAULT CURRENT_TIMESTAMP;\\012ALTER TABLE sample_types\\012\\011ADD COLUMN modification_timestamp TIME_STAMP DEFAULT CURRENT_TIMESTAMP;\\012ALTER TABLE material_types\\012\\011ADD COLUMN modification_timestamp TIME_STAMP DEFAULT CURRENT_TIMESTAMP;\\012ALTER TABLE data_set_types\\012\\011ADD COLUMN modification_timestamp TIME_STAMP DEFAULT CURRENT_TIMESTAMP;\\012ALTER TABLE controlled_vocabularies\\012\\011ADD COLUMN modification_timestamp TIME_STAMP DEFAULT CURRENT_TIMESTAMP;\\012-- -------\\012-- add properties to data sets\\012-- -------\\012CREATE TABLE DATA_SET_PROPERTIES (ID TECH_ID NOT NULL,DS_ID TECH_ID NOT NULL,DSTPT_ID TECH_ID NOT NULL,VALUE GENERIC_VALUE,CVTE_ID TECH_ID, MATE_PROP_ID TECH_ID, PERS_ID_REGISTERER TECH_ID NOT NULL,REGISTRATION_TIMESTAMP TIME_STAMP_DFL NOT NULL DEFAULT CURRENT_TIMESTAMP, MODIFICATION_TIMESTAMP TIME_STAMP DEFAULT CURRENT_TIMESTAMP);\\012CREATE TABLE DATA_SET_TYPE_PROPERTY_TYPES (ID TECH_ID NOT NULL,DSTY_ID TECH_ID NOT NULL,PRTY_ID TECH_ID NOT NULL,IS_MANDATORY BOOLEAN_CHAR NOT NULL DEFAULT 'F',IS_MANAGED_INTERNALLY BOOLEAN_CHAR NOT NULL DEFAULT 'F',PERS_ID_REGISTERER TECH_ID NOT NULL,REGISTRATION_TIMESTAMP TIME_STAMP_DFL NOT NULL DEFAULT CURRENT_TIMESTAMP);\\012\\012CREATE SEQUENCE DATA_SET_PROPERTY_ID_SEQ;\\012CREATE SEQUENCE DSTPT_ID_SEQ;\\012\\012ALTER TABLE DATA_SET_TYPE_PROPERTY_TYPES ADD CONSTRAINT DSTPT_PK PRIMARY KEY(ID);\\012ALTER TABLE DATA_SET_PROPERTIES ADD CONSTRAINT DSPR_PK PRIMARY KEY(ID);\\012\\012ALTER TABLE DATA_SET_TYPE_PROPERTY_TYPES ADD CONSTRAINT DSTPT_BK_UK UNIQUE(DSTY_ID,PRTY_ID);\\012ALTER TABLE DATA_SET_PROPERTIES ADD CONSTRAINT DSPR_BK_UK UNIQUE(DS_ID,DSTPT_ID);\\012\\012\\012ALTER TABLE DATA_SET_TYPE_PROPERTY_TYPES ADD CONSTRAINT DSTPT_DSTY_FK FOREIGN KEY (DSTY_ID) REFERENCES DATA_SET_TYPES(ID);\\012ALTER TABLE DATA_SET_TYPE_PROPERTY_TYPES ADD CONSTRAINT DSTPT_PERS_FK FOREIGN KEY (PERS_ID_REGISTERER) REFERENCES PERSONS(ID);\\012ALTER TABLE DATA_SET_TYPE_PROPERTY_TYPES ADD CONSTRAINT DSTPT_PRTY_FK FOREIGN KEY (PRTY_ID) REFERENCES PROPERTY_TYPES(ID);\\012ALTER TABLE DATA_SET_PROPERTIES ADD CONSTRAINT DSPR_CVTE_FK FOREIGN KEY (CVTE_ID) REFERENCES CONTROLLED_VOCABULARY_TERMS(ID);\\012ALTER TABLE DATA_SET_PROPERTIES ADD CONSTRAINT DSPR_DSTPT_FK FOREIGN KEY (DSTPT_ID) REFERENCES DATA_SET_TYPE_PROPERTY_TYPES(ID) ON DELETE CASCADE;\\012ALTER TABLE DATA_SET_PROPERTIES ADD CONSTRAINT DSPR_DS_FK FOREIGN KEY (DS_ID) REFERENCES DATA(ID);\\012ALTER TABLE DATA_SET_PROPERTIES ADD CONSTRAINT DSPR_PERS_FK FOREIGN KEY (PERS_ID_REGISTERER) REFERENCES PERSONS(ID);\\012ALTER TABLE DATA_SET_PROPERTIES ADD CONSTRAINT DSPR_MAPR_FK FOREIGN KEY (MATE_PROP_ID) REFERENCES MATERIALS(ID);\\012\\012ALTER TABLE DATA_SET_PROPERTIES ADD CONSTRAINT DSPR_CK CHECK \\012\\011((VALUE IS NOT NULL AND CVTE_ID IS NULL AND MATE_PROP_ID IS NULL) OR \\012\\011 (VALUE IS NULL AND CVTE_ID IS NOT NULL AND MATE_PROP_ID IS NULL) OR\\012\\011 (VALUE IS NULL AND CVTE_ID IS NULL AND MATE_PROP_ID IS NOT NULL)\\012\\011);\\012\\012CREATE INDEX DSPR_CVTE_FK_I ON DATA_SET_PROPERTIES (CVTE_ID);\\012CREATE INDEX DSPR_DSTPT_FK_I ON DATA_SET_PROPERTIES (DSTPT_ID);\\012CREATE INDEX DSPR_DS_FK_I ON DATA_SET_PROPERTIES (DS_ID);\\012CREATE INDEX DSPR_PERS_FK_I ON DATA_SET_PROPERTIES (PERS_ID_REGISTERER);\\012CREATE INDEX DSTPT_DSTY_FK_I ON DATA_SET_TYPE_PROPERTY_TYPES (DSTY_ID);\\012CREATE INDEX DSTPT_PERS_FK_I ON DATA_SET_TYPE_PROPERTY_TYPES (PERS_ID_REGISTERER);\\012CREATE INDEX DSTPT_PRTY_FK_I ON DATA_SET_TYPE_PROPERTY_TYPES (PRTY_ID);\\012\\012CREATE OR REPLACE FUNCTION DATA_SET_PROPERTY_WITH_MATERIAL_DATA_TYPE_CHECK() RETURNS trigger AS $$\\012DECLARE\\012   v_type_id  CODE;\\012   v_type_id_prop  CODE;\\012BEGIN\\012   if NEW.mate_prop_id IS NOT NULL then\\012\\011\\011\\011-- find material type id of the property type \\012\\011\\011\\011select pt.maty_prop_id into v_type_id_prop \\012\\011\\011\\011  from data_set_type_property_types dstpt, property_types pt \\012\\011\\011\\011 where NEW.dstpt_id = dstpt.id AND dstpt.prty_id = pt.id;\\012\\011\\011\\012\\011\\011\\011if v_type_id_prop IS NOT NULL then\\012\\011\\011\\011\\011-- find material type id of the material which consists the entity's property value\\012\\011\\011\\011\\011select entity.maty_id into v_type_id \\012\\011\\011\\011\\011  from materials entity\\012\\011\\011\\011\\011 where NEW.mate_prop_id = entity.id;\\012\\011\\011\\011\\011if v_type_id != v_type_id_prop then\\012\\011\\011\\011\\011\\011RAISE EXCEPTION 'Insert/Update of property value referencing material (id: %) failed, as referenced material type is different than expected (id %, expected id: %).', \\012\\011\\011\\011\\011\\011\\011\\011\\011\\011\\011\\011\\011 NEW.mate_prop_id, v_type_id, v_type_id_prop;\\012\\011\\011\\011\\011end if;\\012\\011\\011\\011end if;\\012   end if;\\012   RETURN NEW;\\012END;\\012$$ LANGUAGE 'plpgsql';\\012\\012CREATE TRIGGER DATA_SET_PROPERTY_WITH_MATERIAL_DATA_TYPE_CHECK BEFORE INSERT OR UPDATE ON data_set_properties\\012    FOR EACH ROW EXECUTE PROCEDURE DATA_SET_PROPERTY_WITH_MATERIAL_DATA_TYPE_CHECK();   \\012	\N
+./sourceTest/sql/postgresql/044/017=database_version_logs.tsv:032	source/sql/postgresql/migration/migration-031-032.sql	SUCCESS	2009-04-09 09:36:36.20	-- -------\\012-- Modify MATERIAL_BATCHES\\012-- -------\\012\\012ALTER TABLE material_batches\\012    DROP COLUMN proc_id;\\012\\012-- -------\\012-- Modify SAMPLES\\012-- -------\\012\\012ALTER TABLE samples\\012    ADD COLUMN expe_id tech_id;\\012\\012ALTER TABLE samples\\012    ADD CONSTRAINT samp_expe_fk FOREIGN KEY (expe_id) REFERENCES experiments(id);\\012\\012CREATE INDEX samp_expe_fk_i ON samples USING btree (expe_id);\\012\\012-- relink samples directly to experiments\\012\\012UPDATE samples\\012SET expe_id = (SELECT e.id FROM experiments e, procedures p, sample_inputs si \\012               WHERE si.samp_id = samples.id AND si.proc_id = p.id AND p.expe_id = e.id AND e.inva_id IS NULL);\\012\\012\\012-- -------\\012-- Modify DATA\\012-- -------\\012\\012ALTER TABLE data\\012    ADD COLUMN expe_id tech_id;\\012\\012ALTER TABLE data\\012    ADD CONSTRAINT data_expe_fk FOREIGN KEY (expe_id) REFERENCES experiments(id);\\012\\012CREATE INDEX data_expe_fk_i ON data USING btree (expe_id);\\012\\012UPDATE data\\012SET expe_id = (SELECT e.id FROM experiments e, procedures p \\012               WHERE data.proc_id_produced_by = p.id AND p.expe_id = e.id);\\012\\012ALTER TABLE data\\012    ALTER COLUMN expe_id SET NOT NULL;\\012\\012ALTER TABLE data\\012    DROP COLUMN proc_id_produced_by;\\012\\012-- -------\\012-- Drop PROCEDURES, PROCEDURE_TYPES, and SAMPLE_INPUTS\\012-- -------\\012\\012DROP TABLE sample_inputs;\\012DROP TABLE procedures;\\012DROP TABLE procedure_types;\\012\\012DROP SEQUENCE procedure_id_seq;\\012DROP SEQUENCE procedure_type_id_seq;\\012\\012-- -------\\012-- Add CODE_SEQ\\012-- -------\\012\\012CREATE SEQUENCE CODE_SEQ;\\012\\012-- -------\\012-- Add new columns to DATA_STORES\\012-- -------\\012\\012ALTER TABLE data_stores\\012    ADD COLUMN remote_url character varying(250),\\012    ADD COLUMN session_token character varying(50),\\012    ADD COLUMN modification_timestamp time_stamp DEFAULT now();\\012\\012UPDATE data_stores\\012SET remote_url = '', session_token='';\\012\\012ALTER TABLE data_stores\\012    ALTER COLUMN remote_url SET NOT NULL,\\012    ALTER COLUMN session_token SET NOT NULL;\\012\\012-- -------\\012-- Drop foreign keys onto DATA_STORES\\012-- -------\\012\\012ALTER TABLE database_instances\\012    DROP COLUMN dast_id;\\012\\012ALTER TABLE groups\\012    DROP COLUMN dast_id;\\012\\012ALTER TABLE projects\\012    DROP COLUMN dast_id;\\012\\012ALTER TABLE experiments\\012    DROP COLUMN dast_id;\\012\\012-- -------\\012-- Add foreign key from DATA onto DATA_STORES\\012-- -------\\012\\012ALTER TABLE data\\012    ADD COLUMN dast_id tech_id;\\012\\012ALTER TABLE data\\012    ADD CONSTRAINT data_dast_fk FOREIGN KEY (dast_id) REFERENCES data_stores(id);\\012\\012UPDATE data\\012SET dast_id = (select id from data_stores where code = 'STANDARD');\\012\\012ALTER TABLE data\\012    ALTER COLUMN dast_id SET NOT NULL;\\012\\012\\012------------------------------------------------------------------------------------\\012--  Purpose:  Replace trigger SAMPLE_CODE_UNIQUENESS_CHECK \\012------------------------------------------------------------------------------------\\012\\012CREATE OR REPLACE FUNCTION SAMPLE_CODE_UNIQUENESS_CHECK() RETURNS trigger AS $$\\012DECLARE\\012   counter  INTEGER;\\012BEGIN\\012    LOCK TABLE samples IN EXCLUSIVE MODE;\\012    IF (NEW.samp_id_part_of is NULL) THEN\\012        IF (NEW.dbin_id is not NULL) THEN\\012            SELECT count(*) into counter FROM samples \\012                where id != NEW.id and code = NEW.code and samp_id_part_of is NULL and dbin_id = NEW.dbin_id;\\012            IF (counter > 0) THEN\\012                RAISE EXCEPTION 'Insert/Update of Sample (Code: %) failed because database instance sample with the same code already exists.', NEW.code;\\012            END IF;\\012        ELSIF (NEW.grou_id is not NULL) THEN\\012            SELECT count(*) into counter FROM samples \\012                where id != NEW.id and code = NEW.code and samp_id_part_of is NULL and grou_id = NEW.grou_id;\\012            IF (counter > 0) THEN\\012                RAISE EXCEPTION 'Insert/Update of Sample (Code: %) failed because group sample with the same code already exists.', NEW.code;\\012            END IF;\\012        END IF;\\012        ELSE\\012        IF (NEW.dbin_id is not NULL) THEN\\012            SELECT count(*) into counter FROM samples \\012                where id != NEW.id and code = NEW.code and samp_id_part_of = NEW.samp_id_part_of and dbin_id = NEW.dbin_id;\\012            IF (counter > 0) THEN\\012                RAISE EXCEPTION 'Insert/Update of Sample (Code: %) failed because database instance sample with the same code and being the part of the same parent already exists.', NEW.code;\\012            END IF;\\012        ELSIF (NEW.grou_id is not NULL) THEN\\012            SELECT count(*) into counter FROM samples \\012                where id != NEW.id and code = NEW.code and samp_id_part_of = NEW.samp_id_part_of and grou_id = NEW.grou_id;\\012            IF (counter > 0) THEN\\012                RAISE EXCEPTION 'Insert/Update of Sample (Code: %) failed because group sample with the same code and being the part of the same parent already exists.', NEW.code;\\012            END IF;\\012        END IF;\\012        END IF;   \\012   RETURN NEW;\\012END;\\012$$ LANGUAGE 'plpgsql';\\012\\012\\012\\012	\N
+./sourceTest/sql/postgresql/044/017=database_version_logs.tsv:034	source/sql/postgresql/migration/migration-033-034.sql	SUCCESS	2009-05-26 08:32:49.935	------------------------------------------------------------------------------------\\012-- Create sequence for generating permanent identifiers starting with nextval of existing dataset sequence.\\012------------------------------------------------------------------------------------\\012CREATE FUNCTION CREATE_SEQUENCE(EXISTING_SEQUENCE VARCHAR, NEW_SEQUENCE VARCHAR) RETURNS VOID AS $$\\012DECLARE\\012  CURR_SEQ_VAL   INTEGER;\\012BEGIN\\012  SELECT INTO CURR_SEQ_VAL NEXTVAL(EXISTING_SEQUENCE);\\012  EXECUTE 'CREATE SEQUENCE ' || NEW_SEQUENCE || ' START WITH ' || CURR_SEQ_VAL;\\012  RETURN;\\012END;\\012$$ LANGUAGE 'plpgsql';\\012\\012SELECT CREATE_SEQUENCE('DATA_ID_SEQ', 'PERM_ID_SEQ');\\012DROP FUNCTION CREATE_SEQUENCE(VARCHAR, VARCHAR);\\012\\012------------------------------------------------------------------------------------\\012-- Add perm_id columns to samples and experiments.\\012------------------------------------------------------------------------------------\\012ALTER TABLE SAMPLES ADD COLUMN PERM_ID CODE;\\012ALTER TABLE EXPERIMENTS ADD COLUMN PERM_ID CODE;\\012\\012UPDATE SAMPLES SET PERM_ID = to_char(registration_timestamp,'YYYYMMDDHHSSMS') || '-' || NEXTVAL('PERM_ID_SEQ');\\012UPDATE EXPERIMENTS SET PERM_ID = to_char(registration_timestamp,'YYYYMMDDHHSSMS') || '-' || NEXTVAL('PERM_ID_SEQ');\\012ALTER TABLE SAMPLES ALTER COLUMN PERM_ID SET NOT NULL;\\012ALTER TABLE EXPERIMENTS ALTER COLUMN PERM_ID SET NOT NULL;\\012ALTER TABLE SAMPLES ADD CONSTRAINT SAMP_PI_UK UNIQUE(PERM_ID);\\012ALTER TABLE EXPERIMENTS ADD CONSTRAINT EXPE_PI_UK UNIQUE(PERM_ID);\\012\\012\\012------------------------------------------------------------------------------------\\012-- Add column is_chosen_from_list to controlled_vocabularies.\\012------------------------------------------------------------------------------------\\012ALTER TABLE controlled_vocabularies ADD COLUMN is_chosen_from_list BOOLEAN_CHAR NOT NULL DEFAULT TRUE;\\012ALTER TABLE controlled_vocabularies ADD COLUMN source_uri CHARACTER VARYING(250);\\012------------------------------------------------------------------------------------\\012-- Modify Data table - remove arc connection between Sample and Data table, use a flag instead\\012------------------------------------------------------------------------------------\\012\\012-- add new columns\\012\\012ALTER TABLE data\\012    ADD COLUMN is_derived boolean_char;\\012ALTER TABLE data\\012    ADD COLUMN samp_id tech_id;\\012\\012-- update values in new columns\\012\\012UPDATE data\\012    SET is_derived = (samp_id_derived_from IS NOT NULL); \\012UPDATE data\\012    SET samp_id = samp_id_derived_from \\012    WHERE is_derived = 'TRUE';\\012UPDATE data\\012    SET samp_id = samp_id_acquired_from \\012    WHERE is_derived = 'FALSE';\\012\\012-- add constraints and indexes to new columns\\012\\012ALTER TABLE data\\012    ALTER COLUMN is_derived SET NOT NULL;\\012ALTER TABLE data\\012    ALTER COLUMN samp_id SET NOT NULL;   \\012ALTER TABLE data\\012    ADD CONSTRAINT data_samp_fk FOREIGN KEY (samp_id) REFERENCES samples (id);\\012CREATE INDEX data_samp_fk_i ON data USING btree (samp_id);\\012\\012-- remove old columns\\012\\012ALTER TABLE data\\012    DROP COLUMN samp_id_acquired_from;\\012ALTER TABLE data\\012    DROP COLUMN samp_id_derived_from;\\012    \\012------------------------------------------------------------------------------------\\012-- Granting SELECT privilege to group openbis_readonly\\012------------------------------------------------------------------------------------\\012\\012GRANT SELECT ON SEQUENCE attachment_content_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE attachment_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE code_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE controlled_vocabulary_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE cvte_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE data_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE data_set_property_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE data_set_relationship_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE data_set_type_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE data_store_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE data_type_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE database_instance_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE dstpt_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE etpt_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE event_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE experiment_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE experiment_property_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE experiment_type_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE file_format_type_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE group_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE invalidation_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE locator_type_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE material_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE material_property_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE material_type_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE mtpt_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE perm_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE person_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE project_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE property_type_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE role_assignment_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE sample_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE sample_property_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE sample_type_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE stpt_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE attachment_contents TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE attachments TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE controlled_vocabularies TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE controlled_vocabulary_terms TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE data TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE data_set_properties TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE data_set_relationships TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE data_set_type_property_types TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE data_set_types TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE data_stores TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE data_types TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE database_instances TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE database_version_logs TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE events TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE experiment_properties TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE experiment_type_property_types TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE experiment_types TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE experiments TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE external_data TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE file_format_types TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE groups TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE invalidations TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE locator_types TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE material_properties TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE material_type_property_types TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE material_types TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE materials TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE persons TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE projects TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE property_types TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE role_assignments TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE sample_properties TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE sample_type_property_types TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE sample_types TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE samples TO GROUP OPENBIS_READONLY;\\012\\012------------------------------------------------------------------------------------\\012-- Delete MATERIAL_BATCHES table\\012------------------------------------------------------------------------------------\\012\\012-- WARNING: Potential data lost!!!\\012-- WARNING: Potential data lost!!!\\012-- WARNING: Potential data lost!!!\\012\\012DROP TABLE SAMPLE_MATERIAL_BATCHES;\\012DROP TABLE MATERIAL_BATCHES;\\012DROP SEQUENCE MATERIAL_BATCH_ID_SEQ;\\012\\012------------------------------------------------------------------------------------\\012-- Delete MATE_ID_INHIBITOR_OF from table MATERIALS\\012------------------------------------------------------------------------------------\\012\\012-- WARNING: Potential data lost!!!\\012-- WARNING: Potential data lost!!!\\012-- WARNING: Potential data lost!!!\\012\\012ALTER TABLE MATERIALS DROP COLUMN MATE_ID_INHIBITOR_OF;\\012	\N
+./sourceTest/sql/postgresql/044/017=database_version_logs.tsv:041	source/sql/postgresql/migration/migration-040-041.sql	SUCCESS	2009-09-14 13:48:57.539	-- Create FILTERS table\\012\\012CREATE TABLE FILTERS (ID TECH_ID NOT NULL, DBIN_ID TECH_ID NOT NULL, NAME VARCHAR(200) NOT NULL, DESCRIPTION DESCRIPTION_1000,REGISTRATION_TIMESTAMP TIME_STAMP_DFL NOT NULL DEFAULT CURRENT_TIMESTAMP, PERS_ID_REGISTERER TECH_ID NOT NULL, MODIFICATION_TIMESTAMP TIME_STAMP DEFAULT CURRENT_TIMESTAMP, EXPRESSION VARCHAR(2000) NOT NULL, IS_PUBLIC BOOLEAN NOT NULL, GRID_ID VARCHAR(200) NOT NULL);\\012CREATE SEQUENCE FILTER_ID_SEQ;\\012ALTER TABLE FILTERS ADD CONSTRAINT FILT_PK PRIMARY KEY(ID);\\012ALTER TABLE FILTERS ADD CONSTRAINT FILT_BK_UK UNIQUE(NAME, DBIN_ID, GRID_ID);\\012ALTER TABLE FILTERS ADD CONSTRAINT FILT_PERS_FK FOREIGN KEY (PERS_ID_REGISTERER) REFERENCES PERSONS(ID);\\012ALTER TABLE FILTERS ADD CONSTRAINT FILT_DBIN_FK FOREIGN KEY (DBIN_ID) REFERENCES DATABASE_INSTANCES(ID);\\012CREATE INDEX FILT_PERS_FK_I ON FILTERS (PERS_ID_REGISTERER);\\012CREATE INDEX FILT_DBIN_FK_I ON FILTERS (DBIN_ID);\\012GRANT SELECT ON SEQUENCE filter_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE filters TO GROUP OPENBIS_READONLY;\\012\\012-- Add missing foreign key to role assignments authorization group\\012ALTER TABLE ROLE_ASSIGNMENTS ADD CONSTRAINT ROAS_AG_FK_GRANTEE FOREIGN KEY (AG_ID_GRANTEE) REFERENCES AUTHORIZATION_GROUPS(ID);\\012\\012--------------------------------------------------------------------------------------------------\\012-- Modify dataset connections:\\012-- 1. connection with sample shouldn't be mandatory any more\\012-- 2. introduce an arc condition that dataset cannot be connected with a sample and a parent dataset at the same time\\012--------------------------------------------------------------------------------------------------\\012\\012-- Weaken data-sample connection constraint - allow dataset to have no connection with sample\\012ALTER TABLE data ALTER COLUMN samp_id DROP NOT NULL;\\012\\012-- Remove data-sample connection for datasets that have a parent\\012\\012UPDATE data \\012   SET samp_id = NULL \\012 WHERE id IN (SELECT DISTINCT data_id_child FROM data_set_relationships);\\012\\012-- With PostgreSQL 8.4 one can check that before migration there were no cycles in dataset relationships:\\012--\\012-- WITH RECURSIVE data_set_parents(id, parent_ids, cycle) AS (\\012--         SELECT  r.data_id_child AS id, \\012--                 ARRAY[CAST (r.data_id_parent AS bigint)] AS parent_ids, \\012--                 false AS cycle \\012--         FROM data_set_relationships r\\012--     UNION ALL\\012--         SELECT  r.data_id_child,\\012--                 CAST (r.data_id_parent AS bigint) || p.parent_ids,\\012--                 r.data_id_child = ANY(p.parent_ids)\\012--         FROM data_set_relationships r, data_set_parents p\\012--         WHERE r.data_id_parent = p.id AND NOT cycle\\012-- )\\012-- SELECT count(*) AS cycles FROM data_set_parents WHERE cycle = true;\\012\\012---------------------------------------------------------------------------------------------------\\012--  Purpose:  Create DEFERRED triggers:\\012--            * check_dataset_relationships_on_data_table_modification,\\012--            * check_dataset_relationships_on_relationships_table_modification.\\012--            They check that after all modifications of database (just before commit) \\012--            if 'data'/'data_set_relationships' tables are among modified tables \\012--            dataset is not connected with a sample and a parent dataset at the same time.\\012--            This connections are held in two different tables so simple immediate trigger \\012--            with arc check cannot be used and we need two deferred triggers.\\012----------------------------------------------------------------------------------------------------\\012\\012-- trigger for 'data' table\\012\\012CREATE OR REPLACE FUNCTION check_dataset_relationships_on_data_table_modification() RETURNS trigger AS $$\\012DECLARE\\012\\011counter\\011INTEGER;\\012BEGIN\\012\\011-- if there is a connection with a Sample there should not be any connection with a parent Data Set\\012\\011IF (NEW.samp_id IS NOT NULL) THEN\\012\\011\\011-- count number of parents\\012\\011\\011SELECT count(*) INTO counter \\012\\011\\011\\011FROM data_set_relationships \\012\\011\\011\\011WHERE data_id_child = OLD.id;\\012\\011\\011IF (counter > 0) THEN\\012\\011\\011\\011RAISE EXCEPTION 'Insert/Update of Data Set (Code: %) failed because it cannot be connected with a Sample and a parent Data Set at the same time.', OLD.code;\\012\\011\\011END IF;\\012\\011END IF;\\012  RETURN NEW;\\012END;\\012$$ LANGUAGE 'plpgsql';\\012\\012CREATE CONSTRAINT TRIGGER check_dataset_relationships_on_data_table_modification \\012  AFTER INSERT OR UPDATE ON data\\012\\011DEFERRABLE INITIALLY DEFERRED\\012\\011FOR EACH ROW \\012\\011EXECUTE PROCEDURE check_dataset_relationships_on_data_table_modification();\\012\\012-- trigger for 'data_set_relationships'\\012\\012CREATE OR REPLACE FUNCTION check_dataset_relationships_on_relationships_table_modification() RETURNS trigger AS $$\\012DECLARE\\012\\011counter\\011INTEGER;\\012\\011sample_id\\011TECH_ID;\\012\\011data_code\\011CODE;\\012BEGIN\\012\\011-- child will have a parent added so it should not be connected with any sample\\012\\011SELECT samp_id, code INTO sample_id, data_code \\012\\011\\011FROM data \\012\\011\\011WHERE id = NEW.data_id_child;\\012\\011IF (sample_id IS NOT NULL) THEN\\012\\011\\011RAISE EXCEPTION 'Insert/Update of Data Set (Code: %) failed because it cannot be connected to a Sample and to a parent Data Set at the same time.', data_code;\\012\\011END IF;\\012\\011RETURN NEW;\\012END;\\012$$ LANGUAGE 'plpgsql';\\012  \\012CREATE CONSTRAINT TRIGGER check_dataset_relationships_on_relationships_table_modification \\012  AFTER INSERT OR UPDATE ON data_set_relationships\\012\\011DEFERRABLE INITIALLY DEFERRED\\012\\011FOR EACH ROW \\012\\011EXECUTE PROCEDURE check_dataset_relationships_on_relationships_table_modification();\\012	\N
+./sourceTest/sql/postgresql/044/schema-044.sql:    LANGUAGE plpgsql;
+./sourceTest/sql/postgresql/044/schema-044.sql:    LANGUAGE plpgsql;
+./sourceTest/sql/postgresql/044/schema-044.sql:    LANGUAGE plpgsql;
+./sourceTest/sql/postgresql/044/schema-044.sql:    LANGUAGE plpgsql;
+./sourceTest/sql/postgresql/044/schema-044.sql:    LANGUAGE plpgsql;
+./sourceTest/sql/postgresql/044/schema-044.sql:    LANGUAGE plpgsql;
+./sourceTest/sql/postgresql/044/schema-044.sql:    LANGUAGE plpgsql;
+./sourceTest/sql/postgresql/044/schema-044.sql:    LANGUAGE plpgsql;
+./sourceTest/sql/postgresql/044/schema-044.sql:    LANGUAGE plpgsql;
+./sourceTest/sql/postgresql/044/schema-044.sql:    LANGUAGE plpgsql;
+./sourceTest/sql/postgresql/045/.svn/text-base/017=database_version_logs.tsv.svn-base:027	D:\\User\\felmer\\dev-workspace\\openbis/source/sql/postgresql/027/function-027.sql	SUCCESS	2008-11-05 09:18:00.403	-- Creating Functions\\012\\012------------------------------------------------------------------------------------\\012--  Purpose:  Create function RENAME_SEQUENCE() that is required for renaming the sequences belonging to tables\\012------------------------------------------------------------------------------------\\012CREATE FUNCTION RENAME_SEQUENCE(OLD_NAME VARCHAR, NEW_NAME VARCHAR) RETURNS INTEGER AS $$\\012DECLARE\\012  CURR_SEQ_VAL   INTEGER;\\012BEGIN\\012  SELECT INTO CURR_SEQ_VAL NEXTVAL(OLD_NAME);\\012  EXECUTE 'CREATE SEQUENCE ' || NEW_NAME || ' START WITH ' || CURR_SEQ_VAL;\\012  EXECUTE 'DROP SEQUENCE ' || OLD_NAME;\\012  RETURN CURR_SEQ_VAL;\\012END;\\012$$ LANGUAGE 'plpgsql';\\012\\012\\012------------------------------------------------------------------------------------\\012--  Purpose:  Create trigger CONTROLLED_VOCABULARY_CHECK \\012------------------------------------------------------------------------------------\\012\\012CREATE OR REPLACE FUNCTION CONTROLLED_VOCABULARY_CHECK() RETURNS trigger AS $$\\012DECLARE\\012   v_code  CODE;\\012BEGIN\\012\\012   select code into v_code from data_types where id = NEW.daty_id;\\012\\012   -- Check if the data is of type "CONTROLLEDVOCABULARY"\\012   if v_code = 'CONTROLLEDVOCABULARY' then\\012      if NEW.covo_id IS NULL then\\012         RAISE EXCEPTION 'Insert/Update of Property Type (Code: %) failed, as its Data Type is CONTROLLEDVOCABULARY, but it is not linked to a Controlled Vocabulary.', NEW.code;\\012      end if;\\012   end if;\\012\\012   RETURN NEW;\\012\\012END;\\012$$ LANGUAGE 'plpgsql';\\012\\012CREATE TRIGGER CONTROLLED_VOCABULARY_CHECK BEFORE INSERT OR UPDATE ON PROPERTY_TYPES\\012    FOR EACH ROW EXECUTE PROCEDURE CONTROLLED_VOCABULARY_CHECK();\\012\\012\\012------------------------------------------------------------------------------------\\012--  Purpose:  Create trigger EXTERNAL_DATA_STORAGE_FORMAT_CHECK \\012------------------------------------------------------------------------------------\\012\\012CREATE OR REPLACE FUNCTION EXTERNAL_DATA_STORAGE_FORMAT_CHECK() RETURNS trigger AS $$\\012DECLARE\\012   v_covo_code  CODE;\\012   data_code CODE;\\012BEGIN\\012\\012   select code into v_covo_code from controlled_vocabularies\\012      where is_internal_namespace = true and \\012         id = (select covo_id from controlled_vocabulary_terms where id = NEW.cvte_id_stor_fmt);\\012   -- Check if the data storage format is a term of the controlled vocabulary "STORAGE_FORMAT"\\012   if v_covo_code != 'STORAGE_FORMAT' then\\012      select code into data_code from data where id = NEW.data_id; \\012      RAISE EXCEPTION 'Insert/Update of Data (Code: %) failed, as its Storage Format is %, but is required to be STORAGE_FORMAT.', data_code, v_covo_code;\\012   end if;\\012\\012   RETURN NEW;\\012\\012END;\\012$$ LANGUAGE 'plpgsql';\\012\\012CREATE TRIGGER EXTERNAL_DATA_STORAGE_FORMAT_CHECK BEFORE INSERT OR UPDATE ON EXTERNAL_DATA\\012    FOR EACH ROW EXECUTE PROCEDURE EXTERNAL_DATA_STORAGE_FORMAT_CHECK();\\012\\012------------------------------------------------------------------------------------\\012--  Purpose:  Create trigger SAMPLE_CODE_UNIQUENESS_CHECK \\012------------------------------------------------------------------------------------\\012\\012CREATE OR REPLACE FUNCTION SAMPLE_CODE_UNIQUENESS_CHECK() RETURNS trigger AS $$\\012DECLARE\\012   counter  INTEGER;\\012BEGIN\\012\\011IF (NEW.samp_id_part_of is NULL) THEN\\012\\011\\011IF (NEW.dbin_id is not NULL) THEN\\012\\011\\011\\011SELECT count(*) into counter FROM samples \\012\\011\\011\\011\\011where id != NEW.id and code = NEW.code and samp_id_part_of is NULL and dbin_id = NEW.dbin_id;\\012\\011\\011\\011IF (counter > 0) THEN\\012\\011\\011\\011\\011RAISE EXCEPTION 'Insert/Update of Sample (Code: %) failed because database instance sample with the same code already exists.', NEW.code;\\012\\011\\011\\011END IF;\\012\\011\\011ELSIF (NEW.grou_id is not NULL) THEN\\012\\011\\011\\011SELECT count(*) into counter FROM samples \\012\\011\\011\\011\\011where id != NEW.id and code = NEW.code and samp_id_part_of is NULL and grou_id = NEW.grou_id;\\012\\011\\011\\011IF (counter > 0) THEN\\012\\011\\011\\011\\011RAISE EXCEPTION 'Insert/Update of Sample (Code: %) failed because group sample with the same code already exists.', NEW.code;\\012\\011\\011\\011END IF;\\012\\011\\011END IF;\\012        ELSE\\012\\011\\011IF (NEW.dbin_id is not NULL) THEN\\012\\011\\011\\011SELECT count(*) into counter FROM samples \\012\\011\\011\\011\\011where id != NEW.id and code = NEW.code and samp_id_part_of = NEW.samp_id_part_of and dbin_id = NEW.dbin_id;\\012\\011\\011\\011IF (counter > 0) THEN\\012\\011\\011\\011\\011RAISE EXCEPTION 'Insert/Update of Sample (Code: %) failed because database instance sample with the same code and being the part of the same parent already exists.', NEW.code;\\012\\011\\011\\011END IF;\\012\\011\\011ELSIF (NEW.grou_id is not NULL) THEN\\012\\011\\011\\011SELECT count(*) into counter FROM samples \\012\\011\\011\\011\\011where id != NEW.id and code = NEW.code and samp_id_part_of = NEW.samp_id_part_of and grou_id = NEW.grou_id;\\012\\011\\011\\011IF (counter > 0) THEN\\012\\011\\011\\011\\011RAISE EXCEPTION 'Insert/Update of Sample (Code: %) failed because group sample with the same code and being the part of the same parent already exists.', NEW.code;\\012\\011\\011\\011END IF;\\012\\011\\011END IF;\\012        END IF;   \\012   RETURN NEW;\\012END;\\012$$ LANGUAGE 'plpgsql';\\012\\012CREATE TRIGGER SAMPLE_CODE_UNIQUENESS_CHECK BEFORE INSERT OR UPDATE ON SAMPLES\\012    FOR EACH ROW EXECUTE PROCEDURE SAMPLE_CODE_UNIQUENESS_CHECK();\\012	\N
+./sourceTest/sql/postgresql/045/.svn/text-base/017=database_version_logs.tsv.svn-base:028	source/sql/postgresql/migration/migration-027-028.sql	SUCCESS	2008-11-18 13:24:17.508	-- Create EXPERIMENT_ATTACHMENT_CONTENTS.\\012CREATE TABLE EXPERIMENT_ATTACHMENT_CONTENTS (ID TECH_ID NOT NULL,VALUE FILE NOT NULL);\\012CREATE SEQUENCE EXPERIMENT_ATTACHMENT_CONTENT_ID_SEQ;\\012ALTER TABLE EXPERIMENT_ATTACHMENT_CONTENTS ADD CONSTRAINT EXAC_PK PRIMARY KEY(ID);\\012\\012-- Alter EXPERIMENT_ATTACHMENTS by adding the new column which has a NULL constraint.\\012-- The NOT NULL constraint is added later on.\\012ALTER TABLE EXPERIMENT_ATTACHMENTS ADD COLUMN EXAC_ID TECH_ID;\\012\\012-- Does the VALUE migration between EXPERIMENT_ATTACHMENTS to EXPERIMENT_ATTACHMENT_CONTENTS.\\012CREATE OR REPLACE FUNCTION move_exp_att_content() RETURNS integer AS $$\\012DECLARE\\012    rec RECORD;\\012    seq BIGINT;\\012BEGIN\\012  FOR rec IN SELECT id, value FROM EXPERIMENT_ATTACHMENTS LOOP\\012  \\011seq := nextval('EXPERIMENT_ATTACHMENT_CONTENT_ID_SEQ');\\012    INSERT INTO EXPERIMENT_ATTACHMENT_CONTENTS (id, value) VALUES (seq, rec.value);\\012    UPDATE EXPERIMENT_ATTACHMENTS SET exac_id = seq WHERE id = rec.id;\\012  END LOOP;\\012  RETURN 1;\\012END;\\012$$ LANGUAGE 'plpgsql';\\012\\012-- Call the function.\\012SELECT move_exp_att_content();\\012DROP FUNCTION move_exp_att_content();\\012\\012\\012-- Finish EXPERIMENT_ATTACHMENTS changes.\\012ALTER TABLE EXPERIMENT_ATTACHMENTS ADD CONSTRAINT EXAT_CONT_FK FOREIGN KEY (EXAC_ID) REFERENCES EXPERIMENT_ATTACHMENT_CONTENTS(ID);\\012ALTER TABLE EXPERIMENT_ATTACHMENTS DROP COLUMN VALUE;\\012ALTER TABLE EXPERIMENT_ATTACHMENTS ALTER COLUMN EXAC_ID SET NOT NULL;\\012	\N
+./sourceTest/sql/postgresql/045/.svn/text-base/017=database_version_logs.tsv.svn-base:029	source/sql/postgresql/migration/migration-028-029.sql	SUCCESS	2009-03-18 10:50:20.105	-- -------\\012-- add modification_timestamp field to allow edition with Hibernate\\012-- -------\\012\\012ALTER TABLE samples\\012\\011ADD COLUMN modification_timestamp TIME_STAMP DEFAULT CURRENT_TIMESTAMP;\\012\\012ALTER TABLE experiments\\012\\011ADD COLUMN modification_timestamp TIME_STAMP DEFAULT CURRENT_TIMESTAMP;\\012\\012ALTER TABLE materials\\012\\011ADD COLUMN modification_timestamp TIME_STAMP DEFAULT CURRENT_TIMESTAMP;\\012\\012ALTER TABLE experiment_properties\\012\\011ADD COLUMN modification_timestamp TIME_STAMP DEFAULT CURRENT_TIMESTAMP;\\012\\012ALTER TABLE material_properties\\012\\011ADD COLUMN modification_timestamp TIME_STAMP DEFAULT CURRENT_TIMESTAMP;\\012\\012ALTER TABLE sample_properties\\012\\011ADD COLUMN modification_timestamp TIME_STAMP DEFAULT CURRENT_TIMESTAMP;\\012\\012-- -------\\012-- add property data type which references materials\\012-- -------\\012\\012ALTER TABLE property_types\\012\\011ADD COLUMN maty_prop_id tech_id;\\012\\012ALTER TABLE property_types\\012\\011ADD CONSTRAINT prty_maty_fk FOREIGN KEY (maty_prop_id) REFERENCES material_types(id);\\012\\012ALTER TABLE experiment_properties\\012\\011ADD COLUMN mate_prop_id tech_id;\\012\\012ALTER TABLE material_properties\\012\\011ADD COLUMN mate_prop_id tech_id;\\012\\012ALTER TABLE sample_properties\\012\\011ADD COLUMN mate_prop_id tech_id;\\012\\012ALTER TABLE experiment_properties\\012\\011ADD CONSTRAINT expr_mapr_fk FOREIGN KEY (mate_prop_id) REFERENCES materials(id);\\012\\012ALTER TABLE material_properties\\012\\011ADD CONSTRAINT mapr_mapr_fk FOREIGN KEY (mate_prop_id) REFERENCES materials(id);\\012\\012ALTER TABLE sample_properties\\012\\011ADD CONSTRAINT sapr_mapr_fk FOREIGN KEY (mate_prop_id) REFERENCES materials(id);\\012\\012insert into data_types\\012(id\\012 ,code\\012 ,description)\\012 values \\012 (nextval('DATA_TYPE_ID_SEQ')\\012 ,'MATERIAL'\\012 ,'Reference to a material'\\012);\\012\\012ALTER TABLE MATERIAL_PROPERTIES DROP CONSTRAINT MAPR_CK;\\012ALTER TABLE MATERIAL_PROPERTIES ADD CONSTRAINT MAPR_CK CHECK \\012\\011((VALUE IS NOT NULL AND CVTE_ID IS NULL AND MATE_PROP_ID IS NULL) OR \\012\\011 (VALUE IS NULL AND CVTE_ID IS NOT NULL AND MATE_PROP_ID IS NULL) OR\\012\\011 (VALUE IS NULL AND CVTE_ID IS NULL AND MATE_PROP_ID IS NOT NULL)\\012\\011);\\012\\012ALTER TABLE EXPERIMENT_PROPERTIES DROP CONSTRAINT EXPR_CK;\\012ALTER TABLE EXPERIMENT_PROPERTIES ADD CONSTRAINT EXPR_CK CHECK \\012\\011((VALUE IS NOT NULL AND CVTE_ID IS NULL AND MATE_PROP_ID IS NULL) OR \\012\\011 (VALUE IS NULL AND CVTE_ID IS NOT NULL AND MATE_PROP_ID IS NULL) OR\\012\\011 (VALUE IS NULL AND CVTE_ID IS NULL AND MATE_PROP_ID IS NOT NULL)\\012\\011);\\012\\012ALTER TABLE SAMPLE_PROPERTIES DROP CONSTRAINT SAPR_CK;\\012ALTER TABLE SAMPLE_PROPERTIES ADD CONSTRAINT SAPR_CK CHECK \\012\\011((VALUE IS NOT NULL AND CVTE_ID IS NULL AND MATE_PROP_ID IS NULL) OR \\012\\011 (VALUE IS NULL AND CVTE_ID IS NOT NULL AND MATE_PROP_ID IS NULL) OR\\012\\011 (VALUE IS NULL AND CVTE_ID IS NULL AND MATE_PROP_ID IS NOT NULL)\\012\\011);\\012\\012------------------------------------------------------------------------------------\\012--  Purpose:  Create trigger MATERIAL/SAMPLE/EXPERIMENT _PROPERTY_WITH_MATERIAL_DATA_TYPE_CHECK\\012--            It checks that if material property value is assigned to the entity,\\012--\\011\\011\\011\\011\\011\\011then the material type is equal to the one described by property type.\\012------------------------------------------------------------------------------------\\012\\012CREATE OR REPLACE FUNCTION MATERIAL_PROPERTY_WITH_MATERIAL_DATA_TYPE_CHECK() RETURNS trigger AS $$\\012DECLARE\\012   v_type_id  CODE;\\012   v_type_id_prop  CODE;\\012BEGIN\\012   if NEW.mate_prop_id IS NOT NULL then\\012\\011\\011\\011-- find material type id of the property type \\012\\011\\011\\011select pt.maty_prop_id into v_type_id_prop \\012\\011\\011\\011  from material_type_property_types etpt, property_types pt \\012\\011\\011\\011 where NEW.mtpt_id = etpt.id AND etpt.prty_id = pt.id;\\012\\011\\011\\012\\011\\011\\011if v_type_id_prop IS NOT NULL then\\012\\011\\011\\011\\011-- find material type id of the material which consists the entity's property value\\012\\011\\011\\011\\011select entity.maty_id into v_type_id \\012\\011\\011\\011\\011  from materials entity\\012\\011\\011\\011\\011 where NEW.mate_prop_id = entity.id;\\012\\011\\011\\011\\011if v_type_id != v_type_id_prop then\\012\\011\\011\\011\\011\\011RAISE EXCEPTION 'Insert/Update of property value referencing material (id: %) failed, as referenced material type is different than expected (id %, expected id: %).', \\012\\011\\011\\011\\011\\011\\011\\011 NEW.mate_prop_id, v_type_id, v_type_id_prop;\\012\\011\\011\\011\\011end if;\\012\\011\\011\\011end if;\\012   end if;\\012   RETURN NEW;\\012END;\\012$$ LANGUAGE 'plpgsql';\\012\\012CREATE TRIGGER MATERIAL_PROPERTY_WITH_MATERIAL_DATA_TYPE_CHECK BEFORE INSERT OR UPDATE ON material_properties\\012    FOR EACH ROW EXECUTE PROCEDURE MATERIAL_PROPERTY_WITH_MATERIAL_DATA_TYPE_CHECK();\\012    \\012CREATE OR REPLACE FUNCTION SAMPLE_PROPERTY_WITH_MATERIAL_DATA_TYPE_CHECK() RETURNS trigger AS $$\\012DECLARE\\012   v_type_id  CODE;\\012   v_type_id_prop  CODE;\\012BEGIN\\012   if NEW.mate_prop_id IS NOT NULL then\\012\\011\\011\\011-- find material type id of the property type \\012\\011\\011\\011select pt.maty_prop_id into v_type_id_prop \\012\\011\\011\\011  from sample_type_property_types etpt, property_types pt \\012\\011\\011\\011 where NEW.stpt_id = etpt.id AND etpt.prty_id = pt.id;\\012\\011\\011\\012\\011\\011\\011if v_type_id_prop IS NOT NULL then\\012\\011\\011\\011\\011-- find material type id of the material which consists the entity's property value\\012\\011\\011\\011\\011select entity.maty_id into v_type_id \\012\\011\\011\\011\\011  from materials entity\\012\\011\\011\\011\\011 where NEW.mate_prop_id = entity.id;\\012\\011\\011\\011\\011if v_type_id != v_type_id_prop then\\012\\011\\011\\011\\011\\011RAISE EXCEPTION 'Insert/Update of property value referencing material (id: %) failed, as referenced material type is different than expected (id %, expected id: %).', \\012\\011\\011\\011\\011\\011\\011\\011\\011\\011\\011\\011\\011 NEW.mate_prop_id, v_type_id, v_type_id_prop;\\012\\011\\011\\011\\011end if;\\012\\011\\011\\011end if;\\012   end if;\\012   RETURN NEW;\\012END;\\012$$ LANGUAGE 'plpgsql';\\012\\012CREATE TRIGGER SAMPLE_PROPERTY_WITH_MATERIAL_DATA_TYPE_CHECK BEFORE INSERT OR UPDATE ON sample_properties\\012    FOR EACH ROW EXECUTE PROCEDURE SAMPLE_PROPERTY_WITH_MATERIAL_DATA_TYPE_CHECK();\\012    \\012CREATE OR REPLACE FUNCTION EXPERIMENT_PROPERTY_WITH_MATERIAL_DATA_TYPE_CHECK() RETURNS trigger AS $$\\012DECLARE\\012   v_type_id  CODE;\\012   v_type_id_prop  CODE;\\012BEGIN\\012   if NEW.mate_prop_id IS NOT NULL then\\012\\011\\011\\011-- find material type id of the property type \\012\\011\\011\\011select pt.maty_prop_id into v_type_id_prop \\012\\011\\011\\011  from experiment_type_property_types etpt, property_types pt \\012\\011\\011\\011 where NEW.etpt_id = etpt.id AND etpt.prty_id = pt.id;\\012\\011\\011\\012\\011\\011\\011if v_type_id_prop IS NOT NULL then\\012\\011\\011\\011\\011-- find material type id of the material which consists the entity's property value\\012\\011\\011\\011\\011select entity.maty_id into v_type_id \\012\\011\\011\\011\\011  from materials entity\\012\\011\\011\\011\\011 where NEW.mate_prop_id = entity.id;\\012\\011\\011\\011\\011if v_type_id != v_type_id_prop then\\012\\011\\011\\011\\011\\011RAISE EXCEPTION 'Insert/Update of property value referencing material (id: %) failed, as referenced material type is different than expected (id %, expected id: %).', \\012\\011\\011\\011\\011\\011\\011\\011\\011\\011\\011\\011\\011 NEW.mate_prop_id, v_type_id, v_type_id_prop;\\012\\011\\011\\011\\011end if;\\012\\011\\011\\011end if;\\012   end if;\\012   RETURN NEW;\\012END;\\012$$ LANGUAGE 'plpgsql';\\012\\012CREATE TRIGGER EXPERIMENT_PROPERTY_WITH_MATERIAL_DATA_TYPE_CHECK BEFORE INSERT OR UPDATE ON experiment_properties\\012    FOR EACH ROW EXECUTE PROCEDURE EXPERIMENT_PROPERTY_WITH_MATERIAL_DATA_TYPE_CHECK();\\012       \\012-- -------\\012-- remove the reminescents of the OBSERVABLE_TYPE\\012-- -------\\012\\012ALTER TABLE data\\012\\011DROP CONSTRAINT data_obty_fk;\\012\\012ALTER TABLE data_set_types\\012\\011DROP CONSTRAINT obty_pk;\\012\\012ALTER TABLE data_set_types\\012\\011ADD CONSTRAINT dsty_pk PRIMARY KEY (id);\\012\\012ALTER TABLE data\\012\\011ADD CONSTRAINT data_dsty_fk FOREIGN KEY (dsty_id) REFERENCES data_set_types(id);\\012\\012ALTER TABLE data_set_types\\012\\011DROP CONSTRAINT obty_bk_uk;\\012\\012ALTER TABLE data_set_types\\012\\011DROP CONSTRAINT obty_dbin_fk;\\012\\012ALTER TABLE data_set_types\\012\\011ADD CONSTRAINT dsty_bk_uk UNIQUE (code, dbin_id);\\012\\012ALTER TABLE data_set_types\\012\\011ADD CONSTRAINT dsty_dbin_fk FOREIGN KEY (dbin_id) REFERENCES database_instances(id);\\012\\012DROP INDEX data_obty_fk_i;\\012\\012CREATE INDEX data_dsty_fk_i ON data(dsty_id);\\012	\N
+./sourceTest/sql/postgresql/045/.svn/text-base/017=database_version_logs.tsv.svn-base:030	source/sql/postgresql/migration/migration-029-030.sql	SUCCESS	2009-03-23 15:34:44.72	-- -------\\012-- add modification_timestamp field to allow edition with Hibernate\\012-- -------\\012ALTER TABLE data\\012\\011ADD COLUMN modification_timestamp TIME_STAMP DEFAULT CURRENT_TIMESTAMP;\\012ALTER TABLE experiment_types\\012\\011ADD COLUMN modification_timestamp TIME_STAMP DEFAULT CURRENT_TIMESTAMP;\\012ALTER TABLE sample_types\\012\\011ADD COLUMN modification_timestamp TIME_STAMP DEFAULT CURRENT_TIMESTAMP;\\012ALTER TABLE material_types\\012\\011ADD COLUMN modification_timestamp TIME_STAMP DEFAULT CURRENT_TIMESTAMP;\\012ALTER TABLE data_set_types\\012\\011ADD COLUMN modification_timestamp TIME_STAMP DEFAULT CURRENT_TIMESTAMP;\\012ALTER TABLE controlled_vocabularies\\012\\011ADD COLUMN modification_timestamp TIME_STAMP DEFAULT CURRENT_TIMESTAMP;\\012-- -------\\012-- add properties to data sets\\012-- -------\\012CREATE TABLE DATA_SET_PROPERTIES (ID TECH_ID NOT NULL,DS_ID TECH_ID NOT NULL,DSTPT_ID TECH_ID NOT NULL,VALUE GENERIC_VALUE,CVTE_ID TECH_ID, MATE_PROP_ID TECH_ID, PERS_ID_REGISTERER TECH_ID NOT NULL,REGISTRATION_TIMESTAMP TIME_STAMP_DFL NOT NULL DEFAULT CURRENT_TIMESTAMP, MODIFICATION_TIMESTAMP TIME_STAMP DEFAULT CURRENT_TIMESTAMP);\\012CREATE TABLE DATA_SET_TYPE_PROPERTY_TYPES (ID TECH_ID NOT NULL,DSTY_ID TECH_ID NOT NULL,PRTY_ID TECH_ID NOT NULL,IS_MANDATORY BOOLEAN_CHAR NOT NULL DEFAULT 'F',IS_MANAGED_INTERNALLY BOOLEAN_CHAR NOT NULL DEFAULT 'F',PERS_ID_REGISTERER TECH_ID NOT NULL,REGISTRATION_TIMESTAMP TIME_STAMP_DFL NOT NULL DEFAULT CURRENT_TIMESTAMP);\\012\\012CREATE SEQUENCE DATA_SET_PROPERTY_ID_SEQ;\\012CREATE SEQUENCE DSTPT_ID_SEQ;\\012\\012ALTER TABLE DATA_SET_TYPE_PROPERTY_TYPES ADD CONSTRAINT DSTPT_PK PRIMARY KEY(ID);\\012ALTER TABLE DATA_SET_PROPERTIES ADD CONSTRAINT DSPR_PK PRIMARY KEY(ID);\\012\\012ALTER TABLE DATA_SET_TYPE_PROPERTY_TYPES ADD CONSTRAINT DSTPT_BK_UK UNIQUE(DSTY_ID,PRTY_ID);\\012ALTER TABLE DATA_SET_PROPERTIES ADD CONSTRAINT DSPR_BK_UK UNIQUE(DS_ID,DSTPT_ID);\\012\\012\\012ALTER TABLE DATA_SET_TYPE_PROPERTY_TYPES ADD CONSTRAINT DSTPT_DSTY_FK FOREIGN KEY (DSTY_ID) REFERENCES DATA_SET_TYPES(ID);\\012ALTER TABLE DATA_SET_TYPE_PROPERTY_TYPES ADD CONSTRAINT DSTPT_PERS_FK FOREIGN KEY (PERS_ID_REGISTERER) REFERENCES PERSONS(ID);\\012ALTER TABLE DATA_SET_TYPE_PROPERTY_TYPES ADD CONSTRAINT DSTPT_PRTY_FK FOREIGN KEY (PRTY_ID) REFERENCES PROPERTY_TYPES(ID);\\012ALTER TABLE DATA_SET_PROPERTIES ADD CONSTRAINT DSPR_CVTE_FK FOREIGN KEY (CVTE_ID) REFERENCES CONTROLLED_VOCABULARY_TERMS(ID);\\012ALTER TABLE DATA_SET_PROPERTIES ADD CONSTRAINT DSPR_DSTPT_FK FOREIGN KEY (DSTPT_ID) REFERENCES DATA_SET_TYPE_PROPERTY_TYPES(ID) ON DELETE CASCADE;\\012ALTER TABLE DATA_SET_PROPERTIES ADD CONSTRAINT DSPR_DS_FK FOREIGN KEY (DS_ID) REFERENCES DATA(ID);\\012ALTER TABLE DATA_SET_PROPERTIES ADD CONSTRAINT DSPR_PERS_FK FOREIGN KEY (PERS_ID_REGISTERER) REFERENCES PERSONS(ID);\\012ALTER TABLE DATA_SET_PROPERTIES ADD CONSTRAINT DSPR_MAPR_FK FOREIGN KEY (MATE_PROP_ID) REFERENCES MATERIALS(ID);\\012\\012ALTER TABLE DATA_SET_PROPERTIES ADD CONSTRAINT DSPR_CK CHECK \\012\\011((VALUE IS NOT NULL AND CVTE_ID IS NULL AND MATE_PROP_ID IS NULL) OR \\012\\011 (VALUE IS NULL AND CVTE_ID IS NOT NULL AND MATE_PROP_ID IS NULL) OR\\012\\011 (VALUE IS NULL AND CVTE_ID IS NULL AND MATE_PROP_ID IS NOT NULL)\\012\\011);\\012\\012CREATE INDEX DSPR_CVTE_FK_I ON DATA_SET_PROPERTIES (CVTE_ID);\\012CREATE INDEX DSPR_DSTPT_FK_I ON DATA_SET_PROPERTIES (DSTPT_ID);\\012CREATE INDEX DSPR_DS_FK_I ON DATA_SET_PROPERTIES (DS_ID);\\012CREATE INDEX DSPR_PERS_FK_I ON DATA_SET_PROPERTIES (PERS_ID_REGISTERER);\\012CREATE INDEX DSTPT_DSTY_FK_I ON DATA_SET_TYPE_PROPERTY_TYPES (DSTY_ID);\\012CREATE INDEX DSTPT_PERS_FK_I ON DATA_SET_TYPE_PROPERTY_TYPES (PERS_ID_REGISTERER);\\012CREATE INDEX DSTPT_PRTY_FK_I ON DATA_SET_TYPE_PROPERTY_TYPES (PRTY_ID);\\012\\012CREATE OR REPLACE FUNCTION DATA_SET_PROPERTY_WITH_MATERIAL_DATA_TYPE_CHECK() RETURNS trigger AS $$\\012DECLARE\\012   v_type_id  CODE;\\012   v_type_id_prop  CODE;\\012BEGIN\\012   if NEW.mate_prop_id IS NOT NULL then\\012\\011\\011\\011-- find material type id of the property type \\012\\011\\011\\011select pt.maty_prop_id into v_type_id_prop \\012\\011\\011\\011  from data_set_type_property_types dstpt, property_types pt \\012\\011\\011\\011 where NEW.dstpt_id = dstpt.id AND dstpt.prty_id = pt.id;\\012\\011\\011\\012\\011\\011\\011if v_type_id_prop IS NOT NULL then\\012\\011\\011\\011\\011-- find material type id of the material which consists the entity's property value\\012\\011\\011\\011\\011select entity.maty_id into v_type_id \\012\\011\\011\\011\\011  from materials entity\\012\\011\\011\\011\\011 where NEW.mate_prop_id = entity.id;\\012\\011\\011\\011\\011if v_type_id != v_type_id_prop then\\012\\011\\011\\011\\011\\011RAISE EXCEPTION 'Insert/Update of property value referencing material (id: %) failed, as referenced material type is different than expected (id %, expected id: %).', \\012\\011\\011\\011\\011\\011\\011\\011\\011\\011\\011\\011\\011 NEW.mate_prop_id, v_type_id, v_type_id_prop;\\012\\011\\011\\011\\011end if;\\012\\011\\011\\011end if;\\012   end if;\\012   RETURN NEW;\\012END;\\012$$ LANGUAGE 'plpgsql';\\012\\012CREATE TRIGGER DATA_SET_PROPERTY_WITH_MATERIAL_DATA_TYPE_CHECK BEFORE INSERT OR UPDATE ON data_set_properties\\012    FOR EACH ROW EXECUTE PROCEDURE DATA_SET_PROPERTY_WITH_MATERIAL_DATA_TYPE_CHECK();   \\012	\N
+./sourceTest/sql/postgresql/045/.svn/text-base/017=database_version_logs.tsv.svn-base:032	source/sql/postgresql/migration/migration-031-032.sql	SUCCESS	2009-04-09 09:36:36.20	-- -------\\012-- Modify MATERIAL_BATCHES\\012-- -------\\012\\012ALTER TABLE material_batches\\012    DROP COLUMN proc_id;\\012\\012-- -------\\012-- Modify SAMPLES\\012-- -------\\012\\012ALTER TABLE samples\\012    ADD COLUMN expe_id tech_id;\\012\\012ALTER TABLE samples\\012    ADD CONSTRAINT samp_expe_fk FOREIGN KEY (expe_id) REFERENCES experiments(id);\\012\\012CREATE INDEX samp_expe_fk_i ON samples USING btree (expe_id);\\012\\012-- relink samples directly to experiments\\012\\012UPDATE samples\\012SET expe_id = (SELECT e.id FROM experiments e, procedures p, sample_inputs si \\012               WHERE si.samp_id = samples.id AND si.proc_id = p.id AND p.expe_id = e.id AND e.inva_id IS NULL);\\012\\012\\012-- -------\\012-- Modify DATA\\012-- -------\\012\\012ALTER TABLE data\\012    ADD COLUMN expe_id tech_id;\\012\\012ALTER TABLE data\\012    ADD CONSTRAINT data_expe_fk FOREIGN KEY (expe_id) REFERENCES experiments(id);\\012\\012CREATE INDEX data_expe_fk_i ON data USING btree (expe_id);\\012\\012UPDATE data\\012SET expe_id = (SELECT e.id FROM experiments e, procedures p \\012               WHERE data.proc_id_produced_by = p.id AND p.expe_id = e.id);\\012\\012ALTER TABLE data\\012    ALTER COLUMN expe_id SET NOT NULL;\\012\\012ALTER TABLE data\\012    DROP COLUMN proc_id_produced_by;\\012\\012-- -------\\012-- Drop PROCEDURES, PROCEDURE_TYPES, and SAMPLE_INPUTS\\012-- -------\\012\\012DROP TABLE sample_inputs;\\012DROP TABLE procedures;\\012DROP TABLE procedure_types;\\012\\012DROP SEQUENCE procedure_id_seq;\\012DROP SEQUENCE procedure_type_id_seq;\\012\\012-- -------\\012-- Add CODE_SEQ\\012-- -------\\012\\012CREATE SEQUENCE CODE_SEQ;\\012\\012-- -------\\012-- Add new columns to DATA_STORES\\012-- -------\\012\\012ALTER TABLE data_stores\\012    ADD COLUMN remote_url character varying(250),\\012    ADD COLUMN session_token character varying(50),\\012    ADD COLUMN modification_timestamp time_stamp DEFAULT now();\\012\\012UPDATE data_stores\\012SET remote_url = '', session_token='';\\012\\012ALTER TABLE data_stores\\012    ALTER COLUMN remote_url SET NOT NULL,\\012    ALTER COLUMN session_token SET NOT NULL;\\012\\012-- -------\\012-- Drop foreign keys onto DATA_STORES\\012-- -------\\012\\012ALTER TABLE database_instances\\012    DROP COLUMN dast_id;\\012\\012ALTER TABLE groups\\012    DROP COLUMN dast_id;\\012\\012ALTER TABLE projects\\012    DROP COLUMN dast_id;\\012\\012ALTER TABLE experiments\\012    DROP COLUMN dast_id;\\012\\012-- -------\\012-- Add foreign key from DATA onto DATA_STORES\\012-- -------\\012\\012ALTER TABLE data\\012    ADD COLUMN dast_id tech_id;\\012\\012ALTER TABLE data\\012    ADD CONSTRAINT data_dast_fk FOREIGN KEY (dast_id) REFERENCES data_stores(id);\\012\\012UPDATE data\\012SET dast_id = (select id from data_stores where code = 'STANDARD');\\012\\012ALTER TABLE data\\012    ALTER COLUMN dast_id SET NOT NULL;\\012\\012\\012------------------------------------------------------------------------------------\\012--  Purpose:  Replace trigger SAMPLE_CODE_UNIQUENESS_CHECK \\012------------------------------------------------------------------------------------\\012\\012CREATE OR REPLACE FUNCTION SAMPLE_CODE_UNIQUENESS_CHECK() RETURNS trigger AS $$\\012DECLARE\\012   counter  INTEGER;\\012BEGIN\\012    LOCK TABLE samples IN EXCLUSIVE MODE;\\012    IF (NEW.samp_id_part_of is NULL) THEN\\012        IF (NEW.dbin_id is not NULL) THEN\\012            SELECT count(*) into counter FROM samples \\012                where id != NEW.id and code = NEW.code and samp_id_part_of is NULL and dbin_id = NEW.dbin_id;\\012            IF (counter > 0) THEN\\012                RAISE EXCEPTION 'Insert/Update of Sample (Code: %) failed because database instance sample with the same code already exists.', NEW.code;\\012            END IF;\\012        ELSIF (NEW.grou_id is not NULL) THEN\\012            SELECT count(*) into counter FROM samples \\012                where id != NEW.id and code = NEW.code and samp_id_part_of is NULL and grou_id = NEW.grou_id;\\012            IF (counter > 0) THEN\\012                RAISE EXCEPTION 'Insert/Update of Sample (Code: %) failed because group sample with the same code already exists.', NEW.code;\\012            END IF;\\012        END IF;\\012        ELSE\\012        IF (NEW.dbin_id is not NULL) THEN\\012            SELECT count(*) into counter FROM samples \\012                where id != NEW.id and code = NEW.code and samp_id_part_of = NEW.samp_id_part_of and dbin_id = NEW.dbin_id;\\012            IF (counter > 0) THEN\\012                RAISE EXCEPTION 'Insert/Update of Sample (Code: %) failed because database instance sample with the same code and being the part of the same parent already exists.', NEW.code;\\012            END IF;\\012        ELSIF (NEW.grou_id is not NULL) THEN\\012            SELECT count(*) into counter FROM samples \\012                where id != NEW.id and code = NEW.code and samp_id_part_of = NEW.samp_id_part_of and grou_id = NEW.grou_id;\\012            IF (counter > 0) THEN\\012                RAISE EXCEPTION 'Insert/Update of Sample (Code: %) failed because group sample with the same code and being the part of the same parent already exists.', NEW.code;\\012            END IF;\\012        END IF;\\012        END IF;   \\012   RETURN NEW;\\012END;\\012$$ LANGUAGE 'plpgsql';\\012\\012\\012\\012	\N
+./sourceTest/sql/postgresql/045/.svn/text-base/017=database_version_logs.tsv.svn-base:034	source/sql/postgresql/migration/migration-033-034.sql	SUCCESS	2009-05-26 08:32:49.935	------------------------------------------------------------------------------------\\012-- Create sequence for generating permanent identifiers starting with nextval of existing dataset sequence.\\012------------------------------------------------------------------------------------\\012CREATE FUNCTION CREATE_SEQUENCE(EXISTING_SEQUENCE VARCHAR, NEW_SEQUENCE VARCHAR) RETURNS VOID AS $$\\012DECLARE\\012  CURR_SEQ_VAL   INTEGER;\\012BEGIN\\012  SELECT INTO CURR_SEQ_VAL NEXTVAL(EXISTING_SEQUENCE);\\012  EXECUTE 'CREATE SEQUENCE ' || NEW_SEQUENCE || ' START WITH ' || CURR_SEQ_VAL;\\012  RETURN;\\012END;\\012$$ LANGUAGE 'plpgsql';\\012\\012SELECT CREATE_SEQUENCE('DATA_ID_SEQ', 'PERM_ID_SEQ');\\012DROP FUNCTION CREATE_SEQUENCE(VARCHAR, VARCHAR);\\012\\012------------------------------------------------------------------------------------\\012-- Add perm_id columns to samples and experiments.\\012------------------------------------------------------------------------------------\\012ALTER TABLE SAMPLES ADD COLUMN PERM_ID CODE;\\012ALTER TABLE EXPERIMENTS ADD COLUMN PERM_ID CODE;\\012\\012UPDATE SAMPLES SET PERM_ID = to_char(registration_timestamp,'YYYYMMDDHHSSMS') || '-' || NEXTVAL('PERM_ID_SEQ');\\012UPDATE EXPERIMENTS SET PERM_ID = to_char(registration_timestamp,'YYYYMMDDHHSSMS') || '-' || NEXTVAL('PERM_ID_SEQ');\\012ALTER TABLE SAMPLES ALTER COLUMN PERM_ID SET NOT NULL;\\012ALTER TABLE EXPERIMENTS ALTER COLUMN PERM_ID SET NOT NULL;\\012ALTER TABLE SAMPLES ADD CONSTRAINT SAMP_PI_UK UNIQUE(PERM_ID);\\012ALTER TABLE EXPERIMENTS ADD CONSTRAINT EXPE_PI_UK UNIQUE(PERM_ID);\\012\\012\\012------------------------------------------------------------------------------------\\012-- Add column is_chosen_from_list to controlled_vocabularies.\\012------------------------------------------------------------------------------------\\012ALTER TABLE controlled_vocabularies ADD COLUMN is_chosen_from_list BOOLEAN_CHAR NOT NULL DEFAULT TRUE;\\012ALTER TABLE controlled_vocabularies ADD COLUMN source_uri CHARACTER VARYING(250);\\012------------------------------------------------------------------------------------\\012-- Modify Data table - remove arc connection between Sample and Data table, use a flag instead\\012------------------------------------------------------------------------------------\\012\\012-- add new columns\\012\\012ALTER TABLE data\\012    ADD COLUMN is_derived boolean_char;\\012ALTER TABLE data\\012    ADD COLUMN samp_id tech_id;\\012\\012-- update values in new columns\\012\\012UPDATE data\\012    SET is_derived = (samp_id_derived_from IS NOT NULL); \\012UPDATE data\\012    SET samp_id = samp_id_derived_from \\012    WHERE is_derived = 'TRUE';\\012UPDATE data\\012    SET samp_id = samp_id_acquired_from \\012    WHERE is_derived = 'FALSE';\\012\\012-- add constraints and indexes to new columns\\012\\012ALTER TABLE data\\012    ALTER COLUMN is_derived SET NOT NULL;\\012ALTER TABLE data\\012    ALTER COLUMN samp_id SET NOT NULL;   \\012ALTER TABLE data\\012    ADD CONSTRAINT data_samp_fk FOREIGN KEY (samp_id) REFERENCES samples (id);\\012CREATE INDEX data_samp_fk_i ON data USING btree (samp_id);\\012\\012-- remove old columns\\012\\012ALTER TABLE data\\012    DROP COLUMN samp_id_acquired_from;\\012ALTER TABLE data\\012    DROP COLUMN samp_id_derived_from;\\012    \\012------------------------------------------------------------------------------------\\012-- Granting SELECT privilege to group openbis_readonly\\012------------------------------------------------------------------------------------\\012\\012GRANT SELECT ON SEQUENCE attachment_content_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE attachment_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE code_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE controlled_vocabulary_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE cvte_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE data_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE data_set_property_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE data_set_relationship_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE data_set_type_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE data_store_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE data_type_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE database_instance_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE dstpt_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE etpt_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE event_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE experiment_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE experiment_property_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE experiment_type_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE file_format_type_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE group_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE invalidation_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE locator_type_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE material_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE material_property_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE material_type_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE mtpt_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE perm_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE person_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE project_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE property_type_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE role_assignment_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE sample_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE sample_property_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE sample_type_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE stpt_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE attachment_contents TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE attachments TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE controlled_vocabularies TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE controlled_vocabulary_terms TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE data TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE data_set_properties TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE data_set_relationships TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE data_set_type_property_types TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE data_set_types TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE data_stores TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE data_types TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE database_instances TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE database_version_logs TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE events TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE experiment_properties TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE experiment_type_property_types TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE experiment_types TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE experiments TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE external_data TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE file_format_types TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE groups TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE invalidations TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE locator_types TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE material_properties TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE material_type_property_types TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE material_types TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE materials TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE persons TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE projects TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE property_types TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE role_assignments TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE sample_properties TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE sample_type_property_types TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE sample_types TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE samples TO GROUP OPENBIS_READONLY;\\012\\012------------------------------------------------------------------------------------\\012-- Delete MATERIAL_BATCHES table\\012------------------------------------------------------------------------------------\\012\\012-- WARNING: Potential data lost!!!\\012-- WARNING: Potential data lost!!!\\012-- WARNING: Potential data lost!!!\\012\\012DROP TABLE SAMPLE_MATERIAL_BATCHES;\\012DROP TABLE MATERIAL_BATCHES;\\012DROP SEQUENCE MATERIAL_BATCH_ID_SEQ;\\012\\012------------------------------------------------------------------------------------\\012-- Delete MATE_ID_INHIBITOR_OF from table MATERIALS\\012------------------------------------------------------------------------------------\\012\\012-- WARNING: Potential data lost!!!\\012-- WARNING: Potential data lost!!!\\012-- WARNING: Potential data lost!!!\\012\\012ALTER TABLE MATERIALS DROP COLUMN MATE_ID_INHIBITOR_OF;\\012	\N
+./sourceTest/sql/postgresql/045/.svn/text-base/017=database_version_logs.tsv.svn-base:041	source/sql/postgresql/migration/migration-040-041.sql	SUCCESS	2009-09-14 13:48:57.539	-- Create FILTERS table\\012\\012CREATE TABLE FILTERS (ID TECH_ID NOT NULL, DBIN_ID TECH_ID NOT NULL, NAME VARCHAR(200) NOT NULL, DESCRIPTION DESCRIPTION_1000,REGISTRATION_TIMESTAMP TIME_STAMP_DFL NOT NULL DEFAULT CURRENT_TIMESTAMP, PERS_ID_REGISTERER TECH_ID NOT NULL, MODIFICATION_TIMESTAMP TIME_STAMP DEFAULT CURRENT_TIMESTAMP, EXPRESSION VARCHAR(2000) NOT NULL, IS_PUBLIC BOOLEAN NOT NULL, GRID_ID VARCHAR(200) NOT NULL);\\012CREATE SEQUENCE FILTER_ID_SEQ;\\012ALTER TABLE FILTERS ADD CONSTRAINT FILT_PK PRIMARY KEY(ID);\\012ALTER TABLE FILTERS ADD CONSTRAINT FILT_BK_UK UNIQUE(NAME, DBIN_ID, GRID_ID);\\012ALTER TABLE FILTERS ADD CONSTRAINT FILT_PERS_FK FOREIGN KEY (PERS_ID_REGISTERER) REFERENCES PERSONS(ID);\\012ALTER TABLE FILTERS ADD CONSTRAINT FILT_DBIN_FK FOREIGN KEY (DBIN_ID) REFERENCES DATABASE_INSTANCES(ID);\\012CREATE INDEX FILT_PERS_FK_I ON FILTERS (PERS_ID_REGISTERER);\\012CREATE INDEX FILT_DBIN_FK_I ON FILTERS (DBIN_ID);\\012GRANT SELECT ON SEQUENCE filter_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE filters TO GROUP OPENBIS_READONLY;\\012\\012-- Add missing foreign key to role assignments authorization group\\012ALTER TABLE ROLE_ASSIGNMENTS ADD CONSTRAINT ROAS_AG_FK_GRANTEE FOREIGN KEY (AG_ID_GRANTEE) REFERENCES AUTHORIZATION_GROUPS(ID);\\012\\012--------------------------------------------------------------------------------------------------\\012-- Modify dataset connections:\\012-- 1. connection with sample shouldn't be mandatory any more\\012-- 2. introduce an arc condition that dataset cannot be connected with a sample and a parent dataset at the same time\\012--------------------------------------------------------------------------------------------------\\012\\012-- Weaken data-sample connection constraint - allow dataset to have no connection with sample\\012ALTER TABLE data ALTER COLUMN samp_id DROP NOT NULL;\\012\\012-- Remove data-sample connection for datasets that have a parent\\012\\012UPDATE data \\012   SET samp_id = NULL \\012 WHERE id IN (SELECT DISTINCT data_id_child FROM data_set_relationships);\\012\\012-- With PostgreSQL 8.4 one can check that before migration there were no cycles in dataset relationships:\\012--\\012-- WITH RECURSIVE data_set_parents(id, parent_ids, cycle) AS (\\012--         SELECT  r.data_id_child AS id, \\012--                 ARRAY[CAST (r.data_id_parent AS bigint)] AS parent_ids, \\012--                 false AS cycle \\012--         FROM data_set_relationships r\\012--     UNION ALL\\012--         SELECT  r.data_id_child,\\012--                 CAST (r.data_id_parent AS bigint) || p.parent_ids,\\012--                 r.data_id_child = ANY(p.parent_ids)\\012--         FROM data_set_relationships r, data_set_parents p\\012--         WHERE r.data_id_parent = p.id AND NOT cycle\\012-- )\\012-- SELECT count(*) AS cycles FROM data_set_parents WHERE cycle = true;\\012\\012---------------------------------------------------------------------------------------------------\\012--  Purpose:  Create DEFERRED triggers:\\012--            * check_dataset_relationships_on_data_table_modification,\\012--            * check_dataset_relationships_on_relationships_table_modification.\\012--            They check that after all modifications of database (just before commit) \\012--            if 'data'/'data_set_relationships' tables are among modified tables \\012--            dataset is not connected with a sample and a parent dataset at the same time.\\012--            This connections are held in two different tables so simple immediate trigger \\012--            with arc check cannot be used and we need two deferred triggers.\\012----------------------------------------------------------------------------------------------------\\012\\012-- trigger for 'data' table\\012\\012CREATE OR REPLACE FUNCTION check_dataset_relationships_on_data_table_modification() RETURNS trigger AS $$\\012DECLARE\\012\\011counter\\011INTEGER;\\012BEGIN\\012\\011-- if there is a connection with a Sample there should not be any connection with a parent Data Set\\012\\011IF (NEW.samp_id IS NOT NULL) THEN\\012\\011\\011-- count number of parents\\012\\011\\011SELECT count(*) INTO counter \\012\\011\\011\\011FROM data_set_relationships \\012\\011\\011\\011WHERE data_id_child = OLD.id;\\012\\011\\011IF (counter > 0) THEN\\012\\011\\011\\011RAISE EXCEPTION 'Insert/Update of Data Set (Code: %) failed because it cannot be connected with a Sample and a parent Data Set at the same time.', OLD.code;\\012\\011\\011END IF;\\012\\011END IF;\\012  RETURN NEW;\\012END;\\012$$ LANGUAGE 'plpgsql';\\012\\012CREATE CONSTRAINT TRIGGER check_dataset_relationships_on_data_table_modification \\012  AFTER INSERT OR UPDATE ON data\\012\\011DEFERRABLE INITIALLY DEFERRED\\012\\011FOR EACH ROW \\012\\011EXECUTE PROCEDURE check_dataset_relationships_on_data_table_modification();\\012\\012-- trigger for 'data_set_relationships'\\012\\012CREATE OR REPLACE FUNCTION check_dataset_relationships_on_relationships_table_modification() RETURNS trigger AS $$\\012DECLARE\\012\\011counter\\011INTEGER;\\012\\011sample_id\\011TECH_ID;\\012\\011data_code\\011CODE;\\012BEGIN\\012\\011-- child will have a parent added so it should not be connected with any sample\\012\\011SELECT samp_id, code INTO sample_id, data_code \\012\\011\\011FROM data \\012\\011\\011WHERE id = NEW.data_id_child;\\012\\011IF (sample_id IS NOT NULL) THEN\\012\\011\\011RAISE EXCEPTION 'Insert/Update of Data Set (Code: %) failed because it cannot be connected to a Sample and to a parent Data Set at the same time.', data_code;\\012\\011END IF;\\012\\011RETURN NEW;\\012END;\\012$$ LANGUAGE 'plpgsql';\\012  \\012CREATE CONSTRAINT TRIGGER check_dataset_relationships_on_relationships_table_modification \\012  AFTER INSERT OR UPDATE ON data_set_relationships\\012\\011DEFERRABLE INITIALLY DEFERRED\\012\\011FOR EACH ROW \\012\\011EXECUTE PROCEDURE check_dataset_relationships_on_relationships_table_modification();\\012	\N
+./sourceTest/sql/postgresql/045/.svn/text-base/schema-045.sql.svn-base:    LANGUAGE plpgsql;
+./sourceTest/sql/postgresql/045/.svn/text-base/schema-045.sql.svn-base:    LANGUAGE plpgsql;
+./sourceTest/sql/postgresql/045/.svn/text-base/schema-045.sql.svn-base:    LANGUAGE plpgsql;
+./sourceTest/sql/postgresql/045/.svn/text-base/schema-045.sql.svn-base:    LANGUAGE plpgsql;
+./sourceTest/sql/postgresql/045/.svn/text-base/schema-045.sql.svn-base:    LANGUAGE plpgsql;
+./sourceTest/sql/postgresql/045/.svn/text-base/schema-045.sql.svn-base:    LANGUAGE plpgsql;
+./sourceTest/sql/postgresql/045/.svn/text-base/schema-045.sql.svn-base:    LANGUAGE plpgsql;
+./sourceTest/sql/postgresql/045/.svn/text-base/schema-045.sql.svn-base:    LANGUAGE plpgsql;
+./sourceTest/sql/postgresql/045/.svn/text-base/schema-045.sql.svn-base:    LANGUAGE plpgsql;
+./sourceTest/sql/postgresql/045/.svn/text-base/schema-045.sql.svn-base:    LANGUAGE plpgsql;
+./sourceTest/sql/postgresql/045/017=database_version_logs.tsv:027	D:\\User\\felmer\\dev-workspace\\openbis/source/sql/postgresql/027/function-027.sql	SUCCESS	2008-11-05 09:18:00.403	-- Creating Functions\\012\\012------------------------------------------------------------------------------------\\012--  Purpose:  Create function RENAME_SEQUENCE() that is required for renaming the sequences belonging to tables\\012------------------------------------------------------------------------------------\\012CREATE FUNCTION RENAME_SEQUENCE(OLD_NAME VARCHAR, NEW_NAME VARCHAR) RETURNS INTEGER AS $$\\012DECLARE\\012  CURR_SEQ_VAL   INTEGER;\\012BEGIN\\012  SELECT INTO CURR_SEQ_VAL NEXTVAL(OLD_NAME);\\012  EXECUTE 'CREATE SEQUENCE ' || NEW_NAME || ' START WITH ' || CURR_SEQ_VAL;\\012  EXECUTE 'DROP SEQUENCE ' || OLD_NAME;\\012  RETURN CURR_SEQ_VAL;\\012END;\\012$$ LANGUAGE 'plpgsql';\\012\\012\\012------------------------------------------------------------------------------------\\012--  Purpose:  Create trigger CONTROLLED_VOCABULARY_CHECK \\012------------------------------------------------------------------------------------\\012\\012CREATE OR REPLACE FUNCTION CONTROLLED_VOCABULARY_CHECK() RETURNS trigger AS $$\\012DECLARE\\012   v_code  CODE;\\012BEGIN\\012\\012   select code into v_code from data_types where id = NEW.daty_id;\\012\\012   -- Check if the data is of type "CONTROLLEDVOCABULARY"\\012   if v_code = 'CONTROLLEDVOCABULARY' then\\012      if NEW.covo_id IS NULL then\\012         RAISE EXCEPTION 'Insert/Update of Property Type (Code: %) failed, as its Data Type is CONTROLLEDVOCABULARY, but it is not linked to a Controlled Vocabulary.', NEW.code;\\012      end if;\\012   end if;\\012\\012   RETURN NEW;\\012\\012END;\\012$$ LANGUAGE 'plpgsql';\\012\\012CREATE TRIGGER CONTROLLED_VOCABULARY_CHECK BEFORE INSERT OR UPDATE ON PROPERTY_TYPES\\012    FOR EACH ROW EXECUTE PROCEDURE CONTROLLED_VOCABULARY_CHECK();\\012\\012\\012------------------------------------------------------------------------------------\\012--  Purpose:  Create trigger EXTERNAL_DATA_STORAGE_FORMAT_CHECK \\012------------------------------------------------------------------------------------\\012\\012CREATE OR REPLACE FUNCTION EXTERNAL_DATA_STORAGE_FORMAT_CHECK() RETURNS trigger AS $$\\012DECLARE\\012   v_covo_code  CODE;\\012   data_code CODE;\\012BEGIN\\012\\012   select code into v_covo_code from controlled_vocabularies\\012      where is_internal_namespace = true and \\012         id = (select covo_id from controlled_vocabulary_terms where id = NEW.cvte_id_stor_fmt);\\012   -- Check if the data storage format is a term of the controlled vocabulary "STORAGE_FORMAT"\\012   if v_covo_code != 'STORAGE_FORMAT' then\\012      select code into data_code from data where id = NEW.data_id; \\012      RAISE EXCEPTION 'Insert/Update of Data (Code: %) failed, as its Storage Format is %, but is required to be STORAGE_FORMAT.', data_code, v_covo_code;\\012   end if;\\012\\012   RETURN NEW;\\012\\012END;\\012$$ LANGUAGE 'plpgsql';\\012\\012CREATE TRIGGER EXTERNAL_DATA_STORAGE_FORMAT_CHECK BEFORE INSERT OR UPDATE ON EXTERNAL_DATA\\012    FOR EACH ROW EXECUTE PROCEDURE EXTERNAL_DATA_STORAGE_FORMAT_CHECK();\\012\\012------------------------------------------------------------------------------------\\012--  Purpose:  Create trigger SAMPLE_CODE_UNIQUENESS_CHECK \\012------------------------------------------------------------------------------------\\012\\012CREATE OR REPLACE FUNCTION SAMPLE_CODE_UNIQUENESS_CHECK() RETURNS trigger AS $$\\012DECLARE\\012   counter  INTEGER;\\012BEGIN\\012\\011IF (NEW.samp_id_part_of is NULL) THEN\\012\\011\\011IF (NEW.dbin_id is not NULL) THEN\\012\\011\\011\\011SELECT count(*) into counter FROM samples \\012\\011\\011\\011\\011where id != NEW.id and code = NEW.code and samp_id_part_of is NULL and dbin_id = NEW.dbin_id;\\012\\011\\011\\011IF (counter > 0) THEN\\012\\011\\011\\011\\011RAISE EXCEPTION 'Insert/Update of Sample (Code: %) failed because database instance sample with the same code already exists.', NEW.code;\\012\\011\\011\\011END IF;\\012\\011\\011ELSIF (NEW.grou_id is not NULL) THEN\\012\\011\\011\\011SELECT count(*) into counter FROM samples \\012\\011\\011\\011\\011where id != NEW.id and code = NEW.code and samp_id_part_of is NULL and grou_id = NEW.grou_id;\\012\\011\\011\\011IF (counter > 0) THEN\\012\\011\\011\\011\\011RAISE EXCEPTION 'Insert/Update of Sample (Code: %) failed because group sample with the same code already exists.', NEW.code;\\012\\011\\011\\011END IF;\\012\\011\\011END IF;\\012        ELSE\\012\\011\\011IF (NEW.dbin_id is not NULL) THEN\\012\\011\\011\\011SELECT count(*) into counter FROM samples \\012\\011\\011\\011\\011where id != NEW.id and code = NEW.code and samp_id_part_of = NEW.samp_id_part_of and dbin_id = NEW.dbin_id;\\012\\011\\011\\011IF (counter > 0) THEN\\012\\011\\011\\011\\011RAISE EXCEPTION 'Insert/Update of Sample (Code: %) failed because database instance sample with the same code and being the part of the same parent already exists.', NEW.code;\\012\\011\\011\\011END IF;\\012\\011\\011ELSIF (NEW.grou_id is not NULL) THEN\\012\\011\\011\\011SELECT count(*) into counter FROM samples \\012\\011\\011\\011\\011where id != NEW.id and code = NEW.code and samp_id_part_of = NEW.samp_id_part_of and grou_id = NEW.grou_id;\\012\\011\\011\\011IF (counter > 0) THEN\\012\\011\\011\\011\\011RAISE EXCEPTION 'Insert/Update of Sample (Code: %) failed because group sample with the same code and being the part of the same parent already exists.', NEW.code;\\012\\011\\011\\011END IF;\\012\\011\\011END IF;\\012        END IF;   \\012   RETURN NEW;\\012END;\\012$$ LANGUAGE 'plpgsql';\\012\\012CREATE TRIGGER SAMPLE_CODE_UNIQUENESS_CHECK BEFORE INSERT OR UPDATE ON SAMPLES\\012    FOR EACH ROW EXECUTE PROCEDURE SAMPLE_CODE_UNIQUENESS_CHECK();\\012	\N
+./sourceTest/sql/postgresql/045/017=database_version_logs.tsv:028	source/sql/postgresql/migration/migration-027-028.sql	SUCCESS	2008-11-18 13:24:17.508	-- Create EXPERIMENT_ATTACHMENT_CONTENTS.\\012CREATE TABLE EXPERIMENT_ATTACHMENT_CONTENTS (ID TECH_ID NOT NULL,VALUE FILE NOT NULL);\\012CREATE SEQUENCE EXPERIMENT_ATTACHMENT_CONTENT_ID_SEQ;\\012ALTER TABLE EXPERIMENT_ATTACHMENT_CONTENTS ADD CONSTRAINT EXAC_PK PRIMARY KEY(ID);\\012\\012-- Alter EXPERIMENT_ATTACHMENTS by adding the new column which has a NULL constraint.\\012-- The NOT NULL constraint is added later on.\\012ALTER TABLE EXPERIMENT_ATTACHMENTS ADD COLUMN EXAC_ID TECH_ID;\\012\\012-- Does the VALUE migration between EXPERIMENT_ATTACHMENTS to EXPERIMENT_ATTACHMENT_CONTENTS.\\012CREATE OR REPLACE FUNCTION move_exp_att_content() RETURNS integer AS $$\\012DECLARE\\012    rec RECORD;\\012    seq BIGINT;\\012BEGIN\\012  FOR rec IN SELECT id, value FROM EXPERIMENT_ATTACHMENTS LOOP\\012  \\011seq := nextval('EXPERIMENT_ATTACHMENT_CONTENT_ID_SEQ');\\012    INSERT INTO EXPERIMENT_ATTACHMENT_CONTENTS (id, value) VALUES (seq, rec.value);\\012    UPDATE EXPERIMENT_ATTACHMENTS SET exac_id = seq WHERE id = rec.id;\\012  END LOOP;\\012  RETURN 1;\\012END;\\012$$ LANGUAGE 'plpgsql';\\012\\012-- Call the function.\\012SELECT move_exp_att_content();\\012DROP FUNCTION move_exp_att_content();\\012\\012\\012-- Finish EXPERIMENT_ATTACHMENTS changes.\\012ALTER TABLE EXPERIMENT_ATTACHMENTS ADD CONSTRAINT EXAT_CONT_FK FOREIGN KEY (EXAC_ID) REFERENCES EXPERIMENT_ATTACHMENT_CONTENTS(ID);\\012ALTER TABLE EXPERIMENT_ATTACHMENTS DROP COLUMN VALUE;\\012ALTER TABLE EXPERIMENT_ATTACHMENTS ALTER COLUMN EXAC_ID SET NOT NULL;\\012	\N
+./sourceTest/sql/postgresql/045/017=database_version_logs.tsv:029	source/sql/postgresql/migration/migration-028-029.sql	SUCCESS	2009-03-18 10:50:20.105	-- -------\\012-- add modification_timestamp field to allow edition with Hibernate\\012-- -------\\012\\012ALTER TABLE samples\\012\\011ADD COLUMN modification_timestamp TIME_STAMP DEFAULT CURRENT_TIMESTAMP;\\012\\012ALTER TABLE experiments\\012\\011ADD COLUMN modification_timestamp TIME_STAMP DEFAULT CURRENT_TIMESTAMP;\\012\\012ALTER TABLE materials\\012\\011ADD COLUMN modification_timestamp TIME_STAMP DEFAULT CURRENT_TIMESTAMP;\\012\\012ALTER TABLE experiment_properties\\012\\011ADD COLUMN modification_timestamp TIME_STAMP DEFAULT CURRENT_TIMESTAMP;\\012\\012ALTER TABLE material_properties\\012\\011ADD COLUMN modification_timestamp TIME_STAMP DEFAULT CURRENT_TIMESTAMP;\\012\\012ALTER TABLE sample_properties\\012\\011ADD COLUMN modification_timestamp TIME_STAMP DEFAULT CURRENT_TIMESTAMP;\\012\\012-- -------\\012-- add property data type which references materials\\012-- -------\\012\\012ALTER TABLE property_types\\012\\011ADD COLUMN maty_prop_id tech_id;\\012\\012ALTER TABLE property_types\\012\\011ADD CONSTRAINT prty_maty_fk FOREIGN KEY (maty_prop_id) REFERENCES material_types(id);\\012\\012ALTER TABLE experiment_properties\\012\\011ADD COLUMN mate_prop_id tech_id;\\012\\012ALTER TABLE material_properties\\012\\011ADD COLUMN mate_prop_id tech_id;\\012\\012ALTER TABLE sample_properties\\012\\011ADD COLUMN mate_prop_id tech_id;\\012\\012ALTER TABLE experiment_properties\\012\\011ADD CONSTRAINT expr_mapr_fk FOREIGN KEY (mate_prop_id) REFERENCES materials(id);\\012\\012ALTER TABLE material_properties\\012\\011ADD CONSTRAINT mapr_mapr_fk FOREIGN KEY (mate_prop_id) REFERENCES materials(id);\\012\\012ALTER TABLE sample_properties\\012\\011ADD CONSTRAINT sapr_mapr_fk FOREIGN KEY (mate_prop_id) REFERENCES materials(id);\\012\\012insert into data_types\\012(id\\012 ,code\\012 ,description)\\012 values \\012 (nextval('DATA_TYPE_ID_SEQ')\\012 ,'MATERIAL'\\012 ,'Reference to a material'\\012);\\012\\012ALTER TABLE MATERIAL_PROPERTIES DROP CONSTRAINT MAPR_CK;\\012ALTER TABLE MATERIAL_PROPERTIES ADD CONSTRAINT MAPR_CK CHECK \\012\\011((VALUE IS NOT NULL AND CVTE_ID IS NULL AND MATE_PROP_ID IS NULL) OR \\012\\011 (VALUE IS NULL AND CVTE_ID IS NOT NULL AND MATE_PROP_ID IS NULL) OR\\012\\011 (VALUE IS NULL AND CVTE_ID IS NULL AND MATE_PROP_ID IS NOT NULL)\\012\\011);\\012\\012ALTER TABLE EXPERIMENT_PROPERTIES DROP CONSTRAINT EXPR_CK;\\012ALTER TABLE EXPERIMENT_PROPERTIES ADD CONSTRAINT EXPR_CK CHECK \\012\\011((VALUE IS NOT NULL AND CVTE_ID IS NULL AND MATE_PROP_ID IS NULL) OR \\012\\011 (VALUE IS NULL AND CVTE_ID IS NOT NULL AND MATE_PROP_ID IS NULL) OR\\012\\011 (VALUE IS NULL AND CVTE_ID IS NULL AND MATE_PROP_ID IS NOT NULL)\\012\\011);\\012\\012ALTER TABLE SAMPLE_PROPERTIES DROP CONSTRAINT SAPR_CK;\\012ALTER TABLE SAMPLE_PROPERTIES ADD CONSTRAINT SAPR_CK CHECK \\012\\011((VALUE IS NOT NULL AND CVTE_ID IS NULL AND MATE_PROP_ID IS NULL) OR \\012\\011 (VALUE IS NULL AND CVTE_ID IS NOT NULL AND MATE_PROP_ID IS NULL) OR\\012\\011 (VALUE IS NULL AND CVTE_ID IS NULL AND MATE_PROP_ID IS NOT NULL)\\012\\011);\\012\\012------------------------------------------------------------------------------------\\012--  Purpose:  Create trigger MATERIAL/SAMPLE/EXPERIMENT _PROPERTY_WITH_MATERIAL_DATA_TYPE_CHECK\\012--            It checks that if material property value is assigned to the entity,\\012--\\011\\011\\011\\011\\011\\011then the material type is equal to the one described by property type.\\012------------------------------------------------------------------------------------\\012\\012CREATE OR REPLACE FUNCTION MATERIAL_PROPERTY_WITH_MATERIAL_DATA_TYPE_CHECK() RETURNS trigger AS $$\\012DECLARE\\012   v_type_id  CODE;\\012   v_type_id_prop  CODE;\\012BEGIN\\012   if NEW.mate_prop_id IS NOT NULL then\\012\\011\\011\\011-- find material type id of the property type \\012\\011\\011\\011select pt.maty_prop_id into v_type_id_prop \\012\\011\\011\\011  from material_type_property_types etpt, property_types pt \\012\\011\\011\\011 where NEW.mtpt_id = etpt.id AND etpt.prty_id = pt.id;\\012\\011\\011\\012\\011\\011\\011if v_type_id_prop IS NOT NULL then\\012\\011\\011\\011\\011-- find material type id of the material which consists the entity's property value\\012\\011\\011\\011\\011select entity.maty_id into v_type_id \\012\\011\\011\\011\\011  from materials entity\\012\\011\\011\\011\\011 where NEW.mate_prop_id = entity.id;\\012\\011\\011\\011\\011if v_type_id != v_type_id_prop then\\012\\011\\011\\011\\011\\011RAISE EXCEPTION 'Insert/Update of property value referencing material (id: %) failed, as referenced material type is different than expected (id %, expected id: %).', \\012\\011\\011\\011\\011\\011\\011\\011 NEW.mate_prop_id, v_type_id, v_type_id_prop;\\012\\011\\011\\011\\011end if;\\012\\011\\011\\011end if;\\012   end if;\\012   RETURN NEW;\\012END;\\012$$ LANGUAGE 'plpgsql';\\012\\012CREATE TRIGGER MATERIAL_PROPERTY_WITH_MATERIAL_DATA_TYPE_CHECK BEFORE INSERT OR UPDATE ON material_properties\\012    FOR EACH ROW EXECUTE PROCEDURE MATERIAL_PROPERTY_WITH_MATERIAL_DATA_TYPE_CHECK();\\012    \\012CREATE OR REPLACE FUNCTION SAMPLE_PROPERTY_WITH_MATERIAL_DATA_TYPE_CHECK() RETURNS trigger AS $$\\012DECLARE\\012   v_type_id  CODE;\\012   v_type_id_prop  CODE;\\012BEGIN\\012   if NEW.mate_prop_id IS NOT NULL then\\012\\011\\011\\011-- find material type id of the property type \\012\\011\\011\\011select pt.maty_prop_id into v_type_id_prop \\012\\011\\011\\011  from sample_type_property_types etpt, property_types pt \\012\\011\\011\\011 where NEW.stpt_id = etpt.id AND etpt.prty_id = pt.id;\\012\\011\\011\\012\\011\\011\\011if v_type_id_prop IS NOT NULL then\\012\\011\\011\\011\\011-- find material type id of the material which consists the entity's property value\\012\\011\\011\\011\\011select entity.maty_id into v_type_id \\012\\011\\011\\011\\011  from materials entity\\012\\011\\011\\011\\011 where NEW.mate_prop_id = entity.id;\\012\\011\\011\\011\\011if v_type_id != v_type_id_prop then\\012\\011\\011\\011\\011\\011RAISE EXCEPTION 'Insert/Update of property value referencing material (id: %) failed, as referenced material type is different than expected (id %, expected id: %).', \\012\\011\\011\\011\\011\\011\\011\\011\\011\\011\\011\\011\\011 NEW.mate_prop_id, v_type_id, v_type_id_prop;\\012\\011\\011\\011\\011end if;\\012\\011\\011\\011end if;\\012   end if;\\012   RETURN NEW;\\012END;\\012$$ LANGUAGE 'plpgsql';\\012\\012CREATE TRIGGER SAMPLE_PROPERTY_WITH_MATERIAL_DATA_TYPE_CHECK BEFORE INSERT OR UPDATE ON sample_properties\\012    FOR EACH ROW EXECUTE PROCEDURE SAMPLE_PROPERTY_WITH_MATERIAL_DATA_TYPE_CHECK();\\012    \\012CREATE OR REPLACE FUNCTION EXPERIMENT_PROPERTY_WITH_MATERIAL_DATA_TYPE_CHECK() RETURNS trigger AS $$\\012DECLARE\\012   v_type_id  CODE;\\012   v_type_id_prop  CODE;\\012BEGIN\\012   if NEW.mate_prop_id IS NOT NULL then\\012\\011\\011\\011-- find material type id of the property type \\012\\011\\011\\011select pt.maty_prop_id into v_type_id_prop \\012\\011\\011\\011  from experiment_type_property_types etpt, property_types pt \\012\\011\\011\\011 where NEW.etpt_id = etpt.id AND etpt.prty_id = pt.id;\\012\\011\\011\\012\\011\\011\\011if v_type_id_prop IS NOT NULL then\\012\\011\\011\\011\\011-- find material type id of the material which consists the entity's property value\\012\\011\\011\\011\\011select entity.maty_id into v_type_id \\012\\011\\011\\011\\011  from materials entity\\012\\011\\011\\011\\011 where NEW.mate_prop_id = entity.id;\\012\\011\\011\\011\\011if v_type_id != v_type_id_prop then\\012\\011\\011\\011\\011\\011RAISE EXCEPTION 'Insert/Update of property value referencing material (id: %) failed, as referenced material type is different than expected (id %, expected id: %).', \\012\\011\\011\\011\\011\\011\\011\\011\\011\\011\\011\\011\\011 NEW.mate_prop_id, v_type_id, v_type_id_prop;\\012\\011\\011\\011\\011end if;\\012\\011\\011\\011end if;\\012   end if;\\012   RETURN NEW;\\012END;\\012$$ LANGUAGE 'plpgsql';\\012\\012CREATE TRIGGER EXPERIMENT_PROPERTY_WITH_MATERIAL_DATA_TYPE_CHECK BEFORE INSERT OR UPDATE ON experiment_properties\\012    FOR EACH ROW EXECUTE PROCEDURE EXPERIMENT_PROPERTY_WITH_MATERIAL_DATA_TYPE_CHECK();\\012       \\012-- -------\\012-- remove the reminescents of the OBSERVABLE_TYPE\\012-- -------\\012\\012ALTER TABLE data\\012\\011DROP CONSTRAINT data_obty_fk;\\012\\012ALTER TABLE data_set_types\\012\\011DROP CONSTRAINT obty_pk;\\012\\012ALTER TABLE data_set_types\\012\\011ADD CONSTRAINT dsty_pk PRIMARY KEY (id);\\012\\012ALTER TABLE data\\012\\011ADD CONSTRAINT data_dsty_fk FOREIGN KEY (dsty_id) REFERENCES data_set_types(id);\\012\\012ALTER TABLE data_set_types\\012\\011DROP CONSTRAINT obty_bk_uk;\\012\\012ALTER TABLE data_set_types\\012\\011DROP CONSTRAINT obty_dbin_fk;\\012\\012ALTER TABLE data_set_types\\012\\011ADD CONSTRAINT dsty_bk_uk UNIQUE (code, dbin_id);\\012\\012ALTER TABLE data_set_types\\012\\011ADD CONSTRAINT dsty_dbin_fk FOREIGN KEY (dbin_id) REFERENCES database_instances(id);\\012\\012DROP INDEX data_obty_fk_i;\\012\\012CREATE INDEX data_dsty_fk_i ON data(dsty_id);\\012	\N
+./sourceTest/sql/postgresql/045/017=database_version_logs.tsv:030	source/sql/postgresql/migration/migration-029-030.sql	SUCCESS	2009-03-23 15:34:44.72	-- -------\\012-- add modification_timestamp field to allow edition with Hibernate\\012-- -------\\012ALTER TABLE data\\012\\011ADD COLUMN modification_timestamp TIME_STAMP DEFAULT CURRENT_TIMESTAMP;\\012ALTER TABLE experiment_types\\012\\011ADD COLUMN modification_timestamp TIME_STAMP DEFAULT CURRENT_TIMESTAMP;\\012ALTER TABLE sample_types\\012\\011ADD COLUMN modification_timestamp TIME_STAMP DEFAULT CURRENT_TIMESTAMP;\\012ALTER TABLE material_types\\012\\011ADD COLUMN modification_timestamp TIME_STAMP DEFAULT CURRENT_TIMESTAMP;\\012ALTER TABLE data_set_types\\012\\011ADD COLUMN modification_timestamp TIME_STAMP DEFAULT CURRENT_TIMESTAMP;\\012ALTER TABLE controlled_vocabularies\\012\\011ADD COLUMN modification_timestamp TIME_STAMP DEFAULT CURRENT_TIMESTAMP;\\012-- -------\\012-- add properties to data sets\\012-- -------\\012CREATE TABLE DATA_SET_PROPERTIES (ID TECH_ID NOT NULL,DS_ID TECH_ID NOT NULL,DSTPT_ID TECH_ID NOT NULL,VALUE GENERIC_VALUE,CVTE_ID TECH_ID, MATE_PROP_ID TECH_ID, PERS_ID_REGISTERER TECH_ID NOT NULL,REGISTRATION_TIMESTAMP TIME_STAMP_DFL NOT NULL DEFAULT CURRENT_TIMESTAMP, MODIFICATION_TIMESTAMP TIME_STAMP DEFAULT CURRENT_TIMESTAMP);\\012CREATE TABLE DATA_SET_TYPE_PROPERTY_TYPES (ID TECH_ID NOT NULL,DSTY_ID TECH_ID NOT NULL,PRTY_ID TECH_ID NOT NULL,IS_MANDATORY BOOLEAN_CHAR NOT NULL DEFAULT 'F',IS_MANAGED_INTERNALLY BOOLEAN_CHAR NOT NULL DEFAULT 'F',PERS_ID_REGISTERER TECH_ID NOT NULL,REGISTRATION_TIMESTAMP TIME_STAMP_DFL NOT NULL DEFAULT CURRENT_TIMESTAMP);\\012\\012CREATE SEQUENCE DATA_SET_PROPERTY_ID_SEQ;\\012CREATE SEQUENCE DSTPT_ID_SEQ;\\012\\012ALTER TABLE DATA_SET_TYPE_PROPERTY_TYPES ADD CONSTRAINT DSTPT_PK PRIMARY KEY(ID);\\012ALTER TABLE DATA_SET_PROPERTIES ADD CONSTRAINT DSPR_PK PRIMARY KEY(ID);\\012\\012ALTER TABLE DATA_SET_TYPE_PROPERTY_TYPES ADD CONSTRAINT DSTPT_BK_UK UNIQUE(DSTY_ID,PRTY_ID);\\012ALTER TABLE DATA_SET_PROPERTIES ADD CONSTRAINT DSPR_BK_UK UNIQUE(DS_ID,DSTPT_ID);\\012\\012\\012ALTER TABLE DATA_SET_TYPE_PROPERTY_TYPES ADD CONSTRAINT DSTPT_DSTY_FK FOREIGN KEY (DSTY_ID) REFERENCES DATA_SET_TYPES(ID);\\012ALTER TABLE DATA_SET_TYPE_PROPERTY_TYPES ADD CONSTRAINT DSTPT_PERS_FK FOREIGN KEY (PERS_ID_REGISTERER) REFERENCES PERSONS(ID);\\012ALTER TABLE DATA_SET_TYPE_PROPERTY_TYPES ADD CONSTRAINT DSTPT_PRTY_FK FOREIGN KEY (PRTY_ID) REFERENCES PROPERTY_TYPES(ID);\\012ALTER TABLE DATA_SET_PROPERTIES ADD CONSTRAINT DSPR_CVTE_FK FOREIGN KEY (CVTE_ID) REFERENCES CONTROLLED_VOCABULARY_TERMS(ID);\\012ALTER TABLE DATA_SET_PROPERTIES ADD CONSTRAINT DSPR_DSTPT_FK FOREIGN KEY (DSTPT_ID) REFERENCES DATA_SET_TYPE_PROPERTY_TYPES(ID) ON DELETE CASCADE;\\012ALTER TABLE DATA_SET_PROPERTIES ADD CONSTRAINT DSPR_DS_FK FOREIGN KEY (DS_ID) REFERENCES DATA(ID);\\012ALTER TABLE DATA_SET_PROPERTIES ADD CONSTRAINT DSPR_PERS_FK FOREIGN KEY (PERS_ID_REGISTERER) REFERENCES PERSONS(ID);\\012ALTER TABLE DATA_SET_PROPERTIES ADD CONSTRAINT DSPR_MAPR_FK FOREIGN KEY (MATE_PROP_ID) REFERENCES MATERIALS(ID);\\012\\012ALTER TABLE DATA_SET_PROPERTIES ADD CONSTRAINT DSPR_CK CHECK \\012\\011((VALUE IS NOT NULL AND CVTE_ID IS NULL AND MATE_PROP_ID IS NULL) OR \\012\\011 (VALUE IS NULL AND CVTE_ID IS NOT NULL AND MATE_PROP_ID IS NULL) OR\\012\\011 (VALUE IS NULL AND CVTE_ID IS NULL AND MATE_PROP_ID IS NOT NULL)\\012\\011);\\012\\012CREATE INDEX DSPR_CVTE_FK_I ON DATA_SET_PROPERTIES (CVTE_ID);\\012CREATE INDEX DSPR_DSTPT_FK_I ON DATA_SET_PROPERTIES (DSTPT_ID);\\012CREATE INDEX DSPR_DS_FK_I ON DATA_SET_PROPERTIES (DS_ID);\\012CREATE INDEX DSPR_PERS_FK_I ON DATA_SET_PROPERTIES (PERS_ID_REGISTERER);\\012CREATE INDEX DSTPT_DSTY_FK_I ON DATA_SET_TYPE_PROPERTY_TYPES (DSTY_ID);\\012CREATE INDEX DSTPT_PERS_FK_I ON DATA_SET_TYPE_PROPERTY_TYPES (PERS_ID_REGISTERER);\\012CREATE INDEX DSTPT_PRTY_FK_I ON DATA_SET_TYPE_PROPERTY_TYPES (PRTY_ID);\\012\\012CREATE OR REPLACE FUNCTION DATA_SET_PROPERTY_WITH_MATERIAL_DATA_TYPE_CHECK() RETURNS trigger AS $$\\012DECLARE\\012   v_type_id  CODE;\\012   v_type_id_prop  CODE;\\012BEGIN\\012   if NEW.mate_prop_id IS NOT NULL then\\012\\011\\011\\011-- find material type id of the property type \\012\\011\\011\\011select pt.maty_prop_id into v_type_id_prop \\012\\011\\011\\011  from data_set_type_property_types dstpt, property_types pt \\012\\011\\011\\011 where NEW.dstpt_id = dstpt.id AND dstpt.prty_id = pt.id;\\012\\011\\011\\012\\011\\011\\011if v_type_id_prop IS NOT NULL then\\012\\011\\011\\011\\011-- find material type id of the material which consists the entity's property value\\012\\011\\011\\011\\011select entity.maty_id into v_type_id \\012\\011\\011\\011\\011  from materials entity\\012\\011\\011\\011\\011 where NEW.mate_prop_id = entity.id;\\012\\011\\011\\011\\011if v_type_id != v_type_id_prop then\\012\\011\\011\\011\\011\\011RAISE EXCEPTION 'Insert/Update of property value referencing material (id: %) failed, as referenced material type is different than expected (id %, expected id: %).', \\012\\011\\011\\011\\011\\011\\011\\011\\011\\011\\011\\011\\011 NEW.mate_prop_id, v_type_id, v_type_id_prop;\\012\\011\\011\\011\\011end if;\\012\\011\\011\\011end if;\\012   end if;\\012   RETURN NEW;\\012END;\\012$$ LANGUAGE 'plpgsql';\\012\\012CREATE TRIGGER DATA_SET_PROPERTY_WITH_MATERIAL_DATA_TYPE_CHECK BEFORE INSERT OR UPDATE ON data_set_properties\\012    FOR EACH ROW EXECUTE PROCEDURE DATA_SET_PROPERTY_WITH_MATERIAL_DATA_TYPE_CHECK();   \\012	\N
+./sourceTest/sql/postgresql/045/017=database_version_logs.tsv:032	source/sql/postgresql/migration/migration-031-032.sql	SUCCESS	2009-04-09 09:36:36.20	-- -------\\012-- Modify MATERIAL_BATCHES\\012-- -------\\012\\012ALTER TABLE material_batches\\012    DROP COLUMN proc_id;\\012\\012-- -------\\012-- Modify SAMPLES\\012-- -------\\012\\012ALTER TABLE samples\\012    ADD COLUMN expe_id tech_id;\\012\\012ALTER TABLE samples\\012    ADD CONSTRAINT samp_expe_fk FOREIGN KEY (expe_id) REFERENCES experiments(id);\\012\\012CREATE INDEX samp_expe_fk_i ON samples USING btree (expe_id);\\012\\012-- relink samples directly to experiments\\012\\012UPDATE samples\\012SET expe_id = (SELECT e.id FROM experiments e, procedures p, sample_inputs si \\012               WHERE si.samp_id = samples.id AND si.proc_id = p.id AND p.expe_id = e.id AND e.inva_id IS NULL);\\012\\012\\012-- -------\\012-- Modify DATA\\012-- -------\\012\\012ALTER TABLE data\\012    ADD COLUMN expe_id tech_id;\\012\\012ALTER TABLE data\\012    ADD CONSTRAINT data_expe_fk FOREIGN KEY (expe_id) REFERENCES experiments(id);\\012\\012CREATE INDEX data_expe_fk_i ON data USING btree (expe_id);\\012\\012UPDATE data\\012SET expe_id = (SELECT e.id FROM experiments e, procedures p \\012               WHERE data.proc_id_produced_by = p.id AND p.expe_id = e.id);\\012\\012ALTER TABLE data\\012    ALTER COLUMN expe_id SET NOT NULL;\\012\\012ALTER TABLE data\\012    DROP COLUMN proc_id_produced_by;\\012\\012-- -------\\012-- Drop PROCEDURES, PROCEDURE_TYPES, and SAMPLE_INPUTS\\012-- -------\\012\\012DROP TABLE sample_inputs;\\012DROP TABLE procedures;\\012DROP TABLE procedure_types;\\012\\012DROP SEQUENCE procedure_id_seq;\\012DROP SEQUENCE procedure_type_id_seq;\\012\\012-- -------\\012-- Add CODE_SEQ\\012-- -------\\012\\012CREATE SEQUENCE CODE_SEQ;\\012\\012-- -------\\012-- Add new columns to DATA_STORES\\012-- -------\\012\\012ALTER TABLE data_stores\\012    ADD COLUMN remote_url character varying(250),\\012    ADD COLUMN session_token character varying(50),\\012    ADD COLUMN modification_timestamp time_stamp DEFAULT now();\\012\\012UPDATE data_stores\\012SET remote_url = '', session_token='';\\012\\012ALTER TABLE data_stores\\012    ALTER COLUMN remote_url SET NOT NULL,\\012    ALTER COLUMN session_token SET NOT NULL;\\012\\012-- -------\\012-- Drop foreign keys onto DATA_STORES\\012-- -------\\012\\012ALTER TABLE database_instances\\012    DROP COLUMN dast_id;\\012\\012ALTER TABLE groups\\012    DROP COLUMN dast_id;\\012\\012ALTER TABLE projects\\012    DROP COLUMN dast_id;\\012\\012ALTER TABLE experiments\\012    DROP COLUMN dast_id;\\012\\012-- -------\\012-- Add foreign key from DATA onto DATA_STORES\\012-- -------\\012\\012ALTER TABLE data\\012    ADD COLUMN dast_id tech_id;\\012\\012ALTER TABLE data\\012    ADD CONSTRAINT data_dast_fk FOREIGN KEY (dast_id) REFERENCES data_stores(id);\\012\\012UPDATE data\\012SET dast_id = (select id from data_stores where code = 'STANDARD');\\012\\012ALTER TABLE data\\012    ALTER COLUMN dast_id SET NOT NULL;\\012\\012\\012------------------------------------------------------------------------------------\\012--  Purpose:  Replace trigger SAMPLE_CODE_UNIQUENESS_CHECK \\012------------------------------------------------------------------------------------\\012\\012CREATE OR REPLACE FUNCTION SAMPLE_CODE_UNIQUENESS_CHECK() RETURNS trigger AS $$\\012DECLARE\\012   counter  INTEGER;\\012BEGIN\\012    LOCK TABLE samples IN EXCLUSIVE MODE;\\012    IF (NEW.samp_id_part_of is NULL) THEN\\012        IF (NEW.dbin_id is not NULL) THEN\\012            SELECT count(*) into counter FROM samples \\012                where id != NEW.id and code = NEW.code and samp_id_part_of is NULL and dbin_id = NEW.dbin_id;\\012            IF (counter > 0) THEN\\012                RAISE EXCEPTION 'Insert/Update of Sample (Code: %) failed because database instance sample with the same code already exists.', NEW.code;\\012            END IF;\\012        ELSIF (NEW.grou_id is not NULL) THEN\\012            SELECT count(*) into counter FROM samples \\012                where id != NEW.id and code = NEW.code and samp_id_part_of is NULL and grou_id = NEW.grou_id;\\012            IF (counter > 0) THEN\\012                RAISE EXCEPTION 'Insert/Update of Sample (Code: %) failed because group sample with the same code already exists.', NEW.code;\\012            END IF;\\012        END IF;\\012        ELSE\\012        IF (NEW.dbin_id is not NULL) THEN\\012            SELECT count(*) into counter FROM samples \\012                where id != NEW.id and code = NEW.code and samp_id_part_of = NEW.samp_id_part_of and dbin_id = NEW.dbin_id;\\012            IF (counter > 0) THEN\\012                RAISE EXCEPTION 'Insert/Update of Sample (Code: %) failed because database instance sample with the same code and being the part of the same parent already exists.', NEW.code;\\012            END IF;\\012        ELSIF (NEW.grou_id is not NULL) THEN\\012            SELECT count(*) into counter FROM samples \\012                where id != NEW.id and code = NEW.code and samp_id_part_of = NEW.samp_id_part_of and grou_id = NEW.grou_id;\\012            IF (counter > 0) THEN\\012                RAISE EXCEPTION 'Insert/Update of Sample (Code: %) failed because group sample with the same code and being the part of the same parent already exists.', NEW.code;\\012            END IF;\\012        END IF;\\012        END IF;   \\012   RETURN NEW;\\012END;\\012$$ LANGUAGE 'plpgsql';\\012\\012\\012\\012	\N
+./sourceTest/sql/postgresql/045/017=database_version_logs.tsv:034	source/sql/postgresql/migration/migration-033-034.sql	SUCCESS	2009-05-26 08:32:49.935	------------------------------------------------------------------------------------\\012-- Create sequence for generating permanent identifiers starting with nextval of existing dataset sequence.\\012------------------------------------------------------------------------------------\\012CREATE FUNCTION CREATE_SEQUENCE(EXISTING_SEQUENCE VARCHAR, NEW_SEQUENCE VARCHAR) RETURNS VOID AS $$\\012DECLARE\\012  CURR_SEQ_VAL   INTEGER;\\012BEGIN\\012  SELECT INTO CURR_SEQ_VAL NEXTVAL(EXISTING_SEQUENCE);\\012  EXECUTE 'CREATE SEQUENCE ' || NEW_SEQUENCE || ' START WITH ' || CURR_SEQ_VAL;\\012  RETURN;\\012END;\\012$$ LANGUAGE 'plpgsql';\\012\\012SELECT CREATE_SEQUENCE('DATA_ID_SEQ', 'PERM_ID_SEQ');\\012DROP FUNCTION CREATE_SEQUENCE(VARCHAR, VARCHAR);\\012\\012------------------------------------------------------------------------------------\\012-- Add perm_id columns to samples and experiments.\\012------------------------------------------------------------------------------------\\012ALTER TABLE SAMPLES ADD COLUMN PERM_ID CODE;\\012ALTER TABLE EXPERIMENTS ADD COLUMN PERM_ID CODE;\\012\\012UPDATE SAMPLES SET PERM_ID = to_char(registration_timestamp,'YYYYMMDDHHSSMS') || '-' || NEXTVAL('PERM_ID_SEQ');\\012UPDATE EXPERIMENTS SET PERM_ID = to_char(registration_timestamp,'YYYYMMDDHHSSMS') || '-' || NEXTVAL('PERM_ID_SEQ');\\012ALTER TABLE SAMPLES ALTER COLUMN PERM_ID SET NOT NULL;\\012ALTER TABLE EXPERIMENTS ALTER COLUMN PERM_ID SET NOT NULL;\\012ALTER TABLE SAMPLES ADD CONSTRAINT SAMP_PI_UK UNIQUE(PERM_ID);\\012ALTER TABLE EXPERIMENTS ADD CONSTRAINT EXPE_PI_UK UNIQUE(PERM_ID);\\012\\012\\012------------------------------------------------------------------------------------\\012-- Add column is_chosen_from_list to controlled_vocabularies.\\012------------------------------------------------------------------------------------\\012ALTER TABLE controlled_vocabularies ADD COLUMN is_chosen_from_list BOOLEAN_CHAR NOT NULL DEFAULT TRUE;\\012ALTER TABLE controlled_vocabularies ADD COLUMN source_uri CHARACTER VARYING(250);\\012------------------------------------------------------------------------------------\\012-- Modify Data table - remove arc connection between Sample and Data table, use a flag instead\\012------------------------------------------------------------------------------------\\012\\012-- add new columns\\012\\012ALTER TABLE data\\012    ADD COLUMN is_derived boolean_char;\\012ALTER TABLE data\\012    ADD COLUMN samp_id tech_id;\\012\\012-- update values in new columns\\012\\012UPDATE data\\012    SET is_derived = (samp_id_derived_from IS NOT NULL); \\012UPDATE data\\012    SET samp_id = samp_id_derived_from \\012    WHERE is_derived = 'TRUE';\\012UPDATE data\\012    SET samp_id = samp_id_acquired_from \\012    WHERE is_derived = 'FALSE';\\012\\012-- add constraints and indexes to new columns\\012\\012ALTER TABLE data\\012    ALTER COLUMN is_derived SET NOT NULL;\\012ALTER TABLE data\\012    ALTER COLUMN samp_id SET NOT NULL;   \\012ALTER TABLE data\\012    ADD CONSTRAINT data_samp_fk FOREIGN KEY (samp_id) REFERENCES samples (id);\\012CREATE INDEX data_samp_fk_i ON data USING btree (samp_id);\\012\\012-- remove old columns\\012\\012ALTER TABLE data\\012    DROP COLUMN samp_id_acquired_from;\\012ALTER TABLE data\\012    DROP COLUMN samp_id_derived_from;\\012    \\012------------------------------------------------------------------------------------\\012-- Granting SELECT privilege to group openbis_readonly\\012------------------------------------------------------------------------------------\\012\\012GRANT SELECT ON SEQUENCE attachment_content_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE attachment_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE code_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE controlled_vocabulary_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE cvte_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE data_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE data_set_property_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE data_set_relationship_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE data_set_type_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE data_store_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE data_type_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE database_instance_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE dstpt_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE etpt_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE event_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE experiment_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE experiment_property_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE experiment_type_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE file_format_type_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE group_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE invalidation_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE locator_type_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE material_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE material_property_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE material_type_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE mtpt_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE perm_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE person_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE project_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE property_type_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE role_assignment_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE sample_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE sample_property_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE sample_type_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE stpt_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE attachment_contents TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE attachments TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE controlled_vocabularies TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE controlled_vocabulary_terms TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE data TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE data_set_properties TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE data_set_relationships TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE data_set_type_property_types TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE data_set_types TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE data_stores TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE data_types TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE database_instances TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE database_version_logs TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE events TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE experiment_properties TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE experiment_type_property_types TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE experiment_types TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE experiments TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE external_data TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE file_format_types TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE groups TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE invalidations TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE locator_types TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE material_properties TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE material_type_property_types TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE material_types TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE materials TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE persons TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE projects TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE property_types TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE role_assignments TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE sample_properties TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE sample_type_property_types TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE sample_types TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE samples TO GROUP OPENBIS_READONLY;\\012\\012------------------------------------------------------------------------------------\\012-- Delete MATERIAL_BATCHES table\\012------------------------------------------------------------------------------------\\012\\012-- WARNING: Potential data lost!!!\\012-- WARNING: Potential data lost!!!\\012-- WARNING: Potential data lost!!!\\012\\012DROP TABLE SAMPLE_MATERIAL_BATCHES;\\012DROP TABLE MATERIAL_BATCHES;\\012DROP SEQUENCE MATERIAL_BATCH_ID_SEQ;\\012\\012------------------------------------------------------------------------------------\\012-- Delete MATE_ID_INHIBITOR_OF from table MATERIALS\\012------------------------------------------------------------------------------------\\012\\012-- WARNING: Potential data lost!!!\\012-- WARNING: Potential data lost!!!\\012-- WARNING: Potential data lost!!!\\012\\012ALTER TABLE MATERIALS DROP COLUMN MATE_ID_INHIBITOR_OF;\\012	\N
+./sourceTest/sql/postgresql/045/017=database_version_logs.tsv:041	source/sql/postgresql/migration/migration-040-041.sql	SUCCESS	2009-09-14 13:48:57.539	-- Create FILTERS table\\012\\012CREATE TABLE FILTERS (ID TECH_ID NOT NULL, DBIN_ID TECH_ID NOT NULL, NAME VARCHAR(200) NOT NULL, DESCRIPTION DESCRIPTION_1000,REGISTRATION_TIMESTAMP TIME_STAMP_DFL NOT NULL DEFAULT CURRENT_TIMESTAMP, PERS_ID_REGISTERER TECH_ID NOT NULL, MODIFICATION_TIMESTAMP TIME_STAMP DEFAULT CURRENT_TIMESTAMP, EXPRESSION VARCHAR(2000) NOT NULL, IS_PUBLIC BOOLEAN NOT NULL, GRID_ID VARCHAR(200) NOT NULL);\\012CREATE SEQUENCE FILTER_ID_SEQ;\\012ALTER TABLE FILTERS ADD CONSTRAINT FILT_PK PRIMARY KEY(ID);\\012ALTER TABLE FILTERS ADD CONSTRAINT FILT_BK_UK UNIQUE(NAME, DBIN_ID, GRID_ID);\\012ALTER TABLE FILTERS ADD CONSTRAINT FILT_PERS_FK FOREIGN KEY (PERS_ID_REGISTERER) REFERENCES PERSONS(ID);\\012ALTER TABLE FILTERS ADD CONSTRAINT FILT_DBIN_FK FOREIGN KEY (DBIN_ID) REFERENCES DATABASE_INSTANCES(ID);\\012CREATE INDEX FILT_PERS_FK_I ON FILTERS (PERS_ID_REGISTERER);\\012CREATE INDEX FILT_DBIN_FK_I ON FILTERS (DBIN_ID);\\012GRANT SELECT ON SEQUENCE filter_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE filters TO GROUP OPENBIS_READONLY;\\012\\012-- Add missing foreign key to role assignments authorization group\\012ALTER TABLE ROLE_ASSIGNMENTS ADD CONSTRAINT ROAS_AG_FK_GRANTEE FOREIGN KEY (AG_ID_GRANTEE) REFERENCES AUTHORIZATION_GROUPS(ID);\\012\\012--------------------------------------------------------------------------------------------------\\012-- Modify dataset connections:\\012-- 1. connection with sample shouldn't be mandatory any more\\012-- 2. introduce an arc condition that dataset cannot be connected with a sample and a parent dataset at the same time\\012--------------------------------------------------------------------------------------------------\\012\\012-- Weaken data-sample connection constraint - allow dataset to have no connection with sample\\012ALTER TABLE data ALTER COLUMN samp_id DROP NOT NULL;\\012\\012-- Remove data-sample connection for datasets that have a parent\\012\\012UPDATE data \\012   SET samp_id = NULL \\012 WHERE id IN (SELECT DISTINCT data_id_child FROM data_set_relationships);\\012\\012-- With PostgreSQL 8.4 one can check that before migration there were no cycles in dataset relationships:\\012--\\012-- WITH RECURSIVE data_set_parents(id, parent_ids, cycle) AS (\\012--         SELECT  r.data_id_child AS id, \\012--                 ARRAY[CAST (r.data_id_parent AS bigint)] AS parent_ids, \\012--                 false AS cycle \\012--         FROM data_set_relationships r\\012--     UNION ALL\\012--         SELECT  r.data_id_child,\\012--                 CAST (r.data_id_parent AS bigint) || p.parent_ids,\\012--                 r.data_id_child = ANY(p.parent_ids)\\012--         FROM data_set_relationships r, data_set_parents p\\012--         WHERE r.data_id_parent = p.id AND NOT cycle\\012-- )\\012-- SELECT count(*) AS cycles FROM data_set_parents WHERE cycle = true;\\012\\012---------------------------------------------------------------------------------------------------\\012--  Purpose:  Create DEFERRED triggers:\\012--            * check_dataset_relationships_on_data_table_modification,\\012--            * check_dataset_relationships_on_relationships_table_modification.\\012--            They check that after all modifications of database (just before commit) \\012--            if 'data'/'data_set_relationships' tables are among modified tables \\012--            dataset is not connected with a sample and a parent dataset at the same time.\\012--            This connections are held in two different tables so simple immediate trigger \\012--            with arc check cannot be used and we need two deferred triggers.\\012----------------------------------------------------------------------------------------------------\\012\\012-- trigger for 'data' table\\012\\012CREATE OR REPLACE FUNCTION check_dataset_relationships_on_data_table_modification() RETURNS trigger AS $$\\012DECLARE\\012\\011counter\\011INTEGER;\\012BEGIN\\012\\011-- if there is a connection with a Sample there should not be any connection with a parent Data Set\\012\\011IF (NEW.samp_id IS NOT NULL) THEN\\012\\011\\011-- count number of parents\\012\\011\\011SELECT count(*) INTO counter \\012\\011\\011\\011FROM data_set_relationships \\012\\011\\011\\011WHERE data_id_child = OLD.id;\\012\\011\\011IF (counter > 0) THEN\\012\\011\\011\\011RAISE EXCEPTION 'Insert/Update of Data Set (Code: %) failed because it cannot be connected with a Sample and a parent Data Set at the same time.', OLD.code;\\012\\011\\011END IF;\\012\\011END IF;\\012  RETURN NEW;\\012END;\\012$$ LANGUAGE 'plpgsql';\\012\\012CREATE CONSTRAINT TRIGGER check_dataset_relationships_on_data_table_modification \\012  AFTER INSERT OR UPDATE ON data\\012\\011DEFERRABLE INITIALLY DEFERRED\\012\\011FOR EACH ROW \\012\\011EXECUTE PROCEDURE check_dataset_relationships_on_data_table_modification();\\012\\012-- trigger for 'data_set_relationships'\\012\\012CREATE OR REPLACE FUNCTION check_dataset_relationships_on_relationships_table_modification() RETURNS trigger AS $$\\012DECLARE\\012\\011counter\\011INTEGER;\\012\\011sample_id\\011TECH_ID;\\012\\011data_code\\011CODE;\\012BEGIN\\012\\011-- child will have a parent added so it should not be connected with any sample\\012\\011SELECT samp_id, code INTO sample_id, data_code \\012\\011\\011FROM data \\012\\011\\011WHERE id = NEW.data_id_child;\\012\\011IF (sample_id IS NOT NULL) THEN\\012\\011\\011RAISE EXCEPTION 'Insert/Update of Data Set (Code: %) failed because it cannot be connected to a Sample and to a parent Data Set at the same time.', data_code;\\012\\011END IF;\\012\\011RETURN NEW;\\012END;\\012$$ LANGUAGE 'plpgsql';\\012  \\012CREATE CONSTRAINT TRIGGER check_dataset_relationships_on_relationships_table_modification \\012  AFTER INSERT OR UPDATE ON data_set_relationships\\012\\011DEFERRABLE INITIALLY DEFERRED\\012\\011FOR EACH ROW \\012\\011EXECUTE PROCEDURE check_dataset_relationships_on_relationships_table_modification();\\012	\N
+./sourceTest/sql/postgresql/045/schema-045.sql:    LANGUAGE plpgsql;
+./sourceTest/sql/postgresql/045/schema-045.sql:    LANGUAGE plpgsql;
+./sourceTest/sql/postgresql/045/schema-045.sql:    LANGUAGE plpgsql;
+./sourceTest/sql/postgresql/045/schema-045.sql:    LANGUAGE plpgsql;
+./sourceTest/sql/postgresql/045/schema-045.sql:    LANGUAGE plpgsql;
+./sourceTest/sql/postgresql/045/schema-045.sql:    LANGUAGE plpgsql;
+./sourceTest/sql/postgresql/045/schema-045.sql:    LANGUAGE plpgsql;
+./sourceTest/sql/postgresql/045/schema-045.sql:    LANGUAGE plpgsql;
+./sourceTest/sql/postgresql/045/schema-045.sql:    LANGUAGE plpgsql;
+./sourceTest/sql/postgresql/045/schema-045.sql:    LANGUAGE plpgsql;
+./sourceTest/sql/postgresql/046/.svn/text-base/017=database_version_logs.tsv.svn-base:027	D:\\User\\felmer\\dev-workspace\\openbis/source/sql/postgresql/027/function-027.sql	SUCCESS	2008-11-05 09:18:00.403	-- Creating Functions\\012\\012------------------------------------------------------------------------------------\\012--  Purpose:  Create function RENAME_SEQUENCE() that is required for renaming the sequences belonging to tables\\012------------------------------------------------------------------------------------\\012CREATE FUNCTION RENAME_SEQUENCE(OLD_NAME VARCHAR, NEW_NAME VARCHAR) RETURNS INTEGER AS $$\\012DECLARE\\012  CURR_SEQ_VAL   INTEGER;\\012BEGIN\\012  SELECT INTO CURR_SEQ_VAL NEXTVAL(OLD_NAME);\\012  EXECUTE 'CREATE SEQUENCE ' || NEW_NAME || ' START WITH ' || CURR_SEQ_VAL;\\012  EXECUTE 'DROP SEQUENCE ' || OLD_NAME;\\012  RETURN CURR_SEQ_VAL;\\012END;\\012$$ LANGUAGE 'plpgsql';\\012\\012\\012------------------------------------------------------------------------------------\\012--  Purpose:  Create trigger CONTROLLED_VOCABULARY_CHECK \\012------------------------------------------------------------------------------------\\012\\012CREATE OR REPLACE FUNCTION CONTROLLED_VOCABULARY_CHECK() RETURNS trigger AS $$\\012DECLARE\\012   v_code  CODE;\\012BEGIN\\012\\012   select code into v_code from data_types where id = NEW.daty_id;\\012\\012   -- Check if the data is of type "CONTROLLEDVOCABULARY"\\012   if v_code = 'CONTROLLEDVOCABULARY' then\\012      if NEW.covo_id IS NULL then\\012         RAISE EXCEPTION 'Insert/Update of Property Type (Code: %) failed, as its Data Type is CONTROLLEDVOCABULARY, but it is not linked to a Controlled Vocabulary.', NEW.code;\\012      end if;\\012   end if;\\012\\012   RETURN NEW;\\012\\012END;\\012$$ LANGUAGE 'plpgsql';\\012\\012CREATE TRIGGER CONTROLLED_VOCABULARY_CHECK BEFORE INSERT OR UPDATE ON PROPERTY_TYPES\\012    FOR EACH ROW EXECUTE PROCEDURE CONTROLLED_VOCABULARY_CHECK();\\012\\012\\012------------------------------------------------------------------------------------\\012--  Purpose:  Create trigger EXTERNAL_DATA_STORAGE_FORMAT_CHECK \\012------------------------------------------------------------------------------------\\012\\012CREATE OR REPLACE FUNCTION EXTERNAL_DATA_STORAGE_FORMAT_CHECK() RETURNS trigger AS $$\\012DECLARE\\012   v_covo_code  CODE;\\012   data_code CODE;\\012BEGIN\\012\\012   select code into v_covo_code from controlled_vocabularies\\012      where is_internal_namespace = true and \\012         id = (select covo_id from controlled_vocabulary_terms where id = NEW.cvte_id_stor_fmt);\\012   -- Check if the data storage format is a term of the controlled vocabulary "STORAGE_FORMAT"\\012   if v_covo_code != 'STORAGE_FORMAT' then\\012      select code into data_code from data where id = NEW.data_id; \\012      RAISE EXCEPTION 'Insert/Update of Data (Code: %) failed, as its Storage Format is %, but is required to be STORAGE_FORMAT.', data_code, v_covo_code;\\012   end if;\\012\\012   RETURN NEW;\\012\\012END;\\012$$ LANGUAGE 'plpgsql';\\012\\012CREATE TRIGGER EXTERNAL_DATA_STORAGE_FORMAT_CHECK BEFORE INSERT OR UPDATE ON EXTERNAL_DATA\\012    FOR EACH ROW EXECUTE PROCEDURE EXTERNAL_DATA_STORAGE_FORMAT_CHECK();\\012\\012------------------------------------------------------------------------------------\\012--  Purpose:  Create trigger SAMPLE_CODE_UNIQUENESS_CHECK \\012------------------------------------------------------------------------------------\\012\\012CREATE OR REPLACE FUNCTION SAMPLE_CODE_UNIQUENESS_CHECK() RETURNS trigger AS $$\\012DECLARE\\012   counter  INTEGER;\\012BEGIN\\012\\011IF (NEW.samp_id_part_of is NULL) THEN\\012\\011\\011IF (NEW.dbin_id is not NULL) THEN\\012\\011\\011\\011SELECT count(*) into counter FROM samples \\012\\011\\011\\011\\011where id != NEW.id and code = NEW.code and samp_id_part_of is NULL and dbin_id = NEW.dbin_id;\\012\\011\\011\\011IF (counter > 0) THEN\\012\\011\\011\\011\\011RAISE EXCEPTION 'Insert/Update of Sample (Code: %) failed because database instance sample with the same code already exists.', NEW.code;\\012\\011\\011\\011END IF;\\012\\011\\011ELSIF (NEW.grou_id is not NULL) THEN\\012\\011\\011\\011SELECT count(*) into counter FROM samples \\012\\011\\011\\011\\011where id != NEW.id and code = NEW.code and samp_id_part_of is NULL and grou_id = NEW.grou_id;\\012\\011\\011\\011IF (counter > 0) THEN\\012\\011\\011\\011\\011RAISE EXCEPTION 'Insert/Update of Sample (Code: %) failed because group sample with the same code already exists.', NEW.code;\\012\\011\\011\\011END IF;\\012\\011\\011END IF;\\012        ELSE\\012\\011\\011IF (NEW.dbin_id is not NULL) THEN\\012\\011\\011\\011SELECT count(*) into counter FROM samples \\012\\011\\011\\011\\011where id != NEW.id and code = NEW.code and samp_id_part_of = NEW.samp_id_part_of and dbin_id = NEW.dbin_id;\\012\\011\\011\\011IF (counter > 0) THEN\\012\\011\\011\\011\\011RAISE EXCEPTION 'Insert/Update of Sample (Code: %) failed because database instance sample with the same code and being the part of the same parent already exists.', NEW.code;\\012\\011\\011\\011END IF;\\012\\011\\011ELSIF (NEW.grou_id is not NULL) THEN\\012\\011\\011\\011SELECT count(*) into counter FROM samples \\012\\011\\011\\011\\011where id != NEW.id and code = NEW.code and samp_id_part_of = NEW.samp_id_part_of and grou_id = NEW.grou_id;\\012\\011\\011\\011IF (counter > 0) THEN\\012\\011\\011\\011\\011RAISE EXCEPTION 'Insert/Update of Sample (Code: %) failed because group sample with the same code and being the part of the same parent already exists.', NEW.code;\\012\\011\\011\\011END IF;\\012\\011\\011END IF;\\012        END IF;   \\012   RETURN NEW;\\012END;\\012$$ LANGUAGE 'plpgsql';\\012\\012CREATE TRIGGER SAMPLE_CODE_UNIQUENESS_CHECK BEFORE INSERT OR UPDATE ON SAMPLES\\012    FOR EACH ROW EXECUTE PROCEDURE SAMPLE_CODE_UNIQUENESS_CHECK();\\012	\N
+./sourceTest/sql/postgresql/046/.svn/text-base/017=database_version_logs.tsv.svn-base:028	source/sql/postgresql/migration/migration-027-028.sql	SUCCESS	2008-11-18 13:24:17.508	-- Create EXPERIMENT_ATTACHMENT_CONTENTS.\\012CREATE TABLE EXPERIMENT_ATTACHMENT_CONTENTS (ID TECH_ID NOT NULL,VALUE FILE NOT NULL);\\012CREATE SEQUENCE EXPERIMENT_ATTACHMENT_CONTENT_ID_SEQ;\\012ALTER TABLE EXPERIMENT_ATTACHMENT_CONTENTS ADD CONSTRAINT EXAC_PK PRIMARY KEY(ID);\\012\\012-- Alter EXPERIMENT_ATTACHMENTS by adding the new column which has a NULL constraint.\\012-- The NOT NULL constraint is added later on.\\012ALTER TABLE EXPERIMENT_ATTACHMENTS ADD COLUMN EXAC_ID TECH_ID;\\012\\012-- Does the VALUE migration between EXPERIMENT_ATTACHMENTS to EXPERIMENT_ATTACHMENT_CONTENTS.\\012CREATE OR REPLACE FUNCTION move_exp_att_content() RETURNS integer AS $$\\012DECLARE\\012    rec RECORD;\\012    seq BIGINT;\\012BEGIN\\012  FOR rec IN SELECT id, value FROM EXPERIMENT_ATTACHMENTS LOOP\\012  \\011seq := nextval('EXPERIMENT_ATTACHMENT_CONTENT_ID_SEQ');\\012    INSERT INTO EXPERIMENT_ATTACHMENT_CONTENTS (id, value) VALUES (seq, rec.value);\\012    UPDATE EXPERIMENT_ATTACHMENTS SET exac_id = seq WHERE id = rec.id;\\012  END LOOP;\\012  RETURN 1;\\012END;\\012$$ LANGUAGE 'plpgsql';\\012\\012-- Call the function.\\012SELECT move_exp_att_content();\\012DROP FUNCTION move_exp_att_content();\\012\\012\\012-- Finish EXPERIMENT_ATTACHMENTS changes.\\012ALTER TABLE EXPERIMENT_ATTACHMENTS ADD CONSTRAINT EXAT_CONT_FK FOREIGN KEY (EXAC_ID) REFERENCES EXPERIMENT_ATTACHMENT_CONTENTS(ID);\\012ALTER TABLE EXPERIMENT_ATTACHMENTS DROP COLUMN VALUE;\\012ALTER TABLE EXPERIMENT_ATTACHMENTS ALTER COLUMN EXAC_ID SET NOT NULL;\\012	\N
+./sourceTest/sql/postgresql/046/.svn/text-base/017=database_version_logs.tsv.svn-base:029	source/sql/postgresql/migration/migration-028-029.sql	SUCCESS	2009-03-18 10:50:20.105	-- -------\\012-- add modification_timestamp field to allow edition with Hibernate\\012-- -------\\012\\012ALTER TABLE samples\\012\\011ADD COLUMN modification_timestamp TIME_STAMP DEFAULT CURRENT_TIMESTAMP;\\012\\012ALTER TABLE experiments\\012\\011ADD COLUMN modification_timestamp TIME_STAMP DEFAULT CURRENT_TIMESTAMP;\\012\\012ALTER TABLE materials\\012\\011ADD COLUMN modification_timestamp TIME_STAMP DEFAULT CURRENT_TIMESTAMP;\\012\\012ALTER TABLE experiment_properties\\012\\011ADD COLUMN modification_timestamp TIME_STAMP DEFAULT CURRENT_TIMESTAMP;\\012\\012ALTER TABLE material_properties\\012\\011ADD COLUMN modification_timestamp TIME_STAMP DEFAULT CURRENT_TIMESTAMP;\\012\\012ALTER TABLE sample_properties\\012\\011ADD COLUMN modification_timestamp TIME_STAMP DEFAULT CURRENT_TIMESTAMP;\\012\\012-- -------\\012-- add property data type which references materials\\012-- -------\\012\\012ALTER TABLE property_types\\012\\011ADD COLUMN maty_prop_id tech_id;\\012\\012ALTER TABLE property_types\\012\\011ADD CONSTRAINT prty_maty_fk FOREIGN KEY (maty_prop_id) REFERENCES material_types(id);\\012\\012ALTER TABLE experiment_properties\\012\\011ADD COLUMN mate_prop_id tech_id;\\012\\012ALTER TABLE material_properties\\012\\011ADD COLUMN mate_prop_id tech_id;\\012\\012ALTER TABLE sample_properties\\012\\011ADD COLUMN mate_prop_id tech_id;\\012\\012ALTER TABLE experiment_properties\\012\\011ADD CONSTRAINT expr_mapr_fk FOREIGN KEY (mate_prop_id) REFERENCES materials(id);\\012\\012ALTER TABLE material_properties\\012\\011ADD CONSTRAINT mapr_mapr_fk FOREIGN KEY (mate_prop_id) REFERENCES materials(id);\\012\\012ALTER TABLE sample_properties\\012\\011ADD CONSTRAINT sapr_mapr_fk FOREIGN KEY (mate_prop_id) REFERENCES materials(id);\\012\\012insert into data_types\\012(id\\012 ,code\\012 ,description)\\012 values \\012 (nextval('DATA_TYPE_ID_SEQ')\\012 ,'MATERIAL'\\012 ,'Reference to a material'\\012);\\012\\012ALTER TABLE MATERIAL_PROPERTIES DROP CONSTRAINT MAPR_CK;\\012ALTER TABLE MATERIAL_PROPERTIES ADD CONSTRAINT MAPR_CK CHECK \\012\\011((VALUE IS NOT NULL AND CVTE_ID IS NULL AND MATE_PROP_ID IS NULL) OR \\012\\011 (VALUE IS NULL AND CVTE_ID IS NOT NULL AND MATE_PROP_ID IS NULL) OR\\012\\011 (VALUE IS NULL AND CVTE_ID IS NULL AND MATE_PROP_ID IS NOT NULL)\\012\\011);\\012\\012ALTER TABLE EXPERIMENT_PROPERTIES DROP CONSTRAINT EXPR_CK;\\012ALTER TABLE EXPERIMENT_PROPERTIES ADD CONSTRAINT EXPR_CK CHECK \\012\\011((VALUE IS NOT NULL AND CVTE_ID IS NULL AND MATE_PROP_ID IS NULL) OR \\012\\011 (VALUE IS NULL AND CVTE_ID IS NOT NULL AND MATE_PROP_ID IS NULL) OR\\012\\011 (VALUE IS NULL AND CVTE_ID IS NULL AND MATE_PROP_ID IS NOT NULL)\\012\\011);\\012\\012ALTER TABLE SAMPLE_PROPERTIES DROP CONSTRAINT SAPR_CK;\\012ALTER TABLE SAMPLE_PROPERTIES ADD CONSTRAINT SAPR_CK CHECK \\012\\011((VALUE IS NOT NULL AND CVTE_ID IS NULL AND MATE_PROP_ID IS NULL) OR \\012\\011 (VALUE IS NULL AND CVTE_ID IS NOT NULL AND MATE_PROP_ID IS NULL) OR\\012\\011 (VALUE IS NULL AND CVTE_ID IS NULL AND MATE_PROP_ID IS NOT NULL)\\012\\011);\\012\\012------------------------------------------------------------------------------------\\012--  Purpose:  Create trigger MATERIAL/SAMPLE/EXPERIMENT _PROPERTY_WITH_MATERIAL_DATA_TYPE_CHECK\\012--            It checks that if material property value is assigned to the entity,\\012--\\011\\011\\011\\011\\011\\011then the material type is equal to the one described by property type.\\012------------------------------------------------------------------------------------\\012\\012CREATE OR REPLACE FUNCTION MATERIAL_PROPERTY_WITH_MATERIAL_DATA_TYPE_CHECK() RETURNS trigger AS $$\\012DECLARE\\012   v_type_id  CODE;\\012   v_type_id_prop  CODE;\\012BEGIN\\012   if NEW.mate_prop_id IS NOT NULL then\\012\\011\\011\\011-- find material type id of the property type \\012\\011\\011\\011select pt.maty_prop_id into v_type_id_prop \\012\\011\\011\\011  from material_type_property_types etpt, property_types pt \\012\\011\\011\\011 where NEW.mtpt_id = etpt.id AND etpt.prty_id = pt.id;\\012\\011\\011\\012\\011\\011\\011if v_type_id_prop IS NOT NULL then\\012\\011\\011\\011\\011-- find material type id of the material which consists the entity's property value\\012\\011\\011\\011\\011select entity.maty_id into v_type_id \\012\\011\\011\\011\\011  from materials entity\\012\\011\\011\\011\\011 where NEW.mate_prop_id = entity.id;\\012\\011\\011\\011\\011if v_type_id != v_type_id_prop then\\012\\011\\011\\011\\011\\011RAISE EXCEPTION 'Insert/Update of property value referencing material (id: %) failed, as referenced material type is different than expected (id %, expected id: %).', \\012\\011\\011\\011\\011\\011\\011\\011 NEW.mate_prop_id, v_type_id, v_type_id_prop;\\012\\011\\011\\011\\011end if;\\012\\011\\011\\011end if;\\012   end if;\\012   RETURN NEW;\\012END;\\012$$ LANGUAGE 'plpgsql';\\012\\012CREATE TRIGGER MATERIAL_PROPERTY_WITH_MATERIAL_DATA_TYPE_CHECK BEFORE INSERT OR UPDATE ON material_properties\\012    FOR EACH ROW EXECUTE PROCEDURE MATERIAL_PROPERTY_WITH_MATERIAL_DATA_TYPE_CHECK();\\012    \\012CREATE OR REPLACE FUNCTION SAMPLE_PROPERTY_WITH_MATERIAL_DATA_TYPE_CHECK() RETURNS trigger AS $$\\012DECLARE\\012   v_type_id  CODE;\\012   v_type_id_prop  CODE;\\012BEGIN\\012   if NEW.mate_prop_id IS NOT NULL then\\012\\011\\011\\011-- find material type id of the property type \\012\\011\\011\\011select pt.maty_prop_id into v_type_id_prop \\012\\011\\011\\011  from sample_type_property_types etpt, property_types pt \\012\\011\\011\\011 where NEW.stpt_id = etpt.id AND etpt.prty_id = pt.id;\\012\\011\\011\\012\\011\\011\\011if v_type_id_prop IS NOT NULL then\\012\\011\\011\\011\\011-- find material type id of the material which consists the entity's property value\\012\\011\\011\\011\\011select entity.maty_id into v_type_id \\012\\011\\011\\011\\011  from materials entity\\012\\011\\011\\011\\011 where NEW.mate_prop_id = entity.id;\\012\\011\\011\\011\\011if v_type_id != v_type_id_prop then\\012\\011\\011\\011\\011\\011RAISE EXCEPTION 'Insert/Update of property value referencing material (id: %) failed, as referenced material type is different than expected (id %, expected id: %).', \\012\\011\\011\\011\\011\\011\\011\\011\\011\\011\\011\\011\\011 NEW.mate_prop_id, v_type_id, v_type_id_prop;\\012\\011\\011\\011\\011end if;\\012\\011\\011\\011end if;\\012   end if;\\012   RETURN NEW;\\012END;\\012$$ LANGUAGE 'plpgsql';\\012\\012CREATE TRIGGER SAMPLE_PROPERTY_WITH_MATERIAL_DATA_TYPE_CHECK BEFORE INSERT OR UPDATE ON sample_properties\\012    FOR EACH ROW EXECUTE PROCEDURE SAMPLE_PROPERTY_WITH_MATERIAL_DATA_TYPE_CHECK();\\012    \\012CREATE OR REPLACE FUNCTION EXPERIMENT_PROPERTY_WITH_MATERIAL_DATA_TYPE_CHECK() RETURNS trigger AS $$\\012DECLARE\\012   v_type_id  CODE;\\012   v_type_id_prop  CODE;\\012BEGIN\\012   if NEW.mate_prop_id IS NOT NULL then\\012\\011\\011\\011-- find material type id of the property type \\012\\011\\011\\011select pt.maty_prop_id into v_type_id_prop \\012\\011\\011\\011  from experiment_type_property_types etpt, property_types pt \\012\\011\\011\\011 where NEW.etpt_id = etpt.id AND etpt.prty_id = pt.id;\\012\\011\\011\\012\\011\\011\\011if v_type_id_prop IS NOT NULL then\\012\\011\\011\\011\\011-- find material type id of the material which consists the entity's property value\\012\\011\\011\\011\\011select entity.maty_id into v_type_id \\012\\011\\011\\011\\011  from materials entity\\012\\011\\011\\011\\011 where NEW.mate_prop_id = entity.id;\\012\\011\\011\\011\\011if v_type_id != v_type_id_prop then\\012\\011\\011\\011\\011\\011RAISE EXCEPTION 'Insert/Update of property value referencing material (id: %) failed, as referenced material type is different than expected (id %, expected id: %).', \\012\\011\\011\\011\\011\\011\\011\\011\\011\\011\\011\\011\\011 NEW.mate_prop_id, v_type_id, v_type_id_prop;\\012\\011\\011\\011\\011end if;\\012\\011\\011\\011end if;\\012   end if;\\012   RETURN NEW;\\012END;\\012$$ LANGUAGE 'plpgsql';\\012\\012CREATE TRIGGER EXPERIMENT_PROPERTY_WITH_MATERIAL_DATA_TYPE_CHECK BEFORE INSERT OR UPDATE ON experiment_properties\\012    FOR EACH ROW EXECUTE PROCEDURE EXPERIMENT_PROPERTY_WITH_MATERIAL_DATA_TYPE_CHECK();\\012       \\012-- -------\\012-- remove the reminescents of the OBSERVABLE_TYPE\\012-- -------\\012\\012ALTER TABLE data\\012\\011DROP CONSTRAINT data_obty_fk;\\012\\012ALTER TABLE data_set_types\\012\\011DROP CONSTRAINT obty_pk;\\012\\012ALTER TABLE data_set_types\\012\\011ADD CONSTRAINT dsty_pk PRIMARY KEY (id);\\012\\012ALTER TABLE data\\012\\011ADD CONSTRAINT data_dsty_fk FOREIGN KEY (dsty_id) REFERENCES data_set_types(id);\\012\\012ALTER TABLE data_set_types\\012\\011DROP CONSTRAINT obty_bk_uk;\\012\\012ALTER TABLE data_set_types\\012\\011DROP CONSTRAINT obty_dbin_fk;\\012\\012ALTER TABLE data_set_types\\012\\011ADD CONSTRAINT dsty_bk_uk UNIQUE (code, dbin_id);\\012\\012ALTER TABLE data_set_types\\012\\011ADD CONSTRAINT dsty_dbin_fk FOREIGN KEY (dbin_id) REFERENCES database_instances(id);\\012\\012DROP INDEX data_obty_fk_i;\\012\\012CREATE INDEX data_dsty_fk_i ON data(dsty_id);\\012	\N
+./sourceTest/sql/postgresql/046/.svn/text-base/017=database_version_logs.tsv.svn-base:030	source/sql/postgresql/migration/migration-029-030.sql	SUCCESS	2009-03-23 15:34:44.72	-- -------\\012-- add modification_timestamp field to allow edition with Hibernate\\012-- -------\\012ALTER TABLE data\\012\\011ADD COLUMN modification_timestamp TIME_STAMP DEFAULT CURRENT_TIMESTAMP;\\012ALTER TABLE experiment_types\\012\\011ADD COLUMN modification_timestamp TIME_STAMP DEFAULT CURRENT_TIMESTAMP;\\012ALTER TABLE sample_types\\012\\011ADD COLUMN modification_timestamp TIME_STAMP DEFAULT CURRENT_TIMESTAMP;\\012ALTER TABLE material_types\\012\\011ADD COLUMN modification_timestamp TIME_STAMP DEFAULT CURRENT_TIMESTAMP;\\012ALTER TABLE data_set_types\\012\\011ADD COLUMN modification_timestamp TIME_STAMP DEFAULT CURRENT_TIMESTAMP;\\012ALTER TABLE controlled_vocabularies\\012\\011ADD COLUMN modification_timestamp TIME_STAMP DEFAULT CURRENT_TIMESTAMP;\\012-- -------\\012-- add properties to data sets\\012-- -------\\012CREATE TABLE DATA_SET_PROPERTIES (ID TECH_ID NOT NULL,DS_ID TECH_ID NOT NULL,DSTPT_ID TECH_ID NOT NULL,VALUE GENERIC_VALUE,CVTE_ID TECH_ID, MATE_PROP_ID TECH_ID, PERS_ID_REGISTERER TECH_ID NOT NULL,REGISTRATION_TIMESTAMP TIME_STAMP_DFL NOT NULL DEFAULT CURRENT_TIMESTAMP, MODIFICATION_TIMESTAMP TIME_STAMP DEFAULT CURRENT_TIMESTAMP);\\012CREATE TABLE DATA_SET_TYPE_PROPERTY_TYPES (ID TECH_ID NOT NULL,DSTY_ID TECH_ID NOT NULL,PRTY_ID TECH_ID NOT NULL,IS_MANDATORY BOOLEAN_CHAR NOT NULL DEFAULT 'F',IS_MANAGED_INTERNALLY BOOLEAN_CHAR NOT NULL DEFAULT 'F',PERS_ID_REGISTERER TECH_ID NOT NULL,REGISTRATION_TIMESTAMP TIME_STAMP_DFL NOT NULL DEFAULT CURRENT_TIMESTAMP);\\012\\012CREATE SEQUENCE DATA_SET_PROPERTY_ID_SEQ;\\012CREATE SEQUENCE DSTPT_ID_SEQ;\\012\\012ALTER TABLE DATA_SET_TYPE_PROPERTY_TYPES ADD CONSTRAINT DSTPT_PK PRIMARY KEY(ID);\\012ALTER TABLE DATA_SET_PROPERTIES ADD CONSTRAINT DSPR_PK PRIMARY KEY(ID);\\012\\012ALTER TABLE DATA_SET_TYPE_PROPERTY_TYPES ADD CONSTRAINT DSTPT_BK_UK UNIQUE(DSTY_ID,PRTY_ID);\\012ALTER TABLE DATA_SET_PROPERTIES ADD CONSTRAINT DSPR_BK_UK UNIQUE(DS_ID,DSTPT_ID);\\012\\012\\012ALTER TABLE DATA_SET_TYPE_PROPERTY_TYPES ADD CONSTRAINT DSTPT_DSTY_FK FOREIGN KEY (DSTY_ID) REFERENCES DATA_SET_TYPES(ID);\\012ALTER TABLE DATA_SET_TYPE_PROPERTY_TYPES ADD CONSTRAINT DSTPT_PERS_FK FOREIGN KEY (PERS_ID_REGISTERER) REFERENCES PERSONS(ID);\\012ALTER TABLE DATA_SET_TYPE_PROPERTY_TYPES ADD CONSTRAINT DSTPT_PRTY_FK FOREIGN KEY (PRTY_ID) REFERENCES PROPERTY_TYPES(ID);\\012ALTER TABLE DATA_SET_PROPERTIES ADD CONSTRAINT DSPR_CVTE_FK FOREIGN KEY (CVTE_ID) REFERENCES CONTROLLED_VOCABULARY_TERMS(ID);\\012ALTER TABLE DATA_SET_PROPERTIES ADD CONSTRAINT DSPR_DSTPT_FK FOREIGN KEY (DSTPT_ID) REFERENCES DATA_SET_TYPE_PROPERTY_TYPES(ID) ON DELETE CASCADE;\\012ALTER TABLE DATA_SET_PROPERTIES ADD CONSTRAINT DSPR_DS_FK FOREIGN KEY (DS_ID) REFERENCES DATA(ID);\\012ALTER TABLE DATA_SET_PROPERTIES ADD CONSTRAINT DSPR_PERS_FK FOREIGN KEY (PERS_ID_REGISTERER) REFERENCES PERSONS(ID);\\012ALTER TABLE DATA_SET_PROPERTIES ADD CONSTRAINT DSPR_MAPR_FK FOREIGN KEY (MATE_PROP_ID) REFERENCES MATERIALS(ID);\\012\\012ALTER TABLE DATA_SET_PROPERTIES ADD CONSTRAINT DSPR_CK CHECK \\012\\011((VALUE IS NOT NULL AND CVTE_ID IS NULL AND MATE_PROP_ID IS NULL) OR \\012\\011 (VALUE IS NULL AND CVTE_ID IS NOT NULL AND MATE_PROP_ID IS NULL) OR\\012\\011 (VALUE IS NULL AND CVTE_ID IS NULL AND MATE_PROP_ID IS NOT NULL)\\012\\011);\\012\\012CREATE INDEX DSPR_CVTE_FK_I ON DATA_SET_PROPERTIES (CVTE_ID);\\012CREATE INDEX DSPR_DSTPT_FK_I ON DATA_SET_PROPERTIES (DSTPT_ID);\\012CREATE INDEX DSPR_DS_FK_I ON DATA_SET_PROPERTIES (DS_ID);\\012CREATE INDEX DSPR_PERS_FK_I ON DATA_SET_PROPERTIES (PERS_ID_REGISTERER);\\012CREATE INDEX DSTPT_DSTY_FK_I ON DATA_SET_TYPE_PROPERTY_TYPES (DSTY_ID);\\012CREATE INDEX DSTPT_PERS_FK_I ON DATA_SET_TYPE_PROPERTY_TYPES (PERS_ID_REGISTERER);\\012CREATE INDEX DSTPT_PRTY_FK_I ON DATA_SET_TYPE_PROPERTY_TYPES (PRTY_ID);\\012\\012CREATE OR REPLACE FUNCTION DATA_SET_PROPERTY_WITH_MATERIAL_DATA_TYPE_CHECK() RETURNS trigger AS $$\\012DECLARE\\012   v_type_id  CODE;\\012   v_type_id_prop  CODE;\\012BEGIN\\012   if NEW.mate_prop_id IS NOT NULL then\\012\\011\\011\\011-- find material type id of the property type \\012\\011\\011\\011select pt.maty_prop_id into v_type_id_prop \\012\\011\\011\\011  from data_set_type_property_types dstpt, property_types pt \\012\\011\\011\\011 where NEW.dstpt_id = dstpt.id AND dstpt.prty_id = pt.id;\\012\\011\\011\\012\\011\\011\\011if v_type_id_prop IS NOT NULL then\\012\\011\\011\\011\\011-- find material type id of the material which consists the entity's property value\\012\\011\\011\\011\\011select entity.maty_id into v_type_id \\012\\011\\011\\011\\011  from materials entity\\012\\011\\011\\011\\011 where NEW.mate_prop_id = entity.id;\\012\\011\\011\\011\\011if v_type_id != v_type_id_prop then\\012\\011\\011\\011\\011\\011RAISE EXCEPTION 'Insert/Update of property value referencing material (id: %) failed, as referenced material type is different than expected (id %, expected id: %).', \\012\\011\\011\\011\\011\\011\\011\\011\\011\\011\\011\\011\\011 NEW.mate_prop_id, v_type_id, v_type_id_prop;\\012\\011\\011\\011\\011end if;\\012\\011\\011\\011end if;\\012   end if;\\012   RETURN NEW;\\012END;\\012$$ LANGUAGE 'plpgsql';\\012\\012CREATE TRIGGER DATA_SET_PROPERTY_WITH_MATERIAL_DATA_TYPE_CHECK BEFORE INSERT OR UPDATE ON data_set_properties\\012    FOR EACH ROW EXECUTE PROCEDURE DATA_SET_PROPERTY_WITH_MATERIAL_DATA_TYPE_CHECK();   \\012	\N
+./sourceTest/sql/postgresql/046/.svn/text-base/017=database_version_logs.tsv.svn-base:032	source/sql/postgresql/migration/migration-031-032.sql	SUCCESS	2009-04-09 09:36:36.2	-- -------\\012-- Modify MATERIAL_BATCHES\\012-- -------\\012\\012ALTER TABLE material_batches\\012    DROP COLUMN proc_id;\\012\\012-- -------\\012-- Modify SAMPLES\\012-- -------\\012\\012ALTER TABLE samples\\012    ADD COLUMN expe_id tech_id;\\012\\012ALTER TABLE samples\\012    ADD CONSTRAINT samp_expe_fk FOREIGN KEY (expe_id) REFERENCES experiments(id);\\012\\012CREATE INDEX samp_expe_fk_i ON samples USING btree (expe_id);\\012\\012-- relink samples directly to experiments\\012\\012UPDATE samples\\012SET expe_id = (SELECT e.id FROM experiments e, procedures p, sample_inputs si \\012               WHERE si.samp_id = samples.id AND si.proc_id = p.id AND p.expe_id = e.id AND e.inva_id IS NULL);\\012\\012\\012-- -------\\012-- Modify DATA\\012-- -------\\012\\012ALTER TABLE data\\012    ADD COLUMN expe_id tech_id;\\012\\012ALTER TABLE data\\012    ADD CONSTRAINT data_expe_fk FOREIGN KEY (expe_id) REFERENCES experiments(id);\\012\\012CREATE INDEX data_expe_fk_i ON data USING btree (expe_id);\\012\\012UPDATE data\\012SET expe_id = (SELECT e.id FROM experiments e, procedures p \\012               WHERE data.proc_id_produced_by = p.id AND p.expe_id = e.id);\\012\\012ALTER TABLE data\\012    ALTER COLUMN expe_id SET NOT NULL;\\012\\012ALTER TABLE data\\012    DROP COLUMN proc_id_produced_by;\\012\\012-- -------\\012-- Drop PROCEDURES, PROCEDURE_TYPES, and SAMPLE_INPUTS\\012-- -------\\012\\012DROP TABLE sample_inputs;\\012DROP TABLE procedures;\\012DROP TABLE procedure_types;\\012\\012DROP SEQUENCE procedure_id_seq;\\012DROP SEQUENCE procedure_type_id_seq;\\012\\012-- -------\\012-- Add CODE_SEQ\\012-- -------\\012\\012CREATE SEQUENCE CODE_SEQ;\\012\\012-- -------\\012-- Add new columns to DATA_STORES\\012-- -------\\012\\012ALTER TABLE data_stores\\012    ADD COLUMN remote_url character varying(250),\\012    ADD COLUMN session_token character varying(50),\\012    ADD COLUMN modification_timestamp time_stamp DEFAULT now();\\012\\012UPDATE data_stores\\012SET remote_url = '', session_token='';\\012\\012ALTER TABLE data_stores\\012    ALTER COLUMN remote_url SET NOT NULL,\\012    ALTER COLUMN session_token SET NOT NULL;\\012\\012-- -------\\012-- Drop foreign keys onto DATA_STORES\\012-- -------\\012\\012ALTER TABLE database_instances\\012    DROP COLUMN dast_id;\\012\\012ALTER TABLE groups\\012    DROP COLUMN dast_id;\\012\\012ALTER TABLE projects\\012    DROP COLUMN dast_id;\\012\\012ALTER TABLE experiments\\012    DROP COLUMN dast_id;\\012\\012-- -------\\012-- Add foreign key from DATA onto DATA_STORES\\012-- -------\\012\\012ALTER TABLE data\\012    ADD COLUMN dast_id tech_id;\\012\\012ALTER TABLE data\\012    ADD CONSTRAINT data_dast_fk FOREIGN KEY (dast_id) REFERENCES data_stores(id);\\012\\012UPDATE data\\012SET dast_id = (select id from data_stores where code = 'STANDARD');\\012\\012ALTER TABLE data\\012    ALTER COLUMN dast_id SET NOT NULL;\\012\\012\\012------------------------------------------------------------------------------------\\012--  Purpose:  Replace trigger SAMPLE_CODE_UNIQUENESS_CHECK \\012------------------------------------------------------------------------------------\\012\\012CREATE OR REPLACE FUNCTION SAMPLE_CODE_UNIQUENESS_CHECK() RETURNS trigger AS $$\\012DECLARE\\012   counter  INTEGER;\\012BEGIN\\012    LOCK TABLE samples IN EXCLUSIVE MODE;\\012    IF (NEW.samp_id_part_of is NULL) THEN\\012        IF (NEW.dbin_id is not NULL) THEN\\012            SELECT count(*) into counter FROM samples \\012                where id != NEW.id and code = NEW.code and samp_id_part_of is NULL and dbin_id = NEW.dbin_id;\\012            IF (counter > 0) THEN\\012                RAISE EXCEPTION 'Insert/Update of Sample (Code: %) failed because database instance sample with the same code already exists.', NEW.code;\\012            END IF;\\012        ELSIF (NEW.grou_id is not NULL) THEN\\012            SELECT count(*) into counter FROM samples \\012                where id != NEW.id and code = NEW.code and samp_id_part_of is NULL and grou_id = NEW.grou_id;\\012            IF (counter > 0) THEN\\012                RAISE EXCEPTION 'Insert/Update of Sample (Code: %) failed because group sample with the same code already exists.', NEW.code;\\012            END IF;\\012        END IF;\\012        ELSE\\012        IF (NEW.dbin_id is not NULL) THEN\\012            SELECT count(*) into counter FROM samples \\012                where id != NEW.id and code = NEW.code and samp_id_part_of = NEW.samp_id_part_of and dbin_id = NEW.dbin_id;\\012            IF (counter > 0) THEN\\012                RAISE EXCEPTION 'Insert/Update of Sample (Code: %) failed because database instance sample with the same code and being the part of the same parent already exists.', NEW.code;\\012            END IF;\\012        ELSIF (NEW.grou_id is not NULL) THEN\\012            SELECT count(*) into counter FROM samples \\012                where id != NEW.id and code = NEW.code and samp_id_part_of = NEW.samp_id_part_of and grou_id = NEW.grou_id;\\012            IF (counter > 0) THEN\\012                RAISE EXCEPTION 'Insert/Update of Sample (Code: %) failed because group sample with the same code and being the part of the same parent already exists.', NEW.code;\\012            END IF;\\012        END IF;\\012        END IF;   \\012   RETURN NEW;\\012END;\\012$$ LANGUAGE 'plpgsql';\\012\\012\\012\\012	\N
+./sourceTest/sql/postgresql/046/.svn/text-base/017=database_version_logs.tsv.svn-base:034	source/sql/postgresql/migration/migration-033-034.sql	SUCCESS	2009-05-26 08:32:49.935	------------------------------------------------------------------------------------\\012-- Create sequence for generating permanent identifiers starting with nextval of existing dataset sequence.\\012------------------------------------------------------------------------------------\\012CREATE FUNCTION CREATE_SEQUENCE(EXISTING_SEQUENCE VARCHAR, NEW_SEQUENCE VARCHAR) RETURNS VOID AS $$\\012DECLARE\\012  CURR_SEQ_VAL   INTEGER;\\012BEGIN\\012  SELECT INTO CURR_SEQ_VAL NEXTVAL(EXISTING_SEQUENCE);\\012  EXECUTE 'CREATE SEQUENCE ' || NEW_SEQUENCE || ' START WITH ' || CURR_SEQ_VAL;\\012  RETURN;\\012END;\\012$$ LANGUAGE 'plpgsql';\\012\\012SELECT CREATE_SEQUENCE('DATA_ID_SEQ', 'PERM_ID_SEQ');\\012DROP FUNCTION CREATE_SEQUENCE(VARCHAR, VARCHAR);\\012\\012------------------------------------------------------------------------------------\\012-- Add perm_id columns to samples and experiments.\\012------------------------------------------------------------------------------------\\012ALTER TABLE SAMPLES ADD COLUMN PERM_ID CODE;\\012ALTER TABLE EXPERIMENTS ADD COLUMN PERM_ID CODE;\\012\\012UPDATE SAMPLES SET PERM_ID = to_char(registration_timestamp,'YYYYMMDDHHSSMS') || '-' || NEXTVAL('PERM_ID_SEQ');\\012UPDATE EXPERIMENTS SET PERM_ID = to_char(registration_timestamp,'YYYYMMDDHHSSMS') || '-' || NEXTVAL('PERM_ID_SEQ');\\012ALTER TABLE SAMPLES ALTER COLUMN PERM_ID SET NOT NULL;\\012ALTER TABLE EXPERIMENTS ALTER COLUMN PERM_ID SET NOT NULL;\\012ALTER TABLE SAMPLES ADD CONSTRAINT SAMP_PI_UK UNIQUE(PERM_ID);\\012ALTER TABLE EXPERIMENTS ADD CONSTRAINT EXPE_PI_UK UNIQUE(PERM_ID);\\012\\012\\012------------------------------------------------------------------------------------\\012-- Add column is_chosen_from_list to controlled_vocabularies.\\012------------------------------------------------------------------------------------\\012ALTER TABLE controlled_vocabularies ADD COLUMN is_chosen_from_list BOOLEAN_CHAR NOT NULL DEFAULT TRUE;\\012ALTER TABLE controlled_vocabularies ADD COLUMN source_uri CHARACTER VARYING(250);\\012------------------------------------------------------------------------------------\\012-- Modify Data table - remove arc connection between Sample and Data table, use a flag instead\\012------------------------------------------------------------------------------------\\012\\012-- add new columns\\012\\012ALTER TABLE data\\012    ADD COLUMN is_derived boolean_char;\\012ALTER TABLE data\\012    ADD COLUMN samp_id tech_id;\\012\\012-- update values in new columns\\012\\012UPDATE data\\012    SET is_derived = (samp_id_derived_from IS NOT NULL); \\012UPDATE data\\012    SET samp_id = samp_id_derived_from \\012    WHERE is_derived = 'TRUE';\\012UPDATE data\\012    SET samp_id = samp_id_acquired_from \\012    WHERE is_derived = 'FALSE';\\012\\012-- add constraints and indexes to new columns\\012\\012ALTER TABLE data\\012    ALTER COLUMN is_derived SET NOT NULL;\\012ALTER TABLE data\\012    ALTER COLUMN samp_id SET NOT NULL;   \\012ALTER TABLE data\\012    ADD CONSTRAINT data_samp_fk FOREIGN KEY (samp_id) REFERENCES samples (id);\\012CREATE INDEX data_samp_fk_i ON data USING btree (samp_id);\\012\\012-- remove old columns\\012\\012ALTER TABLE data\\012    DROP COLUMN samp_id_acquired_from;\\012ALTER TABLE data\\012    DROP COLUMN samp_id_derived_from;\\012    \\012------------------------------------------------------------------------------------\\012-- Granting SELECT privilege to group openbis_readonly\\012------------------------------------------------------------------------------------\\012\\012GRANT SELECT ON SEQUENCE attachment_content_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE attachment_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE code_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE controlled_vocabulary_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE cvte_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE data_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE data_set_property_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE data_set_relationship_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE data_set_type_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE data_store_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE data_type_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE database_instance_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE dstpt_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE etpt_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE event_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE experiment_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE experiment_property_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE experiment_type_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE file_format_type_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE group_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE invalidation_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE locator_type_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE material_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE material_property_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE material_type_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE mtpt_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE perm_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE person_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE project_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE property_type_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE role_assignment_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE sample_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE sample_property_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE sample_type_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE stpt_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE attachment_contents TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE attachments TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE controlled_vocabularies TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE controlled_vocabulary_terms TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE data TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE data_set_properties TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE data_set_relationships TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE data_set_type_property_types TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE data_set_types TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE data_stores TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE data_types TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE database_instances TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE database_version_logs TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE events TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE experiment_properties TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE experiment_type_property_types TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE experiment_types TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE experiments TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE external_data TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE file_format_types TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE groups TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE invalidations TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE locator_types TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE material_properties TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE material_type_property_types TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE material_types TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE materials TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE persons TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE projects TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE property_types TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE role_assignments TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE sample_properties TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE sample_type_property_types TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE sample_types TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE samples TO GROUP OPENBIS_READONLY;\\012\\012------------------------------------------------------------------------------------\\012-- Delete MATERIAL_BATCHES table\\012------------------------------------------------------------------------------------\\012\\012-- WARNING: Potential data lost!!!\\012-- WARNING: Potential data lost!!!\\012-- WARNING: Potential data lost!!!\\012\\012DROP TABLE SAMPLE_MATERIAL_BATCHES;\\012DROP TABLE MATERIAL_BATCHES;\\012DROP SEQUENCE MATERIAL_BATCH_ID_SEQ;\\012\\012------------------------------------------------------------------------------------\\012-- Delete MATE_ID_INHIBITOR_OF from table MATERIALS\\012------------------------------------------------------------------------------------\\012\\012-- WARNING: Potential data lost!!!\\012-- WARNING: Potential data lost!!!\\012-- WARNING: Potential data lost!!!\\012\\012ALTER TABLE MATERIALS DROP COLUMN MATE_ID_INHIBITOR_OF;\\012	\N
+./sourceTest/sql/postgresql/046/.svn/text-base/017=database_version_logs.tsv.svn-base:041	source/sql/postgresql/migration/migration-040-041.sql	SUCCESS	2009-09-14 13:48:57.539	-- Create FILTERS table\\012\\012CREATE TABLE FILTERS (ID TECH_ID NOT NULL, DBIN_ID TECH_ID NOT NULL, NAME VARCHAR(200) NOT NULL, DESCRIPTION DESCRIPTION_1000,REGISTRATION_TIMESTAMP TIME_STAMP_DFL NOT NULL DEFAULT CURRENT_TIMESTAMP, PERS_ID_REGISTERER TECH_ID NOT NULL, MODIFICATION_TIMESTAMP TIME_STAMP DEFAULT CURRENT_TIMESTAMP, EXPRESSION VARCHAR(2000) NOT NULL, IS_PUBLIC BOOLEAN NOT NULL, GRID_ID VARCHAR(200) NOT NULL);\\012CREATE SEQUENCE FILTER_ID_SEQ;\\012ALTER TABLE FILTERS ADD CONSTRAINT FILT_PK PRIMARY KEY(ID);\\012ALTER TABLE FILTERS ADD CONSTRAINT FILT_BK_UK UNIQUE(NAME, DBIN_ID, GRID_ID);\\012ALTER TABLE FILTERS ADD CONSTRAINT FILT_PERS_FK FOREIGN KEY (PERS_ID_REGISTERER) REFERENCES PERSONS(ID);\\012ALTER TABLE FILTERS ADD CONSTRAINT FILT_DBIN_FK FOREIGN KEY (DBIN_ID) REFERENCES DATABASE_INSTANCES(ID);\\012CREATE INDEX FILT_PERS_FK_I ON FILTERS (PERS_ID_REGISTERER);\\012CREATE INDEX FILT_DBIN_FK_I ON FILTERS (DBIN_ID);\\012GRANT SELECT ON SEQUENCE filter_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE filters TO GROUP OPENBIS_READONLY;\\012\\012-- Add missing foreign key to role assignments authorization group\\012ALTER TABLE ROLE_ASSIGNMENTS ADD CONSTRAINT ROAS_AG_FK_GRANTEE FOREIGN KEY (AG_ID_GRANTEE) REFERENCES AUTHORIZATION_GROUPS(ID);\\012\\012--------------------------------------------------------------------------------------------------\\012-- Modify dataset connections:\\012-- 1. connection with sample shouldn't be mandatory any more\\012-- 2. introduce an arc condition that dataset cannot be connected with a sample and a parent dataset at the same time\\012--------------------------------------------------------------------------------------------------\\012\\012-- Weaken data-sample connection constraint - allow dataset to have no connection with sample\\012ALTER TABLE data ALTER COLUMN samp_id DROP NOT NULL;\\012\\012-- Remove data-sample connection for datasets that have a parent\\012\\012UPDATE data \\012   SET samp_id = NULL \\012 WHERE id IN (SELECT DISTINCT data_id_child FROM data_set_relationships);\\012\\012-- With PostgreSQL 8.4 one can check that before migration there were no cycles in dataset relationships:\\012--\\012-- WITH RECURSIVE data_set_parents(id, parent_ids, cycle) AS (\\012--         SELECT  r.data_id_child AS id, \\012--                 ARRAY[CAST (r.data_id_parent AS bigint)] AS parent_ids, \\012--                 false AS cycle \\012--         FROM data_set_relationships r\\012--     UNION ALL\\012--         SELECT  r.data_id_child,\\012--                 CAST (r.data_id_parent AS bigint) || p.parent_ids,\\012--                 r.data_id_child = ANY(p.parent_ids)\\012--         FROM data_set_relationships r, data_set_parents p\\012--         WHERE r.data_id_parent = p.id AND NOT cycle\\012-- )\\012-- SELECT count(*) AS cycles FROM data_set_parents WHERE cycle = true;\\012\\012---------------------------------------------------------------------------------------------------\\012--  Purpose:  Create DEFERRED triggers:\\012--            * check_dataset_relationships_on_data_table_modification,\\012--            * check_dataset_relationships_on_relationships_table_modification.\\012--            They check that after all modifications of database (just before commit) \\012--            if 'data'/'data_set_relationships' tables are among modified tables \\012--            dataset is not connected with a sample and a parent dataset at the same time.\\012--            This connections are held in two different tables so simple immediate trigger \\012--            with arc check cannot be used and we need two deferred triggers.\\012----------------------------------------------------------------------------------------------------\\012\\012-- trigger for 'data' table\\012\\012CREATE OR REPLACE FUNCTION check_dataset_relationships_on_data_table_modification() RETURNS trigger AS $$\\012DECLARE\\012\\011counter\\011INTEGER;\\012BEGIN\\012\\011-- if there is a connection with a Sample there should not be any connection with a parent Data Set\\012\\011IF (NEW.samp_id IS NOT NULL) THEN\\012\\011\\011-- count number of parents\\012\\011\\011SELECT count(*) INTO counter \\012\\011\\011\\011FROM data_set_relationships \\012\\011\\011\\011WHERE data_id_child = OLD.id;\\012\\011\\011IF (counter > 0) THEN\\012\\011\\011\\011RAISE EXCEPTION 'Insert/Update of Data Set (Code: %) failed because it cannot be connected with a Sample and a parent Data Set at the same time.', OLD.code;\\012\\011\\011END IF;\\012\\011END IF;\\012  RETURN NEW;\\012END;\\012$$ LANGUAGE 'plpgsql';\\012\\012CREATE CONSTRAINT TRIGGER check_dataset_relationships_on_data_table_modification \\012  AFTER INSERT OR UPDATE ON data\\012\\011DEFERRABLE INITIALLY DEFERRED\\012\\011FOR EACH ROW \\012\\011EXECUTE PROCEDURE check_dataset_relationships_on_data_table_modification();\\012\\012-- trigger for 'data_set_relationships'\\012\\012CREATE OR REPLACE FUNCTION check_dataset_relationships_on_relationships_table_modification() RETURNS trigger AS $$\\012DECLARE\\012\\011counter\\011INTEGER;\\012\\011sample_id\\011TECH_ID;\\012\\011data_code\\011CODE;\\012BEGIN\\012\\011-- child will have a parent added so it should not be connected with any sample\\012\\011SELECT samp_id, code INTO sample_id, data_code \\012\\011\\011FROM data \\012\\011\\011WHERE id = NEW.data_id_child;\\012\\011IF (sample_id IS NOT NULL) THEN\\012\\011\\011RAISE EXCEPTION 'Insert/Update of Data Set (Code: %) failed because it cannot be connected to a Sample and to a parent Data Set at the same time.', data_code;\\012\\011END IF;\\012\\011RETURN NEW;\\012END;\\012$$ LANGUAGE 'plpgsql';\\012  \\012CREATE CONSTRAINT TRIGGER check_dataset_relationships_on_relationships_table_modification \\012  AFTER INSERT OR UPDATE ON data_set_relationships\\012\\011DEFERRABLE INITIALLY DEFERRED\\012\\011FOR EACH ROW \\012\\011EXECUTE PROCEDURE check_dataset_relationships_on_relationships_table_modification();\\012	\N
+./sourceTest/sql/postgresql/046/.svn/text-base/schema-046.sql.svn-base:    LANGUAGE plpgsql
+./sourceTest/sql/postgresql/046/.svn/text-base/schema-046.sql.svn-base:    LANGUAGE plpgsql
+./sourceTest/sql/postgresql/046/.svn/text-base/schema-046.sql.svn-base:    LANGUAGE plpgsql
+./sourceTest/sql/postgresql/046/.svn/text-base/schema-046.sql.svn-base:    LANGUAGE plpgsql
+./sourceTest/sql/postgresql/046/.svn/text-base/schema-046.sql.svn-base:    LANGUAGE plpgsql
+./sourceTest/sql/postgresql/046/.svn/text-base/schema-046.sql.svn-base:    LANGUAGE plpgsql
+./sourceTest/sql/postgresql/046/.svn/text-base/schema-046.sql.svn-base:    LANGUAGE plpgsql
+./sourceTest/sql/postgresql/046/.svn/text-base/schema-046.sql.svn-base:    LANGUAGE plpgsql
+./sourceTest/sql/postgresql/046/.svn/text-base/schema-046.sql.svn-base:    LANGUAGE plpgsql
+./sourceTest/sql/postgresql/046/.svn/text-base/schema-046.sql.svn-base:    LANGUAGE plpgsql
+./sourceTest/sql/postgresql/046/017=database_version_logs.tsv:027	D:\\User\\felmer\\dev-workspace\\openbis/source/sql/postgresql/027/function-027.sql	SUCCESS	2008-11-05 09:18:00.403	-- Creating Functions\\012\\012------------------------------------------------------------------------------------\\012--  Purpose:  Create function RENAME_SEQUENCE() that is required for renaming the sequences belonging to tables\\012------------------------------------------------------------------------------------\\012CREATE FUNCTION RENAME_SEQUENCE(OLD_NAME VARCHAR, NEW_NAME VARCHAR) RETURNS INTEGER AS $$\\012DECLARE\\012  CURR_SEQ_VAL   INTEGER;\\012BEGIN\\012  SELECT INTO CURR_SEQ_VAL NEXTVAL(OLD_NAME);\\012  EXECUTE 'CREATE SEQUENCE ' || NEW_NAME || ' START WITH ' || CURR_SEQ_VAL;\\012  EXECUTE 'DROP SEQUENCE ' || OLD_NAME;\\012  RETURN CURR_SEQ_VAL;\\012END;\\012$$ LANGUAGE 'plpgsql';\\012\\012\\012------------------------------------------------------------------------------------\\012--  Purpose:  Create trigger CONTROLLED_VOCABULARY_CHECK \\012------------------------------------------------------------------------------------\\012\\012CREATE OR REPLACE FUNCTION CONTROLLED_VOCABULARY_CHECK() RETURNS trigger AS $$\\012DECLARE\\012   v_code  CODE;\\012BEGIN\\012\\012   select code into v_code from data_types where id = NEW.daty_id;\\012\\012   -- Check if the data is of type "CONTROLLEDVOCABULARY"\\012   if v_code = 'CONTROLLEDVOCABULARY' then\\012      if NEW.covo_id IS NULL then\\012         RAISE EXCEPTION 'Insert/Update of Property Type (Code: %) failed, as its Data Type is CONTROLLEDVOCABULARY, but it is not linked to a Controlled Vocabulary.', NEW.code;\\012      end if;\\012   end if;\\012\\012   RETURN NEW;\\012\\012END;\\012$$ LANGUAGE 'plpgsql';\\012\\012CREATE TRIGGER CONTROLLED_VOCABULARY_CHECK BEFORE INSERT OR UPDATE ON PROPERTY_TYPES\\012    FOR EACH ROW EXECUTE PROCEDURE CONTROLLED_VOCABULARY_CHECK();\\012\\012\\012------------------------------------------------------------------------------------\\012--  Purpose:  Create trigger EXTERNAL_DATA_STORAGE_FORMAT_CHECK \\012------------------------------------------------------------------------------------\\012\\012CREATE OR REPLACE FUNCTION EXTERNAL_DATA_STORAGE_FORMAT_CHECK() RETURNS trigger AS $$\\012DECLARE\\012   v_covo_code  CODE;\\012   data_code CODE;\\012BEGIN\\012\\012   select code into v_covo_code from controlled_vocabularies\\012      where is_internal_namespace = true and \\012         id = (select covo_id from controlled_vocabulary_terms where id = NEW.cvte_id_stor_fmt);\\012   -- Check if the data storage format is a term of the controlled vocabulary "STORAGE_FORMAT"\\012   if v_covo_code != 'STORAGE_FORMAT' then\\012      select code into data_code from data where id = NEW.data_id; \\012      RAISE EXCEPTION 'Insert/Update of Data (Code: %) failed, as its Storage Format is %, but is required to be STORAGE_FORMAT.', data_code, v_covo_code;\\012   end if;\\012\\012   RETURN NEW;\\012\\012END;\\012$$ LANGUAGE 'plpgsql';\\012\\012CREATE TRIGGER EXTERNAL_DATA_STORAGE_FORMAT_CHECK BEFORE INSERT OR UPDATE ON EXTERNAL_DATA\\012    FOR EACH ROW EXECUTE PROCEDURE EXTERNAL_DATA_STORAGE_FORMAT_CHECK();\\012\\012------------------------------------------------------------------------------------\\012--  Purpose:  Create trigger SAMPLE_CODE_UNIQUENESS_CHECK \\012------------------------------------------------------------------------------------\\012\\012CREATE OR REPLACE FUNCTION SAMPLE_CODE_UNIQUENESS_CHECK() RETURNS trigger AS $$\\012DECLARE\\012   counter  INTEGER;\\012BEGIN\\012\\011IF (NEW.samp_id_part_of is NULL) THEN\\012\\011\\011IF (NEW.dbin_id is not NULL) THEN\\012\\011\\011\\011SELECT count(*) into counter FROM samples \\012\\011\\011\\011\\011where id != NEW.id and code = NEW.code and samp_id_part_of is NULL and dbin_id = NEW.dbin_id;\\012\\011\\011\\011IF (counter > 0) THEN\\012\\011\\011\\011\\011RAISE EXCEPTION 'Insert/Update of Sample (Code: %) failed because database instance sample with the same code already exists.', NEW.code;\\012\\011\\011\\011END IF;\\012\\011\\011ELSIF (NEW.grou_id is not NULL) THEN\\012\\011\\011\\011SELECT count(*) into counter FROM samples \\012\\011\\011\\011\\011where id != NEW.id and code = NEW.code and samp_id_part_of is NULL and grou_id = NEW.grou_id;\\012\\011\\011\\011IF (counter > 0) THEN\\012\\011\\011\\011\\011RAISE EXCEPTION 'Insert/Update of Sample (Code: %) failed because group sample with the same code already exists.', NEW.code;\\012\\011\\011\\011END IF;\\012\\011\\011END IF;\\012        ELSE\\012\\011\\011IF (NEW.dbin_id is not NULL) THEN\\012\\011\\011\\011SELECT count(*) into counter FROM samples \\012\\011\\011\\011\\011where id != NEW.id and code = NEW.code and samp_id_part_of = NEW.samp_id_part_of and dbin_id = NEW.dbin_id;\\012\\011\\011\\011IF (counter > 0) THEN\\012\\011\\011\\011\\011RAISE EXCEPTION 'Insert/Update of Sample (Code: %) failed because database instance sample with the same code and being the part of the same parent already exists.', NEW.code;\\012\\011\\011\\011END IF;\\012\\011\\011ELSIF (NEW.grou_id is not NULL) THEN\\012\\011\\011\\011SELECT count(*) into counter FROM samples \\012\\011\\011\\011\\011where id != NEW.id and code = NEW.code and samp_id_part_of = NEW.samp_id_part_of and grou_id = NEW.grou_id;\\012\\011\\011\\011IF (counter > 0) THEN\\012\\011\\011\\011\\011RAISE EXCEPTION 'Insert/Update of Sample (Code: %) failed because group sample with the same code and being the part of the same parent already exists.', NEW.code;\\012\\011\\011\\011END IF;\\012\\011\\011END IF;\\012        END IF;   \\012   RETURN NEW;\\012END;\\012$$ LANGUAGE 'plpgsql';\\012\\012CREATE TRIGGER SAMPLE_CODE_UNIQUENESS_CHECK BEFORE INSERT OR UPDATE ON SAMPLES\\012    FOR EACH ROW EXECUTE PROCEDURE SAMPLE_CODE_UNIQUENESS_CHECK();\\012	\N
+./sourceTest/sql/postgresql/046/017=database_version_logs.tsv:028	source/sql/postgresql/migration/migration-027-028.sql	SUCCESS	2008-11-18 13:24:17.508	-- Create EXPERIMENT_ATTACHMENT_CONTENTS.\\012CREATE TABLE EXPERIMENT_ATTACHMENT_CONTENTS (ID TECH_ID NOT NULL,VALUE FILE NOT NULL);\\012CREATE SEQUENCE EXPERIMENT_ATTACHMENT_CONTENT_ID_SEQ;\\012ALTER TABLE EXPERIMENT_ATTACHMENT_CONTENTS ADD CONSTRAINT EXAC_PK PRIMARY KEY(ID);\\012\\012-- Alter EXPERIMENT_ATTACHMENTS by adding the new column which has a NULL constraint.\\012-- The NOT NULL constraint is added later on.\\012ALTER TABLE EXPERIMENT_ATTACHMENTS ADD COLUMN EXAC_ID TECH_ID;\\012\\012-- Does the VALUE migration between EXPERIMENT_ATTACHMENTS to EXPERIMENT_ATTACHMENT_CONTENTS.\\012CREATE OR REPLACE FUNCTION move_exp_att_content() RETURNS integer AS $$\\012DECLARE\\012    rec RECORD;\\012    seq BIGINT;\\012BEGIN\\012  FOR rec IN SELECT id, value FROM EXPERIMENT_ATTACHMENTS LOOP\\012  \\011seq := nextval('EXPERIMENT_ATTACHMENT_CONTENT_ID_SEQ');\\012    INSERT INTO EXPERIMENT_ATTACHMENT_CONTENTS (id, value) VALUES (seq, rec.value);\\012    UPDATE EXPERIMENT_ATTACHMENTS SET exac_id = seq WHERE id = rec.id;\\012  END LOOP;\\012  RETURN 1;\\012END;\\012$$ LANGUAGE 'plpgsql';\\012\\012-- Call the function.\\012SELECT move_exp_att_content();\\012DROP FUNCTION move_exp_att_content();\\012\\012\\012-- Finish EXPERIMENT_ATTACHMENTS changes.\\012ALTER TABLE EXPERIMENT_ATTACHMENTS ADD CONSTRAINT EXAT_CONT_FK FOREIGN KEY (EXAC_ID) REFERENCES EXPERIMENT_ATTACHMENT_CONTENTS(ID);\\012ALTER TABLE EXPERIMENT_ATTACHMENTS DROP COLUMN VALUE;\\012ALTER TABLE EXPERIMENT_ATTACHMENTS ALTER COLUMN EXAC_ID SET NOT NULL;\\012	\N
+./sourceTest/sql/postgresql/046/017=database_version_logs.tsv:029	source/sql/postgresql/migration/migration-028-029.sql	SUCCESS	2009-03-18 10:50:20.105	-- -------\\012-- add modification_timestamp field to allow edition with Hibernate\\012-- -------\\012\\012ALTER TABLE samples\\012\\011ADD COLUMN modification_timestamp TIME_STAMP DEFAULT CURRENT_TIMESTAMP;\\012\\012ALTER TABLE experiments\\012\\011ADD COLUMN modification_timestamp TIME_STAMP DEFAULT CURRENT_TIMESTAMP;\\012\\012ALTER TABLE materials\\012\\011ADD COLUMN modification_timestamp TIME_STAMP DEFAULT CURRENT_TIMESTAMP;\\012\\012ALTER TABLE experiment_properties\\012\\011ADD COLUMN modification_timestamp TIME_STAMP DEFAULT CURRENT_TIMESTAMP;\\012\\012ALTER TABLE material_properties\\012\\011ADD COLUMN modification_timestamp TIME_STAMP DEFAULT CURRENT_TIMESTAMP;\\012\\012ALTER TABLE sample_properties\\012\\011ADD COLUMN modification_timestamp TIME_STAMP DEFAULT CURRENT_TIMESTAMP;\\012\\012-- -------\\012-- add property data type which references materials\\012-- -------\\012\\012ALTER TABLE property_types\\012\\011ADD COLUMN maty_prop_id tech_id;\\012\\012ALTER TABLE property_types\\012\\011ADD CONSTRAINT prty_maty_fk FOREIGN KEY (maty_prop_id) REFERENCES material_types(id);\\012\\012ALTER TABLE experiment_properties\\012\\011ADD COLUMN mate_prop_id tech_id;\\012\\012ALTER TABLE material_properties\\012\\011ADD COLUMN mate_prop_id tech_id;\\012\\012ALTER TABLE sample_properties\\012\\011ADD COLUMN mate_prop_id tech_id;\\012\\012ALTER TABLE experiment_properties\\012\\011ADD CONSTRAINT expr_mapr_fk FOREIGN KEY (mate_prop_id) REFERENCES materials(id);\\012\\012ALTER TABLE material_properties\\012\\011ADD CONSTRAINT mapr_mapr_fk FOREIGN KEY (mate_prop_id) REFERENCES materials(id);\\012\\012ALTER TABLE sample_properties\\012\\011ADD CONSTRAINT sapr_mapr_fk FOREIGN KEY (mate_prop_id) REFERENCES materials(id);\\012\\012insert into data_types\\012(id\\012 ,code\\012 ,description)\\012 values \\012 (nextval('DATA_TYPE_ID_SEQ')\\012 ,'MATERIAL'\\012 ,'Reference to a material'\\012);\\012\\012ALTER TABLE MATERIAL_PROPERTIES DROP CONSTRAINT MAPR_CK;\\012ALTER TABLE MATERIAL_PROPERTIES ADD CONSTRAINT MAPR_CK CHECK \\012\\011((VALUE IS NOT NULL AND CVTE_ID IS NULL AND MATE_PROP_ID IS NULL) OR \\012\\011 (VALUE IS NULL AND CVTE_ID IS NOT NULL AND MATE_PROP_ID IS NULL) OR\\012\\011 (VALUE IS NULL AND CVTE_ID IS NULL AND MATE_PROP_ID IS NOT NULL)\\012\\011);\\012\\012ALTER TABLE EXPERIMENT_PROPERTIES DROP CONSTRAINT EXPR_CK;\\012ALTER TABLE EXPERIMENT_PROPERTIES ADD CONSTRAINT EXPR_CK CHECK \\012\\011((VALUE IS NOT NULL AND CVTE_ID IS NULL AND MATE_PROP_ID IS NULL) OR \\012\\011 (VALUE IS NULL AND CVTE_ID IS NOT NULL AND MATE_PROP_ID IS NULL) OR\\012\\011 (VALUE IS NULL AND CVTE_ID IS NULL AND MATE_PROP_ID IS NOT NULL)\\012\\011);\\012\\012ALTER TABLE SAMPLE_PROPERTIES DROP CONSTRAINT SAPR_CK;\\012ALTER TABLE SAMPLE_PROPERTIES ADD CONSTRAINT SAPR_CK CHECK \\012\\011((VALUE IS NOT NULL AND CVTE_ID IS NULL AND MATE_PROP_ID IS NULL) OR \\012\\011 (VALUE IS NULL AND CVTE_ID IS NOT NULL AND MATE_PROP_ID IS NULL) OR\\012\\011 (VALUE IS NULL AND CVTE_ID IS NULL AND MATE_PROP_ID IS NOT NULL)\\012\\011);\\012\\012------------------------------------------------------------------------------------\\012--  Purpose:  Create trigger MATERIAL/SAMPLE/EXPERIMENT _PROPERTY_WITH_MATERIAL_DATA_TYPE_CHECK\\012--            It checks that if material property value is assigned to the entity,\\012--\\011\\011\\011\\011\\011\\011then the material type is equal to the one described by property type.\\012------------------------------------------------------------------------------------\\012\\012CREATE OR REPLACE FUNCTION MATERIAL_PROPERTY_WITH_MATERIAL_DATA_TYPE_CHECK() RETURNS trigger AS $$\\012DECLARE\\012   v_type_id  CODE;\\012   v_type_id_prop  CODE;\\012BEGIN\\012   if NEW.mate_prop_id IS NOT NULL then\\012\\011\\011\\011-- find material type id of the property type \\012\\011\\011\\011select pt.maty_prop_id into v_type_id_prop \\012\\011\\011\\011  from material_type_property_types etpt, property_types pt \\012\\011\\011\\011 where NEW.mtpt_id = etpt.id AND etpt.prty_id = pt.id;\\012\\011\\011\\012\\011\\011\\011if v_type_id_prop IS NOT NULL then\\012\\011\\011\\011\\011-- find material type id of the material which consists the entity's property value\\012\\011\\011\\011\\011select entity.maty_id into v_type_id \\012\\011\\011\\011\\011  from materials entity\\012\\011\\011\\011\\011 where NEW.mate_prop_id = entity.id;\\012\\011\\011\\011\\011if v_type_id != v_type_id_prop then\\012\\011\\011\\011\\011\\011RAISE EXCEPTION 'Insert/Update of property value referencing material (id: %) failed, as referenced material type is different than expected (id %, expected id: %).', \\012\\011\\011\\011\\011\\011\\011\\011 NEW.mate_prop_id, v_type_id, v_type_id_prop;\\012\\011\\011\\011\\011end if;\\012\\011\\011\\011end if;\\012   end if;\\012   RETURN NEW;\\012END;\\012$$ LANGUAGE 'plpgsql';\\012\\012CREATE TRIGGER MATERIAL_PROPERTY_WITH_MATERIAL_DATA_TYPE_CHECK BEFORE INSERT OR UPDATE ON material_properties\\012    FOR EACH ROW EXECUTE PROCEDURE MATERIAL_PROPERTY_WITH_MATERIAL_DATA_TYPE_CHECK();\\012    \\012CREATE OR REPLACE FUNCTION SAMPLE_PROPERTY_WITH_MATERIAL_DATA_TYPE_CHECK() RETURNS trigger AS $$\\012DECLARE\\012   v_type_id  CODE;\\012   v_type_id_prop  CODE;\\012BEGIN\\012   if NEW.mate_prop_id IS NOT NULL then\\012\\011\\011\\011-- find material type id of the property type \\012\\011\\011\\011select pt.maty_prop_id into v_type_id_prop \\012\\011\\011\\011  from sample_type_property_types etpt, property_types pt \\012\\011\\011\\011 where NEW.stpt_id = etpt.id AND etpt.prty_id = pt.id;\\012\\011\\011\\012\\011\\011\\011if v_type_id_prop IS NOT NULL then\\012\\011\\011\\011\\011-- find material type id of the material which consists the entity's property value\\012\\011\\011\\011\\011select entity.maty_id into v_type_id \\012\\011\\011\\011\\011  from materials entity\\012\\011\\011\\011\\011 where NEW.mate_prop_id = entity.id;\\012\\011\\011\\011\\011if v_type_id != v_type_id_prop then\\012\\011\\011\\011\\011\\011RAISE EXCEPTION 'Insert/Update of property value referencing material (id: %) failed, as referenced material type is different than expected (id %, expected id: %).', \\012\\011\\011\\011\\011\\011\\011\\011\\011\\011\\011\\011\\011 NEW.mate_prop_id, v_type_id, v_type_id_prop;\\012\\011\\011\\011\\011end if;\\012\\011\\011\\011end if;\\012   end if;\\012   RETURN NEW;\\012END;\\012$$ LANGUAGE 'plpgsql';\\012\\012CREATE TRIGGER SAMPLE_PROPERTY_WITH_MATERIAL_DATA_TYPE_CHECK BEFORE INSERT OR UPDATE ON sample_properties\\012    FOR EACH ROW EXECUTE PROCEDURE SAMPLE_PROPERTY_WITH_MATERIAL_DATA_TYPE_CHECK();\\012    \\012CREATE OR REPLACE FUNCTION EXPERIMENT_PROPERTY_WITH_MATERIAL_DATA_TYPE_CHECK() RETURNS trigger AS $$\\012DECLARE\\012   v_type_id  CODE;\\012   v_type_id_prop  CODE;\\012BEGIN\\012   if NEW.mate_prop_id IS NOT NULL then\\012\\011\\011\\011-- find material type id of the property type \\012\\011\\011\\011select pt.maty_prop_id into v_type_id_prop \\012\\011\\011\\011  from experiment_type_property_types etpt, property_types pt \\012\\011\\011\\011 where NEW.etpt_id = etpt.id AND etpt.prty_id = pt.id;\\012\\011\\011\\012\\011\\011\\011if v_type_id_prop IS NOT NULL then\\012\\011\\011\\011\\011-- find material type id of the material which consists the entity's property value\\012\\011\\011\\011\\011select entity.maty_id into v_type_id \\012\\011\\011\\011\\011  from materials entity\\012\\011\\011\\011\\011 where NEW.mate_prop_id = entity.id;\\012\\011\\011\\011\\011if v_type_id != v_type_id_prop then\\012\\011\\011\\011\\011\\011RAISE EXCEPTION 'Insert/Update of property value referencing material (id: %) failed, as referenced material type is different than expected (id %, expected id: %).', \\012\\011\\011\\011\\011\\011\\011\\011\\011\\011\\011\\011\\011 NEW.mate_prop_id, v_type_id, v_type_id_prop;\\012\\011\\011\\011\\011end if;\\012\\011\\011\\011end if;\\012   end if;\\012   RETURN NEW;\\012END;\\012$$ LANGUAGE 'plpgsql';\\012\\012CREATE TRIGGER EXPERIMENT_PROPERTY_WITH_MATERIAL_DATA_TYPE_CHECK BEFORE INSERT OR UPDATE ON experiment_properties\\012    FOR EACH ROW EXECUTE PROCEDURE EXPERIMENT_PROPERTY_WITH_MATERIAL_DATA_TYPE_CHECK();\\012       \\012-- -------\\012-- remove the reminescents of the OBSERVABLE_TYPE\\012-- -------\\012\\012ALTER TABLE data\\012\\011DROP CONSTRAINT data_obty_fk;\\012\\012ALTER TABLE data_set_types\\012\\011DROP CONSTRAINT obty_pk;\\012\\012ALTER TABLE data_set_types\\012\\011ADD CONSTRAINT dsty_pk PRIMARY KEY (id);\\012\\012ALTER TABLE data\\012\\011ADD CONSTRAINT data_dsty_fk FOREIGN KEY (dsty_id) REFERENCES data_set_types(id);\\012\\012ALTER TABLE data_set_types\\012\\011DROP CONSTRAINT obty_bk_uk;\\012\\012ALTER TABLE data_set_types\\012\\011DROP CONSTRAINT obty_dbin_fk;\\012\\012ALTER TABLE data_set_types\\012\\011ADD CONSTRAINT dsty_bk_uk UNIQUE (code, dbin_id);\\012\\012ALTER TABLE data_set_types\\012\\011ADD CONSTRAINT dsty_dbin_fk FOREIGN KEY (dbin_id) REFERENCES database_instances(id);\\012\\012DROP INDEX data_obty_fk_i;\\012\\012CREATE INDEX data_dsty_fk_i ON data(dsty_id);\\012	\N
+./sourceTest/sql/postgresql/046/017=database_version_logs.tsv:030	source/sql/postgresql/migration/migration-029-030.sql	SUCCESS	2009-03-23 15:34:44.72	-- -------\\012-- add modification_timestamp field to allow edition with Hibernate\\012-- -------\\012ALTER TABLE data\\012\\011ADD COLUMN modification_timestamp TIME_STAMP DEFAULT CURRENT_TIMESTAMP;\\012ALTER TABLE experiment_types\\012\\011ADD COLUMN modification_timestamp TIME_STAMP DEFAULT CURRENT_TIMESTAMP;\\012ALTER TABLE sample_types\\012\\011ADD COLUMN modification_timestamp TIME_STAMP DEFAULT CURRENT_TIMESTAMP;\\012ALTER TABLE material_types\\012\\011ADD COLUMN modification_timestamp TIME_STAMP DEFAULT CURRENT_TIMESTAMP;\\012ALTER TABLE data_set_types\\012\\011ADD COLUMN modification_timestamp TIME_STAMP DEFAULT CURRENT_TIMESTAMP;\\012ALTER TABLE controlled_vocabularies\\012\\011ADD COLUMN modification_timestamp TIME_STAMP DEFAULT CURRENT_TIMESTAMP;\\012-- -------\\012-- add properties to data sets\\012-- -------\\012CREATE TABLE DATA_SET_PROPERTIES (ID TECH_ID NOT NULL,DS_ID TECH_ID NOT NULL,DSTPT_ID TECH_ID NOT NULL,VALUE GENERIC_VALUE,CVTE_ID TECH_ID, MATE_PROP_ID TECH_ID, PERS_ID_REGISTERER TECH_ID NOT NULL,REGISTRATION_TIMESTAMP TIME_STAMP_DFL NOT NULL DEFAULT CURRENT_TIMESTAMP, MODIFICATION_TIMESTAMP TIME_STAMP DEFAULT CURRENT_TIMESTAMP);\\012CREATE TABLE DATA_SET_TYPE_PROPERTY_TYPES (ID TECH_ID NOT NULL,DSTY_ID TECH_ID NOT NULL,PRTY_ID TECH_ID NOT NULL,IS_MANDATORY BOOLEAN_CHAR NOT NULL DEFAULT 'F',IS_MANAGED_INTERNALLY BOOLEAN_CHAR NOT NULL DEFAULT 'F',PERS_ID_REGISTERER TECH_ID NOT NULL,REGISTRATION_TIMESTAMP TIME_STAMP_DFL NOT NULL DEFAULT CURRENT_TIMESTAMP);\\012\\012CREATE SEQUENCE DATA_SET_PROPERTY_ID_SEQ;\\012CREATE SEQUENCE DSTPT_ID_SEQ;\\012\\012ALTER TABLE DATA_SET_TYPE_PROPERTY_TYPES ADD CONSTRAINT DSTPT_PK PRIMARY KEY(ID);\\012ALTER TABLE DATA_SET_PROPERTIES ADD CONSTRAINT DSPR_PK PRIMARY KEY(ID);\\012\\012ALTER TABLE DATA_SET_TYPE_PROPERTY_TYPES ADD CONSTRAINT DSTPT_BK_UK UNIQUE(DSTY_ID,PRTY_ID);\\012ALTER TABLE DATA_SET_PROPERTIES ADD CONSTRAINT DSPR_BK_UK UNIQUE(DS_ID,DSTPT_ID);\\012\\012\\012ALTER TABLE DATA_SET_TYPE_PROPERTY_TYPES ADD CONSTRAINT DSTPT_DSTY_FK FOREIGN KEY (DSTY_ID) REFERENCES DATA_SET_TYPES(ID);\\012ALTER TABLE DATA_SET_TYPE_PROPERTY_TYPES ADD CONSTRAINT DSTPT_PERS_FK FOREIGN KEY (PERS_ID_REGISTERER) REFERENCES PERSONS(ID);\\012ALTER TABLE DATA_SET_TYPE_PROPERTY_TYPES ADD CONSTRAINT DSTPT_PRTY_FK FOREIGN KEY (PRTY_ID) REFERENCES PROPERTY_TYPES(ID);\\012ALTER TABLE DATA_SET_PROPERTIES ADD CONSTRAINT DSPR_CVTE_FK FOREIGN KEY (CVTE_ID) REFERENCES CONTROLLED_VOCABULARY_TERMS(ID);\\012ALTER TABLE DATA_SET_PROPERTIES ADD CONSTRAINT DSPR_DSTPT_FK FOREIGN KEY (DSTPT_ID) REFERENCES DATA_SET_TYPE_PROPERTY_TYPES(ID) ON DELETE CASCADE;\\012ALTER TABLE DATA_SET_PROPERTIES ADD CONSTRAINT DSPR_DS_FK FOREIGN KEY (DS_ID) REFERENCES DATA(ID);\\012ALTER TABLE DATA_SET_PROPERTIES ADD CONSTRAINT DSPR_PERS_FK FOREIGN KEY (PERS_ID_REGISTERER) REFERENCES PERSONS(ID);\\012ALTER TABLE DATA_SET_PROPERTIES ADD CONSTRAINT DSPR_MAPR_FK FOREIGN KEY (MATE_PROP_ID) REFERENCES MATERIALS(ID);\\012\\012ALTER TABLE DATA_SET_PROPERTIES ADD CONSTRAINT DSPR_CK CHECK \\012\\011((VALUE IS NOT NULL AND CVTE_ID IS NULL AND MATE_PROP_ID IS NULL) OR \\012\\011 (VALUE IS NULL AND CVTE_ID IS NOT NULL AND MATE_PROP_ID IS NULL) OR\\012\\011 (VALUE IS NULL AND CVTE_ID IS NULL AND MATE_PROP_ID IS NOT NULL)\\012\\011);\\012\\012CREATE INDEX DSPR_CVTE_FK_I ON DATA_SET_PROPERTIES (CVTE_ID);\\012CREATE INDEX DSPR_DSTPT_FK_I ON DATA_SET_PROPERTIES (DSTPT_ID);\\012CREATE INDEX DSPR_DS_FK_I ON DATA_SET_PROPERTIES (DS_ID);\\012CREATE INDEX DSPR_PERS_FK_I ON DATA_SET_PROPERTIES (PERS_ID_REGISTERER);\\012CREATE INDEX DSTPT_DSTY_FK_I ON DATA_SET_TYPE_PROPERTY_TYPES (DSTY_ID);\\012CREATE INDEX DSTPT_PERS_FK_I ON DATA_SET_TYPE_PROPERTY_TYPES (PERS_ID_REGISTERER);\\012CREATE INDEX DSTPT_PRTY_FK_I ON DATA_SET_TYPE_PROPERTY_TYPES (PRTY_ID);\\012\\012CREATE OR REPLACE FUNCTION DATA_SET_PROPERTY_WITH_MATERIAL_DATA_TYPE_CHECK() RETURNS trigger AS $$\\012DECLARE\\012   v_type_id  CODE;\\012   v_type_id_prop  CODE;\\012BEGIN\\012   if NEW.mate_prop_id IS NOT NULL then\\012\\011\\011\\011-- find material type id of the property type \\012\\011\\011\\011select pt.maty_prop_id into v_type_id_prop \\012\\011\\011\\011  from data_set_type_property_types dstpt, property_types pt \\012\\011\\011\\011 where NEW.dstpt_id = dstpt.id AND dstpt.prty_id = pt.id;\\012\\011\\011\\012\\011\\011\\011if v_type_id_prop IS NOT NULL then\\012\\011\\011\\011\\011-- find material type id of the material which consists the entity's property value\\012\\011\\011\\011\\011select entity.maty_id into v_type_id \\012\\011\\011\\011\\011  from materials entity\\012\\011\\011\\011\\011 where NEW.mate_prop_id = entity.id;\\012\\011\\011\\011\\011if v_type_id != v_type_id_prop then\\012\\011\\011\\011\\011\\011RAISE EXCEPTION 'Insert/Update of property value referencing material (id: %) failed, as referenced material type is different than expected (id %, expected id: %).', \\012\\011\\011\\011\\011\\011\\011\\011\\011\\011\\011\\011\\011 NEW.mate_prop_id, v_type_id, v_type_id_prop;\\012\\011\\011\\011\\011end if;\\012\\011\\011\\011end if;\\012   end if;\\012   RETURN NEW;\\012END;\\012$$ LANGUAGE 'plpgsql';\\012\\012CREATE TRIGGER DATA_SET_PROPERTY_WITH_MATERIAL_DATA_TYPE_CHECK BEFORE INSERT OR UPDATE ON data_set_properties\\012    FOR EACH ROW EXECUTE PROCEDURE DATA_SET_PROPERTY_WITH_MATERIAL_DATA_TYPE_CHECK();   \\012	\N
+./sourceTest/sql/postgresql/046/017=database_version_logs.tsv:032	source/sql/postgresql/migration/migration-031-032.sql	SUCCESS	2009-04-09 09:36:36.2	-- -------\\012-- Modify MATERIAL_BATCHES\\012-- -------\\012\\012ALTER TABLE material_batches\\012    DROP COLUMN proc_id;\\012\\012-- -------\\012-- Modify SAMPLES\\012-- -------\\012\\012ALTER TABLE samples\\012    ADD COLUMN expe_id tech_id;\\012\\012ALTER TABLE samples\\012    ADD CONSTRAINT samp_expe_fk FOREIGN KEY (expe_id) REFERENCES experiments(id);\\012\\012CREATE INDEX samp_expe_fk_i ON samples USING btree (expe_id);\\012\\012-- relink samples directly to experiments\\012\\012UPDATE samples\\012SET expe_id = (SELECT e.id FROM experiments e, procedures p, sample_inputs si \\012               WHERE si.samp_id = samples.id AND si.proc_id = p.id AND p.expe_id = e.id AND e.inva_id IS NULL);\\012\\012\\012-- -------\\012-- Modify DATA\\012-- -------\\012\\012ALTER TABLE data\\012    ADD COLUMN expe_id tech_id;\\012\\012ALTER TABLE data\\012    ADD CONSTRAINT data_expe_fk FOREIGN KEY (expe_id) REFERENCES experiments(id);\\012\\012CREATE INDEX data_expe_fk_i ON data USING btree (expe_id);\\012\\012UPDATE data\\012SET expe_id = (SELECT e.id FROM experiments e, procedures p \\012               WHERE data.proc_id_produced_by = p.id AND p.expe_id = e.id);\\012\\012ALTER TABLE data\\012    ALTER COLUMN expe_id SET NOT NULL;\\012\\012ALTER TABLE data\\012    DROP COLUMN proc_id_produced_by;\\012\\012-- -------\\012-- Drop PROCEDURES, PROCEDURE_TYPES, and SAMPLE_INPUTS\\012-- -------\\012\\012DROP TABLE sample_inputs;\\012DROP TABLE procedures;\\012DROP TABLE procedure_types;\\012\\012DROP SEQUENCE procedure_id_seq;\\012DROP SEQUENCE procedure_type_id_seq;\\012\\012-- -------\\012-- Add CODE_SEQ\\012-- -------\\012\\012CREATE SEQUENCE CODE_SEQ;\\012\\012-- -------\\012-- Add new columns to DATA_STORES\\012-- -------\\012\\012ALTER TABLE data_stores\\012    ADD COLUMN remote_url character varying(250),\\012    ADD COLUMN session_token character varying(50),\\012    ADD COLUMN modification_timestamp time_stamp DEFAULT now();\\012\\012UPDATE data_stores\\012SET remote_url = '', session_token='';\\012\\012ALTER TABLE data_stores\\012    ALTER COLUMN remote_url SET NOT NULL,\\012    ALTER COLUMN session_token SET NOT NULL;\\012\\012-- -------\\012-- Drop foreign keys onto DATA_STORES\\012-- -------\\012\\012ALTER TABLE database_instances\\012    DROP COLUMN dast_id;\\012\\012ALTER TABLE groups\\012    DROP COLUMN dast_id;\\012\\012ALTER TABLE projects\\012    DROP COLUMN dast_id;\\012\\012ALTER TABLE experiments\\012    DROP COLUMN dast_id;\\012\\012-- -------\\012-- Add foreign key from DATA onto DATA_STORES\\012-- -------\\012\\012ALTER TABLE data\\012    ADD COLUMN dast_id tech_id;\\012\\012ALTER TABLE data\\012    ADD CONSTRAINT data_dast_fk FOREIGN KEY (dast_id) REFERENCES data_stores(id);\\012\\012UPDATE data\\012SET dast_id = (select id from data_stores where code = 'STANDARD');\\012\\012ALTER TABLE data\\012    ALTER COLUMN dast_id SET NOT NULL;\\012\\012\\012------------------------------------------------------------------------------------\\012--  Purpose:  Replace trigger SAMPLE_CODE_UNIQUENESS_CHECK \\012------------------------------------------------------------------------------------\\012\\012CREATE OR REPLACE FUNCTION SAMPLE_CODE_UNIQUENESS_CHECK() RETURNS trigger AS $$\\012DECLARE\\012   counter  INTEGER;\\012BEGIN\\012    LOCK TABLE samples IN EXCLUSIVE MODE;\\012    IF (NEW.samp_id_part_of is NULL) THEN\\012        IF (NEW.dbin_id is not NULL) THEN\\012            SELECT count(*) into counter FROM samples \\012                where id != NEW.id and code = NEW.code and samp_id_part_of is NULL and dbin_id = NEW.dbin_id;\\012            IF (counter > 0) THEN\\012                RAISE EXCEPTION 'Insert/Update of Sample (Code: %) failed because database instance sample with the same code already exists.', NEW.code;\\012            END IF;\\012        ELSIF (NEW.grou_id is not NULL) THEN\\012            SELECT count(*) into counter FROM samples \\012                where id != NEW.id and code = NEW.code and samp_id_part_of is NULL and grou_id = NEW.grou_id;\\012            IF (counter > 0) THEN\\012                RAISE EXCEPTION 'Insert/Update of Sample (Code: %) failed because group sample with the same code already exists.', NEW.code;\\012            END IF;\\012        END IF;\\012        ELSE\\012        IF (NEW.dbin_id is not NULL) THEN\\012            SELECT count(*) into counter FROM samples \\012                where id != NEW.id and code = NEW.code and samp_id_part_of = NEW.samp_id_part_of and dbin_id = NEW.dbin_id;\\012            IF (counter > 0) THEN\\012                RAISE EXCEPTION 'Insert/Update of Sample (Code: %) failed because database instance sample with the same code and being the part of the same parent already exists.', NEW.code;\\012            END IF;\\012        ELSIF (NEW.grou_id is not NULL) THEN\\012            SELECT count(*) into counter FROM samples \\012                where id != NEW.id and code = NEW.code and samp_id_part_of = NEW.samp_id_part_of and grou_id = NEW.grou_id;\\012            IF (counter > 0) THEN\\012                RAISE EXCEPTION 'Insert/Update of Sample (Code: %) failed because group sample with the same code and being the part of the same parent already exists.', NEW.code;\\012            END IF;\\012        END IF;\\012        END IF;   \\012   RETURN NEW;\\012END;\\012$$ LANGUAGE 'plpgsql';\\012\\012\\012\\012	\N
+./sourceTest/sql/postgresql/046/017=database_version_logs.tsv:034	source/sql/postgresql/migration/migration-033-034.sql	SUCCESS	2009-05-26 08:32:49.935	------------------------------------------------------------------------------------\\012-- Create sequence for generating permanent identifiers starting with nextval of existing dataset sequence.\\012------------------------------------------------------------------------------------\\012CREATE FUNCTION CREATE_SEQUENCE(EXISTING_SEQUENCE VARCHAR, NEW_SEQUENCE VARCHAR) RETURNS VOID AS $$\\012DECLARE\\012  CURR_SEQ_VAL   INTEGER;\\012BEGIN\\012  SELECT INTO CURR_SEQ_VAL NEXTVAL(EXISTING_SEQUENCE);\\012  EXECUTE 'CREATE SEQUENCE ' || NEW_SEQUENCE || ' START WITH ' || CURR_SEQ_VAL;\\012  RETURN;\\012END;\\012$$ LANGUAGE 'plpgsql';\\012\\012SELECT CREATE_SEQUENCE('DATA_ID_SEQ', 'PERM_ID_SEQ');\\012DROP FUNCTION CREATE_SEQUENCE(VARCHAR, VARCHAR);\\012\\012------------------------------------------------------------------------------------\\012-- Add perm_id columns to samples and experiments.\\012------------------------------------------------------------------------------------\\012ALTER TABLE SAMPLES ADD COLUMN PERM_ID CODE;\\012ALTER TABLE EXPERIMENTS ADD COLUMN PERM_ID CODE;\\012\\012UPDATE SAMPLES SET PERM_ID = to_char(registration_timestamp,'YYYYMMDDHHSSMS') || '-' || NEXTVAL('PERM_ID_SEQ');\\012UPDATE EXPERIMENTS SET PERM_ID = to_char(registration_timestamp,'YYYYMMDDHHSSMS') || '-' || NEXTVAL('PERM_ID_SEQ');\\012ALTER TABLE SAMPLES ALTER COLUMN PERM_ID SET NOT NULL;\\012ALTER TABLE EXPERIMENTS ALTER COLUMN PERM_ID SET NOT NULL;\\012ALTER TABLE SAMPLES ADD CONSTRAINT SAMP_PI_UK UNIQUE(PERM_ID);\\012ALTER TABLE EXPERIMENTS ADD CONSTRAINT EXPE_PI_UK UNIQUE(PERM_ID);\\012\\012\\012------------------------------------------------------------------------------------\\012-- Add column is_chosen_from_list to controlled_vocabularies.\\012------------------------------------------------------------------------------------\\012ALTER TABLE controlled_vocabularies ADD COLUMN is_chosen_from_list BOOLEAN_CHAR NOT NULL DEFAULT TRUE;\\012ALTER TABLE controlled_vocabularies ADD COLUMN source_uri CHARACTER VARYING(250);\\012------------------------------------------------------------------------------------\\012-- Modify Data table - remove arc connection between Sample and Data table, use a flag instead\\012------------------------------------------------------------------------------------\\012\\012-- add new columns\\012\\012ALTER TABLE data\\012    ADD COLUMN is_derived boolean_char;\\012ALTER TABLE data\\012    ADD COLUMN samp_id tech_id;\\012\\012-- update values in new columns\\012\\012UPDATE data\\012    SET is_derived = (samp_id_derived_from IS NOT NULL); \\012UPDATE data\\012    SET samp_id = samp_id_derived_from \\012    WHERE is_derived = 'TRUE';\\012UPDATE data\\012    SET samp_id = samp_id_acquired_from \\012    WHERE is_derived = 'FALSE';\\012\\012-- add constraints and indexes to new columns\\012\\012ALTER TABLE data\\012    ALTER COLUMN is_derived SET NOT NULL;\\012ALTER TABLE data\\012    ALTER COLUMN samp_id SET NOT NULL;   \\012ALTER TABLE data\\012    ADD CONSTRAINT data_samp_fk FOREIGN KEY (samp_id) REFERENCES samples (id);\\012CREATE INDEX data_samp_fk_i ON data USING btree (samp_id);\\012\\012-- remove old columns\\012\\012ALTER TABLE data\\012    DROP COLUMN samp_id_acquired_from;\\012ALTER TABLE data\\012    DROP COLUMN samp_id_derived_from;\\012    \\012------------------------------------------------------------------------------------\\012-- Granting SELECT privilege to group openbis_readonly\\012------------------------------------------------------------------------------------\\012\\012GRANT SELECT ON SEQUENCE attachment_content_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE attachment_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE code_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE controlled_vocabulary_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE cvte_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE data_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE data_set_property_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE data_set_relationship_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE data_set_type_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE data_store_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE data_type_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE database_instance_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE dstpt_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE etpt_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE event_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE experiment_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE experiment_property_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE experiment_type_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE file_format_type_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE group_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE invalidation_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE locator_type_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE material_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE material_property_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE material_type_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE mtpt_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE perm_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE person_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE project_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE property_type_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE role_assignment_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE sample_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE sample_property_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE sample_type_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE stpt_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE attachment_contents TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE attachments TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE controlled_vocabularies TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE controlled_vocabulary_terms TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE data TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE data_set_properties TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE data_set_relationships TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE data_set_type_property_types TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE data_set_types TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE data_stores TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE data_types TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE database_instances TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE database_version_logs TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE events TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE experiment_properties TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE experiment_type_property_types TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE experiment_types TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE experiments TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE external_data TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE file_format_types TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE groups TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE invalidations TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE locator_types TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE material_properties TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE material_type_property_types TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE material_types TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE materials TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE persons TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE projects TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE property_types TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE role_assignments TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE sample_properties TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE sample_type_property_types TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE sample_types TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE samples TO GROUP OPENBIS_READONLY;\\012\\012------------------------------------------------------------------------------------\\012-- Delete MATERIAL_BATCHES table\\012------------------------------------------------------------------------------------\\012\\012-- WARNING: Potential data lost!!!\\012-- WARNING: Potential data lost!!!\\012-- WARNING: Potential data lost!!!\\012\\012DROP TABLE SAMPLE_MATERIAL_BATCHES;\\012DROP TABLE MATERIAL_BATCHES;\\012DROP SEQUENCE MATERIAL_BATCH_ID_SEQ;\\012\\012------------------------------------------------------------------------------------\\012-- Delete MATE_ID_INHIBITOR_OF from table MATERIALS\\012------------------------------------------------------------------------------------\\012\\012-- WARNING: Potential data lost!!!\\012-- WARNING: Potential data lost!!!\\012-- WARNING: Potential data lost!!!\\012\\012ALTER TABLE MATERIALS DROP COLUMN MATE_ID_INHIBITOR_OF;\\012	\N
+./sourceTest/sql/postgresql/046/017=database_version_logs.tsv:041	source/sql/postgresql/migration/migration-040-041.sql	SUCCESS	2009-09-14 13:48:57.539	-- Create FILTERS table\\012\\012CREATE TABLE FILTERS (ID TECH_ID NOT NULL, DBIN_ID TECH_ID NOT NULL, NAME VARCHAR(200) NOT NULL, DESCRIPTION DESCRIPTION_1000,REGISTRATION_TIMESTAMP TIME_STAMP_DFL NOT NULL DEFAULT CURRENT_TIMESTAMP, PERS_ID_REGISTERER TECH_ID NOT NULL, MODIFICATION_TIMESTAMP TIME_STAMP DEFAULT CURRENT_TIMESTAMP, EXPRESSION VARCHAR(2000) NOT NULL, IS_PUBLIC BOOLEAN NOT NULL, GRID_ID VARCHAR(200) NOT NULL);\\012CREATE SEQUENCE FILTER_ID_SEQ;\\012ALTER TABLE FILTERS ADD CONSTRAINT FILT_PK PRIMARY KEY(ID);\\012ALTER TABLE FILTERS ADD CONSTRAINT FILT_BK_UK UNIQUE(NAME, DBIN_ID, GRID_ID);\\012ALTER TABLE FILTERS ADD CONSTRAINT FILT_PERS_FK FOREIGN KEY (PERS_ID_REGISTERER) REFERENCES PERSONS(ID);\\012ALTER TABLE FILTERS ADD CONSTRAINT FILT_DBIN_FK FOREIGN KEY (DBIN_ID) REFERENCES DATABASE_INSTANCES(ID);\\012CREATE INDEX FILT_PERS_FK_I ON FILTERS (PERS_ID_REGISTERER);\\012CREATE INDEX FILT_DBIN_FK_I ON FILTERS (DBIN_ID);\\012GRANT SELECT ON SEQUENCE filter_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE filters TO GROUP OPENBIS_READONLY;\\012\\012-- Add missing foreign key to role assignments authorization group\\012ALTER TABLE ROLE_ASSIGNMENTS ADD CONSTRAINT ROAS_AG_FK_GRANTEE FOREIGN KEY (AG_ID_GRANTEE) REFERENCES AUTHORIZATION_GROUPS(ID);\\012\\012--------------------------------------------------------------------------------------------------\\012-- Modify dataset connections:\\012-- 1. connection with sample shouldn't be mandatory any more\\012-- 2. introduce an arc condition that dataset cannot be connected with a sample and a parent dataset at the same time\\012--------------------------------------------------------------------------------------------------\\012\\012-- Weaken data-sample connection constraint - allow dataset to have no connection with sample\\012ALTER TABLE data ALTER COLUMN samp_id DROP NOT NULL;\\012\\012-- Remove data-sample connection for datasets that have a parent\\012\\012UPDATE data \\012   SET samp_id = NULL \\012 WHERE id IN (SELECT DISTINCT data_id_child FROM data_set_relationships);\\012\\012-- With PostgreSQL 8.4 one can check that before migration there were no cycles in dataset relationships:\\012--\\012-- WITH RECURSIVE data_set_parents(id, parent_ids, cycle) AS (\\012--         SELECT  r.data_id_child AS id, \\012--                 ARRAY[CAST (r.data_id_parent AS bigint)] AS parent_ids, \\012--                 false AS cycle \\012--         FROM data_set_relationships r\\012--     UNION ALL\\012--         SELECT  r.data_id_child,\\012--                 CAST (r.data_id_parent AS bigint) || p.parent_ids,\\012--                 r.data_id_child = ANY(p.parent_ids)\\012--         FROM data_set_relationships r, data_set_parents p\\012--         WHERE r.data_id_parent = p.id AND NOT cycle\\012-- )\\012-- SELECT count(*) AS cycles FROM data_set_parents WHERE cycle = true;\\012\\012---------------------------------------------------------------------------------------------------\\012--  Purpose:  Create DEFERRED triggers:\\012--            * check_dataset_relationships_on_data_table_modification,\\012--            * check_dataset_relationships_on_relationships_table_modification.\\012--            They check that after all modifications of database (just before commit) \\012--            if 'data'/'data_set_relationships' tables are among modified tables \\012--            dataset is not connected with a sample and a parent dataset at the same time.\\012--            This connections are held in two different tables so simple immediate trigger \\012--            with arc check cannot be used and we need two deferred triggers.\\012----------------------------------------------------------------------------------------------------\\012\\012-- trigger for 'data' table\\012\\012CREATE OR REPLACE FUNCTION check_dataset_relationships_on_data_table_modification() RETURNS trigger AS $$\\012DECLARE\\012\\011counter\\011INTEGER;\\012BEGIN\\012\\011-- if there is a connection with a Sample there should not be any connection with a parent Data Set\\012\\011IF (NEW.samp_id IS NOT NULL) THEN\\012\\011\\011-- count number of parents\\012\\011\\011SELECT count(*) INTO counter \\012\\011\\011\\011FROM data_set_relationships \\012\\011\\011\\011WHERE data_id_child = OLD.id;\\012\\011\\011IF (counter > 0) THEN\\012\\011\\011\\011RAISE EXCEPTION 'Insert/Update of Data Set (Code: %) failed because it cannot be connected with a Sample and a parent Data Set at the same time.', OLD.code;\\012\\011\\011END IF;\\012\\011END IF;\\012  RETURN NEW;\\012END;\\012$$ LANGUAGE 'plpgsql';\\012\\012CREATE CONSTRAINT TRIGGER check_dataset_relationships_on_data_table_modification \\012  AFTER INSERT OR UPDATE ON data\\012\\011DEFERRABLE INITIALLY DEFERRED\\012\\011FOR EACH ROW \\012\\011EXECUTE PROCEDURE check_dataset_relationships_on_data_table_modification();\\012\\012-- trigger for 'data_set_relationships'\\012\\012CREATE OR REPLACE FUNCTION check_dataset_relationships_on_relationships_table_modification() RETURNS trigger AS $$\\012DECLARE\\012\\011counter\\011INTEGER;\\012\\011sample_id\\011TECH_ID;\\012\\011data_code\\011CODE;\\012BEGIN\\012\\011-- child will have a parent added so it should not be connected with any sample\\012\\011SELECT samp_id, code INTO sample_id, data_code \\012\\011\\011FROM data \\012\\011\\011WHERE id = NEW.data_id_child;\\012\\011IF (sample_id IS NOT NULL) THEN\\012\\011\\011RAISE EXCEPTION 'Insert/Update of Data Set (Code: %) failed because it cannot be connected to a Sample and to a parent Data Set at the same time.', data_code;\\012\\011END IF;\\012\\011RETURN NEW;\\012END;\\012$$ LANGUAGE 'plpgsql';\\012  \\012CREATE CONSTRAINT TRIGGER check_dataset_relationships_on_relationships_table_modification \\012  AFTER INSERT OR UPDATE ON data_set_relationships\\012\\011DEFERRABLE INITIALLY DEFERRED\\012\\011FOR EACH ROW \\012\\011EXECUTE PROCEDURE check_dataset_relationships_on_relationships_table_modification();\\012	\N
+./sourceTest/sql/postgresql/046/schema-046.sql:    LANGUAGE plpgsql
+./sourceTest/sql/postgresql/046/schema-046.sql:    LANGUAGE plpgsql
+./sourceTest/sql/postgresql/046/schema-046.sql:    LANGUAGE plpgsql
+./sourceTest/sql/postgresql/046/schema-046.sql:    LANGUAGE plpgsql
+./sourceTest/sql/postgresql/046/schema-046.sql:    LANGUAGE plpgsql
+./sourceTest/sql/postgresql/046/schema-046.sql:    LANGUAGE plpgsql
+./sourceTest/sql/postgresql/046/schema-046.sql:    LANGUAGE plpgsql
+./sourceTest/sql/postgresql/046/schema-046.sql:    LANGUAGE plpgsql
+./sourceTest/sql/postgresql/046/schema-046.sql:    LANGUAGE plpgsql
+./sourceTest/sql/postgresql/046/schema-046.sql:    LANGUAGE plpgsql
+./sourceTest/sql/postgresql/047/.svn/text-base/017=database_version_logs.tsv.svn-base:027	D:\\User\\felmer\\dev-workspace\\openbis/source/sql/postgresql/027/function-027.sql	SUCCESS	2008-11-05 09:18:00.403	-- Creating Functions\\012\\012------------------------------------------------------------------------------------\\012--  Purpose:  Create function RENAME_SEQUENCE() that is required for renaming the sequences belonging to tables\\012------------------------------------------------------------------------------------\\012CREATE FUNCTION RENAME_SEQUENCE(OLD_NAME VARCHAR, NEW_NAME VARCHAR) RETURNS INTEGER AS $$\\012DECLARE\\012  CURR_SEQ_VAL   INTEGER;\\012BEGIN\\012  SELECT INTO CURR_SEQ_VAL NEXTVAL(OLD_NAME);\\012  EXECUTE 'CREATE SEQUENCE ' || NEW_NAME || ' START WITH ' || CURR_SEQ_VAL;\\012  EXECUTE 'DROP SEQUENCE ' || OLD_NAME;\\012  RETURN CURR_SEQ_VAL;\\012END;\\012$$ LANGUAGE 'plpgsql';\\012\\012\\012------------------------------------------------------------------------------------\\012--  Purpose:  Create trigger CONTROLLED_VOCABULARY_CHECK \\012------------------------------------------------------------------------------------\\012\\012CREATE OR REPLACE FUNCTION CONTROLLED_VOCABULARY_CHECK() RETURNS trigger AS $$\\012DECLARE\\012   v_code  CODE;\\012BEGIN\\012\\012   select code into v_code from data_types where id = NEW.daty_id;\\012\\012   -- Check if the data is of type "CONTROLLEDVOCABULARY"\\012   if v_code = 'CONTROLLEDVOCABULARY' then\\012      if NEW.covo_id IS NULL then\\012         RAISE EXCEPTION 'Insert/Update of Property Type (Code: %) failed, as its Data Type is CONTROLLEDVOCABULARY, but it is not linked to a Controlled Vocabulary.', NEW.code;\\012      end if;\\012   end if;\\012\\012   RETURN NEW;\\012\\012END;\\012$$ LANGUAGE 'plpgsql';\\012\\012CREATE TRIGGER CONTROLLED_VOCABULARY_CHECK BEFORE INSERT OR UPDATE ON PROPERTY_TYPES\\012    FOR EACH ROW EXECUTE PROCEDURE CONTROLLED_VOCABULARY_CHECK();\\012\\012\\012------------------------------------------------------------------------------------\\012--  Purpose:  Create trigger EXTERNAL_DATA_STORAGE_FORMAT_CHECK \\012------------------------------------------------------------------------------------\\012\\012CREATE OR REPLACE FUNCTION EXTERNAL_DATA_STORAGE_FORMAT_CHECK() RETURNS trigger AS $$\\012DECLARE\\012   v_covo_code  CODE;\\012   data_code CODE;\\012BEGIN\\012\\012   select code into v_covo_code from controlled_vocabularies\\012      where is_internal_namespace = true and \\012         id = (select covo_id from controlled_vocabulary_terms where id = NEW.cvte_id_stor_fmt);\\012   -- Check if the data storage format is a term of the controlled vocabulary "STORAGE_FORMAT"\\012   if v_covo_code != 'STORAGE_FORMAT' then\\012      select code into data_code from data where id = NEW.data_id; \\012      RAISE EXCEPTION 'Insert/Update of Data (Code: %) failed, as its Storage Format is %, but is required to be STORAGE_FORMAT.', data_code, v_covo_code;\\012   end if;\\012\\012   RETURN NEW;\\012\\012END;\\012$$ LANGUAGE 'plpgsql';\\012\\012CREATE TRIGGER EXTERNAL_DATA_STORAGE_FORMAT_CHECK BEFORE INSERT OR UPDATE ON EXTERNAL_DATA\\012    FOR EACH ROW EXECUTE PROCEDURE EXTERNAL_DATA_STORAGE_FORMAT_CHECK();\\012\\012------------------------------------------------------------------------------------\\012--  Purpose:  Create trigger SAMPLE_CODE_UNIQUENESS_CHECK \\012------------------------------------------------------------------------------------\\012\\012CREATE OR REPLACE FUNCTION SAMPLE_CODE_UNIQUENESS_CHECK() RETURNS trigger AS $$\\012DECLARE\\012   counter  INTEGER;\\012BEGIN\\012\\011IF (NEW.samp_id_part_of is NULL) THEN\\012\\011\\011IF (NEW.dbin_id is not NULL) THEN\\012\\011\\011\\011SELECT count(*) into counter FROM samples \\012\\011\\011\\011\\011where id != NEW.id and code = NEW.code and samp_id_part_of is NULL and dbin_id = NEW.dbin_id;\\012\\011\\011\\011IF (counter > 0) THEN\\012\\011\\011\\011\\011RAISE EXCEPTION 'Insert/Update of Sample (Code: %) failed because database instance sample with the same code already exists.', NEW.code;\\012\\011\\011\\011END IF;\\012\\011\\011ELSIF (NEW.grou_id is not NULL) THEN\\012\\011\\011\\011SELECT count(*) into counter FROM samples \\012\\011\\011\\011\\011where id != NEW.id and code = NEW.code and samp_id_part_of is NULL and grou_id = NEW.grou_id;\\012\\011\\011\\011IF (counter > 0) THEN\\012\\011\\011\\011\\011RAISE EXCEPTION 'Insert/Update of Sample (Code: %) failed because group sample with the same code already exists.', NEW.code;\\012\\011\\011\\011END IF;\\012\\011\\011END IF;\\012        ELSE\\012\\011\\011IF (NEW.dbin_id is not NULL) THEN\\012\\011\\011\\011SELECT count(*) into counter FROM samples \\012\\011\\011\\011\\011where id != NEW.id and code = NEW.code and samp_id_part_of = NEW.samp_id_part_of and dbin_id = NEW.dbin_id;\\012\\011\\011\\011IF (counter > 0) THEN\\012\\011\\011\\011\\011RAISE EXCEPTION 'Insert/Update of Sample (Code: %) failed because database instance sample with the same code and being the part of the same parent already exists.', NEW.code;\\012\\011\\011\\011END IF;\\012\\011\\011ELSIF (NEW.grou_id is not NULL) THEN\\012\\011\\011\\011SELECT count(*) into counter FROM samples \\012\\011\\011\\011\\011where id != NEW.id and code = NEW.code and samp_id_part_of = NEW.samp_id_part_of and grou_id = NEW.grou_id;\\012\\011\\011\\011IF (counter > 0) THEN\\012\\011\\011\\011\\011RAISE EXCEPTION 'Insert/Update of Sample (Code: %) failed because group sample with the same code and being the part of the same parent already exists.', NEW.code;\\012\\011\\011\\011END IF;\\012\\011\\011END IF;\\012        END IF;   \\012   RETURN NEW;\\012END;\\012$$ LANGUAGE 'plpgsql';\\012\\012CREATE TRIGGER SAMPLE_CODE_UNIQUENESS_CHECK BEFORE INSERT OR UPDATE ON SAMPLES\\012    FOR EACH ROW EXECUTE PROCEDURE SAMPLE_CODE_UNIQUENESS_CHECK();\\012	\N
+./sourceTest/sql/postgresql/047/.svn/text-base/017=database_version_logs.tsv.svn-base:028	source/sql/postgresql/migration/migration-027-028.sql	SUCCESS	2008-11-18 13:24:17.508	-- Create EXPERIMENT_ATTACHMENT_CONTENTS.\\012CREATE TABLE EXPERIMENT_ATTACHMENT_CONTENTS (ID TECH_ID NOT NULL,VALUE FILE NOT NULL);\\012CREATE SEQUENCE EXPERIMENT_ATTACHMENT_CONTENT_ID_SEQ;\\012ALTER TABLE EXPERIMENT_ATTACHMENT_CONTENTS ADD CONSTRAINT EXAC_PK PRIMARY KEY(ID);\\012\\012-- Alter EXPERIMENT_ATTACHMENTS by adding the new column which has a NULL constraint.\\012-- The NOT NULL constraint is added later on.\\012ALTER TABLE EXPERIMENT_ATTACHMENTS ADD COLUMN EXAC_ID TECH_ID;\\012\\012-- Does the VALUE migration between EXPERIMENT_ATTACHMENTS to EXPERIMENT_ATTACHMENT_CONTENTS.\\012CREATE OR REPLACE FUNCTION move_exp_att_content() RETURNS integer AS $$\\012DECLARE\\012    rec RECORD;\\012    seq BIGINT;\\012BEGIN\\012  FOR rec IN SELECT id, value FROM EXPERIMENT_ATTACHMENTS LOOP\\012  \\011seq := nextval('EXPERIMENT_ATTACHMENT_CONTENT_ID_SEQ');\\012    INSERT INTO EXPERIMENT_ATTACHMENT_CONTENTS (id, value) VALUES (seq, rec.value);\\012    UPDATE EXPERIMENT_ATTACHMENTS SET exac_id = seq WHERE id = rec.id;\\012  END LOOP;\\012  RETURN 1;\\012END;\\012$$ LANGUAGE 'plpgsql';\\012\\012-- Call the function.\\012SELECT move_exp_att_content();\\012DROP FUNCTION move_exp_att_content();\\012\\012\\012-- Finish EXPERIMENT_ATTACHMENTS changes.\\012ALTER TABLE EXPERIMENT_ATTACHMENTS ADD CONSTRAINT EXAT_CONT_FK FOREIGN KEY (EXAC_ID) REFERENCES EXPERIMENT_ATTACHMENT_CONTENTS(ID);\\012ALTER TABLE EXPERIMENT_ATTACHMENTS DROP COLUMN VALUE;\\012ALTER TABLE EXPERIMENT_ATTACHMENTS ALTER COLUMN EXAC_ID SET NOT NULL;\\012	\N
+./sourceTest/sql/postgresql/047/.svn/text-base/017=database_version_logs.tsv.svn-base:029	source/sql/postgresql/migration/migration-028-029.sql	SUCCESS	2009-03-18 10:50:20.105	-- -------\\012-- add modification_timestamp field to allow edition with Hibernate\\012-- -------\\012\\012ALTER TABLE samples\\012\\011ADD COLUMN modification_timestamp TIME_STAMP DEFAULT CURRENT_TIMESTAMP;\\012\\012ALTER TABLE experiments\\012\\011ADD COLUMN modification_timestamp TIME_STAMP DEFAULT CURRENT_TIMESTAMP;\\012\\012ALTER TABLE materials\\012\\011ADD COLUMN modification_timestamp TIME_STAMP DEFAULT CURRENT_TIMESTAMP;\\012\\012ALTER TABLE experiment_properties\\012\\011ADD COLUMN modification_timestamp TIME_STAMP DEFAULT CURRENT_TIMESTAMP;\\012\\012ALTER TABLE material_properties\\012\\011ADD COLUMN modification_timestamp TIME_STAMP DEFAULT CURRENT_TIMESTAMP;\\012\\012ALTER TABLE sample_properties\\012\\011ADD COLUMN modification_timestamp TIME_STAMP DEFAULT CURRENT_TIMESTAMP;\\012\\012-- -------\\012-- add property data type which references materials\\012-- -------\\012\\012ALTER TABLE property_types\\012\\011ADD COLUMN maty_prop_id tech_id;\\012\\012ALTER TABLE property_types\\012\\011ADD CONSTRAINT prty_maty_fk FOREIGN KEY (maty_prop_id) REFERENCES material_types(id);\\012\\012ALTER TABLE experiment_properties\\012\\011ADD COLUMN mate_prop_id tech_id;\\012\\012ALTER TABLE material_properties\\012\\011ADD COLUMN mate_prop_id tech_id;\\012\\012ALTER TABLE sample_properties\\012\\011ADD COLUMN mate_prop_id tech_id;\\012\\012ALTER TABLE experiment_properties\\012\\011ADD CONSTRAINT expr_mapr_fk FOREIGN KEY (mate_prop_id) REFERENCES materials(id);\\012\\012ALTER TABLE material_properties\\012\\011ADD CONSTRAINT mapr_mapr_fk FOREIGN KEY (mate_prop_id) REFERENCES materials(id);\\012\\012ALTER TABLE sample_properties\\012\\011ADD CONSTRAINT sapr_mapr_fk FOREIGN KEY (mate_prop_id) REFERENCES materials(id);\\012\\012insert into data_types\\012(id\\012 ,code\\012 ,description)\\012 values \\012 (nextval('DATA_TYPE_ID_SEQ')\\012 ,'MATERIAL'\\012 ,'Reference to a material'\\012);\\012\\012ALTER TABLE MATERIAL_PROPERTIES DROP CONSTRAINT MAPR_CK;\\012ALTER TABLE MATERIAL_PROPERTIES ADD CONSTRAINT MAPR_CK CHECK \\012\\011((VALUE IS NOT NULL AND CVTE_ID IS NULL AND MATE_PROP_ID IS NULL) OR \\012\\011 (VALUE IS NULL AND CVTE_ID IS NOT NULL AND MATE_PROP_ID IS NULL) OR\\012\\011 (VALUE IS NULL AND CVTE_ID IS NULL AND MATE_PROP_ID IS NOT NULL)\\012\\011);\\012\\012ALTER TABLE EXPERIMENT_PROPERTIES DROP CONSTRAINT EXPR_CK;\\012ALTER TABLE EXPERIMENT_PROPERTIES ADD CONSTRAINT EXPR_CK CHECK \\012\\011((VALUE IS NOT NULL AND CVTE_ID IS NULL AND MATE_PROP_ID IS NULL) OR \\012\\011 (VALUE IS NULL AND CVTE_ID IS NOT NULL AND MATE_PROP_ID IS NULL) OR\\012\\011 (VALUE IS NULL AND CVTE_ID IS NULL AND MATE_PROP_ID IS NOT NULL)\\012\\011);\\012\\012ALTER TABLE SAMPLE_PROPERTIES DROP CONSTRAINT SAPR_CK;\\012ALTER TABLE SAMPLE_PROPERTIES ADD CONSTRAINT SAPR_CK CHECK \\012\\011((VALUE IS NOT NULL AND CVTE_ID IS NULL AND MATE_PROP_ID IS NULL) OR \\012\\011 (VALUE IS NULL AND CVTE_ID IS NOT NULL AND MATE_PROP_ID IS NULL) OR\\012\\011 (VALUE IS NULL AND CVTE_ID IS NULL AND MATE_PROP_ID IS NOT NULL)\\012\\011);\\012\\012------------------------------------------------------------------------------------\\012--  Purpose:  Create trigger MATERIAL/SAMPLE/EXPERIMENT _PROPERTY_WITH_MATERIAL_DATA_TYPE_CHECK\\012--            It checks that if material property value is assigned to the entity,\\012--\\011\\011\\011\\011\\011\\011then the material type is equal to the one described by property type.\\012------------------------------------------------------------------------------------\\012\\012CREATE OR REPLACE FUNCTION MATERIAL_PROPERTY_WITH_MATERIAL_DATA_TYPE_CHECK() RETURNS trigger AS $$\\012DECLARE\\012   v_type_id  CODE;\\012   v_type_id_prop  CODE;\\012BEGIN\\012   if NEW.mate_prop_id IS NOT NULL then\\012\\011\\011\\011-- find material type id of the property type \\012\\011\\011\\011select pt.maty_prop_id into v_type_id_prop \\012\\011\\011\\011  from material_type_property_types etpt, property_types pt \\012\\011\\011\\011 where NEW.mtpt_id = etpt.id AND etpt.prty_id = pt.id;\\012\\011\\011\\012\\011\\011\\011if v_type_id_prop IS NOT NULL then\\012\\011\\011\\011\\011-- find material type id of the material which consists the entity's property value\\012\\011\\011\\011\\011select entity.maty_id into v_type_id \\012\\011\\011\\011\\011  from materials entity\\012\\011\\011\\011\\011 where NEW.mate_prop_id = entity.id;\\012\\011\\011\\011\\011if v_type_id != v_type_id_prop then\\012\\011\\011\\011\\011\\011RAISE EXCEPTION 'Insert/Update of property value referencing material (id: %) failed, as referenced material type is different than expected (id %, expected id: %).', \\012\\011\\011\\011\\011\\011\\011\\011 NEW.mate_prop_id, v_type_id, v_type_id_prop;\\012\\011\\011\\011\\011end if;\\012\\011\\011\\011end if;\\012   end if;\\012   RETURN NEW;\\012END;\\012$$ LANGUAGE 'plpgsql';\\012\\012CREATE TRIGGER MATERIAL_PROPERTY_WITH_MATERIAL_DATA_TYPE_CHECK BEFORE INSERT OR UPDATE ON material_properties\\012    FOR EACH ROW EXECUTE PROCEDURE MATERIAL_PROPERTY_WITH_MATERIAL_DATA_TYPE_CHECK();\\012    \\012CREATE OR REPLACE FUNCTION SAMPLE_PROPERTY_WITH_MATERIAL_DATA_TYPE_CHECK() RETURNS trigger AS $$\\012DECLARE\\012   v_type_id  CODE;\\012   v_type_id_prop  CODE;\\012BEGIN\\012   if NEW.mate_prop_id IS NOT NULL then\\012\\011\\011\\011-- find material type id of the property type \\012\\011\\011\\011select pt.maty_prop_id into v_type_id_prop \\012\\011\\011\\011  from sample_type_property_types etpt, property_types pt \\012\\011\\011\\011 where NEW.stpt_id = etpt.id AND etpt.prty_id = pt.id;\\012\\011\\011\\012\\011\\011\\011if v_type_id_prop IS NOT NULL then\\012\\011\\011\\011\\011-- find material type id of the material which consists the entity's property value\\012\\011\\011\\011\\011select entity.maty_id into v_type_id \\012\\011\\011\\011\\011  from materials entity\\012\\011\\011\\011\\011 where NEW.mate_prop_id = entity.id;\\012\\011\\011\\011\\011if v_type_id != v_type_id_prop then\\012\\011\\011\\011\\011\\011RAISE EXCEPTION 'Insert/Update of property value referencing material (id: %) failed, as referenced material type is different than expected (id %, expected id: %).', \\012\\011\\011\\011\\011\\011\\011\\011\\011\\011\\011\\011\\011 NEW.mate_prop_id, v_type_id, v_type_id_prop;\\012\\011\\011\\011\\011end if;\\012\\011\\011\\011end if;\\012   end if;\\012   RETURN NEW;\\012END;\\012$$ LANGUAGE 'plpgsql';\\012\\012CREATE TRIGGER SAMPLE_PROPERTY_WITH_MATERIAL_DATA_TYPE_CHECK BEFORE INSERT OR UPDATE ON sample_properties\\012    FOR EACH ROW EXECUTE PROCEDURE SAMPLE_PROPERTY_WITH_MATERIAL_DATA_TYPE_CHECK();\\012    \\012CREATE OR REPLACE FUNCTION EXPERIMENT_PROPERTY_WITH_MATERIAL_DATA_TYPE_CHECK() RETURNS trigger AS $$\\012DECLARE\\012   v_type_id  CODE;\\012   v_type_id_prop  CODE;\\012BEGIN\\012   if NEW.mate_prop_id IS NOT NULL then\\012\\011\\011\\011-- find material type id of the property type \\012\\011\\011\\011select pt.maty_prop_id into v_type_id_prop \\012\\011\\011\\011  from experiment_type_property_types etpt, property_types pt \\012\\011\\011\\011 where NEW.etpt_id = etpt.id AND etpt.prty_id = pt.id;\\012\\011\\011\\012\\011\\011\\011if v_type_id_prop IS NOT NULL then\\012\\011\\011\\011\\011-- find material type id of the material which consists the entity's property value\\012\\011\\011\\011\\011select entity.maty_id into v_type_id \\012\\011\\011\\011\\011  from materials entity\\012\\011\\011\\011\\011 where NEW.mate_prop_id = entity.id;\\012\\011\\011\\011\\011if v_type_id != v_type_id_prop then\\012\\011\\011\\011\\011\\011RAISE EXCEPTION 'Insert/Update of property value referencing material (id: %) failed, as referenced material type is different than expected (id %, expected id: %).', \\012\\011\\011\\011\\011\\011\\011\\011\\011\\011\\011\\011\\011 NEW.mate_prop_id, v_type_id, v_type_id_prop;\\012\\011\\011\\011\\011end if;\\012\\011\\011\\011end if;\\012   end if;\\012   RETURN NEW;\\012END;\\012$$ LANGUAGE 'plpgsql';\\012\\012CREATE TRIGGER EXPERIMENT_PROPERTY_WITH_MATERIAL_DATA_TYPE_CHECK BEFORE INSERT OR UPDATE ON experiment_properties\\012    FOR EACH ROW EXECUTE PROCEDURE EXPERIMENT_PROPERTY_WITH_MATERIAL_DATA_TYPE_CHECK();\\012       \\012-- -------\\012-- remove the reminescents of the OBSERVABLE_TYPE\\012-- -------\\012\\012ALTER TABLE data\\012\\011DROP CONSTRAINT data_obty_fk;\\012\\012ALTER TABLE data_set_types\\012\\011DROP CONSTRAINT obty_pk;\\012\\012ALTER TABLE data_set_types\\012\\011ADD CONSTRAINT dsty_pk PRIMARY KEY (id);\\012\\012ALTER TABLE data\\012\\011ADD CONSTRAINT data_dsty_fk FOREIGN KEY (dsty_id) REFERENCES data_set_types(id);\\012\\012ALTER TABLE data_set_types\\012\\011DROP CONSTRAINT obty_bk_uk;\\012\\012ALTER TABLE data_set_types\\012\\011DROP CONSTRAINT obty_dbin_fk;\\012\\012ALTER TABLE data_set_types\\012\\011ADD CONSTRAINT dsty_bk_uk UNIQUE (code, dbin_id);\\012\\012ALTER TABLE data_set_types\\012\\011ADD CONSTRAINT dsty_dbin_fk FOREIGN KEY (dbin_id) REFERENCES database_instances(id);\\012\\012DROP INDEX data_obty_fk_i;\\012\\012CREATE INDEX data_dsty_fk_i ON data(dsty_id);\\012	\N
+./sourceTest/sql/postgresql/047/.svn/text-base/017=database_version_logs.tsv.svn-base:030	source/sql/postgresql/migration/migration-029-030.sql	SUCCESS	2009-03-23 15:34:44.72	-- -------\\012-- add modification_timestamp field to allow edition with Hibernate\\012-- -------\\012ALTER TABLE data\\012\\011ADD COLUMN modification_timestamp TIME_STAMP DEFAULT CURRENT_TIMESTAMP;\\012ALTER TABLE experiment_types\\012\\011ADD COLUMN modification_timestamp TIME_STAMP DEFAULT CURRENT_TIMESTAMP;\\012ALTER TABLE sample_types\\012\\011ADD COLUMN modification_timestamp TIME_STAMP DEFAULT CURRENT_TIMESTAMP;\\012ALTER TABLE material_types\\012\\011ADD COLUMN modification_timestamp TIME_STAMP DEFAULT CURRENT_TIMESTAMP;\\012ALTER TABLE data_set_types\\012\\011ADD COLUMN modification_timestamp TIME_STAMP DEFAULT CURRENT_TIMESTAMP;\\012ALTER TABLE controlled_vocabularies\\012\\011ADD COLUMN modification_timestamp TIME_STAMP DEFAULT CURRENT_TIMESTAMP;\\012-- -------\\012-- add properties to data sets\\012-- -------\\012CREATE TABLE DATA_SET_PROPERTIES (ID TECH_ID NOT NULL,DS_ID TECH_ID NOT NULL,DSTPT_ID TECH_ID NOT NULL,VALUE GENERIC_VALUE,CVTE_ID TECH_ID, MATE_PROP_ID TECH_ID, PERS_ID_REGISTERER TECH_ID NOT NULL,REGISTRATION_TIMESTAMP TIME_STAMP_DFL NOT NULL DEFAULT CURRENT_TIMESTAMP, MODIFICATION_TIMESTAMP TIME_STAMP DEFAULT CURRENT_TIMESTAMP);\\012CREATE TABLE DATA_SET_TYPE_PROPERTY_TYPES (ID TECH_ID NOT NULL,DSTY_ID TECH_ID NOT NULL,PRTY_ID TECH_ID NOT NULL,IS_MANDATORY BOOLEAN_CHAR NOT NULL DEFAULT 'F',IS_MANAGED_INTERNALLY BOOLEAN_CHAR NOT NULL DEFAULT 'F',PERS_ID_REGISTERER TECH_ID NOT NULL,REGISTRATION_TIMESTAMP TIME_STAMP_DFL NOT NULL DEFAULT CURRENT_TIMESTAMP);\\012\\012CREATE SEQUENCE DATA_SET_PROPERTY_ID_SEQ;\\012CREATE SEQUENCE DSTPT_ID_SEQ;\\012\\012ALTER TABLE DATA_SET_TYPE_PROPERTY_TYPES ADD CONSTRAINT DSTPT_PK PRIMARY KEY(ID);\\012ALTER TABLE DATA_SET_PROPERTIES ADD CONSTRAINT DSPR_PK PRIMARY KEY(ID);\\012\\012ALTER TABLE DATA_SET_TYPE_PROPERTY_TYPES ADD CONSTRAINT DSTPT_BK_UK UNIQUE(DSTY_ID,PRTY_ID);\\012ALTER TABLE DATA_SET_PROPERTIES ADD CONSTRAINT DSPR_BK_UK UNIQUE(DS_ID,DSTPT_ID);\\012\\012\\012ALTER TABLE DATA_SET_TYPE_PROPERTY_TYPES ADD CONSTRAINT DSTPT_DSTY_FK FOREIGN KEY (DSTY_ID) REFERENCES DATA_SET_TYPES(ID);\\012ALTER TABLE DATA_SET_TYPE_PROPERTY_TYPES ADD CONSTRAINT DSTPT_PERS_FK FOREIGN KEY (PERS_ID_REGISTERER) REFERENCES PERSONS(ID);\\012ALTER TABLE DATA_SET_TYPE_PROPERTY_TYPES ADD CONSTRAINT DSTPT_PRTY_FK FOREIGN KEY (PRTY_ID) REFERENCES PROPERTY_TYPES(ID);\\012ALTER TABLE DATA_SET_PROPERTIES ADD CONSTRAINT DSPR_CVTE_FK FOREIGN KEY (CVTE_ID) REFERENCES CONTROLLED_VOCABULARY_TERMS(ID);\\012ALTER TABLE DATA_SET_PROPERTIES ADD CONSTRAINT DSPR_DSTPT_FK FOREIGN KEY (DSTPT_ID) REFERENCES DATA_SET_TYPE_PROPERTY_TYPES(ID) ON DELETE CASCADE;\\012ALTER TABLE DATA_SET_PROPERTIES ADD CONSTRAINT DSPR_DS_FK FOREIGN KEY (DS_ID) REFERENCES DATA(ID);\\012ALTER TABLE DATA_SET_PROPERTIES ADD CONSTRAINT DSPR_PERS_FK FOREIGN KEY (PERS_ID_REGISTERER) REFERENCES PERSONS(ID);\\012ALTER TABLE DATA_SET_PROPERTIES ADD CONSTRAINT DSPR_MAPR_FK FOREIGN KEY (MATE_PROP_ID) REFERENCES MATERIALS(ID);\\012\\012ALTER TABLE DATA_SET_PROPERTIES ADD CONSTRAINT DSPR_CK CHECK \\012\\011((VALUE IS NOT NULL AND CVTE_ID IS NULL AND MATE_PROP_ID IS NULL) OR \\012\\011 (VALUE IS NULL AND CVTE_ID IS NOT NULL AND MATE_PROP_ID IS NULL) OR\\012\\011 (VALUE IS NULL AND CVTE_ID IS NULL AND MATE_PROP_ID IS NOT NULL)\\012\\011);\\012\\012CREATE INDEX DSPR_CVTE_FK_I ON DATA_SET_PROPERTIES (CVTE_ID);\\012CREATE INDEX DSPR_DSTPT_FK_I ON DATA_SET_PROPERTIES (DSTPT_ID);\\012CREATE INDEX DSPR_DS_FK_I ON DATA_SET_PROPERTIES (DS_ID);\\012CREATE INDEX DSPR_PERS_FK_I ON DATA_SET_PROPERTIES (PERS_ID_REGISTERER);\\012CREATE INDEX DSTPT_DSTY_FK_I ON DATA_SET_TYPE_PROPERTY_TYPES (DSTY_ID);\\012CREATE INDEX DSTPT_PERS_FK_I ON DATA_SET_TYPE_PROPERTY_TYPES (PERS_ID_REGISTERER);\\012CREATE INDEX DSTPT_PRTY_FK_I ON DATA_SET_TYPE_PROPERTY_TYPES (PRTY_ID);\\012\\012CREATE OR REPLACE FUNCTION DATA_SET_PROPERTY_WITH_MATERIAL_DATA_TYPE_CHECK() RETURNS trigger AS $$\\012DECLARE\\012   v_type_id  CODE;\\012   v_type_id_prop  CODE;\\012BEGIN\\012   if NEW.mate_prop_id IS NOT NULL then\\012\\011\\011\\011-- find material type id of the property type \\012\\011\\011\\011select pt.maty_prop_id into v_type_id_prop \\012\\011\\011\\011  from data_set_type_property_types dstpt, property_types pt \\012\\011\\011\\011 where NEW.dstpt_id = dstpt.id AND dstpt.prty_id = pt.id;\\012\\011\\011\\012\\011\\011\\011if v_type_id_prop IS NOT NULL then\\012\\011\\011\\011\\011-- find material type id of the material which consists the entity's property value\\012\\011\\011\\011\\011select entity.maty_id into v_type_id \\012\\011\\011\\011\\011  from materials entity\\012\\011\\011\\011\\011 where NEW.mate_prop_id = entity.id;\\012\\011\\011\\011\\011if v_type_id != v_type_id_prop then\\012\\011\\011\\011\\011\\011RAISE EXCEPTION 'Insert/Update of property value referencing material (id: %) failed, as referenced material type is different than expected (id %, expected id: %).', \\012\\011\\011\\011\\011\\011\\011\\011\\011\\011\\011\\011\\011 NEW.mate_prop_id, v_type_id, v_type_id_prop;\\012\\011\\011\\011\\011end if;\\012\\011\\011\\011end if;\\012   end if;\\012   RETURN NEW;\\012END;\\012$$ LANGUAGE 'plpgsql';\\012\\012CREATE TRIGGER DATA_SET_PROPERTY_WITH_MATERIAL_DATA_TYPE_CHECK BEFORE INSERT OR UPDATE ON data_set_properties\\012    FOR EACH ROW EXECUTE PROCEDURE DATA_SET_PROPERTY_WITH_MATERIAL_DATA_TYPE_CHECK();   \\012	\N
+./sourceTest/sql/postgresql/047/.svn/text-base/017=database_version_logs.tsv.svn-base:032	source/sql/postgresql/migration/migration-031-032.sql	SUCCESS	2009-04-09 09:36:36.2	-- -------\\012-- Modify MATERIAL_BATCHES\\012-- -------\\012\\012ALTER TABLE material_batches\\012    DROP COLUMN proc_id;\\012\\012-- -------\\012-- Modify SAMPLES\\012-- -------\\012\\012ALTER TABLE samples\\012    ADD COLUMN expe_id tech_id;\\012\\012ALTER TABLE samples\\012    ADD CONSTRAINT samp_expe_fk FOREIGN KEY (expe_id) REFERENCES experiments(id);\\012\\012CREATE INDEX samp_expe_fk_i ON samples USING btree (expe_id);\\012\\012-- relink samples directly to experiments\\012\\012UPDATE samples\\012SET expe_id = (SELECT e.id FROM experiments e, procedures p, sample_inputs si \\012               WHERE si.samp_id = samples.id AND si.proc_id = p.id AND p.expe_id = e.id AND e.inva_id IS NULL);\\012\\012\\012-- -------\\012-- Modify DATA\\012-- -------\\012\\012ALTER TABLE data\\012    ADD COLUMN expe_id tech_id;\\012\\012ALTER TABLE data\\012    ADD CONSTRAINT data_expe_fk FOREIGN KEY (expe_id) REFERENCES experiments(id);\\012\\012CREATE INDEX data_expe_fk_i ON data USING btree (expe_id);\\012\\012UPDATE data\\012SET expe_id = (SELECT e.id FROM experiments e, procedures p \\012               WHERE data.proc_id_produced_by = p.id AND p.expe_id = e.id);\\012\\012ALTER TABLE data\\012    ALTER COLUMN expe_id SET NOT NULL;\\012\\012ALTER TABLE data\\012    DROP COLUMN proc_id_produced_by;\\012\\012-- -------\\012-- Drop PROCEDURES, PROCEDURE_TYPES, and SAMPLE_INPUTS\\012-- -------\\012\\012DROP TABLE sample_inputs;\\012DROP TABLE procedures;\\012DROP TABLE procedure_types;\\012\\012DROP SEQUENCE procedure_id_seq;\\012DROP SEQUENCE procedure_type_id_seq;\\012\\012-- -------\\012-- Add CODE_SEQ\\012-- -------\\012\\012CREATE SEQUENCE CODE_SEQ;\\012\\012-- -------\\012-- Add new columns to DATA_STORES\\012-- -------\\012\\012ALTER TABLE data_stores\\012    ADD COLUMN remote_url character varying(250),\\012    ADD COLUMN session_token character varying(50),\\012    ADD COLUMN modification_timestamp time_stamp DEFAULT now();\\012\\012UPDATE data_stores\\012SET remote_url = '', session_token='';\\012\\012ALTER TABLE data_stores\\012    ALTER COLUMN remote_url SET NOT NULL,\\012    ALTER COLUMN session_token SET NOT NULL;\\012\\012-- -------\\012-- Drop foreign keys onto DATA_STORES\\012-- -------\\012\\012ALTER TABLE database_instances\\012    DROP COLUMN dast_id;\\012\\012ALTER TABLE groups\\012    DROP COLUMN dast_id;\\012\\012ALTER TABLE projects\\012    DROP COLUMN dast_id;\\012\\012ALTER TABLE experiments\\012    DROP COLUMN dast_id;\\012\\012-- -------\\012-- Add foreign key from DATA onto DATA_STORES\\012-- -------\\012\\012ALTER TABLE data\\012    ADD COLUMN dast_id tech_id;\\012\\012ALTER TABLE data\\012    ADD CONSTRAINT data_dast_fk FOREIGN KEY (dast_id) REFERENCES data_stores(id);\\012\\012UPDATE data\\012SET dast_id = (select id from data_stores where code = 'STANDARD');\\012\\012ALTER TABLE data\\012    ALTER COLUMN dast_id SET NOT NULL;\\012\\012\\012------------------------------------------------------------------------------------\\012--  Purpose:  Replace trigger SAMPLE_CODE_UNIQUENESS_CHECK \\012------------------------------------------------------------------------------------\\012\\012CREATE OR REPLACE FUNCTION SAMPLE_CODE_UNIQUENESS_CHECK() RETURNS trigger AS $$\\012DECLARE\\012   counter  INTEGER;\\012BEGIN\\012    LOCK TABLE samples IN EXCLUSIVE MODE;\\012    IF (NEW.samp_id_part_of is NULL) THEN\\012        IF (NEW.dbin_id is not NULL) THEN\\012            SELECT count(*) into counter FROM samples \\012                where id != NEW.id and code = NEW.code and samp_id_part_of is NULL and dbin_id = NEW.dbin_id;\\012            IF (counter > 0) THEN\\012                RAISE EXCEPTION 'Insert/Update of Sample (Code: %) failed because database instance sample with the same code already exists.', NEW.code;\\012            END IF;\\012        ELSIF (NEW.grou_id is not NULL) THEN\\012            SELECT count(*) into counter FROM samples \\012                where id != NEW.id and code = NEW.code and samp_id_part_of is NULL and grou_id = NEW.grou_id;\\012            IF (counter > 0) THEN\\012                RAISE EXCEPTION 'Insert/Update of Sample (Code: %) failed because group sample with the same code already exists.', NEW.code;\\012            END IF;\\012        END IF;\\012        ELSE\\012        IF (NEW.dbin_id is not NULL) THEN\\012            SELECT count(*) into counter FROM samples \\012                where id != NEW.id and code = NEW.code and samp_id_part_of = NEW.samp_id_part_of and dbin_id = NEW.dbin_id;\\012            IF (counter > 0) THEN\\012                RAISE EXCEPTION 'Insert/Update of Sample (Code: %) failed because database instance sample with the same code and being the part of the same parent already exists.', NEW.code;\\012            END IF;\\012        ELSIF (NEW.grou_id is not NULL) THEN\\012            SELECT count(*) into counter FROM samples \\012                where id != NEW.id and code = NEW.code and samp_id_part_of = NEW.samp_id_part_of and grou_id = NEW.grou_id;\\012            IF (counter > 0) THEN\\012                RAISE EXCEPTION 'Insert/Update of Sample (Code: %) failed because group sample with the same code and being the part of the same parent already exists.', NEW.code;\\012            END IF;\\012        END IF;\\012        END IF;   \\012   RETURN NEW;\\012END;\\012$$ LANGUAGE 'plpgsql';\\012\\012\\012\\012	\N
+./sourceTest/sql/postgresql/047/.svn/text-base/017=database_version_logs.tsv.svn-base:034	source/sql/postgresql/migration/migration-033-034.sql	SUCCESS	2009-05-26 08:32:49.935	------------------------------------------------------------------------------------\\012-- Create sequence for generating permanent identifiers starting with nextval of existing dataset sequence.\\012------------------------------------------------------------------------------------\\012CREATE FUNCTION CREATE_SEQUENCE(EXISTING_SEQUENCE VARCHAR, NEW_SEQUENCE VARCHAR) RETURNS VOID AS $$\\012DECLARE\\012  CURR_SEQ_VAL   INTEGER;\\012BEGIN\\012  SELECT INTO CURR_SEQ_VAL NEXTVAL(EXISTING_SEQUENCE);\\012  EXECUTE 'CREATE SEQUENCE ' || NEW_SEQUENCE || ' START WITH ' || CURR_SEQ_VAL;\\012  RETURN;\\012END;\\012$$ LANGUAGE 'plpgsql';\\012\\012SELECT CREATE_SEQUENCE('DATA_ID_SEQ', 'PERM_ID_SEQ');\\012DROP FUNCTION CREATE_SEQUENCE(VARCHAR, VARCHAR);\\012\\012------------------------------------------------------------------------------------\\012-- Add perm_id columns to samples and experiments.\\012------------------------------------------------------------------------------------\\012ALTER TABLE SAMPLES ADD COLUMN PERM_ID CODE;\\012ALTER TABLE EXPERIMENTS ADD COLUMN PERM_ID CODE;\\012\\012UPDATE SAMPLES SET PERM_ID = to_char(registration_timestamp,'YYYYMMDDHHSSMS') || '-' || NEXTVAL('PERM_ID_SEQ');\\012UPDATE EXPERIMENTS SET PERM_ID = to_char(registration_timestamp,'YYYYMMDDHHSSMS') || '-' || NEXTVAL('PERM_ID_SEQ');\\012ALTER TABLE SAMPLES ALTER COLUMN PERM_ID SET NOT NULL;\\012ALTER TABLE EXPERIMENTS ALTER COLUMN PERM_ID SET NOT NULL;\\012ALTER TABLE SAMPLES ADD CONSTRAINT SAMP_PI_UK UNIQUE(PERM_ID);\\012ALTER TABLE EXPERIMENTS ADD CONSTRAINT EXPE_PI_UK UNIQUE(PERM_ID);\\012\\012\\012------------------------------------------------------------------------------------\\012-- Add column is_chosen_from_list to controlled_vocabularies.\\012------------------------------------------------------------------------------------\\012ALTER TABLE controlled_vocabularies ADD COLUMN is_chosen_from_list BOOLEAN_CHAR NOT NULL DEFAULT TRUE;\\012ALTER TABLE controlled_vocabularies ADD COLUMN source_uri CHARACTER VARYING(250);\\012------------------------------------------------------------------------------------\\012-- Modify Data table - remove arc connection between Sample and Data table, use a flag instead\\012------------------------------------------------------------------------------------\\012\\012-- add new columns\\012\\012ALTER TABLE data\\012    ADD COLUMN is_derived boolean_char;\\012ALTER TABLE data\\012    ADD COLUMN samp_id tech_id;\\012\\012-- update values in new columns\\012\\012UPDATE data\\012    SET is_derived = (samp_id_derived_from IS NOT NULL); \\012UPDATE data\\012    SET samp_id = samp_id_derived_from \\012    WHERE is_derived = 'TRUE';\\012UPDATE data\\012    SET samp_id = samp_id_acquired_from \\012    WHERE is_derived = 'FALSE';\\012\\012-- add constraints and indexes to new columns\\012\\012ALTER TABLE data\\012    ALTER COLUMN is_derived SET NOT NULL;\\012ALTER TABLE data\\012    ALTER COLUMN samp_id SET NOT NULL;   \\012ALTER TABLE data\\012    ADD CONSTRAINT data_samp_fk FOREIGN KEY (samp_id) REFERENCES samples (id);\\012CREATE INDEX data_samp_fk_i ON data USING btree (samp_id);\\012\\012-- remove old columns\\012\\012ALTER TABLE data\\012    DROP COLUMN samp_id_acquired_from;\\012ALTER TABLE data\\012    DROP COLUMN samp_id_derived_from;\\012    \\012------------------------------------------------------------------------------------\\012-- Granting SELECT privilege to group openbis_readonly\\012------------------------------------------------------------------------------------\\012\\012GRANT SELECT ON SEQUENCE attachment_content_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE attachment_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE code_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE controlled_vocabulary_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE cvte_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE data_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE data_set_property_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE data_set_relationship_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE data_set_type_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE data_store_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE data_type_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE database_instance_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE dstpt_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE etpt_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE event_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE experiment_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE experiment_property_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE experiment_type_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE file_format_type_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE group_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE invalidation_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE locator_type_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE material_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE material_property_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE material_type_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE mtpt_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE perm_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE person_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE project_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE property_type_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE role_assignment_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE sample_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE sample_property_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE sample_type_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE stpt_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE attachment_contents TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE attachments TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE controlled_vocabularies TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE controlled_vocabulary_terms TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE data TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE data_set_properties TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE data_set_relationships TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE data_set_type_property_types TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE data_set_types TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE data_stores TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE data_types TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE database_instances TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE database_version_logs TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE events TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE experiment_properties TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE experiment_type_property_types TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE experiment_types TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE experiments TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE external_data TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE file_format_types TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE groups TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE invalidations TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE locator_types TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE material_properties TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE material_type_property_types TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE material_types TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE materials TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE persons TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE projects TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE property_types TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE role_assignments TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE sample_properties TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE sample_type_property_types TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE sample_types TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE samples TO GROUP OPENBIS_READONLY;\\012\\012------------------------------------------------------------------------------------\\012-- Delete MATERIAL_BATCHES table\\012------------------------------------------------------------------------------------\\012\\012-- WARNING: Potential data lost!!!\\012-- WARNING: Potential data lost!!!\\012-- WARNING: Potential data lost!!!\\012\\012DROP TABLE SAMPLE_MATERIAL_BATCHES;\\012DROP TABLE MATERIAL_BATCHES;\\012DROP SEQUENCE MATERIAL_BATCH_ID_SEQ;\\012\\012------------------------------------------------------------------------------------\\012-- Delete MATE_ID_INHIBITOR_OF from table MATERIALS\\012------------------------------------------------------------------------------------\\012\\012-- WARNING: Potential data lost!!!\\012-- WARNING: Potential data lost!!!\\012-- WARNING: Potential data lost!!!\\012\\012ALTER TABLE MATERIALS DROP COLUMN MATE_ID_INHIBITOR_OF;\\012	\N
+./sourceTest/sql/postgresql/047/.svn/text-base/017=database_version_logs.tsv.svn-base:041	source/sql/postgresql/migration/migration-040-041.sql	SUCCESS	2009-09-14 13:48:57.539	-- Create FILTERS table\\012\\012CREATE TABLE FILTERS (ID TECH_ID NOT NULL, DBIN_ID TECH_ID NOT NULL, NAME VARCHAR(200) NOT NULL, DESCRIPTION DESCRIPTION_1000,REGISTRATION_TIMESTAMP TIME_STAMP_DFL NOT NULL DEFAULT CURRENT_TIMESTAMP, PERS_ID_REGISTERER TECH_ID NOT NULL, MODIFICATION_TIMESTAMP TIME_STAMP DEFAULT CURRENT_TIMESTAMP, EXPRESSION VARCHAR(2000) NOT NULL, IS_PUBLIC BOOLEAN NOT NULL, GRID_ID VARCHAR(200) NOT NULL);\\012CREATE SEQUENCE FILTER_ID_SEQ;\\012ALTER TABLE FILTERS ADD CONSTRAINT FILT_PK PRIMARY KEY(ID);\\012ALTER TABLE FILTERS ADD CONSTRAINT FILT_BK_UK UNIQUE(NAME, DBIN_ID, GRID_ID);\\012ALTER TABLE FILTERS ADD CONSTRAINT FILT_PERS_FK FOREIGN KEY (PERS_ID_REGISTERER) REFERENCES PERSONS(ID);\\012ALTER TABLE FILTERS ADD CONSTRAINT FILT_DBIN_FK FOREIGN KEY (DBIN_ID) REFERENCES DATABASE_INSTANCES(ID);\\012CREATE INDEX FILT_PERS_FK_I ON FILTERS (PERS_ID_REGISTERER);\\012CREATE INDEX FILT_DBIN_FK_I ON FILTERS (DBIN_ID);\\012GRANT SELECT ON SEQUENCE filter_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE filters TO GROUP OPENBIS_READONLY;\\012\\012-- Add missing foreign key to role assignments authorization group\\012ALTER TABLE ROLE_ASSIGNMENTS ADD CONSTRAINT ROAS_AG_FK_GRANTEE FOREIGN KEY (AG_ID_GRANTEE) REFERENCES AUTHORIZATION_GROUPS(ID);\\012\\012--------------------------------------------------------------------------------------------------\\012-- Modify dataset connections:\\012-- 1. connection with sample shouldn't be mandatory any more\\012-- 2. introduce an arc condition that dataset cannot be connected with a sample and a parent dataset at the same time\\012--------------------------------------------------------------------------------------------------\\012\\012-- Weaken data-sample connection constraint - allow dataset to have no connection with sample\\012ALTER TABLE data ALTER COLUMN samp_id DROP NOT NULL;\\012\\012-- Remove data-sample connection for datasets that have a parent\\012\\012UPDATE data \\012   SET samp_id = NULL \\012 WHERE id IN (SELECT DISTINCT data_id_child FROM data_set_relationships);\\012\\012-- With PostgreSQL 8.4 one can check that before migration there were no cycles in dataset relationships:\\012--\\012-- WITH RECURSIVE data_set_parents(id, parent_ids, cycle) AS (\\012--         SELECT  r.data_id_child AS id, \\012--                 ARRAY[CAST (r.data_id_parent AS bigint)] AS parent_ids, \\012--                 false AS cycle \\012--         FROM data_set_relationships r\\012--     UNION ALL\\012--         SELECT  r.data_id_child,\\012--                 CAST (r.data_id_parent AS bigint) || p.parent_ids,\\012--                 r.data_id_child = ANY(p.parent_ids)\\012--         FROM data_set_relationships r, data_set_parents p\\012--         WHERE r.data_id_parent = p.id AND NOT cycle\\012-- )\\012-- SELECT count(*) AS cycles FROM data_set_parents WHERE cycle = true;\\012\\012---------------------------------------------------------------------------------------------------\\012--  Purpose:  Create DEFERRED triggers:\\012--            * check_dataset_relationships_on_data_table_modification,\\012--            * check_dataset_relationships_on_relationships_table_modification.\\012--            They check that after all modifications of database (just before commit) \\012--            if 'data'/'data_set_relationships' tables are among modified tables \\012--            dataset is not connected with a sample and a parent dataset at the same time.\\012--            This connections are held in two different tables so simple immediate trigger \\012--            with arc check cannot be used and we need two deferred triggers.\\012----------------------------------------------------------------------------------------------------\\012\\012-- trigger for 'data' table\\012\\012CREATE OR REPLACE FUNCTION check_dataset_relationships_on_data_table_modification() RETURNS trigger AS $$\\012DECLARE\\012\\011counter\\011INTEGER;\\012BEGIN\\012\\011-- if there is a connection with a Sample there should not be any connection with a parent Data Set\\012\\011IF (NEW.samp_id IS NOT NULL) THEN\\012\\011\\011-- count number of parents\\012\\011\\011SELECT count(*) INTO counter \\012\\011\\011\\011FROM data_set_relationships \\012\\011\\011\\011WHERE data_id_child = OLD.id;\\012\\011\\011IF (counter > 0) THEN\\012\\011\\011\\011RAISE EXCEPTION 'Insert/Update of Data Set (Code: %) failed because it cannot be connected with a Sample and a parent Data Set at the same time.', OLD.code;\\012\\011\\011END IF;\\012\\011END IF;\\012  RETURN NEW;\\012END;\\012$$ LANGUAGE 'plpgsql';\\012\\012CREATE CONSTRAINT TRIGGER check_dataset_relationships_on_data_table_modification \\012  AFTER INSERT OR UPDATE ON data\\012\\011DEFERRABLE INITIALLY DEFERRED\\012\\011FOR EACH ROW \\012\\011EXECUTE PROCEDURE check_dataset_relationships_on_data_table_modification();\\012\\012-- trigger for 'data_set_relationships'\\012\\012CREATE OR REPLACE FUNCTION check_dataset_relationships_on_relationships_table_modification() RETURNS trigger AS $$\\012DECLARE\\012\\011counter\\011INTEGER;\\012\\011sample_id\\011TECH_ID;\\012\\011data_code\\011CODE;\\012BEGIN\\012\\011-- child will have a parent added so it should not be connected with any sample\\012\\011SELECT samp_id, code INTO sample_id, data_code \\012\\011\\011FROM data \\012\\011\\011WHERE id = NEW.data_id_child;\\012\\011IF (sample_id IS NOT NULL) THEN\\012\\011\\011RAISE EXCEPTION 'Insert/Update of Data Set (Code: %) failed because it cannot be connected to a Sample and to a parent Data Set at the same time.', data_code;\\012\\011END IF;\\012\\011RETURN NEW;\\012END;\\012$$ LANGUAGE 'plpgsql';\\012  \\012CREATE CONSTRAINT TRIGGER check_dataset_relationships_on_relationships_table_modification \\012  AFTER INSERT OR UPDATE ON data_set_relationships\\012\\011DEFERRABLE INITIALLY DEFERRED\\012\\011FOR EACH ROW \\012\\011EXECUTE PROCEDURE check_dataset_relationships_on_relationships_table_modification();\\012	\N
+./sourceTest/sql/postgresql/047/.svn/text-base/schema-047.sql.svn-base:    LANGUAGE plpgsql
+./sourceTest/sql/postgresql/047/.svn/text-base/schema-047.sql.svn-base:    LANGUAGE plpgsql
+./sourceTest/sql/postgresql/047/.svn/text-base/schema-047.sql.svn-base:    LANGUAGE plpgsql
+./sourceTest/sql/postgresql/047/.svn/text-base/schema-047.sql.svn-base:    LANGUAGE plpgsql
+./sourceTest/sql/postgresql/047/.svn/text-base/schema-047.sql.svn-base:    LANGUAGE plpgsql
+./sourceTest/sql/postgresql/047/.svn/text-base/schema-047.sql.svn-base:    LANGUAGE plpgsql
+./sourceTest/sql/postgresql/047/.svn/text-base/schema-047.sql.svn-base:    LANGUAGE plpgsql
+./sourceTest/sql/postgresql/047/.svn/text-base/schema-047.sql.svn-base:    LANGUAGE plpgsql
+./sourceTest/sql/postgresql/047/.svn/text-base/schema-047.sql.svn-base:    LANGUAGE plpgsql
+./sourceTest/sql/postgresql/047/.svn/text-base/schema-047.sql.svn-base:    LANGUAGE plpgsql
+./sourceTest/sql/postgresql/047/017=database_version_logs.tsv:027	D:\\User\\felmer\\dev-workspace\\openbis/source/sql/postgresql/027/function-027.sql	SUCCESS	2008-11-05 09:18:00.403	-- Creating Functions\\012\\012------------------------------------------------------------------------------------\\012--  Purpose:  Create function RENAME_SEQUENCE() that is required for renaming the sequences belonging to tables\\012------------------------------------------------------------------------------------\\012CREATE FUNCTION RENAME_SEQUENCE(OLD_NAME VARCHAR, NEW_NAME VARCHAR) RETURNS INTEGER AS $$\\012DECLARE\\012  CURR_SEQ_VAL   INTEGER;\\012BEGIN\\012  SELECT INTO CURR_SEQ_VAL NEXTVAL(OLD_NAME);\\012  EXECUTE 'CREATE SEQUENCE ' || NEW_NAME || ' START WITH ' || CURR_SEQ_VAL;\\012  EXECUTE 'DROP SEQUENCE ' || OLD_NAME;\\012  RETURN CURR_SEQ_VAL;\\012END;\\012$$ LANGUAGE 'plpgsql';\\012\\012\\012------------------------------------------------------------------------------------\\012--  Purpose:  Create trigger CONTROLLED_VOCABULARY_CHECK \\012------------------------------------------------------------------------------------\\012\\012CREATE OR REPLACE FUNCTION CONTROLLED_VOCABULARY_CHECK() RETURNS trigger AS $$\\012DECLARE\\012   v_code  CODE;\\012BEGIN\\012\\012   select code into v_code from data_types where id = NEW.daty_id;\\012\\012   -- Check if the data is of type "CONTROLLEDVOCABULARY"\\012   if v_code = 'CONTROLLEDVOCABULARY' then\\012      if NEW.covo_id IS NULL then\\012         RAISE EXCEPTION 'Insert/Update of Property Type (Code: %) failed, as its Data Type is CONTROLLEDVOCABULARY, but it is not linked to a Controlled Vocabulary.', NEW.code;\\012      end if;\\012   end if;\\012\\012   RETURN NEW;\\012\\012END;\\012$$ LANGUAGE 'plpgsql';\\012\\012CREATE TRIGGER CONTROLLED_VOCABULARY_CHECK BEFORE INSERT OR UPDATE ON PROPERTY_TYPES\\012    FOR EACH ROW EXECUTE PROCEDURE CONTROLLED_VOCABULARY_CHECK();\\012\\012\\012------------------------------------------------------------------------------------\\012--  Purpose:  Create trigger EXTERNAL_DATA_STORAGE_FORMAT_CHECK \\012------------------------------------------------------------------------------------\\012\\012CREATE OR REPLACE FUNCTION EXTERNAL_DATA_STORAGE_FORMAT_CHECK() RETURNS trigger AS $$\\012DECLARE\\012   v_covo_code  CODE;\\012   data_code CODE;\\012BEGIN\\012\\012   select code into v_covo_code from controlled_vocabularies\\012      where is_internal_namespace = true and \\012         id = (select covo_id from controlled_vocabulary_terms where id = NEW.cvte_id_stor_fmt);\\012   -- Check if the data storage format is a term of the controlled vocabulary "STORAGE_FORMAT"\\012   if v_covo_code != 'STORAGE_FORMAT' then\\012      select code into data_code from data where id = NEW.data_id; \\012      RAISE EXCEPTION 'Insert/Update of Data (Code: %) failed, as its Storage Format is %, but is required to be STORAGE_FORMAT.', data_code, v_covo_code;\\012   end if;\\012\\012   RETURN NEW;\\012\\012END;\\012$$ LANGUAGE 'plpgsql';\\012\\012CREATE TRIGGER EXTERNAL_DATA_STORAGE_FORMAT_CHECK BEFORE INSERT OR UPDATE ON EXTERNAL_DATA\\012    FOR EACH ROW EXECUTE PROCEDURE EXTERNAL_DATA_STORAGE_FORMAT_CHECK();\\012\\012------------------------------------------------------------------------------------\\012--  Purpose:  Create trigger SAMPLE_CODE_UNIQUENESS_CHECK \\012------------------------------------------------------------------------------------\\012\\012CREATE OR REPLACE FUNCTION SAMPLE_CODE_UNIQUENESS_CHECK() RETURNS trigger AS $$\\012DECLARE\\012   counter  INTEGER;\\012BEGIN\\012\\011IF (NEW.samp_id_part_of is NULL) THEN\\012\\011\\011IF (NEW.dbin_id is not NULL) THEN\\012\\011\\011\\011SELECT count(*) into counter FROM samples \\012\\011\\011\\011\\011where id != NEW.id and code = NEW.code and samp_id_part_of is NULL and dbin_id = NEW.dbin_id;\\012\\011\\011\\011IF (counter > 0) THEN\\012\\011\\011\\011\\011RAISE EXCEPTION 'Insert/Update of Sample (Code: %) failed because database instance sample with the same code already exists.', NEW.code;\\012\\011\\011\\011END IF;\\012\\011\\011ELSIF (NEW.grou_id is not NULL) THEN\\012\\011\\011\\011SELECT count(*) into counter FROM samples \\012\\011\\011\\011\\011where id != NEW.id and code = NEW.code and samp_id_part_of is NULL and grou_id = NEW.grou_id;\\012\\011\\011\\011IF (counter > 0) THEN\\012\\011\\011\\011\\011RAISE EXCEPTION 'Insert/Update of Sample (Code: %) failed because group sample with the same code already exists.', NEW.code;\\012\\011\\011\\011END IF;\\012\\011\\011END IF;\\012        ELSE\\012\\011\\011IF (NEW.dbin_id is not NULL) THEN\\012\\011\\011\\011SELECT count(*) into counter FROM samples \\012\\011\\011\\011\\011where id != NEW.id and code = NEW.code and samp_id_part_of = NEW.samp_id_part_of and dbin_id = NEW.dbin_id;\\012\\011\\011\\011IF (counter > 0) THEN\\012\\011\\011\\011\\011RAISE EXCEPTION 'Insert/Update of Sample (Code: %) failed because database instance sample with the same code and being the part of the same parent already exists.', NEW.code;\\012\\011\\011\\011END IF;\\012\\011\\011ELSIF (NEW.grou_id is not NULL) THEN\\012\\011\\011\\011SELECT count(*) into counter FROM samples \\012\\011\\011\\011\\011where id != NEW.id and code = NEW.code and samp_id_part_of = NEW.samp_id_part_of and grou_id = NEW.grou_id;\\012\\011\\011\\011IF (counter > 0) THEN\\012\\011\\011\\011\\011RAISE EXCEPTION 'Insert/Update of Sample (Code: %) failed because group sample with the same code and being the part of the same parent already exists.', NEW.code;\\012\\011\\011\\011END IF;\\012\\011\\011END IF;\\012        END IF;   \\012   RETURN NEW;\\012END;\\012$$ LANGUAGE 'plpgsql';\\012\\012CREATE TRIGGER SAMPLE_CODE_UNIQUENESS_CHECK BEFORE INSERT OR UPDATE ON SAMPLES\\012    FOR EACH ROW EXECUTE PROCEDURE SAMPLE_CODE_UNIQUENESS_CHECK();\\012	\N
+./sourceTest/sql/postgresql/047/017=database_version_logs.tsv:028	source/sql/postgresql/migration/migration-027-028.sql	SUCCESS	2008-11-18 13:24:17.508	-- Create EXPERIMENT_ATTACHMENT_CONTENTS.\\012CREATE TABLE EXPERIMENT_ATTACHMENT_CONTENTS (ID TECH_ID NOT NULL,VALUE FILE NOT NULL);\\012CREATE SEQUENCE EXPERIMENT_ATTACHMENT_CONTENT_ID_SEQ;\\012ALTER TABLE EXPERIMENT_ATTACHMENT_CONTENTS ADD CONSTRAINT EXAC_PK PRIMARY KEY(ID);\\012\\012-- Alter EXPERIMENT_ATTACHMENTS by adding the new column which has a NULL constraint.\\012-- The NOT NULL constraint is added later on.\\012ALTER TABLE EXPERIMENT_ATTACHMENTS ADD COLUMN EXAC_ID TECH_ID;\\012\\012-- Does the VALUE migration between EXPERIMENT_ATTACHMENTS to EXPERIMENT_ATTACHMENT_CONTENTS.\\012CREATE OR REPLACE FUNCTION move_exp_att_content() RETURNS integer AS $$\\012DECLARE\\012    rec RECORD;\\012    seq BIGINT;\\012BEGIN\\012  FOR rec IN SELECT id, value FROM EXPERIMENT_ATTACHMENTS LOOP\\012  \\011seq := nextval('EXPERIMENT_ATTACHMENT_CONTENT_ID_SEQ');\\012    INSERT INTO EXPERIMENT_ATTACHMENT_CONTENTS (id, value) VALUES (seq, rec.value);\\012    UPDATE EXPERIMENT_ATTACHMENTS SET exac_id = seq WHERE id = rec.id;\\012  END LOOP;\\012  RETURN 1;\\012END;\\012$$ LANGUAGE 'plpgsql';\\012\\012-- Call the function.\\012SELECT move_exp_att_content();\\012DROP FUNCTION move_exp_att_content();\\012\\012\\012-- Finish EXPERIMENT_ATTACHMENTS changes.\\012ALTER TABLE EXPERIMENT_ATTACHMENTS ADD CONSTRAINT EXAT_CONT_FK FOREIGN KEY (EXAC_ID) REFERENCES EXPERIMENT_ATTACHMENT_CONTENTS(ID);\\012ALTER TABLE EXPERIMENT_ATTACHMENTS DROP COLUMN VALUE;\\012ALTER TABLE EXPERIMENT_ATTACHMENTS ALTER COLUMN EXAC_ID SET NOT NULL;\\012	\N
+./sourceTest/sql/postgresql/047/017=database_version_logs.tsv:029	source/sql/postgresql/migration/migration-028-029.sql	SUCCESS	2009-03-18 10:50:20.105	-- -------\\012-- add modification_timestamp field to allow edition with Hibernate\\012-- -------\\012\\012ALTER TABLE samples\\012\\011ADD COLUMN modification_timestamp TIME_STAMP DEFAULT CURRENT_TIMESTAMP;\\012\\012ALTER TABLE experiments\\012\\011ADD COLUMN modification_timestamp TIME_STAMP DEFAULT CURRENT_TIMESTAMP;\\012\\012ALTER TABLE materials\\012\\011ADD COLUMN modification_timestamp TIME_STAMP DEFAULT CURRENT_TIMESTAMP;\\012\\012ALTER TABLE experiment_properties\\012\\011ADD COLUMN modification_timestamp TIME_STAMP DEFAULT CURRENT_TIMESTAMP;\\012\\012ALTER TABLE material_properties\\012\\011ADD COLUMN modification_timestamp TIME_STAMP DEFAULT CURRENT_TIMESTAMP;\\012\\012ALTER TABLE sample_properties\\012\\011ADD COLUMN modification_timestamp TIME_STAMP DEFAULT CURRENT_TIMESTAMP;\\012\\012-- -------\\012-- add property data type which references materials\\012-- -------\\012\\012ALTER TABLE property_types\\012\\011ADD COLUMN maty_prop_id tech_id;\\012\\012ALTER TABLE property_types\\012\\011ADD CONSTRAINT prty_maty_fk FOREIGN KEY (maty_prop_id) REFERENCES material_types(id);\\012\\012ALTER TABLE experiment_properties\\012\\011ADD COLUMN mate_prop_id tech_id;\\012\\012ALTER TABLE material_properties\\012\\011ADD COLUMN mate_prop_id tech_id;\\012\\012ALTER TABLE sample_properties\\012\\011ADD COLUMN mate_prop_id tech_id;\\012\\012ALTER TABLE experiment_properties\\012\\011ADD CONSTRAINT expr_mapr_fk FOREIGN KEY (mate_prop_id) REFERENCES materials(id);\\012\\012ALTER TABLE material_properties\\012\\011ADD CONSTRAINT mapr_mapr_fk FOREIGN KEY (mate_prop_id) REFERENCES materials(id);\\012\\012ALTER TABLE sample_properties\\012\\011ADD CONSTRAINT sapr_mapr_fk FOREIGN KEY (mate_prop_id) REFERENCES materials(id);\\012\\012insert into data_types\\012(id\\012 ,code\\012 ,description)\\012 values \\012 (nextval('DATA_TYPE_ID_SEQ')\\012 ,'MATERIAL'\\012 ,'Reference to a material'\\012);\\012\\012ALTER TABLE MATERIAL_PROPERTIES DROP CONSTRAINT MAPR_CK;\\012ALTER TABLE MATERIAL_PROPERTIES ADD CONSTRAINT MAPR_CK CHECK \\012\\011((VALUE IS NOT NULL AND CVTE_ID IS NULL AND MATE_PROP_ID IS NULL) OR \\012\\011 (VALUE IS NULL AND CVTE_ID IS NOT NULL AND MATE_PROP_ID IS NULL) OR\\012\\011 (VALUE IS NULL AND CVTE_ID IS NULL AND MATE_PROP_ID IS NOT NULL)\\012\\011);\\012\\012ALTER TABLE EXPERIMENT_PROPERTIES DROP CONSTRAINT EXPR_CK;\\012ALTER TABLE EXPERIMENT_PROPERTIES ADD CONSTRAINT EXPR_CK CHECK \\012\\011((VALUE IS NOT NULL AND CVTE_ID IS NULL AND MATE_PROP_ID IS NULL) OR \\012\\011 (VALUE IS NULL AND CVTE_ID IS NOT NULL AND MATE_PROP_ID IS NULL) OR\\012\\011 (VALUE IS NULL AND CVTE_ID IS NULL AND MATE_PROP_ID IS NOT NULL)\\012\\011);\\012\\012ALTER TABLE SAMPLE_PROPERTIES DROP CONSTRAINT SAPR_CK;\\012ALTER TABLE SAMPLE_PROPERTIES ADD CONSTRAINT SAPR_CK CHECK \\012\\011((VALUE IS NOT NULL AND CVTE_ID IS NULL AND MATE_PROP_ID IS NULL) OR \\012\\011 (VALUE IS NULL AND CVTE_ID IS NOT NULL AND MATE_PROP_ID IS NULL) OR\\012\\011 (VALUE IS NULL AND CVTE_ID IS NULL AND MATE_PROP_ID IS NOT NULL)\\012\\011);\\012\\012------------------------------------------------------------------------------------\\012--  Purpose:  Create trigger MATERIAL/SAMPLE/EXPERIMENT _PROPERTY_WITH_MATERIAL_DATA_TYPE_CHECK\\012--            It checks that if material property value is assigned to the entity,\\012--\\011\\011\\011\\011\\011\\011then the material type is equal to the one described by property type.\\012------------------------------------------------------------------------------------\\012\\012CREATE OR REPLACE FUNCTION MATERIAL_PROPERTY_WITH_MATERIAL_DATA_TYPE_CHECK() RETURNS trigger AS $$\\012DECLARE\\012   v_type_id  CODE;\\012   v_type_id_prop  CODE;\\012BEGIN\\012   if NEW.mate_prop_id IS NOT NULL then\\012\\011\\011\\011-- find material type id of the property type \\012\\011\\011\\011select pt.maty_prop_id into v_type_id_prop \\012\\011\\011\\011  from material_type_property_types etpt, property_types pt \\012\\011\\011\\011 where NEW.mtpt_id = etpt.id AND etpt.prty_id = pt.id;\\012\\011\\011\\012\\011\\011\\011if v_type_id_prop IS NOT NULL then\\012\\011\\011\\011\\011-- find material type id of the material which consists the entity's property value\\012\\011\\011\\011\\011select entity.maty_id into v_type_id \\012\\011\\011\\011\\011  from materials entity\\012\\011\\011\\011\\011 where NEW.mate_prop_id = entity.id;\\012\\011\\011\\011\\011if v_type_id != v_type_id_prop then\\012\\011\\011\\011\\011\\011RAISE EXCEPTION 'Insert/Update of property value referencing material (id: %) failed, as referenced material type is different than expected (id %, expected id: %).', \\012\\011\\011\\011\\011\\011\\011\\011 NEW.mate_prop_id, v_type_id, v_type_id_prop;\\012\\011\\011\\011\\011end if;\\012\\011\\011\\011end if;\\012   end if;\\012   RETURN NEW;\\012END;\\012$$ LANGUAGE 'plpgsql';\\012\\012CREATE TRIGGER MATERIAL_PROPERTY_WITH_MATERIAL_DATA_TYPE_CHECK BEFORE INSERT OR UPDATE ON material_properties\\012    FOR EACH ROW EXECUTE PROCEDURE MATERIAL_PROPERTY_WITH_MATERIAL_DATA_TYPE_CHECK();\\012    \\012CREATE OR REPLACE FUNCTION SAMPLE_PROPERTY_WITH_MATERIAL_DATA_TYPE_CHECK() RETURNS trigger AS $$\\012DECLARE\\012   v_type_id  CODE;\\012   v_type_id_prop  CODE;\\012BEGIN\\012   if NEW.mate_prop_id IS NOT NULL then\\012\\011\\011\\011-- find material type id of the property type \\012\\011\\011\\011select pt.maty_prop_id into v_type_id_prop \\012\\011\\011\\011  from sample_type_property_types etpt, property_types pt \\012\\011\\011\\011 where NEW.stpt_id = etpt.id AND etpt.prty_id = pt.id;\\012\\011\\011\\012\\011\\011\\011if v_type_id_prop IS NOT NULL then\\012\\011\\011\\011\\011-- find material type id of the material which consists the entity's property value\\012\\011\\011\\011\\011select entity.maty_id into v_type_id \\012\\011\\011\\011\\011  from materials entity\\012\\011\\011\\011\\011 where NEW.mate_prop_id = entity.id;\\012\\011\\011\\011\\011if v_type_id != v_type_id_prop then\\012\\011\\011\\011\\011\\011RAISE EXCEPTION 'Insert/Update of property value referencing material (id: %) failed, as referenced material type is different than expected (id %, expected id: %).', \\012\\011\\011\\011\\011\\011\\011\\011\\011\\011\\011\\011\\011 NEW.mate_prop_id, v_type_id, v_type_id_prop;\\012\\011\\011\\011\\011end if;\\012\\011\\011\\011end if;\\012   end if;\\012   RETURN NEW;\\012END;\\012$$ LANGUAGE 'plpgsql';\\012\\012CREATE TRIGGER SAMPLE_PROPERTY_WITH_MATERIAL_DATA_TYPE_CHECK BEFORE INSERT OR UPDATE ON sample_properties\\012    FOR EACH ROW EXECUTE PROCEDURE SAMPLE_PROPERTY_WITH_MATERIAL_DATA_TYPE_CHECK();\\012    \\012CREATE OR REPLACE FUNCTION EXPERIMENT_PROPERTY_WITH_MATERIAL_DATA_TYPE_CHECK() RETURNS trigger AS $$\\012DECLARE\\012   v_type_id  CODE;\\012   v_type_id_prop  CODE;\\012BEGIN\\012   if NEW.mate_prop_id IS NOT NULL then\\012\\011\\011\\011-- find material type id of the property type \\012\\011\\011\\011select pt.maty_prop_id into v_type_id_prop \\012\\011\\011\\011  from experiment_type_property_types etpt, property_types pt \\012\\011\\011\\011 where NEW.etpt_id = etpt.id AND etpt.prty_id = pt.id;\\012\\011\\011\\012\\011\\011\\011if v_type_id_prop IS NOT NULL then\\012\\011\\011\\011\\011-- find material type id of the material which consists the entity's property value\\012\\011\\011\\011\\011select entity.maty_id into v_type_id \\012\\011\\011\\011\\011  from materials entity\\012\\011\\011\\011\\011 where NEW.mate_prop_id = entity.id;\\012\\011\\011\\011\\011if v_type_id != v_type_id_prop then\\012\\011\\011\\011\\011\\011RAISE EXCEPTION 'Insert/Update of property value referencing material (id: %) failed, as referenced material type is different than expected (id %, expected id: %).', \\012\\011\\011\\011\\011\\011\\011\\011\\011\\011\\011\\011\\011 NEW.mate_prop_id, v_type_id, v_type_id_prop;\\012\\011\\011\\011\\011end if;\\012\\011\\011\\011end if;\\012   end if;\\012   RETURN NEW;\\012END;\\012$$ LANGUAGE 'plpgsql';\\012\\012CREATE TRIGGER EXPERIMENT_PROPERTY_WITH_MATERIAL_DATA_TYPE_CHECK BEFORE INSERT OR UPDATE ON experiment_properties\\012    FOR EACH ROW EXECUTE PROCEDURE EXPERIMENT_PROPERTY_WITH_MATERIAL_DATA_TYPE_CHECK();\\012       \\012-- -------\\012-- remove the reminescents of the OBSERVABLE_TYPE\\012-- -------\\012\\012ALTER TABLE data\\012\\011DROP CONSTRAINT data_obty_fk;\\012\\012ALTER TABLE data_set_types\\012\\011DROP CONSTRAINT obty_pk;\\012\\012ALTER TABLE data_set_types\\012\\011ADD CONSTRAINT dsty_pk PRIMARY KEY (id);\\012\\012ALTER TABLE data\\012\\011ADD CONSTRAINT data_dsty_fk FOREIGN KEY (dsty_id) REFERENCES data_set_types(id);\\012\\012ALTER TABLE data_set_types\\012\\011DROP CONSTRAINT obty_bk_uk;\\012\\012ALTER TABLE data_set_types\\012\\011DROP CONSTRAINT obty_dbin_fk;\\012\\012ALTER TABLE data_set_types\\012\\011ADD CONSTRAINT dsty_bk_uk UNIQUE (code, dbin_id);\\012\\012ALTER TABLE data_set_types\\012\\011ADD CONSTRAINT dsty_dbin_fk FOREIGN KEY (dbin_id) REFERENCES database_instances(id);\\012\\012DROP INDEX data_obty_fk_i;\\012\\012CREATE INDEX data_dsty_fk_i ON data(dsty_id);\\012	\N
+./sourceTest/sql/postgresql/047/017=database_version_logs.tsv:030	source/sql/postgresql/migration/migration-029-030.sql	SUCCESS	2009-03-23 15:34:44.72	-- -------\\012-- add modification_timestamp field to allow edition with Hibernate\\012-- -------\\012ALTER TABLE data\\012\\011ADD COLUMN modification_timestamp TIME_STAMP DEFAULT CURRENT_TIMESTAMP;\\012ALTER TABLE experiment_types\\012\\011ADD COLUMN modification_timestamp TIME_STAMP DEFAULT CURRENT_TIMESTAMP;\\012ALTER TABLE sample_types\\012\\011ADD COLUMN modification_timestamp TIME_STAMP DEFAULT CURRENT_TIMESTAMP;\\012ALTER TABLE material_types\\012\\011ADD COLUMN modification_timestamp TIME_STAMP DEFAULT CURRENT_TIMESTAMP;\\012ALTER TABLE data_set_types\\012\\011ADD COLUMN modification_timestamp TIME_STAMP DEFAULT CURRENT_TIMESTAMP;\\012ALTER TABLE controlled_vocabularies\\012\\011ADD COLUMN modification_timestamp TIME_STAMP DEFAULT CURRENT_TIMESTAMP;\\012-- -------\\012-- add properties to data sets\\012-- -------\\012CREATE TABLE DATA_SET_PROPERTIES (ID TECH_ID NOT NULL,DS_ID TECH_ID NOT NULL,DSTPT_ID TECH_ID NOT NULL,VALUE GENERIC_VALUE,CVTE_ID TECH_ID, MATE_PROP_ID TECH_ID, PERS_ID_REGISTERER TECH_ID NOT NULL,REGISTRATION_TIMESTAMP TIME_STAMP_DFL NOT NULL DEFAULT CURRENT_TIMESTAMP, MODIFICATION_TIMESTAMP TIME_STAMP DEFAULT CURRENT_TIMESTAMP);\\012CREATE TABLE DATA_SET_TYPE_PROPERTY_TYPES (ID TECH_ID NOT NULL,DSTY_ID TECH_ID NOT NULL,PRTY_ID TECH_ID NOT NULL,IS_MANDATORY BOOLEAN_CHAR NOT NULL DEFAULT 'F',IS_MANAGED_INTERNALLY BOOLEAN_CHAR NOT NULL DEFAULT 'F',PERS_ID_REGISTERER TECH_ID NOT NULL,REGISTRATION_TIMESTAMP TIME_STAMP_DFL NOT NULL DEFAULT CURRENT_TIMESTAMP);\\012\\012CREATE SEQUENCE DATA_SET_PROPERTY_ID_SEQ;\\012CREATE SEQUENCE DSTPT_ID_SEQ;\\012\\012ALTER TABLE DATA_SET_TYPE_PROPERTY_TYPES ADD CONSTRAINT DSTPT_PK PRIMARY KEY(ID);\\012ALTER TABLE DATA_SET_PROPERTIES ADD CONSTRAINT DSPR_PK PRIMARY KEY(ID);\\012\\012ALTER TABLE DATA_SET_TYPE_PROPERTY_TYPES ADD CONSTRAINT DSTPT_BK_UK UNIQUE(DSTY_ID,PRTY_ID);\\012ALTER TABLE DATA_SET_PROPERTIES ADD CONSTRAINT DSPR_BK_UK UNIQUE(DS_ID,DSTPT_ID);\\012\\012\\012ALTER TABLE DATA_SET_TYPE_PROPERTY_TYPES ADD CONSTRAINT DSTPT_DSTY_FK FOREIGN KEY (DSTY_ID) REFERENCES DATA_SET_TYPES(ID);\\012ALTER TABLE DATA_SET_TYPE_PROPERTY_TYPES ADD CONSTRAINT DSTPT_PERS_FK FOREIGN KEY (PERS_ID_REGISTERER) REFERENCES PERSONS(ID);\\012ALTER TABLE DATA_SET_TYPE_PROPERTY_TYPES ADD CONSTRAINT DSTPT_PRTY_FK FOREIGN KEY (PRTY_ID) REFERENCES PROPERTY_TYPES(ID);\\012ALTER TABLE DATA_SET_PROPERTIES ADD CONSTRAINT DSPR_CVTE_FK FOREIGN KEY (CVTE_ID) REFERENCES CONTROLLED_VOCABULARY_TERMS(ID);\\012ALTER TABLE DATA_SET_PROPERTIES ADD CONSTRAINT DSPR_DSTPT_FK FOREIGN KEY (DSTPT_ID) REFERENCES DATA_SET_TYPE_PROPERTY_TYPES(ID) ON DELETE CASCADE;\\012ALTER TABLE DATA_SET_PROPERTIES ADD CONSTRAINT DSPR_DS_FK FOREIGN KEY (DS_ID) REFERENCES DATA(ID);\\012ALTER TABLE DATA_SET_PROPERTIES ADD CONSTRAINT DSPR_PERS_FK FOREIGN KEY (PERS_ID_REGISTERER) REFERENCES PERSONS(ID);\\012ALTER TABLE DATA_SET_PROPERTIES ADD CONSTRAINT DSPR_MAPR_FK FOREIGN KEY (MATE_PROP_ID) REFERENCES MATERIALS(ID);\\012\\012ALTER TABLE DATA_SET_PROPERTIES ADD CONSTRAINT DSPR_CK CHECK \\012\\011((VALUE IS NOT NULL AND CVTE_ID IS NULL AND MATE_PROP_ID IS NULL) OR \\012\\011 (VALUE IS NULL AND CVTE_ID IS NOT NULL AND MATE_PROP_ID IS NULL) OR\\012\\011 (VALUE IS NULL AND CVTE_ID IS NULL AND MATE_PROP_ID IS NOT NULL)\\012\\011);\\012\\012CREATE INDEX DSPR_CVTE_FK_I ON DATA_SET_PROPERTIES (CVTE_ID);\\012CREATE INDEX DSPR_DSTPT_FK_I ON DATA_SET_PROPERTIES (DSTPT_ID);\\012CREATE INDEX DSPR_DS_FK_I ON DATA_SET_PROPERTIES (DS_ID);\\012CREATE INDEX DSPR_PERS_FK_I ON DATA_SET_PROPERTIES (PERS_ID_REGISTERER);\\012CREATE INDEX DSTPT_DSTY_FK_I ON DATA_SET_TYPE_PROPERTY_TYPES (DSTY_ID);\\012CREATE INDEX DSTPT_PERS_FK_I ON DATA_SET_TYPE_PROPERTY_TYPES (PERS_ID_REGISTERER);\\012CREATE INDEX DSTPT_PRTY_FK_I ON DATA_SET_TYPE_PROPERTY_TYPES (PRTY_ID);\\012\\012CREATE OR REPLACE FUNCTION DATA_SET_PROPERTY_WITH_MATERIAL_DATA_TYPE_CHECK() RETURNS trigger AS $$\\012DECLARE\\012   v_type_id  CODE;\\012   v_type_id_prop  CODE;\\012BEGIN\\012   if NEW.mate_prop_id IS NOT NULL then\\012\\011\\011\\011-- find material type id of the property type \\012\\011\\011\\011select pt.maty_prop_id into v_type_id_prop \\012\\011\\011\\011  from data_set_type_property_types dstpt, property_types pt \\012\\011\\011\\011 where NEW.dstpt_id = dstpt.id AND dstpt.prty_id = pt.id;\\012\\011\\011\\012\\011\\011\\011if v_type_id_prop IS NOT NULL then\\012\\011\\011\\011\\011-- find material type id of the material which consists the entity's property value\\012\\011\\011\\011\\011select entity.maty_id into v_type_id \\012\\011\\011\\011\\011  from materials entity\\012\\011\\011\\011\\011 where NEW.mate_prop_id = entity.id;\\012\\011\\011\\011\\011if v_type_id != v_type_id_prop then\\012\\011\\011\\011\\011\\011RAISE EXCEPTION 'Insert/Update of property value referencing material (id: %) failed, as referenced material type is different than expected (id %, expected id: %).', \\012\\011\\011\\011\\011\\011\\011\\011\\011\\011\\011\\011\\011 NEW.mate_prop_id, v_type_id, v_type_id_prop;\\012\\011\\011\\011\\011end if;\\012\\011\\011\\011end if;\\012   end if;\\012   RETURN NEW;\\012END;\\012$$ LANGUAGE 'plpgsql';\\012\\012CREATE TRIGGER DATA_SET_PROPERTY_WITH_MATERIAL_DATA_TYPE_CHECK BEFORE INSERT OR UPDATE ON data_set_properties\\012    FOR EACH ROW EXECUTE PROCEDURE DATA_SET_PROPERTY_WITH_MATERIAL_DATA_TYPE_CHECK();   \\012	\N
+./sourceTest/sql/postgresql/047/017=database_version_logs.tsv:032	source/sql/postgresql/migration/migration-031-032.sql	SUCCESS	2009-04-09 09:36:36.2	-- -------\\012-- Modify MATERIAL_BATCHES\\012-- -------\\012\\012ALTER TABLE material_batches\\012    DROP COLUMN proc_id;\\012\\012-- -------\\012-- Modify SAMPLES\\012-- -------\\012\\012ALTER TABLE samples\\012    ADD COLUMN expe_id tech_id;\\012\\012ALTER TABLE samples\\012    ADD CONSTRAINT samp_expe_fk FOREIGN KEY (expe_id) REFERENCES experiments(id);\\012\\012CREATE INDEX samp_expe_fk_i ON samples USING btree (expe_id);\\012\\012-- relink samples directly to experiments\\012\\012UPDATE samples\\012SET expe_id = (SELECT e.id FROM experiments e, procedures p, sample_inputs si \\012               WHERE si.samp_id = samples.id AND si.proc_id = p.id AND p.expe_id = e.id AND e.inva_id IS NULL);\\012\\012\\012-- -------\\012-- Modify DATA\\012-- -------\\012\\012ALTER TABLE data\\012    ADD COLUMN expe_id tech_id;\\012\\012ALTER TABLE data\\012    ADD CONSTRAINT data_expe_fk FOREIGN KEY (expe_id) REFERENCES experiments(id);\\012\\012CREATE INDEX data_expe_fk_i ON data USING btree (expe_id);\\012\\012UPDATE data\\012SET expe_id = (SELECT e.id FROM experiments e, procedures p \\012               WHERE data.proc_id_produced_by = p.id AND p.expe_id = e.id);\\012\\012ALTER TABLE data\\012    ALTER COLUMN expe_id SET NOT NULL;\\012\\012ALTER TABLE data\\012    DROP COLUMN proc_id_produced_by;\\012\\012-- -------\\012-- Drop PROCEDURES, PROCEDURE_TYPES, and SAMPLE_INPUTS\\012-- -------\\012\\012DROP TABLE sample_inputs;\\012DROP TABLE procedures;\\012DROP TABLE procedure_types;\\012\\012DROP SEQUENCE procedure_id_seq;\\012DROP SEQUENCE procedure_type_id_seq;\\012\\012-- -------\\012-- Add CODE_SEQ\\012-- -------\\012\\012CREATE SEQUENCE CODE_SEQ;\\012\\012-- -------\\012-- Add new columns to DATA_STORES\\012-- -------\\012\\012ALTER TABLE data_stores\\012    ADD COLUMN remote_url character varying(250),\\012    ADD COLUMN session_token character varying(50),\\012    ADD COLUMN modification_timestamp time_stamp DEFAULT now();\\012\\012UPDATE data_stores\\012SET remote_url = '', session_token='';\\012\\012ALTER TABLE data_stores\\012    ALTER COLUMN remote_url SET NOT NULL,\\012    ALTER COLUMN session_token SET NOT NULL;\\012\\012-- -------\\012-- Drop foreign keys onto DATA_STORES\\012-- -------\\012\\012ALTER TABLE database_instances\\012    DROP COLUMN dast_id;\\012\\012ALTER TABLE groups\\012    DROP COLUMN dast_id;\\012\\012ALTER TABLE projects\\012    DROP COLUMN dast_id;\\012\\012ALTER TABLE experiments\\012    DROP COLUMN dast_id;\\012\\012-- -------\\012-- Add foreign key from DATA onto DATA_STORES\\012-- -------\\012\\012ALTER TABLE data\\012    ADD COLUMN dast_id tech_id;\\012\\012ALTER TABLE data\\012    ADD CONSTRAINT data_dast_fk FOREIGN KEY (dast_id) REFERENCES data_stores(id);\\012\\012UPDATE data\\012SET dast_id = (select id from data_stores where code = 'STANDARD');\\012\\012ALTER TABLE data\\012    ALTER COLUMN dast_id SET NOT NULL;\\012\\012\\012------------------------------------------------------------------------------------\\012--  Purpose:  Replace trigger SAMPLE_CODE_UNIQUENESS_CHECK \\012------------------------------------------------------------------------------------\\012\\012CREATE OR REPLACE FUNCTION SAMPLE_CODE_UNIQUENESS_CHECK() RETURNS trigger AS $$\\012DECLARE\\012   counter  INTEGER;\\012BEGIN\\012    LOCK TABLE samples IN EXCLUSIVE MODE;\\012    IF (NEW.samp_id_part_of is NULL) THEN\\012        IF (NEW.dbin_id is not NULL) THEN\\012            SELECT count(*) into counter FROM samples \\012                where id != NEW.id and code = NEW.code and samp_id_part_of is NULL and dbin_id = NEW.dbin_id;\\012            IF (counter > 0) THEN\\012                RAISE EXCEPTION 'Insert/Update of Sample (Code: %) failed because database instance sample with the same code already exists.', NEW.code;\\012            END IF;\\012        ELSIF (NEW.grou_id is not NULL) THEN\\012            SELECT count(*) into counter FROM samples \\012                where id != NEW.id and code = NEW.code and samp_id_part_of is NULL and grou_id = NEW.grou_id;\\012            IF (counter > 0) THEN\\012                RAISE EXCEPTION 'Insert/Update of Sample (Code: %) failed because group sample with the same code already exists.', NEW.code;\\012            END IF;\\012        END IF;\\012        ELSE\\012        IF (NEW.dbin_id is not NULL) THEN\\012            SELECT count(*) into counter FROM samples \\012                where id != NEW.id and code = NEW.code and samp_id_part_of = NEW.samp_id_part_of and dbin_id = NEW.dbin_id;\\012            IF (counter > 0) THEN\\012                RAISE EXCEPTION 'Insert/Update of Sample (Code: %) failed because database instance sample with the same code and being the part of the same parent already exists.', NEW.code;\\012            END IF;\\012        ELSIF (NEW.grou_id is not NULL) THEN\\012            SELECT count(*) into counter FROM samples \\012                where id != NEW.id and code = NEW.code and samp_id_part_of = NEW.samp_id_part_of and grou_id = NEW.grou_id;\\012            IF (counter > 0) THEN\\012                RAISE EXCEPTION 'Insert/Update of Sample (Code: %) failed because group sample with the same code and being the part of the same parent already exists.', NEW.code;\\012            END IF;\\012        END IF;\\012        END IF;   \\012   RETURN NEW;\\012END;\\012$$ LANGUAGE 'plpgsql';\\012\\012\\012\\012	\N
+./sourceTest/sql/postgresql/047/017=database_version_logs.tsv:034	source/sql/postgresql/migration/migration-033-034.sql	SUCCESS	2009-05-26 08:32:49.935	------------------------------------------------------------------------------------\\012-- Create sequence for generating permanent identifiers starting with nextval of existing dataset sequence.\\012------------------------------------------------------------------------------------\\012CREATE FUNCTION CREATE_SEQUENCE(EXISTING_SEQUENCE VARCHAR, NEW_SEQUENCE VARCHAR) RETURNS VOID AS $$\\012DECLARE\\012  CURR_SEQ_VAL   INTEGER;\\012BEGIN\\012  SELECT INTO CURR_SEQ_VAL NEXTVAL(EXISTING_SEQUENCE);\\012  EXECUTE 'CREATE SEQUENCE ' || NEW_SEQUENCE || ' START WITH ' || CURR_SEQ_VAL;\\012  RETURN;\\012END;\\012$$ LANGUAGE 'plpgsql';\\012\\012SELECT CREATE_SEQUENCE('DATA_ID_SEQ', 'PERM_ID_SEQ');\\012DROP FUNCTION CREATE_SEQUENCE(VARCHAR, VARCHAR);\\012\\012------------------------------------------------------------------------------------\\012-- Add perm_id columns to samples and experiments.\\012------------------------------------------------------------------------------------\\012ALTER TABLE SAMPLES ADD COLUMN PERM_ID CODE;\\012ALTER TABLE EXPERIMENTS ADD COLUMN PERM_ID CODE;\\012\\012UPDATE SAMPLES SET PERM_ID = to_char(registration_timestamp,'YYYYMMDDHHSSMS') || '-' || NEXTVAL('PERM_ID_SEQ');\\012UPDATE EXPERIMENTS SET PERM_ID = to_char(registration_timestamp,'YYYYMMDDHHSSMS') || '-' || NEXTVAL('PERM_ID_SEQ');\\012ALTER TABLE SAMPLES ALTER COLUMN PERM_ID SET NOT NULL;\\012ALTER TABLE EXPERIMENTS ALTER COLUMN PERM_ID SET NOT NULL;\\012ALTER TABLE SAMPLES ADD CONSTRAINT SAMP_PI_UK UNIQUE(PERM_ID);\\012ALTER TABLE EXPERIMENTS ADD CONSTRAINT EXPE_PI_UK UNIQUE(PERM_ID);\\012\\012\\012------------------------------------------------------------------------------------\\012-- Add column is_chosen_from_list to controlled_vocabularies.\\012------------------------------------------------------------------------------------\\012ALTER TABLE controlled_vocabularies ADD COLUMN is_chosen_from_list BOOLEAN_CHAR NOT NULL DEFAULT TRUE;\\012ALTER TABLE controlled_vocabularies ADD COLUMN source_uri CHARACTER VARYING(250);\\012------------------------------------------------------------------------------------\\012-- Modify Data table - remove arc connection between Sample and Data table, use a flag instead\\012------------------------------------------------------------------------------------\\012\\012-- add new columns\\012\\012ALTER TABLE data\\012    ADD COLUMN is_derived boolean_char;\\012ALTER TABLE data\\012    ADD COLUMN samp_id tech_id;\\012\\012-- update values in new columns\\012\\012UPDATE data\\012    SET is_derived = (samp_id_derived_from IS NOT NULL); \\012UPDATE data\\012    SET samp_id = samp_id_derived_from \\012    WHERE is_derived = 'TRUE';\\012UPDATE data\\012    SET samp_id = samp_id_acquired_from \\012    WHERE is_derived = 'FALSE';\\012\\012-- add constraints and indexes to new columns\\012\\012ALTER TABLE data\\012    ALTER COLUMN is_derived SET NOT NULL;\\012ALTER TABLE data\\012    ALTER COLUMN samp_id SET NOT NULL;   \\012ALTER TABLE data\\012    ADD CONSTRAINT data_samp_fk FOREIGN KEY (samp_id) REFERENCES samples (id);\\012CREATE INDEX data_samp_fk_i ON data USING btree (samp_id);\\012\\012-- remove old columns\\012\\012ALTER TABLE data\\012    DROP COLUMN samp_id_acquired_from;\\012ALTER TABLE data\\012    DROP COLUMN samp_id_derived_from;\\012    \\012------------------------------------------------------------------------------------\\012-- Granting SELECT privilege to group openbis_readonly\\012------------------------------------------------------------------------------------\\012\\012GRANT SELECT ON SEQUENCE attachment_content_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE attachment_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE code_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE controlled_vocabulary_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE cvte_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE data_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE data_set_property_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE data_set_relationship_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE data_set_type_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE data_store_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE data_type_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE database_instance_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE dstpt_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE etpt_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE event_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE experiment_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE experiment_property_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE experiment_type_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE file_format_type_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE group_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE invalidation_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE locator_type_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE material_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE material_property_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE material_type_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE mtpt_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE perm_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE person_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE project_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE property_type_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE role_assignment_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE sample_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE sample_property_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE sample_type_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE stpt_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE attachment_contents TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE attachments TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE controlled_vocabularies TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE controlled_vocabulary_terms TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE data TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE data_set_properties TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE data_set_relationships TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE data_set_type_property_types TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE data_set_types TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE data_stores TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE data_types TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE database_instances TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE database_version_logs TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE events TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE experiment_properties TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE experiment_type_property_types TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE experiment_types TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE experiments TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE external_data TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE file_format_types TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE groups TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE invalidations TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE locator_types TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE material_properties TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE material_type_property_types TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE material_types TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE materials TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE persons TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE projects TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE property_types TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE role_assignments TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE sample_properties TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE sample_type_property_types TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE sample_types TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE samples TO GROUP OPENBIS_READONLY;\\012\\012------------------------------------------------------------------------------------\\012-- Delete MATERIAL_BATCHES table\\012------------------------------------------------------------------------------------\\012\\012-- WARNING: Potential data lost!!!\\012-- WARNING: Potential data lost!!!\\012-- WARNING: Potential data lost!!!\\012\\012DROP TABLE SAMPLE_MATERIAL_BATCHES;\\012DROP TABLE MATERIAL_BATCHES;\\012DROP SEQUENCE MATERIAL_BATCH_ID_SEQ;\\012\\012------------------------------------------------------------------------------------\\012-- Delete MATE_ID_INHIBITOR_OF from table MATERIALS\\012------------------------------------------------------------------------------------\\012\\012-- WARNING: Potential data lost!!!\\012-- WARNING: Potential data lost!!!\\012-- WARNING: Potential data lost!!!\\012\\012ALTER TABLE MATERIALS DROP COLUMN MATE_ID_INHIBITOR_OF;\\012	\N
+./sourceTest/sql/postgresql/047/017=database_version_logs.tsv:041	source/sql/postgresql/migration/migration-040-041.sql	SUCCESS	2009-09-14 13:48:57.539	-- Create FILTERS table\\012\\012CREATE TABLE FILTERS (ID TECH_ID NOT NULL, DBIN_ID TECH_ID NOT NULL, NAME VARCHAR(200) NOT NULL, DESCRIPTION DESCRIPTION_1000,REGISTRATION_TIMESTAMP TIME_STAMP_DFL NOT NULL DEFAULT CURRENT_TIMESTAMP, PERS_ID_REGISTERER TECH_ID NOT NULL, MODIFICATION_TIMESTAMP TIME_STAMP DEFAULT CURRENT_TIMESTAMP, EXPRESSION VARCHAR(2000) NOT NULL, IS_PUBLIC BOOLEAN NOT NULL, GRID_ID VARCHAR(200) NOT NULL);\\012CREATE SEQUENCE FILTER_ID_SEQ;\\012ALTER TABLE FILTERS ADD CONSTRAINT FILT_PK PRIMARY KEY(ID);\\012ALTER TABLE FILTERS ADD CONSTRAINT FILT_BK_UK UNIQUE(NAME, DBIN_ID, GRID_ID);\\012ALTER TABLE FILTERS ADD CONSTRAINT FILT_PERS_FK FOREIGN KEY (PERS_ID_REGISTERER) REFERENCES PERSONS(ID);\\012ALTER TABLE FILTERS ADD CONSTRAINT FILT_DBIN_FK FOREIGN KEY (DBIN_ID) REFERENCES DATABASE_INSTANCES(ID);\\012CREATE INDEX FILT_PERS_FK_I ON FILTERS (PERS_ID_REGISTERER);\\012CREATE INDEX FILT_DBIN_FK_I ON FILTERS (DBIN_ID);\\012GRANT SELECT ON SEQUENCE filter_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE filters TO GROUP OPENBIS_READONLY;\\012\\012-- Add missing foreign key to role assignments authorization group\\012ALTER TABLE ROLE_ASSIGNMENTS ADD CONSTRAINT ROAS_AG_FK_GRANTEE FOREIGN KEY (AG_ID_GRANTEE) REFERENCES AUTHORIZATION_GROUPS(ID);\\012\\012--------------------------------------------------------------------------------------------------\\012-- Modify dataset connections:\\012-- 1. connection with sample shouldn't be mandatory any more\\012-- 2. introduce an arc condition that dataset cannot be connected with a sample and a parent dataset at the same time\\012--------------------------------------------------------------------------------------------------\\012\\012-- Weaken data-sample connection constraint - allow dataset to have no connection with sample\\012ALTER TABLE data ALTER COLUMN samp_id DROP NOT NULL;\\012\\012-- Remove data-sample connection for datasets that have a parent\\012\\012UPDATE data \\012   SET samp_id = NULL \\012 WHERE id IN (SELECT DISTINCT data_id_child FROM data_set_relationships);\\012\\012-- With PostgreSQL 8.4 one can check that before migration there were no cycles in dataset relationships:\\012--\\012-- WITH RECURSIVE data_set_parents(id, parent_ids, cycle) AS (\\012--         SELECT  r.data_id_child AS id, \\012--                 ARRAY[CAST (r.data_id_parent AS bigint)] AS parent_ids, \\012--                 false AS cycle \\012--         FROM data_set_relationships r\\012--     UNION ALL\\012--         SELECT  r.data_id_child,\\012--                 CAST (r.data_id_parent AS bigint) || p.parent_ids,\\012--                 r.data_id_child = ANY(p.parent_ids)\\012--         FROM data_set_relationships r, data_set_parents p\\012--         WHERE r.data_id_parent = p.id AND NOT cycle\\012-- )\\012-- SELECT count(*) AS cycles FROM data_set_parents WHERE cycle = true;\\012\\012---------------------------------------------------------------------------------------------------\\012--  Purpose:  Create DEFERRED triggers:\\012--            * check_dataset_relationships_on_data_table_modification,\\012--            * check_dataset_relationships_on_relationships_table_modification.\\012--            They check that after all modifications of database (just before commit) \\012--            if 'data'/'data_set_relationships' tables are among modified tables \\012--            dataset is not connected with a sample and a parent dataset at the same time.\\012--            This connections are held in two different tables so simple immediate trigger \\012--            with arc check cannot be used and we need two deferred triggers.\\012----------------------------------------------------------------------------------------------------\\012\\012-- trigger for 'data' table\\012\\012CREATE OR REPLACE FUNCTION check_dataset_relationships_on_data_table_modification() RETURNS trigger AS $$\\012DECLARE\\012\\011counter\\011INTEGER;\\012BEGIN\\012\\011-- if there is a connection with a Sample there should not be any connection with a parent Data Set\\012\\011IF (NEW.samp_id IS NOT NULL) THEN\\012\\011\\011-- count number of parents\\012\\011\\011SELECT count(*) INTO counter \\012\\011\\011\\011FROM data_set_relationships \\012\\011\\011\\011WHERE data_id_child = OLD.id;\\012\\011\\011IF (counter > 0) THEN\\012\\011\\011\\011RAISE EXCEPTION 'Insert/Update of Data Set (Code: %) failed because it cannot be connected with a Sample and a parent Data Set at the same time.', OLD.code;\\012\\011\\011END IF;\\012\\011END IF;\\012  RETURN NEW;\\012END;\\012$$ LANGUAGE 'plpgsql';\\012\\012CREATE CONSTRAINT TRIGGER check_dataset_relationships_on_data_table_modification \\012  AFTER INSERT OR UPDATE ON data\\012\\011DEFERRABLE INITIALLY DEFERRED\\012\\011FOR EACH ROW \\012\\011EXECUTE PROCEDURE check_dataset_relationships_on_data_table_modification();\\012\\012-- trigger for 'data_set_relationships'\\012\\012CREATE OR REPLACE FUNCTION check_dataset_relationships_on_relationships_table_modification() RETURNS trigger AS $$\\012DECLARE\\012\\011counter\\011INTEGER;\\012\\011sample_id\\011TECH_ID;\\012\\011data_code\\011CODE;\\012BEGIN\\012\\011-- child will have a parent added so it should not be connected with any sample\\012\\011SELECT samp_id, code INTO sample_id, data_code \\012\\011\\011FROM data \\012\\011\\011WHERE id = NEW.data_id_child;\\012\\011IF (sample_id IS NOT NULL) THEN\\012\\011\\011RAISE EXCEPTION 'Insert/Update of Data Set (Code: %) failed because it cannot be connected to a Sample and to a parent Data Set at the same time.', data_code;\\012\\011END IF;\\012\\011RETURN NEW;\\012END;\\012$$ LANGUAGE 'plpgsql';\\012  \\012CREATE CONSTRAINT TRIGGER check_dataset_relationships_on_relationships_table_modification \\012  AFTER INSERT OR UPDATE ON data_set_relationships\\012\\011DEFERRABLE INITIALLY DEFERRED\\012\\011FOR EACH ROW \\012\\011EXECUTE PROCEDURE check_dataset_relationships_on_relationships_table_modification();\\012	\N
+./sourceTest/sql/postgresql/047/schema-047.sql:    LANGUAGE plpgsql
+./sourceTest/sql/postgresql/047/schema-047.sql:    LANGUAGE plpgsql
+./sourceTest/sql/postgresql/047/schema-047.sql:    LANGUAGE plpgsql
+./sourceTest/sql/postgresql/047/schema-047.sql:    LANGUAGE plpgsql
+./sourceTest/sql/postgresql/047/schema-047.sql:    LANGUAGE plpgsql
+./sourceTest/sql/postgresql/047/schema-047.sql:    LANGUAGE plpgsql
+./sourceTest/sql/postgresql/047/schema-047.sql:    LANGUAGE plpgsql
+./sourceTest/sql/postgresql/047/schema-047.sql:    LANGUAGE plpgsql
+./sourceTest/sql/postgresql/047/schema-047.sql:    LANGUAGE plpgsql
+./sourceTest/sql/postgresql/047/schema-047.sql:    LANGUAGE plpgsql
+./sourceTest/sql/postgresql/048/.svn/text-base/017=database_version_logs.tsv.svn-base:027	D:\\User\\felmer\\dev-workspace\\openbis/source/sql/postgresql/027/function-027.sql	SUCCESS	2008-11-05 09:18:00.403	-- Creating Functions\\012\\012------------------------------------------------------------------------------------\\012--  Purpose:  Create function RENAME_SEQUENCE() that is required for renaming the sequences belonging to tables\\012------------------------------------------------------------------------------------\\012CREATE FUNCTION RENAME_SEQUENCE(OLD_NAME VARCHAR, NEW_NAME VARCHAR) RETURNS INTEGER AS $$\\012DECLARE\\012  CURR_SEQ_VAL   INTEGER;\\012BEGIN\\012  SELECT INTO CURR_SEQ_VAL NEXTVAL(OLD_NAME);\\012  EXECUTE 'CREATE SEQUENCE ' || NEW_NAME || ' START WITH ' || CURR_SEQ_VAL;\\012  EXECUTE 'DROP SEQUENCE ' || OLD_NAME;\\012  RETURN CURR_SEQ_VAL;\\012END;\\012$$ LANGUAGE 'plpgsql';\\012\\012\\012------------------------------------------------------------------------------------\\012--  Purpose:  Create trigger CONTROLLED_VOCABULARY_CHECK \\012------------------------------------------------------------------------------------\\012\\012CREATE OR REPLACE FUNCTION CONTROLLED_VOCABULARY_CHECK() RETURNS trigger AS $$\\012DECLARE\\012   v_code  CODE;\\012BEGIN\\012\\012   select code into v_code from data_types where id = NEW.daty_id;\\012\\012   -- Check if the data is of type "CONTROLLEDVOCABULARY"\\012   if v_code = 'CONTROLLEDVOCABULARY' then\\012      if NEW.covo_id IS NULL then\\012         RAISE EXCEPTION 'Insert/Update of Property Type (Code: %) failed, as its Data Type is CONTROLLEDVOCABULARY, but it is not linked to a Controlled Vocabulary.', NEW.code;\\012      end if;\\012   end if;\\012\\012   RETURN NEW;\\012\\012END;\\012$$ LANGUAGE 'plpgsql';\\012\\012CREATE TRIGGER CONTROLLED_VOCABULARY_CHECK BEFORE INSERT OR UPDATE ON PROPERTY_TYPES\\012    FOR EACH ROW EXECUTE PROCEDURE CONTROLLED_VOCABULARY_CHECK();\\012\\012\\012------------------------------------------------------------------------------------\\012--  Purpose:  Create trigger EXTERNAL_DATA_STORAGE_FORMAT_CHECK \\012------------------------------------------------------------------------------------\\012\\012CREATE OR REPLACE FUNCTION EXTERNAL_DATA_STORAGE_FORMAT_CHECK() RETURNS trigger AS $$\\012DECLARE\\012   v_covo_code  CODE;\\012   data_code CODE;\\012BEGIN\\012\\012   select code into v_covo_code from controlled_vocabularies\\012      where is_internal_namespace = true and \\012         id = (select covo_id from controlled_vocabulary_terms where id = NEW.cvte_id_stor_fmt);\\012   -- Check if the data storage format is a term of the controlled vocabulary "STORAGE_FORMAT"\\012   if v_covo_code != 'STORAGE_FORMAT' then\\012      select code into data_code from data where id = NEW.data_id; \\012      RAISE EXCEPTION 'Insert/Update of Data (Code: %) failed, as its Storage Format is %, but is required to be STORAGE_FORMAT.', data_code, v_covo_code;\\012   end if;\\012\\012   RETURN NEW;\\012\\012END;\\012$$ LANGUAGE 'plpgsql';\\012\\012CREATE TRIGGER EXTERNAL_DATA_STORAGE_FORMAT_CHECK BEFORE INSERT OR UPDATE ON EXTERNAL_DATA\\012    FOR EACH ROW EXECUTE PROCEDURE EXTERNAL_DATA_STORAGE_FORMAT_CHECK();\\012\\012------------------------------------------------------------------------------------\\012--  Purpose:  Create trigger SAMPLE_CODE_UNIQUENESS_CHECK \\012------------------------------------------------------------------------------------\\012\\012CREATE OR REPLACE FUNCTION SAMPLE_CODE_UNIQUENESS_CHECK() RETURNS trigger AS $$\\012DECLARE\\012   counter  INTEGER;\\012BEGIN\\012\\011IF (NEW.samp_id_part_of is NULL) THEN\\012\\011\\011IF (NEW.dbin_id is not NULL) THEN\\012\\011\\011\\011SELECT count(*) into counter FROM samples \\012\\011\\011\\011\\011where id != NEW.id and code = NEW.code and samp_id_part_of is NULL and dbin_id = NEW.dbin_id;\\012\\011\\011\\011IF (counter > 0) THEN\\012\\011\\011\\011\\011RAISE EXCEPTION 'Insert/Update of Sample (Code: %) failed because database instance sample with the same code already exists.', NEW.code;\\012\\011\\011\\011END IF;\\012\\011\\011ELSIF (NEW.grou_id is not NULL) THEN\\012\\011\\011\\011SELECT count(*) into counter FROM samples \\012\\011\\011\\011\\011where id != NEW.id and code = NEW.code and samp_id_part_of is NULL and grou_id = NEW.grou_id;\\012\\011\\011\\011IF (counter > 0) THEN\\012\\011\\011\\011\\011RAISE EXCEPTION 'Insert/Update of Sample (Code: %) failed because group sample with the same code already exists.', NEW.code;\\012\\011\\011\\011END IF;\\012\\011\\011END IF;\\012        ELSE\\012\\011\\011IF (NEW.dbin_id is not NULL) THEN\\012\\011\\011\\011SELECT count(*) into counter FROM samples \\012\\011\\011\\011\\011where id != NEW.id and code = NEW.code and samp_id_part_of = NEW.samp_id_part_of and dbin_id = NEW.dbin_id;\\012\\011\\011\\011IF (counter > 0) THEN\\012\\011\\011\\011\\011RAISE EXCEPTION 'Insert/Update of Sample (Code: %) failed because database instance sample with the same code and being the part of the same parent already exists.', NEW.code;\\012\\011\\011\\011END IF;\\012\\011\\011ELSIF (NEW.grou_id is not NULL) THEN\\012\\011\\011\\011SELECT count(*) into counter FROM samples \\012\\011\\011\\011\\011where id != NEW.id and code = NEW.code and samp_id_part_of = NEW.samp_id_part_of and grou_id = NEW.grou_id;\\012\\011\\011\\011IF (counter > 0) THEN\\012\\011\\011\\011\\011RAISE EXCEPTION 'Insert/Update of Sample (Code: %) failed because group sample with the same code and being the part of the same parent already exists.', NEW.code;\\012\\011\\011\\011END IF;\\012\\011\\011END IF;\\012        END IF;   \\012   RETURN NEW;\\012END;\\012$$ LANGUAGE 'plpgsql';\\012\\012CREATE TRIGGER SAMPLE_CODE_UNIQUENESS_CHECK BEFORE INSERT OR UPDATE ON SAMPLES\\012    FOR EACH ROW EXECUTE PROCEDURE SAMPLE_CODE_UNIQUENESS_CHECK();\\012	\N
+./sourceTest/sql/postgresql/048/.svn/text-base/017=database_version_logs.tsv.svn-base:028	source/sql/postgresql/migration/migration-027-028.sql	SUCCESS	2008-11-18 13:24:17.508	-- Create EXPERIMENT_ATTACHMENT_CONTENTS.\\012CREATE TABLE EXPERIMENT_ATTACHMENT_CONTENTS (ID TECH_ID NOT NULL,VALUE FILE NOT NULL);\\012CREATE SEQUENCE EXPERIMENT_ATTACHMENT_CONTENT_ID_SEQ;\\012ALTER TABLE EXPERIMENT_ATTACHMENT_CONTENTS ADD CONSTRAINT EXAC_PK PRIMARY KEY(ID);\\012\\012-- Alter EXPERIMENT_ATTACHMENTS by adding the new column which has a NULL constraint.\\012-- The NOT NULL constraint is added later on.\\012ALTER TABLE EXPERIMENT_ATTACHMENTS ADD COLUMN EXAC_ID TECH_ID;\\012\\012-- Does the VALUE migration between EXPERIMENT_ATTACHMENTS to EXPERIMENT_ATTACHMENT_CONTENTS.\\012CREATE OR REPLACE FUNCTION move_exp_att_content() RETURNS integer AS $$\\012DECLARE\\012    rec RECORD;\\012    seq BIGINT;\\012BEGIN\\012  FOR rec IN SELECT id, value FROM EXPERIMENT_ATTACHMENTS LOOP\\012  \\011seq := nextval('EXPERIMENT_ATTACHMENT_CONTENT_ID_SEQ');\\012    INSERT INTO EXPERIMENT_ATTACHMENT_CONTENTS (id, value) VALUES (seq, rec.value);\\012    UPDATE EXPERIMENT_ATTACHMENTS SET exac_id = seq WHERE id = rec.id;\\012  END LOOP;\\012  RETURN 1;\\012END;\\012$$ LANGUAGE 'plpgsql';\\012\\012-- Call the function.\\012SELECT move_exp_att_content();\\012DROP FUNCTION move_exp_att_content();\\012\\012\\012-- Finish EXPERIMENT_ATTACHMENTS changes.\\012ALTER TABLE EXPERIMENT_ATTACHMENTS ADD CONSTRAINT EXAT_CONT_FK FOREIGN KEY (EXAC_ID) REFERENCES EXPERIMENT_ATTACHMENT_CONTENTS(ID);\\012ALTER TABLE EXPERIMENT_ATTACHMENTS DROP COLUMN VALUE;\\012ALTER TABLE EXPERIMENT_ATTACHMENTS ALTER COLUMN EXAC_ID SET NOT NULL;\\012	\N
+./sourceTest/sql/postgresql/048/.svn/text-base/017=database_version_logs.tsv.svn-base:029	source/sql/postgresql/migration/migration-028-029.sql	SUCCESS	2009-03-18 10:50:20.105	-- -------\\012-- add modification_timestamp field to allow edition with Hibernate\\012-- -------\\012\\012ALTER TABLE samples\\012\\011ADD COLUMN modification_timestamp TIME_STAMP DEFAULT CURRENT_TIMESTAMP;\\012\\012ALTER TABLE experiments\\012\\011ADD COLUMN modification_timestamp TIME_STAMP DEFAULT CURRENT_TIMESTAMP;\\012\\012ALTER TABLE materials\\012\\011ADD COLUMN modification_timestamp TIME_STAMP DEFAULT CURRENT_TIMESTAMP;\\012\\012ALTER TABLE experiment_properties\\012\\011ADD COLUMN modification_timestamp TIME_STAMP DEFAULT CURRENT_TIMESTAMP;\\012\\012ALTER TABLE material_properties\\012\\011ADD COLUMN modification_timestamp TIME_STAMP DEFAULT CURRENT_TIMESTAMP;\\012\\012ALTER TABLE sample_properties\\012\\011ADD COLUMN modification_timestamp TIME_STAMP DEFAULT CURRENT_TIMESTAMP;\\012\\012-- -------\\012-- add property data type which references materials\\012-- -------\\012\\012ALTER TABLE property_types\\012\\011ADD COLUMN maty_prop_id tech_id;\\012\\012ALTER TABLE property_types\\012\\011ADD CONSTRAINT prty_maty_fk FOREIGN KEY (maty_prop_id) REFERENCES material_types(id);\\012\\012ALTER TABLE experiment_properties\\012\\011ADD COLUMN mate_prop_id tech_id;\\012\\012ALTER TABLE material_properties\\012\\011ADD COLUMN mate_prop_id tech_id;\\012\\012ALTER TABLE sample_properties\\012\\011ADD COLUMN mate_prop_id tech_id;\\012\\012ALTER TABLE experiment_properties\\012\\011ADD CONSTRAINT expr_mapr_fk FOREIGN KEY (mate_prop_id) REFERENCES materials(id);\\012\\012ALTER TABLE material_properties\\012\\011ADD CONSTRAINT mapr_mapr_fk FOREIGN KEY (mate_prop_id) REFERENCES materials(id);\\012\\012ALTER TABLE sample_properties\\012\\011ADD CONSTRAINT sapr_mapr_fk FOREIGN KEY (mate_prop_id) REFERENCES materials(id);\\012\\012insert into data_types\\012(id\\012 ,code\\012 ,description)\\012 values \\012 (nextval('DATA_TYPE_ID_SEQ')\\012 ,'MATERIAL'\\012 ,'Reference to a material'\\012);\\012\\012ALTER TABLE MATERIAL_PROPERTIES DROP CONSTRAINT MAPR_CK;\\012ALTER TABLE MATERIAL_PROPERTIES ADD CONSTRAINT MAPR_CK CHECK \\012\\011((VALUE IS NOT NULL AND CVTE_ID IS NULL AND MATE_PROP_ID IS NULL) OR \\012\\011 (VALUE IS NULL AND CVTE_ID IS NOT NULL AND MATE_PROP_ID IS NULL) OR\\012\\011 (VALUE IS NULL AND CVTE_ID IS NULL AND MATE_PROP_ID IS NOT NULL)\\012\\011);\\012\\012ALTER TABLE EXPERIMENT_PROPERTIES DROP CONSTRAINT EXPR_CK;\\012ALTER TABLE EXPERIMENT_PROPERTIES ADD CONSTRAINT EXPR_CK CHECK \\012\\011((VALUE IS NOT NULL AND CVTE_ID IS NULL AND MATE_PROP_ID IS NULL) OR \\012\\011 (VALUE IS NULL AND CVTE_ID IS NOT NULL AND MATE_PROP_ID IS NULL) OR\\012\\011 (VALUE IS NULL AND CVTE_ID IS NULL AND MATE_PROP_ID IS NOT NULL)\\012\\011);\\012\\012ALTER TABLE SAMPLE_PROPERTIES DROP CONSTRAINT SAPR_CK;\\012ALTER TABLE SAMPLE_PROPERTIES ADD CONSTRAINT SAPR_CK CHECK \\012\\011((VALUE IS NOT NULL AND CVTE_ID IS NULL AND MATE_PROP_ID IS NULL) OR \\012\\011 (VALUE IS NULL AND CVTE_ID IS NOT NULL AND MATE_PROP_ID IS NULL) OR\\012\\011 (VALUE IS NULL AND CVTE_ID IS NULL AND MATE_PROP_ID IS NOT NULL)\\012\\011);\\012\\012------------------------------------------------------------------------------------\\012--  Purpose:  Create trigger MATERIAL/SAMPLE/EXPERIMENT _PROPERTY_WITH_MATERIAL_DATA_TYPE_CHECK\\012--            It checks that if material property value is assigned to the entity,\\012--\\011\\011\\011\\011\\011\\011then the material type is equal to the one described by property type.\\012------------------------------------------------------------------------------------\\012\\012CREATE OR REPLACE FUNCTION MATERIAL_PROPERTY_WITH_MATERIAL_DATA_TYPE_CHECK() RETURNS trigger AS $$\\012DECLARE\\012   v_type_id  CODE;\\012   v_type_id_prop  CODE;\\012BEGIN\\012   if NEW.mate_prop_id IS NOT NULL then\\012\\011\\011\\011-- find material type id of the property type \\012\\011\\011\\011select pt.maty_prop_id into v_type_id_prop \\012\\011\\011\\011  from material_type_property_types etpt, property_types pt \\012\\011\\011\\011 where NEW.mtpt_id = etpt.id AND etpt.prty_id = pt.id;\\012\\011\\011\\012\\011\\011\\011if v_type_id_prop IS NOT NULL then\\012\\011\\011\\011\\011-- find material type id of the material which consists the entity's property value\\012\\011\\011\\011\\011select entity.maty_id into v_type_id \\012\\011\\011\\011\\011  from materials entity\\012\\011\\011\\011\\011 where NEW.mate_prop_id = entity.id;\\012\\011\\011\\011\\011if v_type_id != v_type_id_prop then\\012\\011\\011\\011\\011\\011RAISE EXCEPTION 'Insert/Update of property value referencing material (id: %) failed, as referenced material type is different than expected (id %, expected id: %).', \\012\\011\\011\\011\\011\\011\\011\\011 NEW.mate_prop_id, v_type_id, v_type_id_prop;\\012\\011\\011\\011\\011end if;\\012\\011\\011\\011end if;\\012   end if;\\012   RETURN NEW;\\012END;\\012$$ LANGUAGE 'plpgsql';\\012\\012CREATE TRIGGER MATERIAL_PROPERTY_WITH_MATERIAL_DATA_TYPE_CHECK BEFORE INSERT OR UPDATE ON material_properties\\012    FOR EACH ROW EXECUTE PROCEDURE MATERIAL_PROPERTY_WITH_MATERIAL_DATA_TYPE_CHECK();\\012    \\012CREATE OR REPLACE FUNCTION SAMPLE_PROPERTY_WITH_MATERIAL_DATA_TYPE_CHECK() RETURNS trigger AS $$\\012DECLARE\\012   v_type_id  CODE;\\012   v_type_id_prop  CODE;\\012BEGIN\\012   if NEW.mate_prop_id IS NOT NULL then\\012\\011\\011\\011-- find material type id of the property type \\012\\011\\011\\011select pt.maty_prop_id into v_type_id_prop \\012\\011\\011\\011  from sample_type_property_types etpt, property_types pt \\012\\011\\011\\011 where NEW.stpt_id = etpt.id AND etpt.prty_id = pt.id;\\012\\011\\011\\012\\011\\011\\011if v_type_id_prop IS NOT NULL then\\012\\011\\011\\011\\011-- find material type id of the material which consists the entity's property value\\012\\011\\011\\011\\011select entity.maty_id into v_type_id \\012\\011\\011\\011\\011  from materials entity\\012\\011\\011\\011\\011 where NEW.mate_prop_id = entity.id;\\012\\011\\011\\011\\011if v_type_id != v_type_id_prop then\\012\\011\\011\\011\\011\\011RAISE EXCEPTION 'Insert/Update of property value referencing material (id: %) failed, as referenced material type is different than expected (id %, expected id: %).', \\012\\011\\011\\011\\011\\011\\011\\011\\011\\011\\011\\011\\011 NEW.mate_prop_id, v_type_id, v_type_id_prop;\\012\\011\\011\\011\\011end if;\\012\\011\\011\\011end if;\\012   end if;\\012   RETURN NEW;\\012END;\\012$$ LANGUAGE 'plpgsql';\\012\\012CREATE TRIGGER SAMPLE_PROPERTY_WITH_MATERIAL_DATA_TYPE_CHECK BEFORE INSERT OR UPDATE ON sample_properties\\012    FOR EACH ROW EXECUTE PROCEDURE SAMPLE_PROPERTY_WITH_MATERIAL_DATA_TYPE_CHECK();\\012    \\012CREATE OR REPLACE FUNCTION EXPERIMENT_PROPERTY_WITH_MATERIAL_DATA_TYPE_CHECK() RETURNS trigger AS $$\\012DECLARE\\012   v_type_id  CODE;\\012   v_type_id_prop  CODE;\\012BEGIN\\012   if NEW.mate_prop_id IS NOT NULL then\\012\\011\\011\\011-- find material type id of the property type \\012\\011\\011\\011select pt.maty_prop_id into v_type_id_prop \\012\\011\\011\\011  from experiment_type_property_types etpt, property_types pt \\012\\011\\011\\011 where NEW.etpt_id = etpt.id AND etpt.prty_id = pt.id;\\012\\011\\011\\012\\011\\011\\011if v_type_id_prop IS NOT NULL then\\012\\011\\011\\011\\011-- find material type id of the material which consists the entity's property value\\012\\011\\011\\011\\011select entity.maty_id into v_type_id \\012\\011\\011\\011\\011  from materials entity\\012\\011\\011\\011\\011 where NEW.mate_prop_id = entity.id;\\012\\011\\011\\011\\011if v_type_id != v_type_id_prop then\\012\\011\\011\\011\\011\\011RAISE EXCEPTION 'Insert/Update of property value referencing material (id: %) failed, as referenced material type is different than expected (id %, expected id: %).', \\012\\011\\011\\011\\011\\011\\011\\011\\011\\011\\011\\011\\011 NEW.mate_prop_id, v_type_id, v_type_id_prop;\\012\\011\\011\\011\\011end if;\\012\\011\\011\\011end if;\\012   end if;\\012   RETURN NEW;\\012END;\\012$$ LANGUAGE 'plpgsql';\\012\\012CREATE TRIGGER EXPERIMENT_PROPERTY_WITH_MATERIAL_DATA_TYPE_CHECK BEFORE INSERT OR UPDATE ON experiment_properties\\012    FOR EACH ROW EXECUTE PROCEDURE EXPERIMENT_PROPERTY_WITH_MATERIAL_DATA_TYPE_CHECK();\\012       \\012-- -------\\012-- remove the reminescents of the OBSERVABLE_TYPE\\012-- -------\\012\\012ALTER TABLE data\\012\\011DROP CONSTRAINT data_obty_fk;\\012\\012ALTER TABLE data_set_types\\012\\011DROP CONSTRAINT obty_pk;\\012\\012ALTER TABLE data_set_types\\012\\011ADD CONSTRAINT dsty_pk PRIMARY KEY (id);\\012\\012ALTER TABLE data\\012\\011ADD CONSTRAINT data_dsty_fk FOREIGN KEY (dsty_id) REFERENCES data_set_types(id);\\012\\012ALTER TABLE data_set_types\\012\\011DROP CONSTRAINT obty_bk_uk;\\012\\012ALTER TABLE data_set_types\\012\\011DROP CONSTRAINT obty_dbin_fk;\\012\\012ALTER TABLE data_set_types\\012\\011ADD CONSTRAINT dsty_bk_uk UNIQUE (code, dbin_id);\\012\\012ALTER TABLE data_set_types\\012\\011ADD CONSTRAINT dsty_dbin_fk FOREIGN KEY (dbin_id) REFERENCES database_instances(id);\\012\\012DROP INDEX data_obty_fk_i;\\012\\012CREATE INDEX data_dsty_fk_i ON data(dsty_id);\\012	\N
+./sourceTest/sql/postgresql/048/.svn/text-base/017=database_version_logs.tsv.svn-base:030	source/sql/postgresql/migration/migration-029-030.sql	SUCCESS	2009-03-23 15:34:44.72	-- -------\\012-- add modification_timestamp field to allow edition with Hibernate\\012-- -------\\012ALTER TABLE data\\012\\011ADD COLUMN modification_timestamp TIME_STAMP DEFAULT CURRENT_TIMESTAMP;\\012ALTER TABLE experiment_types\\012\\011ADD COLUMN modification_timestamp TIME_STAMP DEFAULT CURRENT_TIMESTAMP;\\012ALTER TABLE sample_types\\012\\011ADD COLUMN modification_timestamp TIME_STAMP DEFAULT CURRENT_TIMESTAMP;\\012ALTER TABLE material_types\\012\\011ADD COLUMN modification_timestamp TIME_STAMP DEFAULT CURRENT_TIMESTAMP;\\012ALTER TABLE data_set_types\\012\\011ADD COLUMN modification_timestamp TIME_STAMP DEFAULT CURRENT_TIMESTAMP;\\012ALTER TABLE controlled_vocabularies\\012\\011ADD COLUMN modification_timestamp TIME_STAMP DEFAULT CURRENT_TIMESTAMP;\\012-- -------\\012-- add properties to data sets\\012-- -------\\012CREATE TABLE DATA_SET_PROPERTIES (ID TECH_ID NOT NULL,DS_ID TECH_ID NOT NULL,DSTPT_ID TECH_ID NOT NULL,VALUE GENERIC_VALUE,CVTE_ID TECH_ID, MATE_PROP_ID TECH_ID, PERS_ID_REGISTERER TECH_ID NOT NULL,REGISTRATION_TIMESTAMP TIME_STAMP_DFL NOT NULL DEFAULT CURRENT_TIMESTAMP, MODIFICATION_TIMESTAMP TIME_STAMP DEFAULT CURRENT_TIMESTAMP);\\012CREATE TABLE DATA_SET_TYPE_PROPERTY_TYPES (ID TECH_ID NOT NULL,DSTY_ID TECH_ID NOT NULL,PRTY_ID TECH_ID NOT NULL,IS_MANDATORY BOOLEAN_CHAR NOT NULL DEFAULT 'F',IS_MANAGED_INTERNALLY BOOLEAN_CHAR NOT NULL DEFAULT 'F',PERS_ID_REGISTERER TECH_ID NOT NULL,REGISTRATION_TIMESTAMP TIME_STAMP_DFL NOT NULL DEFAULT CURRENT_TIMESTAMP);\\012\\012CREATE SEQUENCE DATA_SET_PROPERTY_ID_SEQ;\\012CREATE SEQUENCE DSTPT_ID_SEQ;\\012\\012ALTER TABLE DATA_SET_TYPE_PROPERTY_TYPES ADD CONSTRAINT DSTPT_PK PRIMARY KEY(ID);\\012ALTER TABLE DATA_SET_PROPERTIES ADD CONSTRAINT DSPR_PK PRIMARY KEY(ID);\\012\\012ALTER TABLE DATA_SET_TYPE_PROPERTY_TYPES ADD CONSTRAINT DSTPT_BK_UK UNIQUE(DSTY_ID,PRTY_ID);\\012ALTER TABLE DATA_SET_PROPERTIES ADD CONSTRAINT DSPR_BK_UK UNIQUE(DS_ID,DSTPT_ID);\\012\\012\\012ALTER TABLE DATA_SET_TYPE_PROPERTY_TYPES ADD CONSTRAINT DSTPT_DSTY_FK FOREIGN KEY (DSTY_ID) REFERENCES DATA_SET_TYPES(ID);\\012ALTER TABLE DATA_SET_TYPE_PROPERTY_TYPES ADD CONSTRAINT DSTPT_PERS_FK FOREIGN KEY (PERS_ID_REGISTERER) REFERENCES PERSONS(ID);\\012ALTER TABLE DATA_SET_TYPE_PROPERTY_TYPES ADD CONSTRAINT DSTPT_PRTY_FK FOREIGN KEY (PRTY_ID) REFERENCES PROPERTY_TYPES(ID);\\012ALTER TABLE DATA_SET_PROPERTIES ADD CONSTRAINT DSPR_CVTE_FK FOREIGN KEY (CVTE_ID) REFERENCES CONTROLLED_VOCABULARY_TERMS(ID);\\012ALTER TABLE DATA_SET_PROPERTIES ADD CONSTRAINT DSPR_DSTPT_FK FOREIGN KEY (DSTPT_ID) REFERENCES DATA_SET_TYPE_PROPERTY_TYPES(ID) ON DELETE CASCADE;\\012ALTER TABLE DATA_SET_PROPERTIES ADD CONSTRAINT DSPR_DS_FK FOREIGN KEY (DS_ID) REFERENCES DATA(ID);\\012ALTER TABLE DATA_SET_PROPERTIES ADD CONSTRAINT DSPR_PERS_FK FOREIGN KEY (PERS_ID_REGISTERER) REFERENCES PERSONS(ID);\\012ALTER TABLE DATA_SET_PROPERTIES ADD CONSTRAINT DSPR_MAPR_FK FOREIGN KEY (MATE_PROP_ID) REFERENCES MATERIALS(ID);\\012\\012ALTER TABLE DATA_SET_PROPERTIES ADD CONSTRAINT DSPR_CK CHECK \\012\\011((VALUE IS NOT NULL AND CVTE_ID IS NULL AND MATE_PROP_ID IS NULL) OR \\012\\011 (VALUE IS NULL AND CVTE_ID IS NOT NULL AND MATE_PROP_ID IS NULL) OR\\012\\011 (VALUE IS NULL AND CVTE_ID IS NULL AND MATE_PROP_ID IS NOT NULL)\\012\\011);\\012\\012CREATE INDEX DSPR_CVTE_FK_I ON DATA_SET_PROPERTIES (CVTE_ID);\\012CREATE INDEX DSPR_DSTPT_FK_I ON DATA_SET_PROPERTIES (DSTPT_ID);\\012CREATE INDEX DSPR_DS_FK_I ON DATA_SET_PROPERTIES (DS_ID);\\012CREATE INDEX DSPR_PERS_FK_I ON DATA_SET_PROPERTIES (PERS_ID_REGISTERER);\\012CREATE INDEX DSTPT_DSTY_FK_I ON DATA_SET_TYPE_PROPERTY_TYPES (DSTY_ID);\\012CREATE INDEX DSTPT_PERS_FK_I ON DATA_SET_TYPE_PROPERTY_TYPES (PERS_ID_REGISTERER);\\012CREATE INDEX DSTPT_PRTY_FK_I ON DATA_SET_TYPE_PROPERTY_TYPES (PRTY_ID);\\012\\012CREATE OR REPLACE FUNCTION DATA_SET_PROPERTY_WITH_MATERIAL_DATA_TYPE_CHECK() RETURNS trigger AS $$\\012DECLARE\\012   v_type_id  CODE;\\012   v_type_id_prop  CODE;\\012BEGIN\\012   if NEW.mate_prop_id IS NOT NULL then\\012\\011\\011\\011-- find material type id of the property type \\012\\011\\011\\011select pt.maty_prop_id into v_type_id_prop \\012\\011\\011\\011  from data_set_type_property_types dstpt, property_types pt \\012\\011\\011\\011 where NEW.dstpt_id = dstpt.id AND dstpt.prty_id = pt.id;\\012\\011\\011\\012\\011\\011\\011if v_type_id_prop IS NOT NULL then\\012\\011\\011\\011\\011-- find material type id of the material which consists the entity's property value\\012\\011\\011\\011\\011select entity.maty_id into v_type_id \\012\\011\\011\\011\\011  from materials entity\\012\\011\\011\\011\\011 where NEW.mate_prop_id = entity.id;\\012\\011\\011\\011\\011if v_type_id != v_type_id_prop then\\012\\011\\011\\011\\011\\011RAISE EXCEPTION 'Insert/Update of property value referencing material (id: %) failed, as referenced material type is different than expected (id %, expected id: %).', \\012\\011\\011\\011\\011\\011\\011\\011\\011\\011\\011\\011\\011 NEW.mate_prop_id, v_type_id, v_type_id_prop;\\012\\011\\011\\011\\011end if;\\012\\011\\011\\011end if;\\012   end if;\\012   RETURN NEW;\\012END;\\012$$ LANGUAGE 'plpgsql';\\012\\012CREATE TRIGGER DATA_SET_PROPERTY_WITH_MATERIAL_DATA_TYPE_CHECK BEFORE INSERT OR UPDATE ON data_set_properties\\012    FOR EACH ROW EXECUTE PROCEDURE DATA_SET_PROPERTY_WITH_MATERIAL_DATA_TYPE_CHECK();   \\012	\N
+./sourceTest/sql/postgresql/048/.svn/text-base/017=database_version_logs.tsv.svn-base:032	source/sql/postgresql/migration/migration-031-032.sql	SUCCESS	2009-04-09 09:36:36.2	-- -------\\012-- Modify MATERIAL_BATCHES\\012-- -------\\012\\012ALTER TABLE material_batches\\012    DROP COLUMN proc_id;\\012\\012-- -------\\012-- Modify SAMPLES\\012-- -------\\012\\012ALTER TABLE samples\\012    ADD COLUMN expe_id tech_id;\\012\\012ALTER TABLE samples\\012    ADD CONSTRAINT samp_expe_fk FOREIGN KEY (expe_id) REFERENCES experiments(id);\\012\\012CREATE INDEX samp_expe_fk_i ON samples USING btree (expe_id);\\012\\012-- relink samples directly to experiments\\012\\012UPDATE samples\\012SET expe_id = (SELECT e.id FROM experiments e, procedures p, sample_inputs si \\012               WHERE si.samp_id = samples.id AND si.proc_id = p.id AND p.expe_id = e.id AND e.inva_id IS NULL);\\012\\012\\012-- -------\\012-- Modify DATA\\012-- -------\\012\\012ALTER TABLE data\\012    ADD COLUMN expe_id tech_id;\\012\\012ALTER TABLE data\\012    ADD CONSTRAINT data_expe_fk FOREIGN KEY (expe_id) REFERENCES experiments(id);\\012\\012CREATE INDEX data_expe_fk_i ON data USING btree (expe_id);\\012\\012UPDATE data\\012SET expe_id = (SELECT e.id FROM experiments e, procedures p \\012               WHERE data.proc_id_produced_by = p.id AND p.expe_id = e.id);\\012\\012ALTER TABLE data\\012    ALTER COLUMN expe_id SET NOT NULL;\\012\\012ALTER TABLE data\\012    DROP COLUMN proc_id_produced_by;\\012\\012-- -------\\012-- Drop PROCEDURES, PROCEDURE_TYPES, and SAMPLE_INPUTS\\012-- -------\\012\\012DROP TABLE sample_inputs;\\012DROP TABLE procedures;\\012DROP TABLE procedure_types;\\012\\012DROP SEQUENCE procedure_id_seq;\\012DROP SEQUENCE procedure_type_id_seq;\\012\\012-- -------\\012-- Add CODE_SEQ\\012-- -------\\012\\012CREATE SEQUENCE CODE_SEQ;\\012\\012-- -------\\012-- Add new columns to DATA_STORES\\012-- -------\\012\\012ALTER TABLE data_stores\\012    ADD COLUMN remote_url character varying(250),\\012    ADD COLUMN session_token character varying(50),\\012    ADD COLUMN modification_timestamp time_stamp DEFAULT now();\\012\\012UPDATE data_stores\\012SET remote_url = '', session_token='';\\012\\012ALTER TABLE data_stores\\012    ALTER COLUMN remote_url SET NOT NULL,\\012    ALTER COLUMN session_token SET NOT NULL;\\012\\012-- -------\\012-- Drop foreign keys onto DATA_STORES\\012-- -------\\012\\012ALTER TABLE database_instances\\012    DROP COLUMN dast_id;\\012\\012ALTER TABLE groups\\012    DROP COLUMN dast_id;\\012\\012ALTER TABLE projects\\012    DROP COLUMN dast_id;\\012\\012ALTER TABLE experiments\\012    DROP COLUMN dast_id;\\012\\012-- -------\\012-- Add foreign key from DATA onto DATA_STORES\\012-- -------\\012\\012ALTER TABLE data\\012    ADD COLUMN dast_id tech_id;\\012\\012ALTER TABLE data\\012    ADD CONSTRAINT data_dast_fk FOREIGN KEY (dast_id) REFERENCES data_stores(id);\\012\\012UPDATE data\\012SET dast_id = (select id from data_stores where code = 'STANDARD');\\012\\012ALTER TABLE data\\012    ALTER COLUMN dast_id SET NOT NULL;\\012\\012\\012------------------------------------------------------------------------------------\\012--  Purpose:  Replace trigger SAMPLE_CODE_UNIQUENESS_CHECK \\012------------------------------------------------------------------------------------\\012\\012CREATE OR REPLACE FUNCTION SAMPLE_CODE_UNIQUENESS_CHECK() RETURNS trigger AS $$\\012DECLARE\\012   counter  INTEGER;\\012BEGIN\\012    LOCK TABLE samples IN EXCLUSIVE MODE;\\012    IF (NEW.samp_id_part_of is NULL) THEN\\012        IF (NEW.dbin_id is not NULL) THEN\\012            SELECT count(*) into counter FROM samples \\012                where id != NEW.id and code = NEW.code and samp_id_part_of is NULL and dbin_id = NEW.dbin_id;\\012            IF (counter > 0) THEN\\012                RAISE EXCEPTION 'Insert/Update of Sample (Code: %) failed because database instance sample with the same code already exists.', NEW.code;\\012            END IF;\\012        ELSIF (NEW.grou_id is not NULL) THEN\\012            SELECT count(*) into counter FROM samples \\012                where id != NEW.id and code = NEW.code and samp_id_part_of is NULL and grou_id = NEW.grou_id;\\012            IF (counter > 0) THEN\\012                RAISE EXCEPTION 'Insert/Update of Sample (Code: %) failed because group sample with the same code already exists.', NEW.code;\\012            END IF;\\012        END IF;\\012        ELSE\\012        IF (NEW.dbin_id is not NULL) THEN\\012            SELECT count(*) into counter FROM samples \\012                where id != NEW.id and code = NEW.code and samp_id_part_of = NEW.samp_id_part_of and dbin_id = NEW.dbin_id;\\012            IF (counter > 0) THEN\\012                RAISE EXCEPTION 'Insert/Update of Sample (Code: %) failed because database instance sample with the same code and being the part of the same parent already exists.', NEW.code;\\012            END IF;\\012        ELSIF (NEW.grou_id is not NULL) THEN\\012            SELECT count(*) into counter FROM samples \\012                where id != NEW.id and code = NEW.code and samp_id_part_of = NEW.samp_id_part_of and grou_id = NEW.grou_id;\\012            IF (counter > 0) THEN\\012                RAISE EXCEPTION 'Insert/Update of Sample (Code: %) failed because group sample with the same code and being the part of the same parent already exists.', NEW.code;\\012            END IF;\\012        END IF;\\012        END IF;   \\012   RETURN NEW;\\012END;\\012$$ LANGUAGE 'plpgsql';\\012\\012\\012\\012	\N
+./sourceTest/sql/postgresql/048/.svn/text-base/017=database_version_logs.tsv.svn-base:034	source/sql/postgresql/migration/migration-033-034.sql	SUCCESS	2009-05-26 08:32:49.935	------------------------------------------------------------------------------------\\012-- Create sequence for generating permanent identifiers starting with nextval of existing dataset sequence.\\012------------------------------------------------------------------------------------\\012CREATE FUNCTION CREATE_SEQUENCE(EXISTING_SEQUENCE VARCHAR, NEW_SEQUENCE VARCHAR) RETURNS VOID AS $$\\012DECLARE\\012  CURR_SEQ_VAL   INTEGER;\\012BEGIN\\012  SELECT INTO CURR_SEQ_VAL NEXTVAL(EXISTING_SEQUENCE);\\012  EXECUTE 'CREATE SEQUENCE ' || NEW_SEQUENCE || ' START WITH ' || CURR_SEQ_VAL;\\012  RETURN;\\012END;\\012$$ LANGUAGE 'plpgsql';\\012\\012SELECT CREATE_SEQUENCE('DATA_ID_SEQ', 'PERM_ID_SEQ');\\012DROP FUNCTION CREATE_SEQUENCE(VARCHAR, VARCHAR);\\012\\012------------------------------------------------------------------------------------\\012-- Add perm_id columns to samples and experiments.\\012------------------------------------------------------------------------------------\\012ALTER TABLE SAMPLES ADD COLUMN PERM_ID CODE;\\012ALTER TABLE EXPERIMENTS ADD COLUMN PERM_ID CODE;\\012\\012UPDATE SAMPLES SET PERM_ID = to_char(registration_timestamp,'YYYYMMDDHHSSMS') || '-' || NEXTVAL('PERM_ID_SEQ');\\012UPDATE EXPERIMENTS SET PERM_ID = to_char(registration_timestamp,'YYYYMMDDHHSSMS') || '-' || NEXTVAL('PERM_ID_SEQ');\\012ALTER TABLE SAMPLES ALTER COLUMN PERM_ID SET NOT NULL;\\012ALTER TABLE EXPERIMENTS ALTER COLUMN PERM_ID SET NOT NULL;\\012ALTER TABLE SAMPLES ADD CONSTRAINT SAMP_PI_UK UNIQUE(PERM_ID);\\012ALTER TABLE EXPERIMENTS ADD CONSTRAINT EXPE_PI_UK UNIQUE(PERM_ID);\\012\\012\\012------------------------------------------------------------------------------------\\012-- Add column is_chosen_from_list to controlled_vocabularies.\\012------------------------------------------------------------------------------------\\012ALTER TABLE controlled_vocabularies ADD COLUMN is_chosen_from_list BOOLEAN_CHAR NOT NULL DEFAULT TRUE;\\012ALTER TABLE controlled_vocabularies ADD COLUMN source_uri CHARACTER VARYING(250);\\012------------------------------------------------------------------------------------\\012-- Modify Data table - remove arc connection between Sample and Data table, use a flag instead\\012------------------------------------------------------------------------------------\\012\\012-- add new columns\\012\\012ALTER TABLE data\\012    ADD COLUMN is_derived boolean_char;\\012ALTER TABLE data\\012    ADD COLUMN samp_id tech_id;\\012\\012-- update values in new columns\\012\\012UPDATE data\\012    SET is_derived = (samp_id_derived_from IS NOT NULL); \\012UPDATE data\\012    SET samp_id = samp_id_derived_from \\012    WHERE is_derived = 'TRUE';\\012UPDATE data\\012    SET samp_id = samp_id_acquired_from \\012    WHERE is_derived = 'FALSE';\\012\\012-- add constraints and indexes to new columns\\012\\012ALTER TABLE data\\012    ALTER COLUMN is_derived SET NOT NULL;\\012ALTER TABLE data\\012    ALTER COLUMN samp_id SET NOT NULL;   \\012ALTER TABLE data\\012    ADD CONSTRAINT data_samp_fk FOREIGN KEY (samp_id) REFERENCES samples (id);\\012CREATE INDEX data_samp_fk_i ON data USING btree (samp_id);\\012\\012-- remove old columns\\012\\012ALTER TABLE data\\012    DROP COLUMN samp_id_acquired_from;\\012ALTER TABLE data\\012    DROP COLUMN samp_id_derived_from;\\012    \\012------------------------------------------------------------------------------------\\012-- Granting SELECT privilege to group openbis_readonly\\012------------------------------------------------------------------------------------\\012\\012GRANT SELECT ON SEQUENCE attachment_content_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE attachment_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE code_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE controlled_vocabulary_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE cvte_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE data_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE data_set_property_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE data_set_relationship_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE data_set_type_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE data_store_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE data_type_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE database_instance_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE dstpt_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE etpt_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE event_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE experiment_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE experiment_property_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE experiment_type_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE file_format_type_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE group_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE invalidation_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE locator_type_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE material_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE material_property_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE material_type_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE mtpt_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE perm_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE person_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE project_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE property_type_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE role_assignment_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE sample_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE sample_property_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE sample_type_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE stpt_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE attachment_contents TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE attachments TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE controlled_vocabularies TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE controlled_vocabulary_terms TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE data TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE data_set_properties TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE data_set_relationships TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE data_set_type_property_types TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE data_set_types TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE data_stores TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE data_types TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE database_instances TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE database_version_logs TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE events TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE experiment_properties TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE experiment_type_property_types TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE experiment_types TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE experiments TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE external_data TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE file_format_types TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE groups TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE invalidations TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE locator_types TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE material_properties TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE material_type_property_types TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE material_types TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE materials TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE persons TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE projects TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE property_types TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE role_assignments TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE sample_properties TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE sample_type_property_types TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE sample_types TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE samples TO GROUP OPENBIS_READONLY;\\012\\012------------------------------------------------------------------------------------\\012-- Delete MATERIAL_BATCHES table\\012------------------------------------------------------------------------------------\\012\\012-- WARNING: Potential data lost!!!\\012-- WARNING: Potential data lost!!!\\012-- WARNING: Potential data lost!!!\\012\\012DROP TABLE SAMPLE_MATERIAL_BATCHES;\\012DROP TABLE MATERIAL_BATCHES;\\012DROP SEQUENCE MATERIAL_BATCH_ID_SEQ;\\012\\012------------------------------------------------------------------------------------\\012-- Delete MATE_ID_INHIBITOR_OF from table MATERIALS\\012------------------------------------------------------------------------------------\\012\\012-- WARNING: Potential data lost!!!\\012-- WARNING: Potential data lost!!!\\012-- WARNING: Potential data lost!!!\\012\\012ALTER TABLE MATERIALS DROP COLUMN MATE_ID_INHIBITOR_OF;\\012	\N
+./sourceTest/sql/postgresql/048/.svn/text-base/017=database_version_logs.tsv.svn-base:041	source/sql/postgresql/migration/migration-040-041.sql	SUCCESS	2009-09-14 13:48:57.539	-- Create FILTERS table\\012\\012CREATE TABLE FILTERS (ID TECH_ID NOT NULL, DBIN_ID TECH_ID NOT NULL, NAME VARCHAR(200) NOT NULL, DESCRIPTION DESCRIPTION_1000,REGISTRATION_TIMESTAMP TIME_STAMP_DFL NOT NULL DEFAULT CURRENT_TIMESTAMP, PERS_ID_REGISTERER TECH_ID NOT NULL, MODIFICATION_TIMESTAMP TIME_STAMP DEFAULT CURRENT_TIMESTAMP, EXPRESSION VARCHAR(2000) NOT NULL, IS_PUBLIC BOOLEAN NOT NULL, GRID_ID VARCHAR(200) NOT NULL);\\012CREATE SEQUENCE FILTER_ID_SEQ;\\012ALTER TABLE FILTERS ADD CONSTRAINT FILT_PK PRIMARY KEY(ID);\\012ALTER TABLE FILTERS ADD CONSTRAINT FILT_BK_UK UNIQUE(NAME, DBIN_ID, GRID_ID);\\012ALTER TABLE FILTERS ADD CONSTRAINT FILT_PERS_FK FOREIGN KEY (PERS_ID_REGISTERER) REFERENCES PERSONS(ID);\\012ALTER TABLE FILTERS ADD CONSTRAINT FILT_DBIN_FK FOREIGN KEY (DBIN_ID) REFERENCES DATABASE_INSTANCES(ID);\\012CREATE INDEX FILT_PERS_FK_I ON FILTERS (PERS_ID_REGISTERER);\\012CREATE INDEX FILT_DBIN_FK_I ON FILTERS (DBIN_ID);\\012GRANT SELECT ON SEQUENCE filter_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE filters TO GROUP OPENBIS_READONLY;\\012\\012-- Add missing foreign key to role assignments authorization group\\012ALTER TABLE ROLE_ASSIGNMENTS ADD CONSTRAINT ROAS_AG_FK_GRANTEE FOREIGN KEY (AG_ID_GRANTEE) REFERENCES AUTHORIZATION_GROUPS(ID);\\012\\012--------------------------------------------------------------------------------------------------\\012-- Modify dataset connections:\\012-- 1. connection with sample shouldn't be mandatory any more\\012-- 2. introduce an arc condition that dataset cannot be connected with a sample and a parent dataset at the same time\\012--------------------------------------------------------------------------------------------------\\012\\012-- Weaken data-sample connection constraint - allow dataset to have no connection with sample\\012ALTER TABLE data ALTER COLUMN samp_id DROP NOT NULL;\\012\\012-- Remove data-sample connection for datasets that have a parent\\012\\012UPDATE data \\012   SET samp_id = NULL \\012 WHERE id IN (SELECT DISTINCT data_id_child FROM data_set_relationships);\\012\\012-- With PostgreSQL 8.4 one can check that before migration there were no cycles in dataset relationships:\\012--\\012-- WITH RECURSIVE data_set_parents(id, parent_ids, cycle) AS (\\012--         SELECT  r.data_id_child AS id, \\012--                 ARRAY[CAST (r.data_id_parent AS bigint)] AS parent_ids, \\012--                 false AS cycle \\012--         FROM data_set_relationships r\\012--     UNION ALL\\012--         SELECT  r.data_id_child,\\012--                 CAST (r.data_id_parent AS bigint) || p.parent_ids,\\012--                 r.data_id_child = ANY(p.parent_ids)\\012--         FROM data_set_relationships r, data_set_parents p\\012--         WHERE r.data_id_parent = p.id AND NOT cycle\\012-- )\\012-- SELECT count(*) AS cycles FROM data_set_parents WHERE cycle = true;\\012\\012---------------------------------------------------------------------------------------------------\\012--  Purpose:  Create DEFERRED triggers:\\012--            * check_dataset_relationships_on_data_table_modification,\\012--            * check_dataset_relationships_on_relationships_table_modification.\\012--            They check that after all modifications of database (just before commit) \\012--            if 'data'/'data_set_relationships' tables are among modified tables \\012--            dataset is not connected with a sample and a parent dataset at the same time.\\012--            This connections are held in two different tables so simple immediate trigger \\012--            with arc check cannot be used and we need two deferred triggers.\\012----------------------------------------------------------------------------------------------------\\012\\012-- trigger for 'data' table\\012\\012CREATE OR REPLACE FUNCTION check_dataset_relationships_on_data_table_modification() RETURNS trigger AS $$\\012DECLARE\\012\\011counter\\011INTEGER;\\012BEGIN\\012\\011-- if there is a connection with a Sample there should not be any connection with a parent Data Set\\012\\011IF (NEW.samp_id IS NOT NULL) THEN\\012\\011\\011-- count number of parents\\012\\011\\011SELECT count(*) INTO counter \\012\\011\\011\\011FROM data_set_relationships \\012\\011\\011\\011WHERE data_id_child = OLD.id;\\012\\011\\011IF (counter > 0) THEN\\012\\011\\011\\011RAISE EXCEPTION 'Insert/Update of Data Set (Code: %) failed because it cannot be connected with a Sample and a parent Data Set at the same time.', OLD.code;\\012\\011\\011END IF;\\012\\011END IF;\\012  RETURN NEW;\\012END;\\012$$ LANGUAGE 'plpgsql';\\012\\012CREATE CONSTRAINT TRIGGER check_dataset_relationships_on_data_table_modification \\012  AFTER INSERT OR UPDATE ON data\\012\\011DEFERRABLE INITIALLY DEFERRED\\012\\011FOR EACH ROW \\012\\011EXECUTE PROCEDURE check_dataset_relationships_on_data_table_modification();\\012\\012-- trigger for 'data_set_relationships'\\012\\012CREATE OR REPLACE FUNCTION check_dataset_relationships_on_relationships_table_modification() RETURNS trigger AS $$\\012DECLARE\\012\\011counter\\011INTEGER;\\012\\011sample_id\\011TECH_ID;\\012\\011data_code\\011CODE;\\012BEGIN\\012\\011-- child will have a parent added so it should not be connected with any sample\\012\\011SELECT samp_id, code INTO sample_id, data_code \\012\\011\\011FROM data \\012\\011\\011WHERE id = NEW.data_id_child;\\012\\011IF (sample_id IS NOT NULL) THEN\\012\\011\\011RAISE EXCEPTION 'Insert/Update of Data Set (Code: %) failed because it cannot be connected to a Sample and to a parent Data Set at the same time.', data_code;\\012\\011END IF;\\012\\011RETURN NEW;\\012END;\\012$$ LANGUAGE 'plpgsql';\\012  \\012CREATE CONSTRAINT TRIGGER check_dataset_relationships_on_relationships_table_modification \\012  AFTER INSERT OR UPDATE ON data_set_relationships\\012\\011DEFERRABLE INITIALLY DEFERRED\\012\\011FOR EACH ROW \\012\\011EXECUTE PROCEDURE check_dataset_relationships_on_relationships_table_modification();\\012	\N
+./sourceTest/sql/postgresql/048/.svn/text-base/schema-048.sql.svn-base:    LANGUAGE plpgsql
+./sourceTest/sql/postgresql/048/.svn/text-base/schema-048.sql.svn-base:    LANGUAGE plpgsql
+./sourceTest/sql/postgresql/048/.svn/text-base/schema-048.sql.svn-base:    LANGUAGE plpgsql
+./sourceTest/sql/postgresql/048/.svn/text-base/schema-048.sql.svn-base:    LANGUAGE plpgsql
+./sourceTest/sql/postgresql/048/.svn/text-base/schema-048.sql.svn-base:    LANGUAGE plpgsql
+./sourceTest/sql/postgresql/048/.svn/text-base/schema-048.sql.svn-base:    LANGUAGE plpgsql
+./sourceTest/sql/postgresql/048/.svn/text-base/schema-048.sql.svn-base:    LANGUAGE plpgsql
+./sourceTest/sql/postgresql/048/.svn/text-base/schema-048.sql.svn-base:    LANGUAGE plpgsql
+./sourceTest/sql/postgresql/048/.svn/text-base/schema-048.sql.svn-base:    LANGUAGE plpgsql
+./sourceTest/sql/postgresql/048/.svn/text-base/schema-048.sql.svn-base:    LANGUAGE plpgsql
+./sourceTest/sql/postgresql/048/017=database_version_logs.tsv:027	D:\\User\\felmer\\dev-workspace\\openbis/source/sql/postgresql/027/function-027.sql	SUCCESS	2008-11-05 09:18:00.403	-- Creating Functions\\012\\012------------------------------------------------------------------------------------\\012--  Purpose:  Create function RENAME_SEQUENCE() that is required for renaming the sequences belonging to tables\\012------------------------------------------------------------------------------------\\012CREATE FUNCTION RENAME_SEQUENCE(OLD_NAME VARCHAR, NEW_NAME VARCHAR) RETURNS INTEGER AS $$\\012DECLARE\\012  CURR_SEQ_VAL   INTEGER;\\012BEGIN\\012  SELECT INTO CURR_SEQ_VAL NEXTVAL(OLD_NAME);\\012  EXECUTE 'CREATE SEQUENCE ' || NEW_NAME || ' START WITH ' || CURR_SEQ_VAL;\\012  EXECUTE 'DROP SEQUENCE ' || OLD_NAME;\\012  RETURN CURR_SEQ_VAL;\\012END;\\012$$ LANGUAGE 'plpgsql';\\012\\012\\012------------------------------------------------------------------------------------\\012--  Purpose:  Create trigger CONTROLLED_VOCABULARY_CHECK \\012------------------------------------------------------------------------------------\\012\\012CREATE OR REPLACE FUNCTION CONTROLLED_VOCABULARY_CHECK() RETURNS trigger AS $$\\012DECLARE\\012   v_code  CODE;\\012BEGIN\\012\\012   select code into v_code from data_types where id = NEW.daty_id;\\012\\012   -- Check if the data is of type "CONTROLLEDVOCABULARY"\\012   if v_code = 'CONTROLLEDVOCABULARY' then\\012      if NEW.covo_id IS NULL then\\012         RAISE EXCEPTION 'Insert/Update of Property Type (Code: %) failed, as its Data Type is CONTROLLEDVOCABULARY, but it is not linked to a Controlled Vocabulary.', NEW.code;\\012      end if;\\012   end if;\\012\\012   RETURN NEW;\\012\\012END;\\012$$ LANGUAGE 'plpgsql';\\012\\012CREATE TRIGGER CONTROLLED_VOCABULARY_CHECK BEFORE INSERT OR UPDATE ON PROPERTY_TYPES\\012    FOR EACH ROW EXECUTE PROCEDURE CONTROLLED_VOCABULARY_CHECK();\\012\\012\\012------------------------------------------------------------------------------------\\012--  Purpose:  Create trigger EXTERNAL_DATA_STORAGE_FORMAT_CHECK \\012------------------------------------------------------------------------------------\\012\\012CREATE OR REPLACE FUNCTION EXTERNAL_DATA_STORAGE_FORMAT_CHECK() RETURNS trigger AS $$\\012DECLARE\\012   v_covo_code  CODE;\\012   data_code CODE;\\012BEGIN\\012\\012   select code into v_covo_code from controlled_vocabularies\\012      where is_internal_namespace = true and \\012         id = (select covo_id from controlled_vocabulary_terms where id = NEW.cvte_id_stor_fmt);\\012   -- Check if the data storage format is a term of the controlled vocabulary "STORAGE_FORMAT"\\012   if v_covo_code != 'STORAGE_FORMAT' then\\012      select code into data_code from data where id = NEW.data_id; \\012      RAISE EXCEPTION 'Insert/Update of Data (Code: %) failed, as its Storage Format is %, but is required to be STORAGE_FORMAT.', data_code, v_covo_code;\\012   end if;\\012\\012   RETURN NEW;\\012\\012END;\\012$$ LANGUAGE 'plpgsql';\\012\\012CREATE TRIGGER EXTERNAL_DATA_STORAGE_FORMAT_CHECK BEFORE INSERT OR UPDATE ON EXTERNAL_DATA\\012    FOR EACH ROW EXECUTE PROCEDURE EXTERNAL_DATA_STORAGE_FORMAT_CHECK();\\012\\012------------------------------------------------------------------------------------\\012--  Purpose:  Create trigger SAMPLE_CODE_UNIQUENESS_CHECK \\012------------------------------------------------------------------------------------\\012\\012CREATE OR REPLACE FUNCTION SAMPLE_CODE_UNIQUENESS_CHECK() RETURNS trigger AS $$\\012DECLARE\\012   counter  INTEGER;\\012BEGIN\\012\\011IF (NEW.samp_id_part_of is NULL) THEN\\012\\011\\011IF (NEW.dbin_id is not NULL) THEN\\012\\011\\011\\011SELECT count(*) into counter FROM samples \\012\\011\\011\\011\\011where id != NEW.id and code = NEW.code and samp_id_part_of is NULL and dbin_id = NEW.dbin_id;\\012\\011\\011\\011IF (counter > 0) THEN\\012\\011\\011\\011\\011RAISE EXCEPTION 'Insert/Update of Sample (Code: %) failed because database instance sample with the same code already exists.', NEW.code;\\012\\011\\011\\011END IF;\\012\\011\\011ELSIF (NEW.grou_id is not NULL) THEN\\012\\011\\011\\011SELECT count(*) into counter FROM samples \\012\\011\\011\\011\\011where id != NEW.id and code = NEW.code and samp_id_part_of is NULL and grou_id = NEW.grou_id;\\012\\011\\011\\011IF (counter > 0) THEN\\012\\011\\011\\011\\011RAISE EXCEPTION 'Insert/Update of Sample (Code: %) failed because group sample with the same code already exists.', NEW.code;\\012\\011\\011\\011END IF;\\012\\011\\011END IF;\\012        ELSE\\012\\011\\011IF (NEW.dbin_id is not NULL) THEN\\012\\011\\011\\011SELECT count(*) into counter FROM samples \\012\\011\\011\\011\\011where id != NEW.id and code = NEW.code and samp_id_part_of = NEW.samp_id_part_of and dbin_id = NEW.dbin_id;\\012\\011\\011\\011IF (counter > 0) THEN\\012\\011\\011\\011\\011RAISE EXCEPTION 'Insert/Update of Sample (Code: %) failed because database instance sample with the same code and being the part of the same parent already exists.', NEW.code;\\012\\011\\011\\011END IF;\\012\\011\\011ELSIF (NEW.grou_id is not NULL) THEN\\012\\011\\011\\011SELECT count(*) into counter FROM samples \\012\\011\\011\\011\\011where id != NEW.id and code = NEW.code and samp_id_part_of = NEW.samp_id_part_of and grou_id = NEW.grou_id;\\012\\011\\011\\011IF (counter > 0) THEN\\012\\011\\011\\011\\011RAISE EXCEPTION 'Insert/Update of Sample (Code: %) failed because group sample with the same code and being the part of the same parent already exists.', NEW.code;\\012\\011\\011\\011END IF;\\012\\011\\011END IF;\\012        END IF;   \\012   RETURN NEW;\\012END;\\012$$ LANGUAGE 'plpgsql';\\012\\012CREATE TRIGGER SAMPLE_CODE_UNIQUENESS_CHECK BEFORE INSERT OR UPDATE ON SAMPLES\\012    FOR EACH ROW EXECUTE PROCEDURE SAMPLE_CODE_UNIQUENESS_CHECK();\\012	\N
+./sourceTest/sql/postgresql/048/017=database_version_logs.tsv:028	source/sql/postgresql/migration/migration-027-028.sql	SUCCESS	2008-11-18 13:24:17.508	-- Create EXPERIMENT_ATTACHMENT_CONTENTS.\\012CREATE TABLE EXPERIMENT_ATTACHMENT_CONTENTS (ID TECH_ID NOT NULL,VALUE FILE NOT NULL);\\012CREATE SEQUENCE EXPERIMENT_ATTACHMENT_CONTENT_ID_SEQ;\\012ALTER TABLE EXPERIMENT_ATTACHMENT_CONTENTS ADD CONSTRAINT EXAC_PK PRIMARY KEY(ID);\\012\\012-- Alter EXPERIMENT_ATTACHMENTS by adding the new column which has a NULL constraint.\\012-- The NOT NULL constraint is added later on.\\012ALTER TABLE EXPERIMENT_ATTACHMENTS ADD COLUMN EXAC_ID TECH_ID;\\012\\012-- Does the VALUE migration between EXPERIMENT_ATTACHMENTS to EXPERIMENT_ATTACHMENT_CONTENTS.\\012CREATE OR REPLACE FUNCTION move_exp_att_content() RETURNS integer AS $$\\012DECLARE\\012    rec RECORD;\\012    seq BIGINT;\\012BEGIN\\012  FOR rec IN SELECT id, value FROM EXPERIMENT_ATTACHMENTS LOOP\\012  \\011seq := nextval('EXPERIMENT_ATTACHMENT_CONTENT_ID_SEQ');\\012    INSERT INTO EXPERIMENT_ATTACHMENT_CONTENTS (id, value) VALUES (seq, rec.value);\\012    UPDATE EXPERIMENT_ATTACHMENTS SET exac_id = seq WHERE id = rec.id;\\012  END LOOP;\\012  RETURN 1;\\012END;\\012$$ LANGUAGE 'plpgsql';\\012\\012-- Call the function.\\012SELECT move_exp_att_content();\\012DROP FUNCTION move_exp_att_content();\\012\\012\\012-- Finish EXPERIMENT_ATTACHMENTS changes.\\012ALTER TABLE EXPERIMENT_ATTACHMENTS ADD CONSTRAINT EXAT_CONT_FK FOREIGN KEY (EXAC_ID) REFERENCES EXPERIMENT_ATTACHMENT_CONTENTS(ID);\\012ALTER TABLE EXPERIMENT_ATTACHMENTS DROP COLUMN VALUE;\\012ALTER TABLE EXPERIMENT_ATTACHMENTS ALTER COLUMN EXAC_ID SET NOT NULL;\\012	\N
+./sourceTest/sql/postgresql/048/017=database_version_logs.tsv:029	source/sql/postgresql/migration/migration-028-029.sql	SUCCESS	2009-03-18 10:50:20.105	-- -------\\012-- add modification_timestamp field to allow edition with Hibernate\\012-- -------\\012\\012ALTER TABLE samples\\012\\011ADD COLUMN modification_timestamp TIME_STAMP DEFAULT CURRENT_TIMESTAMP;\\012\\012ALTER TABLE experiments\\012\\011ADD COLUMN modification_timestamp TIME_STAMP DEFAULT CURRENT_TIMESTAMP;\\012\\012ALTER TABLE materials\\012\\011ADD COLUMN modification_timestamp TIME_STAMP DEFAULT CURRENT_TIMESTAMP;\\012\\012ALTER TABLE experiment_properties\\012\\011ADD COLUMN modification_timestamp TIME_STAMP DEFAULT CURRENT_TIMESTAMP;\\012\\012ALTER TABLE material_properties\\012\\011ADD COLUMN modification_timestamp TIME_STAMP DEFAULT CURRENT_TIMESTAMP;\\012\\012ALTER TABLE sample_properties\\012\\011ADD COLUMN modification_timestamp TIME_STAMP DEFAULT CURRENT_TIMESTAMP;\\012\\012-- -------\\012-- add property data type which references materials\\012-- -------\\012\\012ALTER TABLE property_types\\012\\011ADD COLUMN maty_prop_id tech_id;\\012\\012ALTER TABLE property_types\\012\\011ADD CONSTRAINT prty_maty_fk FOREIGN KEY (maty_prop_id) REFERENCES material_types(id);\\012\\012ALTER TABLE experiment_properties\\012\\011ADD COLUMN mate_prop_id tech_id;\\012\\012ALTER TABLE material_properties\\012\\011ADD COLUMN mate_prop_id tech_id;\\012\\012ALTER TABLE sample_properties\\012\\011ADD COLUMN mate_prop_id tech_id;\\012\\012ALTER TABLE experiment_properties\\012\\011ADD CONSTRAINT expr_mapr_fk FOREIGN KEY (mate_prop_id) REFERENCES materials(id);\\012\\012ALTER TABLE material_properties\\012\\011ADD CONSTRAINT mapr_mapr_fk FOREIGN KEY (mate_prop_id) REFERENCES materials(id);\\012\\012ALTER TABLE sample_properties\\012\\011ADD CONSTRAINT sapr_mapr_fk FOREIGN KEY (mate_prop_id) REFERENCES materials(id);\\012\\012insert into data_types\\012(id\\012 ,code\\012 ,description)\\012 values \\012 (nextval('DATA_TYPE_ID_SEQ')\\012 ,'MATERIAL'\\012 ,'Reference to a material'\\012);\\012\\012ALTER TABLE MATERIAL_PROPERTIES DROP CONSTRAINT MAPR_CK;\\012ALTER TABLE MATERIAL_PROPERTIES ADD CONSTRAINT MAPR_CK CHECK \\012\\011((VALUE IS NOT NULL AND CVTE_ID IS NULL AND MATE_PROP_ID IS NULL) OR \\012\\011 (VALUE IS NULL AND CVTE_ID IS NOT NULL AND MATE_PROP_ID IS NULL) OR\\012\\011 (VALUE IS NULL AND CVTE_ID IS NULL AND MATE_PROP_ID IS NOT NULL)\\012\\011);\\012\\012ALTER TABLE EXPERIMENT_PROPERTIES DROP CONSTRAINT EXPR_CK;\\012ALTER TABLE EXPERIMENT_PROPERTIES ADD CONSTRAINT EXPR_CK CHECK \\012\\011((VALUE IS NOT NULL AND CVTE_ID IS NULL AND MATE_PROP_ID IS NULL) OR \\012\\011 (VALUE IS NULL AND CVTE_ID IS NOT NULL AND MATE_PROP_ID IS NULL) OR\\012\\011 (VALUE IS NULL AND CVTE_ID IS NULL AND MATE_PROP_ID IS NOT NULL)\\012\\011);\\012\\012ALTER TABLE SAMPLE_PROPERTIES DROP CONSTRAINT SAPR_CK;\\012ALTER TABLE SAMPLE_PROPERTIES ADD CONSTRAINT SAPR_CK CHECK \\012\\011((VALUE IS NOT NULL AND CVTE_ID IS NULL AND MATE_PROP_ID IS NULL) OR \\012\\011 (VALUE IS NULL AND CVTE_ID IS NOT NULL AND MATE_PROP_ID IS NULL) OR\\012\\011 (VALUE IS NULL AND CVTE_ID IS NULL AND MATE_PROP_ID IS NOT NULL)\\012\\011);\\012\\012------------------------------------------------------------------------------------\\012--  Purpose:  Create trigger MATERIAL/SAMPLE/EXPERIMENT _PROPERTY_WITH_MATERIAL_DATA_TYPE_CHECK\\012--            It checks that if material property value is assigned to the entity,\\012--\\011\\011\\011\\011\\011\\011then the material type is equal to the one described by property type.\\012------------------------------------------------------------------------------------\\012\\012CREATE OR REPLACE FUNCTION MATERIAL_PROPERTY_WITH_MATERIAL_DATA_TYPE_CHECK() RETURNS trigger AS $$\\012DECLARE\\012   v_type_id  CODE;\\012   v_type_id_prop  CODE;\\012BEGIN\\012   if NEW.mate_prop_id IS NOT NULL then\\012\\011\\011\\011-- find material type id of the property type \\012\\011\\011\\011select pt.maty_prop_id into v_type_id_prop \\012\\011\\011\\011  from material_type_property_types etpt, property_types pt \\012\\011\\011\\011 where NEW.mtpt_id = etpt.id AND etpt.prty_id = pt.id;\\012\\011\\011\\012\\011\\011\\011if v_type_id_prop IS NOT NULL then\\012\\011\\011\\011\\011-- find material type id of the material which consists the entity's property value\\012\\011\\011\\011\\011select entity.maty_id into v_type_id \\012\\011\\011\\011\\011  from materials entity\\012\\011\\011\\011\\011 where NEW.mate_prop_id = entity.id;\\012\\011\\011\\011\\011if v_type_id != v_type_id_prop then\\012\\011\\011\\011\\011\\011RAISE EXCEPTION 'Insert/Update of property value referencing material (id: %) failed, as referenced material type is different than expected (id %, expected id: %).', \\012\\011\\011\\011\\011\\011\\011\\011 NEW.mate_prop_id, v_type_id, v_type_id_prop;\\012\\011\\011\\011\\011end if;\\012\\011\\011\\011end if;\\012   end if;\\012   RETURN NEW;\\012END;\\012$$ LANGUAGE 'plpgsql';\\012\\012CREATE TRIGGER MATERIAL_PROPERTY_WITH_MATERIAL_DATA_TYPE_CHECK BEFORE INSERT OR UPDATE ON material_properties\\012    FOR EACH ROW EXECUTE PROCEDURE MATERIAL_PROPERTY_WITH_MATERIAL_DATA_TYPE_CHECK();\\012    \\012CREATE OR REPLACE FUNCTION SAMPLE_PROPERTY_WITH_MATERIAL_DATA_TYPE_CHECK() RETURNS trigger AS $$\\012DECLARE\\012   v_type_id  CODE;\\012   v_type_id_prop  CODE;\\012BEGIN\\012   if NEW.mate_prop_id IS NOT NULL then\\012\\011\\011\\011-- find material type id of the property type \\012\\011\\011\\011select pt.maty_prop_id into v_type_id_prop \\012\\011\\011\\011  from sample_type_property_types etpt, property_types pt \\012\\011\\011\\011 where NEW.stpt_id = etpt.id AND etpt.prty_id = pt.id;\\012\\011\\011\\012\\011\\011\\011if v_type_id_prop IS NOT NULL then\\012\\011\\011\\011\\011-- find material type id of the material which consists the entity's property value\\012\\011\\011\\011\\011select entity.maty_id into v_type_id \\012\\011\\011\\011\\011  from materials entity\\012\\011\\011\\011\\011 where NEW.mate_prop_id = entity.id;\\012\\011\\011\\011\\011if v_type_id != v_type_id_prop then\\012\\011\\011\\011\\011\\011RAISE EXCEPTION 'Insert/Update of property value referencing material (id: %) failed, as referenced material type is different than expected (id %, expected id: %).', \\012\\011\\011\\011\\011\\011\\011\\011\\011\\011\\011\\011\\011 NEW.mate_prop_id, v_type_id, v_type_id_prop;\\012\\011\\011\\011\\011end if;\\012\\011\\011\\011end if;\\012   end if;\\012   RETURN NEW;\\012END;\\012$$ LANGUAGE 'plpgsql';\\012\\012CREATE TRIGGER SAMPLE_PROPERTY_WITH_MATERIAL_DATA_TYPE_CHECK BEFORE INSERT OR UPDATE ON sample_properties\\012    FOR EACH ROW EXECUTE PROCEDURE SAMPLE_PROPERTY_WITH_MATERIAL_DATA_TYPE_CHECK();\\012    \\012CREATE OR REPLACE FUNCTION EXPERIMENT_PROPERTY_WITH_MATERIAL_DATA_TYPE_CHECK() RETURNS trigger AS $$\\012DECLARE\\012   v_type_id  CODE;\\012   v_type_id_prop  CODE;\\012BEGIN\\012   if NEW.mate_prop_id IS NOT NULL then\\012\\011\\011\\011-- find material type id of the property type \\012\\011\\011\\011select pt.maty_prop_id into v_type_id_prop \\012\\011\\011\\011  from experiment_type_property_types etpt, property_types pt \\012\\011\\011\\011 where NEW.etpt_id = etpt.id AND etpt.prty_id = pt.id;\\012\\011\\011\\012\\011\\011\\011if v_type_id_prop IS NOT NULL then\\012\\011\\011\\011\\011-- find material type id of the material which consists the entity's property value\\012\\011\\011\\011\\011select entity.maty_id into v_type_id \\012\\011\\011\\011\\011  from materials entity\\012\\011\\011\\011\\011 where NEW.mate_prop_id = entity.id;\\012\\011\\011\\011\\011if v_type_id != v_type_id_prop then\\012\\011\\011\\011\\011\\011RAISE EXCEPTION 'Insert/Update of property value referencing material (id: %) failed, as referenced material type is different than expected (id %, expected id: %).', \\012\\011\\011\\011\\011\\011\\011\\011\\011\\011\\011\\011\\011 NEW.mate_prop_id, v_type_id, v_type_id_prop;\\012\\011\\011\\011\\011end if;\\012\\011\\011\\011end if;\\012   end if;\\012   RETURN NEW;\\012END;\\012$$ LANGUAGE 'plpgsql';\\012\\012CREATE TRIGGER EXPERIMENT_PROPERTY_WITH_MATERIAL_DATA_TYPE_CHECK BEFORE INSERT OR UPDATE ON experiment_properties\\012    FOR EACH ROW EXECUTE PROCEDURE EXPERIMENT_PROPERTY_WITH_MATERIAL_DATA_TYPE_CHECK();\\012       \\012-- -------\\012-- remove the reminescents of the OBSERVABLE_TYPE\\012-- -------\\012\\012ALTER TABLE data\\012\\011DROP CONSTRAINT data_obty_fk;\\012\\012ALTER TABLE data_set_types\\012\\011DROP CONSTRAINT obty_pk;\\012\\012ALTER TABLE data_set_types\\012\\011ADD CONSTRAINT dsty_pk PRIMARY KEY (id);\\012\\012ALTER TABLE data\\012\\011ADD CONSTRAINT data_dsty_fk FOREIGN KEY (dsty_id) REFERENCES data_set_types(id);\\012\\012ALTER TABLE data_set_types\\012\\011DROP CONSTRAINT obty_bk_uk;\\012\\012ALTER TABLE data_set_types\\012\\011DROP CONSTRAINT obty_dbin_fk;\\012\\012ALTER TABLE data_set_types\\012\\011ADD CONSTRAINT dsty_bk_uk UNIQUE (code, dbin_id);\\012\\012ALTER TABLE data_set_types\\012\\011ADD CONSTRAINT dsty_dbin_fk FOREIGN KEY (dbin_id) REFERENCES database_instances(id);\\012\\012DROP INDEX data_obty_fk_i;\\012\\012CREATE INDEX data_dsty_fk_i ON data(dsty_id);\\012	\N
+./sourceTest/sql/postgresql/048/017=database_version_logs.tsv:030	source/sql/postgresql/migration/migration-029-030.sql	SUCCESS	2009-03-23 15:34:44.72	-- -------\\012-- add modification_timestamp field to allow edition with Hibernate\\012-- -------\\012ALTER TABLE data\\012\\011ADD COLUMN modification_timestamp TIME_STAMP DEFAULT CURRENT_TIMESTAMP;\\012ALTER TABLE experiment_types\\012\\011ADD COLUMN modification_timestamp TIME_STAMP DEFAULT CURRENT_TIMESTAMP;\\012ALTER TABLE sample_types\\012\\011ADD COLUMN modification_timestamp TIME_STAMP DEFAULT CURRENT_TIMESTAMP;\\012ALTER TABLE material_types\\012\\011ADD COLUMN modification_timestamp TIME_STAMP DEFAULT CURRENT_TIMESTAMP;\\012ALTER TABLE data_set_types\\012\\011ADD COLUMN modification_timestamp TIME_STAMP DEFAULT CURRENT_TIMESTAMP;\\012ALTER TABLE controlled_vocabularies\\012\\011ADD COLUMN modification_timestamp TIME_STAMP DEFAULT CURRENT_TIMESTAMP;\\012-- -------\\012-- add properties to data sets\\012-- -------\\012CREATE TABLE DATA_SET_PROPERTIES (ID TECH_ID NOT NULL,DS_ID TECH_ID NOT NULL,DSTPT_ID TECH_ID NOT NULL,VALUE GENERIC_VALUE,CVTE_ID TECH_ID, MATE_PROP_ID TECH_ID, PERS_ID_REGISTERER TECH_ID NOT NULL,REGISTRATION_TIMESTAMP TIME_STAMP_DFL NOT NULL DEFAULT CURRENT_TIMESTAMP, MODIFICATION_TIMESTAMP TIME_STAMP DEFAULT CURRENT_TIMESTAMP);\\012CREATE TABLE DATA_SET_TYPE_PROPERTY_TYPES (ID TECH_ID NOT NULL,DSTY_ID TECH_ID NOT NULL,PRTY_ID TECH_ID NOT NULL,IS_MANDATORY BOOLEAN_CHAR NOT NULL DEFAULT 'F',IS_MANAGED_INTERNALLY BOOLEAN_CHAR NOT NULL DEFAULT 'F',PERS_ID_REGISTERER TECH_ID NOT NULL,REGISTRATION_TIMESTAMP TIME_STAMP_DFL NOT NULL DEFAULT CURRENT_TIMESTAMP);\\012\\012CREATE SEQUENCE DATA_SET_PROPERTY_ID_SEQ;\\012CREATE SEQUENCE DSTPT_ID_SEQ;\\012\\012ALTER TABLE DATA_SET_TYPE_PROPERTY_TYPES ADD CONSTRAINT DSTPT_PK PRIMARY KEY(ID);\\012ALTER TABLE DATA_SET_PROPERTIES ADD CONSTRAINT DSPR_PK PRIMARY KEY(ID);\\012\\012ALTER TABLE DATA_SET_TYPE_PROPERTY_TYPES ADD CONSTRAINT DSTPT_BK_UK UNIQUE(DSTY_ID,PRTY_ID);\\012ALTER TABLE DATA_SET_PROPERTIES ADD CONSTRAINT DSPR_BK_UK UNIQUE(DS_ID,DSTPT_ID);\\012\\012\\012ALTER TABLE DATA_SET_TYPE_PROPERTY_TYPES ADD CONSTRAINT DSTPT_DSTY_FK FOREIGN KEY (DSTY_ID) REFERENCES DATA_SET_TYPES(ID);\\012ALTER TABLE DATA_SET_TYPE_PROPERTY_TYPES ADD CONSTRAINT DSTPT_PERS_FK FOREIGN KEY (PERS_ID_REGISTERER) REFERENCES PERSONS(ID);\\012ALTER TABLE DATA_SET_TYPE_PROPERTY_TYPES ADD CONSTRAINT DSTPT_PRTY_FK FOREIGN KEY (PRTY_ID) REFERENCES PROPERTY_TYPES(ID);\\012ALTER TABLE DATA_SET_PROPERTIES ADD CONSTRAINT DSPR_CVTE_FK FOREIGN KEY (CVTE_ID) REFERENCES CONTROLLED_VOCABULARY_TERMS(ID);\\012ALTER TABLE DATA_SET_PROPERTIES ADD CONSTRAINT DSPR_DSTPT_FK FOREIGN KEY (DSTPT_ID) REFERENCES DATA_SET_TYPE_PROPERTY_TYPES(ID) ON DELETE CASCADE;\\012ALTER TABLE DATA_SET_PROPERTIES ADD CONSTRAINT DSPR_DS_FK FOREIGN KEY (DS_ID) REFERENCES DATA(ID);\\012ALTER TABLE DATA_SET_PROPERTIES ADD CONSTRAINT DSPR_PERS_FK FOREIGN KEY (PERS_ID_REGISTERER) REFERENCES PERSONS(ID);\\012ALTER TABLE DATA_SET_PROPERTIES ADD CONSTRAINT DSPR_MAPR_FK FOREIGN KEY (MATE_PROP_ID) REFERENCES MATERIALS(ID);\\012\\012ALTER TABLE DATA_SET_PROPERTIES ADD CONSTRAINT DSPR_CK CHECK \\012\\011((VALUE IS NOT NULL AND CVTE_ID IS NULL AND MATE_PROP_ID IS NULL) OR \\012\\011 (VALUE IS NULL AND CVTE_ID IS NOT NULL AND MATE_PROP_ID IS NULL) OR\\012\\011 (VALUE IS NULL AND CVTE_ID IS NULL AND MATE_PROP_ID IS NOT NULL)\\012\\011);\\012\\012CREATE INDEX DSPR_CVTE_FK_I ON DATA_SET_PROPERTIES (CVTE_ID);\\012CREATE INDEX DSPR_DSTPT_FK_I ON DATA_SET_PROPERTIES (DSTPT_ID);\\012CREATE INDEX DSPR_DS_FK_I ON DATA_SET_PROPERTIES (DS_ID);\\012CREATE INDEX DSPR_PERS_FK_I ON DATA_SET_PROPERTIES (PERS_ID_REGISTERER);\\012CREATE INDEX DSTPT_DSTY_FK_I ON DATA_SET_TYPE_PROPERTY_TYPES (DSTY_ID);\\012CREATE INDEX DSTPT_PERS_FK_I ON DATA_SET_TYPE_PROPERTY_TYPES (PERS_ID_REGISTERER);\\012CREATE INDEX DSTPT_PRTY_FK_I ON DATA_SET_TYPE_PROPERTY_TYPES (PRTY_ID);\\012\\012CREATE OR REPLACE FUNCTION DATA_SET_PROPERTY_WITH_MATERIAL_DATA_TYPE_CHECK() RETURNS trigger AS $$\\012DECLARE\\012   v_type_id  CODE;\\012   v_type_id_prop  CODE;\\012BEGIN\\012   if NEW.mate_prop_id IS NOT NULL then\\012\\011\\011\\011-- find material type id of the property type \\012\\011\\011\\011select pt.maty_prop_id into v_type_id_prop \\012\\011\\011\\011  from data_set_type_property_types dstpt, property_types pt \\012\\011\\011\\011 where NEW.dstpt_id = dstpt.id AND dstpt.prty_id = pt.id;\\012\\011\\011\\012\\011\\011\\011if v_type_id_prop IS NOT NULL then\\012\\011\\011\\011\\011-- find material type id of the material which consists the entity's property value\\012\\011\\011\\011\\011select entity.maty_id into v_type_id \\012\\011\\011\\011\\011  from materials entity\\012\\011\\011\\011\\011 where NEW.mate_prop_id = entity.id;\\012\\011\\011\\011\\011if v_type_id != v_type_id_prop then\\012\\011\\011\\011\\011\\011RAISE EXCEPTION 'Insert/Update of property value referencing material (id: %) failed, as referenced material type is different than expected (id %, expected id: %).', \\012\\011\\011\\011\\011\\011\\011\\011\\011\\011\\011\\011\\011 NEW.mate_prop_id, v_type_id, v_type_id_prop;\\012\\011\\011\\011\\011end if;\\012\\011\\011\\011end if;\\012   end if;\\012   RETURN NEW;\\012END;\\012$$ LANGUAGE 'plpgsql';\\012\\012CREATE TRIGGER DATA_SET_PROPERTY_WITH_MATERIAL_DATA_TYPE_CHECK BEFORE INSERT OR UPDATE ON data_set_properties\\012    FOR EACH ROW EXECUTE PROCEDURE DATA_SET_PROPERTY_WITH_MATERIAL_DATA_TYPE_CHECK();   \\012	\N
+./sourceTest/sql/postgresql/048/017=database_version_logs.tsv:032	source/sql/postgresql/migration/migration-031-032.sql	SUCCESS	2009-04-09 09:36:36.2	-- -------\\012-- Modify MATERIAL_BATCHES\\012-- -------\\012\\012ALTER TABLE material_batches\\012    DROP COLUMN proc_id;\\012\\012-- -------\\012-- Modify SAMPLES\\012-- -------\\012\\012ALTER TABLE samples\\012    ADD COLUMN expe_id tech_id;\\012\\012ALTER TABLE samples\\012    ADD CONSTRAINT samp_expe_fk FOREIGN KEY (expe_id) REFERENCES experiments(id);\\012\\012CREATE INDEX samp_expe_fk_i ON samples USING btree (expe_id);\\012\\012-- relink samples directly to experiments\\012\\012UPDATE samples\\012SET expe_id = (SELECT e.id FROM experiments e, procedures p, sample_inputs si \\012               WHERE si.samp_id = samples.id AND si.proc_id = p.id AND p.expe_id = e.id AND e.inva_id IS NULL);\\012\\012\\012-- -------\\012-- Modify DATA\\012-- -------\\012\\012ALTER TABLE data\\012    ADD COLUMN expe_id tech_id;\\012\\012ALTER TABLE data\\012    ADD CONSTRAINT data_expe_fk FOREIGN KEY (expe_id) REFERENCES experiments(id);\\012\\012CREATE INDEX data_expe_fk_i ON data USING btree (expe_id);\\012\\012UPDATE data\\012SET expe_id = (SELECT e.id FROM experiments e, procedures p \\012               WHERE data.proc_id_produced_by = p.id AND p.expe_id = e.id);\\012\\012ALTER TABLE data\\012    ALTER COLUMN expe_id SET NOT NULL;\\012\\012ALTER TABLE data\\012    DROP COLUMN proc_id_produced_by;\\012\\012-- -------\\012-- Drop PROCEDURES, PROCEDURE_TYPES, and SAMPLE_INPUTS\\012-- -------\\012\\012DROP TABLE sample_inputs;\\012DROP TABLE procedures;\\012DROP TABLE procedure_types;\\012\\012DROP SEQUENCE procedure_id_seq;\\012DROP SEQUENCE procedure_type_id_seq;\\012\\012-- -------\\012-- Add CODE_SEQ\\012-- -------\\012\\012CREATE SEQUENCE CODE_SEQ;\\012\\012-- -------\\012-- Add new columns to DATA_STORES\\012-- -------\\012\\012ALTER TABLE data_stores\\012    ADD COLUMN remote_url character varying(250),\\012    ADD COLUMN session_token character varying(50),\\012    ADD COLUMN modification_timestamp time_stamp DEFAULT now();\\012\\012UPDATE data_stores\\012SET remote_url = '', session_token='';\\012\\012ALTER TABLE data_stores\\012    ALTER COLUMN remote_url SET NOT NULL,\\012    ALTER COLUMN session_token SET NOT NULL;\\012\\012-- -------\\012-- Drop foreign keys onto DATA_STORES\\012-- -------\\012\\012ALTER TABLE database_instances\\012    DROP COLUMN dast_id;\\012\\012ALTER TABLE groups\\012    DROP COLUMN dast_id;\\012\\012ALTER TABLE projects\\012    DROP COLUMN dast_id;\\012\\012ALTER TABLE experiments\\012    DROP COLUMN dast_id;\\012\\012-- -------\\012-- Add foreign key from DATA onto DATA_STORES\\012-- -------\\012\\012ALTER TABLE data\\012    ADD COLUMN dast_id tech_id;\\012\\012ALTER TABLE data\\012    ADD CONSTRAINT data_dast_fk FOREIGN KEY (dast_id) REFERENCES data_stores(id);\\012\\012UPDATE data\\012SET dast_id = (select id from data_stores where code = 'STANDARD');\\012\\012ALTER TABLE data\\012    ALTER COLUMN dast_id SET NOT NULL;\\012\\012\\012------------------------------------------------------------------------------------\\012--  Purpose:  Replace trigger SAMPLE_CODE_UNIQUENESS_CHECK \\012------------------------------------------------------------------------------------\\012\\012CREATE OR REPLACE FUNCTION SAMPLE_CODE_UNIQUENESS_CHECK() RETURNS trigger AS $$\\012DECLARE\\012   counter  INTEGER;\\012BEGIN\\012    LOCK TABLE samples IN EXCLUSIVE MODE;\\012    IF (NEW.samp_id_part_of is NULL) THEN\\012        IF (NEW.dbin_id is not NULL) THEN\\012            SELECT count(*) into counter FROM samples \\012                where id != NEW.id and code = NEW.code and samp_id_part_of is NULL and dbin_id = NEW.dbin_id;\\012            IF (counter > 0) THEN\\012                RAISE EXCEPTION 'Insert/Update of Sample (Code: %) failed because database instance sample with the same code already exists.', NEW.code;\\012            END IF;\\012        ELSIF (NEW.grou_id is not NULL) THEN\\012            SELECT count(*) into counter FROM samples \\012                where id != NEW.id and code = NEW.code and samp_id_part_of is NULL and grou_id = NEW.grou_id;\\012            IF (counter > 0) THEN\\012                RAISE EXCEPTION 'Insert/Update of Sample (Code: %) failed because group sample with the same code already exists.', NEW.code;\\012            END IF;\\012        END IF;\\012        ELSE\\012        IF (NEW.dbin_id is not NULL) THEN\\012            SELECT count(*) into counter FROM samples \\012                where id != NEW.id and code = NEW.code and samp_id_part_of = NEW.samp_id_part_of and dbin_id = NEW.dbin_id;\\012            IF (counter > 0) THEN\\012                RAISE EXCEPTION 'Insert/Update of Sample (Code: %) failed because database instance sample with the same code and being the part of the same parent already exists.', NEW.code;\\012            END IF;\\012        ELSIF (NEW.grou_id is not NULL) THEN\\012            SELECT count(*) into counter FROM samples \\012                where id != NEW.id and code = NEW.code and samp_id_part_of = NEW.samp_id_part_of and grou_id = NEW.grou_id;\\012            IF (counter > 0) THEN\\012                RAISE EXCEPTION 'Insert/Update of Sample (Code: %) failed because group sample with the same code and being the part of the same parent already exists.', NEW.code;\\012            END IF;\\012        END IF;\\012        END IF;   \\012   RETURN NEW;\\012END;\\012$$ LANGUAGE 'plpgsql';\\012\\012\\012\\012	\N
+./sourceTest/sql/postgresql/048/017=database_version_logs.tsv:034	source/sql/postgresql/migration/migration-033-034.sql	SUCCESS	2009-05-26 08:32:49.935	------------------------------------------------------------------------------------\\012-- Create sequence for generating permanent identifiers starting with nextval of existing dataset sequence.\\012------------------------------------------------------------------------------------\\012CREATE FUNCTION CREATE_SEQUENCE(EXISTING_SEQUENCE VARCHAR, NEW_SEQUENCE VARCHAR) RETURNS VOID AS $$\\012DECLARE\\012  CURR_SEQ_VAL   INTEGER;\\012BEGIN\\012  SELECT INTO CURR_SEQ_VAL NEXTVAL(EXISTING_SEQUENCE);\\012  EXECUTE 'CREATE SEQUENCE ' || NEW_SEQUENCE || ' START WITH ' || CURR_SEQ_VAL;\\012  RETURN;\\012END;\\012$$ LANGUAGE 'plpgsql';\\012\\012SELECT CREATE_SEQUENCE('DATA_ID_SEQ', 'PERM_ID_SEQ');\\012DROP FUNCTION CREATE_SEQUENCE(VARCHAR, VARCHAR);\\012\\012------------------------------------------------------------------------------------\\012-- Add perm_id columns to samples and experiments.\\012------------------------------------------------------------------------------------\\012ALTER TABLE SAMPLES ADD COLUMN PERM_ID CODE;\\012ALTER TABLE EXPERIMENTS ADD COLUMN PERM_ID CODE;\\012\\012UPDATE SAMPLES SET PERM_ID = to_char(registration_timestamp,'YYYYMMDDHHSSMS') || '-' || NEXTVAL('PERM_ID_SEQ');\\012UPDATE EXPERIMENTS SET PERM_ID = to_char(registration_timestamp,'YYYYMMDDHHSSMS') || '-' || NEXTVAL('PERM_ID_SEQ');\\012ALTER TABLE SAMPLES ALTER COLUMN PERM_ID SET NOT NULL;\\012ALTER TABLE EXPERIMENTS ALTER COLUMN PERM_ID SET NOT NULL;\\012ALTER TABLE SAMPLES ADD CONSTRAINT SAMP_PI_UK UNIQUE(PERM_ID);\\012ALTER TABLE EXPERIMENTS ADD CONSTRAINT EXPE_PI_UK UNIQUE(PERM_ID);\\012\\012\\012------------------------------------------------------------------------------------\\012-- Add column is_chosen_from_list to controlled_vocabularies.\\012------------------------------------------------------------------------------------\\012ALTER TABLE controlled_vocabularies ADD COLUMN is_chosen_from_list BOOLEAN_CHAR NOT NULL DEFAULT TRUE;\\012ALTER TABLE controlled_vocabularies ADD COLUMN source_uri CHARACTER VARYING(250);\\012------------------------------------------------------------------------------------\\012-- Modify Data table - remove arc connection between Sample and Data table, use a flag instead\\012------------------------------------------------------------------------------------\\012\\012-- add new columns\\012\\012ALTER TABLE data\\012    ADD COLUMN is_derived boolean_char;\\012ALTER TABLE data\\012    ADD COLUMN samp_id tech_id;\\012\\012-- update values in new columns\\012\\012UPDATE data\\012    SET is_derived = (samp_id_derived_from IS NOT NULL); \\012UPDATE data\\012    SET samp_id = samp_id_derived_from \\012    WHERE is_derived = 'TRUE';\\012UPDATE data\\012    SET samp_id = samp_id_acquired_from \\012    WHERE is_derived = 'FALSE';\\012\\012-- add constraints and indexes to new columns\\012\\012ALTER TABLE data\\012    ALTER COLUMN is_derived SET NOT NULL;\\012ALTER TABLE data\\012    ALTER COLUMN samp_id SET NOT NULL;   \\012ALTER TABLE data\\012    ADD CONSTRAINT data_samp_fk FOREIGN KEY (samp_id) REFERENCES samples (id);\\012CREATE INDEX data_samp_fk_i ON data USING btree (samp_id);\\012\\012-- remove old columns\\012\\012ALTER TABLE data\\012    DROP COLUMN samp_id_acquired_from;\\012ALTER TABLE data\\012    DROP COLUMN samp_id_derived_from;\\012    \\012------------------------------------------------------------------------------------\\012-- Granting SELECT privilege to group openbis_readonly\\012------------------------------------------------------------------------------------\\012\\012GRANT SELECT ON SEQUENCE attachment_content_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE attachment_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE code_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE controlled_vocabulary_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE cvte_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE data_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE data_set_property_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE data_set_relationship_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE data_set_type_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE data_store_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE data_type_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE database_instance_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE dstpt_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE etpt_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE event_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE experiment_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE experiment_property_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE experiment_type_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE file_format_type_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE group_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE invalidation_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE locator_type_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE material_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE material_property_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE material_type_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE mtpt_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE perm_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE person_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE project_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE property_type_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE role_assignment_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE sample_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE sample_property_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE sample_type_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE stpt_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE attachment_contents TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE attachments TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE controlled_vocabularies TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE controlled_vocabulary_terms TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE data TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE data_set_properties TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE data_set_relationships TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE data_set_type_property_types TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE data_set_types TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE data_stores TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE data_types TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE database_instances TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE database_version_logs TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE events TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE experiment_properties TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE experiment_type_property_types TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE experiment_types TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE experiments TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE external_data TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE file_format_types TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE groups TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE invalidations TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE locator_types TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE material_properties TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE material_type_property_types TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE material_types TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE materials TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE persons TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE projects TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE property_types TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE role_assignments TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE sample_properties TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE sample_type_property_types TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE sample_types TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE samples TO GROUP OPENBIS_READONLY;\\012\\012------------------------------------------------------------------------------------\\012-- Delete MATERIAL_BATCHES table\\012------------------------------------------------------------------------------------\\012\\012-- WARNING: Potential data lost!!!\\012-- WARNING: Potential data lost!!!\\012-- WARNING: Potential data lost!!!\\012\\012DROP TABLE SAMPLE_MATERIAL_BATCHES;\\012DROP TABLE MATERIAL_BATCHES;\\012DROP SEQUENCE MATERIAL_BATCH_ID_SEQ;\\012\\012------------------------------------------------------------------------------------\\012-- Delete MATE_ID_INHIBITOR_OF from table MATERIALS\\012------------------------------------------------------------------------------------\\012\\012-- WARNING: Potential data lost!!!\\012-- WARNING: Potential data lost!!!\\012-- WARNING: Potential data lost!!!\\012\\012ALTER TABLE MATERIALS DROP COLUMN MATE_ID_INHIBITOR_OF;\\012	\N
+./sourceTest/sql/postgresql/048/017=database_version_logs.tsv:041	source/sql/postgresql/migration/migration-040-041.sql	SUCCESS	2009-09-14 13:48:57.539	-- Create FILTERS table\\012\\012CREATE TABLE FILTERS (ID TECH_ID NOT NULL, DBIN_ID TECH_ID NOT NULL, NAME VARCHAR(200) NOT NULL, DESCRIPTION DESCRIPTION_1000,REGISTRATION_TIMESTAMP TIME_STAMP_DFL NOT NULL DEFAULT CURRENT_TIMESTAMP, PERS_ID_REGISTERER TECH_ID NOT NULL, MODIFICATION_TIMESTAMP TIME_STAMP DEFAULT CURRENT_TIMESTAMP, EXPRESSION VARCHAR(2000) NOT NULL, IS_PUBLIC BOOLEAN NOT NULL, GRID_ID VARCHAR(200) NOT NULL);\\012CREATE SEQUENCE FILTER_ID_SEQ;\\012ALTER TABLE FILTERS ADD CONSTRAINT FILT_PK PRIMARY KEY(ID);\\012ALTER TABLE FILTERS ADD CONSTRAINT FILT_BK_UK UNIQUE(NAME, DBIN_ID, GRID_ID);\\012ALTER TABLE FILTERS ADD CONSTRAINT FILT_PERS_FK FOREIGN KEY (PERS_ID_REGISTERER) REFERENCES PERSONS(ID);\\012ALTER TABLE FILTERS ADD CONSTRAINT FILT_DBIN_FK FOREIGN KEY (DBIN_ID) REFERENCES DATABASE_INSTANCES(ID);\\012CREATE INDEX FILT_PERS_FK_I ON FILTERS (PERS_ID_REGISTERER);\\012CREATE INDEX FILT_DBIN_FK_I ON FILTERS (DBIN_ID);\\012GRANT SELECT ON SEQUENCE filter_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE filters TO GROUP OPENBIS_READONLY;\\012\\012-- Add missing foreign key to role assignments authorization group\\012ALTER TABLE ROLE_ASSIGNMENTS ADD CONSTRAINT ROAS_AG_FK_GRANTEE FOREIGN KEY (AG_ID_GRANTEE) REFERENCES AUTHORIZATION_GROUPS(ID);\\012\\012--------------------------------------------------------------------------------------------------\\012-- Modify dataset connections:\\012-- 1. connection with sample shouldn't be mandatory any more\\012-- 2. introduce an arc condition that dataset cannot be connected with a sample and a parent dataset at the same time\\012--------------------------------------------------------------------------------------------------\\012\\012-- Weaken data-sample connection constraint - allow dataset to have no connection with sample\\012ALTER TABLE data ALTER COLUMN samp_id DROP NOT NULL;\\012\\012-- Remove data-sample connection for datasets that have a parent\\012\\012UPDATE data \\012   SET samp_id = NULL \\012 WHERE id IN (SELECT DISTINCT data_id_child FROM data_set_relationships);\\012\\012-- With PostgreSQL 8.4 one can check that before migration there were no cycles in dataset relationships:\\012--\\012-- WITH RECURSIVE data_set_parents(id, parent_ids, cycle) AS (\\012--         SELECT  r.data_id_child AS id, \\012--                 ARRAY[CAST (r.data_id_parent AS bigint)] AS parent_ids, \\012--                 false AS cycle \\012--         FROM data_set_relationships r\\012--     UNION ALL\\012--         SELECT  r.data_id_child,\\012--                 CAST (r.data_id_parent AS bigint) || p.parent_ids,\\012--                 r.data_id_child = ANY(p.parent_ids)\\012--         FROM data_set_relationships r, data_set_parents p\\012--         WHERE r.data_id_parent = p.id AND NOT cycle\\012-- )\\012-- SELECT count(*) AS cycles FROM data_set_parents WHERE cycle = true;\\012\\012---------------------------------------------------------------------------------------------------\\012--  Purpose:  Create DEFERRED triggers:\\012--            * check_dataset_relationships_on_data_table_modification,\\012--            * check_dataset_relationships_on_relationships_table_modification.\\012--            They check that after all modifications of database (just before commit) \\012--            if 'data'/'data_set_relationships' tables are among modified tables \\012--            dataset is not connected with a sample and a parent dataset at the same time.\\012--            This connections are held in two different tables so simple immediate trigger \\012--            with arc check cannot be used and we need two deferred triggers.\\012----------------------------------------------------------------------------------------------------\\012\\012-- trigger for 'data' table\\012\\012CREATE OR REPLACE FUNCTION check_dataset_relationships_on_data_table_modification() RETURNS trigger AS $$\\012DECLARE\\012\\011counter\\011INTEGER;\\012BEGIN\\012\\011-- if there is a connection with a Sample there should not be any connection with a parent Data Set\\012\\011IF (NEW.samp_id IS NOT NULL) THEN\\012\\011\\011-- count number of parents\\012\\011\\011SELECT count(*) INTO counter \\012\\011\\011\\011FROM data_set_relationships \\012\\011\\011\\011WHERE data_id_child = OLD.id;\\012\\011\\011IF (counter > 0) THEN\\012\\011\\011\\011RAISE EXCEPTION 'Insert/Update of Data Set (Code: %) failed because it cannot be connected with a Sample and a parent Data Set at the same time.', OLD.code;\\012\\011\\011END IF;\\012\\011END IF;\\012  RETURN NEW;\\012END;\\012$$ LANGUAGE 'plpgsql';\\012\\012CREATE CONSTRAINT TRIGGER check_dataset_relationships_on_data_table_modification \\012  AFTER INSERT OR UPDATE ON data\\012\\011DEFERRABLE INITIALLY DEFERRED\\012\\011FOR EACH ROW \\012\\011EXECUTE PROCEDURE check_dataset_relationships_on_data_table_modification();\\012\\012-- trigger for 'data_set_relationships'\\012\\012CREATE OR REPLACE FUNCTION check_dataset_relationships_on_relationships_table_modification() RETURNS trigger AS $$\\012DECLARE\\012\\011counter\\011INTEGER;\\012\\011sample_id\\011TECH_ID;\\012\\011data_code\\011CODE;\\012BEGIN\\012\\011-- child will have a parent added so it should not be connected with any sample\\012\\011SELECT samp_id, code INTO sample_id, data_code \\012\\011\\011FROM data \\012\\011\\011WHERE id = NEW.data_id_child;\\012\\011IF (sample_id IS NOT NULL) THEN\\012\\011\\011RAISE EXCEPTION 'Insert/Update of Data Set (Code: %) failed because it cannot be connected to a Sample and to a parent Data Set at the same time.', data_code;\\012\\011END IF;\\012\\011RETURN NEW;\\012END;\\012$$ LANGUAGE 'plpgsql';\\012  \\012CREATE CONSTRAINT TRIGGER check_dataset_relationships_on_relationships_table_modification \\012  AFTER INSERT OR UPDATE ON data_set_relationships\\012\\011DEFERRABLE INITIALLY DEFERRED\\012\\011FOR EACH ROW \\012\\011EXECUTE PROCEDURE check_dataset_relationships_on_relationships_table_modification();\\012	\N
+./sourceTest/sql/postgresql/048/schema-048.sql:    LANGUAGE plpgsql
+./sourceTest/sql/postgresql/048/schema-048.sql:    LANGUAGE plpgsql
+./sourceTest/sql/postgresql/048/schema-048.sql:    LANGUAGE plpgsql
+./sourceTest/sql/postgresql/048/schema-048.sql:    LANGUAGE plpgsql
+./sourceTest/sql/postgresql/048/schema-048.sql:    LANGUAGE plpgsql
+./sourceTest/sql/postgresql/048/schema-048.sql:    LANGUAGE plpgsql
+./sourceTest/sql/postgresql/048/schema-048.sql:    LANGUAGE plpgsql
+./sourceTest/sql/postgresql/048/schema-048.sql:    LANGUAGE plpgsql
+./sourceTest/sql/postgresql/048/schema-048.sql:    LANGUAGE plpgsql
+./sourceTest/sql/postgresql/048/schema-048.sql:    LANGUAGE plpgsql
+./sourceTest/sql/postgresql/049/.svn/text-base/017=database_version_logs.tsv.svn-base:027	D:\\User\\felmer\\dev-workspace\\openbis/source/sql/postgresql/027/function-027.sql	SUCCESS	2008-11-05 09:18:00.403	-- Creating Functions\\012\\012------------------------------------------------------------------------------------\\012--  Purpose:  Create function RENAME_SEQUENCE() that is required for renaming the sequences belonging to tables\\012------------------------------------------------------------------------------------\\012CREATE FUNCTION RENAME_SEQUENCE(OLD_NAME VARCHAR, NEW_NAME VARCHAR) RETURNS INTEGER AS $$\\012DECLARE\\012  CURR_SEQ_VAL   INTEGER;\\012BEGIN\\012  SELECT INTO CURR_SEQ_VAL NEXTVAL(OLD_NAME);\\012  EXECUTE 'CREATE SEQUENCE ' || NEW_NAME || ' START WITH ' || CURR_SEQ_VAL;\\012  EXECUTE 'DROP SEQUENCE ' || OLD_NAME;\\012  RETURN CURR_SEQ_VAL;\\012END;\\012$$ LANGUAGE 'plpgsql';\\012\\012\\012------------------------------------------------------------------------------------\\012--  Purpose:  Create trigger CONTROLLED_VOCABULARY_CHECK \\012------------------------------------------------------------------------------------\\012\\012CREATE OR REPLACE FUNCTION CONTROLLED_VOCABULARY_CHECK() RETURNS trigger AS $$\\012DECLARE\\012   v_code  CODE;\\012BEGIN\\012\\012   select code into v_code from data_types where id = NEW.daty_id;\\012\\012   -- Check if the data is of type "CONTROLLEDVOCABULARY"\\012   if v_code = 'CONTROLLEDVOCABULARY' then\\012      if NEW.covo_id IS NULL then\\012         RAISE EXCEPTION 'Insert/Update of Property Type (Code: %) failed, as its Data Type is CONTROLLEDVOCABULARY, but it is not linked to a Controlled Vocabulary.', NEW.code;\\012      end if;\\012   end if;\\012\\012   RETURN NEW;\\012\\012END;\\012$$ LANGUAGE 'plpgsql';\\012\\012CREATE TRIGGER CONTROLLED_VOCABULARY_CHECK BEFORE INSERT OR UPDATE ON PROPERTY_TYPES\\012    FOR EACH ROW EXECUTE PROCEDURE CONTROLLED_VOCABULARY_CHECK();\\012\\012\\012------------------------------------------------------------------------------------\\012--  Purpose:  Create trigger EXTERNAL_DATA_STORAGE_FORMAT_CHECK \\012------------------------------------------------------------------------------------\\012\\012CREATE OR REPLACE FUNCTION EXTERNAL_DATA_STORAGE_FORMAT_CHECK() RETURNS trigger AS $$\\012DECLARE\\012   v_covo_code  CODE;\\012   data_code CODE;\\012BEGIN\\012\\012   select code into v_covo_code from controlled_vocabularies\\012      where is_internal_namespace = true and \\012         id = (select covo_id from controlled_vocabulary_terms where id = NEW.cvte_id_stor_fmt);\\012   -- Check if the data storage format is a term of the controlled vocabulary "STORAGE_FORMAT"\\012   if v_covo_code != 'STORAGE_FORMAT' then\\012      select code into data_code from data where id = NEW.data_id; \\012      RAISE EXCEPTION 'Insert/Update of Data (Code: %) failed, as its Storage Format is %, but is required to be STORAGE_FORMAT.', data_code, v_covo_code;\\012   end if;\\012\\012   RETURN NEW;\\012\\012END;\\012$$ LANGUAGE 'plpgsql';\\012\\012CREATE TRIGGER EXTERNAL_DATA_STORAGE_FORMAT_CHECK BEFORE INSERT OR UPDATE ON EXTERNAL_DATA\\012    FOR EACH ROW EXECUTE PROCEDURE EXTERNAL_DATA_STORAGE_FORMAT_CHECK();\\012\\012------------------------------------------------------------------------------------\\012--  Purpose:  Create trigger SAMPLE_CODE_UNIQUENESS_CHECK \\012------------------------------------------------------------------------------------\\012\\012CREATE OR REPLACE FUNCTION SAMPLE_CODE_UNIQUENESS_CHECK() RETURNS trigger AS $$\\012DECLARE\\012   counter  INTEGER;\\012BEGIN\\012\\011IF (NEW.samp_id_part_of is NULL) THEN\\012\\011\\011IF (NEW.dbin_id is not NULL) THEN\\012\\011\\011\\011SELECT count(*) into counter FROM samples \\012\\011\\011\\011\\011where id != NEW.id and code = NEW.code and samp_id_part_of is NULL and dbin_id = NEW.dbin_id;\\012\\011\\011\\011IF (counter > 0) THEN\\012\\011\\011\\011\\011RAISE EXCEPTION 'Insert/Update of Sample (Code: %) failed because database instance sample with the same code already exists.', NEW.code;\\012\\011\\011\\011END IF;\\012\\011\\011ELSIF (NEW.grou_id is not NULL) THEN\\012\\011\\011\\011SELECT count(*) into counter FROM samples \\012\\011\\011\\011\\011where id != NEW.id and code = NEW.code and samp_id_part_of is NULL and grou_id = NEW.grou_id;\\012\\011\\011\\011IF (counter > 0) THEN\\012\\011\\011\\011\\011RAISE EXCEPTION 'Insert/Update of Sample (Code: %) failed because group sample with the same code already exists.', NEW.code;\\012\\011\\011\\011END IF;\\012\\011\\011END IF;\\012        ELSE\\012\\011\\011IF (NEW.dbin_id is not NULL) THEN\\012\\011\\011\\011SELECT count(*) into counter FROM samples \\012\\011\\011\\011\\011where id != NEW.id and code = NEW.code and samp_id_part_of = NEW.samp_id_part_of and dbin_id = NEW.dbin_id;\\012\\011\\011\\011IF (counter > 0) THEN\\012\\011\\011\\011\\011RAISE EXCEPTION 'Insert/Update of Sample (Code: %) failed because database instance sample with the same code and being the part of the same parent already exists.', NEW.code;\\012\\011\\011\\011END IF;\\012\\011\\011ELSIF (NEW.grou_id is not NULL) THEN\\012\\011\\011\\011SELECT count(*) into counter FROM samples \\012\\011\\011\\011\\011where id != NEW.id and code = NEW.code and samp_id_part_of = NEW.samp_id_part_of and grou_id = NEW.grou_id;\\012\\011\\011\\011IF (counter > 0) THEN\\012\\011\\011\\011\\011RAISE EXCEPTION 'Insert/Update of Sample (Code: %) failed because group sample with the same code and being the part of the same parent already exists.', NEW.code;\\012\\011\\011\\011END IF;\\012\\011\\011END IF;\\012        END IF;   \\012   RETURN NEW;\\012END;\\012$$ LANGUAGE 'plpgsql';\\012\\012CREATE TRIGGER SAMPLE_CODE_UNIQUENESS_CHECK BEFORE INSERT OR UPDATE ON SAMPLES\\012    FOR EACH ROW EXECUTE PROCEDURE SAMPLE_CODE_UNIQUENESS_CHECK();\\012	\N
+./sourceTest/sql/postgresql/049/.svn/text-base/017=database_version_logs.tsv.svn-base:028	source/sql/postgresql/migration/migration-027-028.sql	SUCCESS	2008-11-18 13:24:17.508	-- Create EXPERIMENT_ATTACHMENT_CONTENTS.\\012CREATE TABLE EXPERIMENT_ATTACHMENT_CONTENTS (ID TECH_ID NOT NULL,VALUE FILE NOT NULL);\\012CREATE SEQUENCE EXPERIMENT_ATTACHMENT_CONTENT_ID_SEQ;\\012ALTER TABLE EXPERIMENT_ATTACHMENT_CONTENTS ADD CONSTRAINT EXAC_PK PRIMARY KEY(ID);\\012\\012-- Alter EXPERIMENT_ATTACHMENTS by adding the new column which has a NULL constraint.\\012-- The NOT NULL constraint is added later on.\\012ALTER TABLE EXPERIMENT_ATTACHMENTS ADD COLUMN EXAC_ID TECH_ID;\\012\\012-- Does the VALUE migration between EXPERIMENT_ATTACHMENTS to EXPERIMENT_ATTACHMENT_CONTENTS.\\012CREATE OR REPLACE FUNCTION move_exp_att_content() RETURNS integer AS $$\\012DECLARE\\012    rec RECORD;\\012    seq BIGINT;\\012BEGIN\\012  FOR rec IN SELECT id, value FROM EXPERIMENT_ATTACHMENTS LOOP\\012  \\011seq := nextval('EXPERIMENT_ATTACHMENT_CONTENT_ID_SEQ');\\012    INSERT INTO EXPERIMENT_ATTACHMENT_CONTENTS (id, value) VALUES (seq, rec.value);\\012    UPDATE EXPERIMENT_ATTACHMENTS SET exac_id = seq WHERE id = rec.id;\\012  END LOOP;\\012  RETURN 1;\\012END;\\012$$ LANGUAGE 'plpgsql';\\012\\012-- Call the function.\\012SELECT move_exp_att_content();\\012DROP FUNCTION move_exp_att_content();\\012\\012\\012-- Finish EXPERIMENT_ATTACHMENTS changes.\\012ALTER TABLE EXPERIMENT_ATTACHMENTS ADD CONSTRAINT EXAT_CONT_FK FOREIGN KEY (EXAC_ID) REFERENCES EXPERIMENT_ATTACHMENT_CONTENTS(ID);\\012ALTER TABLE EXPERIMENT_ATTACHMENTS DROP COLUMN VALUE;\\012ALTER TABLE EXPERIMENT_ATTACHMENTS ALTER COLUMN EXAC_ID SET NOT NULL;\\012	\N
+./sourceTest/sql/postgresql/049/.svn/text-base/017=database_version_logs.tsv.svn-base:029	source/sql/postgresql/migration/migration-028-029.sql	SUCCESS	2009-03-18 10:50:20.105	-- -------\\012-- add modification_timestamp field to allow edition with Hibernate\\012-- -------\\012\\012ALTER TABLE samples\\012\\011ADD COLUMN modification_timestamp TIME_STAMP DEFAULT CURRENT_TIMESTAMP;\\012\\012ALTER TABLE experiments\\012\\011ADD COLUMN modification_timestamp TIME_STAMP DEFAULT CURRENT_TIMESTAMP;\\012\\012ALTER TABLE materials\\012\\011ADD COLUMN modification_timestamp TIME_STAMP DEFAULT CURRENT_TIMESTAMP;\\012\\012ALTER TABLE experiment_properties\\012\\011ADD COLUMN modification_timestamp TIME_STAMP DEFAULT CURRENT_TIMESTAMP;\\012\\012ALTER TABLE material_properties\\012\\011ADD COLUMN modification_timestamp TIME_STAMP DEFAULT CURRENT_TIMESTAMP;\\012\\012ALTER TABLE sample_properties\\012\\011ADD COLUMN modification_timestamp TIME_STAMP DEFAULT CURRENT_TIMESTAMP;\\012\\012-- -------\\012-- add property data type which references materials\\012-- -------\\012\\012ALTER TABLE property_types\\012\\011ADD COLUMN maty_prop_id tech_id;\\012\\012ALTER TABLE property_types\\012\\011ADD CONSTRAINT prty_maty_fk FOREIGN KEY (maty_prop_id) REFERENCES material_types(id);\\012\\012ALTER TABLE experiment_properties\\012\\011ADD COLUMN mate_prop_id tech_id;\\012\\012ALTER TABLE material_properties\\012\\011ADD COLUMN mate_prop_id tech_id;\\012\\012ALTER TABLE sample_properties\\012\\011ADD COLUMN mate_prop_id tech_id;\\012\\012ALTER TABLE experiment_properties\\012\\011ADD CONSTRAINT expr_mapr_fk FOREIGN KEY (mate_prop_id) REFERENCES materials(id);\\012\\012ALTER TABLE material_properties\\012\\011ADD CONSTRAINT mapr_mapr_fk FOREIGN KEY (mate_prop_id) REFERENCES materials(id);\\012\\012ALTER TABLE sample_properties\\012\\011ADD CONSTRAINT sapr_mapr_fk FOREIGN KEY (mate_prop_id) REFERENCES materials(id);\\012\\012insert into data_types\\012(id\\012 ,code\\012 ,description)\\012 values \\012 (nextval('DATA_TYPE_ID_SEQ')\\012 ,'MATERIAL'\\012 ,'Reference to a material'\\012);\\012\\012ALTER TABLE MATERIAL_PROPERTIES DROP CONSTRAINT MAPR_CK;\\012ALTER TABLE MATERIAL_PROPERTIES ADD CONSTRAINT MAPR_CK CHECK \\012\\011((VALUE IS NOT NULL AND CVTE_ID IS NULL AND MATE_PROP_ID IS NULL) OR \\012\\011 (VALUE IS NULL AND CVTE_ID IS NOT NULL AND MATE_PROP_ID IS NULL) OR\\012\\011 (VALUE IS NULL AND CVTE_ID IS NULL AND MATE_PROP_ID IS NOT NULL)\\012\\011);\\012\\012ALTER TABLE EXPERIMENT_PROPERTIES DROP CONSTRAINT EXPR_CK;\\012ALTER TABLE EXPERIMENT_PROPERTIES ADD CONSTRAINT EXPR_CK CHECK \\012\\011((VALUE IS NOT NULL AND CVTE_ID IS NULL AND MATE_PROP_ID IS NULL) OR \\012\\011 (VALUE IS NULL AND CVTE_ID IS NOT NULL AND MATE_PROP_ID IS NULL) OR\\012\\011 (VALUE IS NULL AND CVTE_ID IS NULL AND MATE_PROP_ID IS NOT NULL)\\012\\011);\\012\\012ALTER TABLE SAMPLE_PROPERTIES DROP CONSTRAINT SAPR_CK;\\012ALTER TABLE SAMPLE_PROPERTIES ADD CONSTRAINT SAPR_CK CHECK \\012\\011((VALUE IS NOT NULL AND CVTE_ID IS NULL AND MATE_PROP_ID IS NULL) OR \\012\\011 (VALUE IS NULL AND CVTE_ID IS NOT NULL AND MATE_PROP_ID IS NULL) OR\\012\\011 (VALUE IS NULL AND CVTE_ID IS NULL AND MATE_PROP_ID IS NOT NULL)\\012\\011);\\012\\012------------------------------------------------------------------------------------\\012--  Purpose:  Create trigger MATERIAL/SAMPLE/EXPERIMENT _PROPERTY_WITH_MATERIAL_DATA_TYPE_CHECK\\012--            It checks that if material property value is assigned to the entity,\\012--\\011\\011\\011\\011\\011\\011then the material type is equal to the one described by property type.\\012------------------------------------------------------------------------------------\\012\\012CREATE OR REPLACE FUNCTION MATERIAL_PROPERTY_WITH_MATERIAL_DATA_TYPE_CHECK() RETURNS trigger AS $$\\012DECLARE\\012   v_type_id  CODE;\\012   v_type_id_prop  CODE;\\012BEGIN\\012   if NEW.mate_prop_id IS NOT NULL then\\012\\011\\011\\011-- find material type id of the property type \\012\\011\\011\\011select pt.maty_prop_id into v_type_id_prop \\012\\011\\011\\011  from material_type_property_types etpt, property_types pt \\012\\011\\011\\011 where NEW.mtpt_id = etpt.id AND etpt.prty_id = pt.id;\\012\\011\\011\\012\\011\\011\\011if v_type_id_prop IS NOT NULL then\\012\\011\\011\\011\\011-- find material type id of the material which consists the entity's property value\\012\\011\\011\\011\\011select entity.maty_id into v_type_id \\012\\011\\011\\011\\011  from materials entity\\012\\011\\011\\011\\011 where NEW.mate_prop_id = entity.id;\\012\\011\\011\\011\\011if v_type_id != v_type_id_prop then\\012\\011\\011\\011\\011\\011RAISE EXCEPTION 'Insert/Update of property value referencing material (id: %) failed, as referenced material type is different than expected (id %, expected id: %).', \\012\\011\\011\\011\\011\\011\\011\\011 NEW.mate_prop_id, v_type_id, v_type_id_prop;\\012\\011\\011\\011\\011end if;\\012\\011\\011\\011end if;\\012   end if;\\012   RETURN NEW;\\012END;\\012$$ LANGUAGE 'plpgsql';\\012\\012CREATE TRIGGER MATERIAL_PROPERTY_WITH_MATERIAL_DATA_TYPE_CHECK BEFORE INSERT OR UPDATE ON material_properties\\012    FOR EACH ROW EXECUTE PROCEDURE MATERIAL_PROPERTY_WITH_MATERIAL_DATA_TYPE_CHECK();\\012    \\012CREATE OR REPLACE FUNCTION SAMPLE_PROPERTY_WITH_MATERIAL_DATA_TYPE_CHECK() RETURNS trigger AS $$\\012DECLARE\\012   v_type_id  CODE;\\012   v_type_id_prop  CODE;\\012BEGIN\\012   if NEW.mate_prop_id IS NOT NULL then\\012\\011\\011\\011-- find material type id of the property type \\012\\011\\011\\011select pt.maty_prop_id into v_type_id_prop \\012\\011\\011\\011  from sample_type_property_types etpt, property_types pt \\012\\011\\011\\011 where NEW.stpt_id = etpt.id AND etpt.prty_id = pt.id;\\012\\011\\011\\012\\011\\011\\011if v_type_id_prop IS NOT NULL then\\012\\011\\011\\011\\011-- find material type id of the material which consists the entity's property value\\012\\011\\011\\011\\011select entity.maty_id into v_type_id \\012\\011\\011\\011\\011  from materials entity\\012\\011\\011\\011\\011 where NEW.mate_prop_id = entity.id;\\012\\011\\011\\011\\011if v_type_id != v_type_id_prop then\\012\\011\\011\\011\\011\\011RAISE EXCEPTION 'Insert/Update of property value referencing material (id: %) failed, as referenced material type is different than expected (id %, expected id: %).', \\012\\011\\011\\011\\011\\011\\011\\011\\011\\011\\011\\011\\011 NEW.mate_prop_id, v_type_id, v_type_id_prop;\\012\\011\\011\\011\\011end if;\\012\\011\\011\\011end if;\\012   end if;\\012   RETURN NEW;\\012END;\\012$$ LANGUAGE 'plpgsql';\\012\\012CREATE TRIGGER SAMPLE_PROPERTY_WITH_MATERIAL_DATA_TYPE_CHECK BEFORE INSERT OR UPDATE ON sample_properties\\012    FOR EACH ROW EXECUTE PROCEDURE SAMPLE_PROPERTY_WITH_MATERIAL_DATA_TYPE_CHECK();\\012    \\012CREATE OR REPLACE FUNCTION EXPERIMENT_PROPERTY_WITH_MATERIAL_DATA_TYPE_CHECK() RETURNS trigger AS $$\\012DECLARE\\012   v_type_id  CODE;\\012   v_type_id_prop  CODE;\\012BEGIN\\012   if NEW.mate_prop_id IS NOT NULL then\\012\\011\\011\\011-- find material type id of the property type \\012\\011\\011\\011select pt.maty_prop_id into v_type_id_prop \\012\\011\\011\\011  from experiment_type_property_types etpt, property_types pt \\012\\011\\011\\011 where NEW.etpt_id = etpt.id AND etpt.prty_id = pt.id;\\012\\011\\011\\012\\011\\011\\011if v_type_id_prop IS NOT NULL then\\012\\011\\011\\011\\011-- find material type id of the material which consists the entity's property value\\012\\011\\011\\011\\011select entity.maty_id into v_type_id \\012\\011\\011\\011\\011  from materials entity\\012\\011\\011\\011\\011 where NEW.mate_prop_id = entity.id;\\012\\011\\011\\011\\011if v_type_id != v_type_id_prop then\\012\\011\\011\\011\\011\\011RAISE EXCEPTION 'Insert/Update of property value referencing material (id: %) failed, as referenced material type is different than expected (id %, expected id: %).', \\012\\011\\011\\011\\011\\011\\011\\011\\011\\011\\011\\011\\011 NEW.mate_prop_id, v_type_id, v_type_id_prop;\\012\\011\\011\\011\\011end if;\\012\\011\\011\\011end if;\\012   end if;\\012   RETURN NEW;\\012END;\\012$$ LANGUAGE 'plpgsql';\\012\\012CREATE TRIGGER EXPERIMENT_PROPERTY_WITH_MATERIAL_DATA_TYPE_CHECK BEFORE INSERT OR UPDATE ON experiment_properties\\012    FOR EACH ROW EXECUTE PROCEDURE EXPERIMENT_PROPERTY_WITH_MATERIAL_DATA_TYPE_CHECK();\\012       \\012-- -------\\012-- remove the reminescents of the OBSERVABLE_TYPE\\012-- -------\\012\\012ALTER TABLE data\\012\\011DROP CONSTRAINT data_obty_fk;\\012\\012ALTER TABLE data_set_types\\012\\011DROP CONSTRAINT obty_pk;\\012\\012ALTER TABLE data_set_types\\012\\011ADD CONSTRAINT dsty_pk PRIMARY KEY (id);\\012\\012ALTER TABLE data\\012\\011ADD CONSTRAINT data_dsty_fk FOREIGN KEY (dsty_id) REFERENCES data_set_types(id);\\012\\012ALTER TABLE data_set_types\\012\\011DROP CONSTRAINT obty_bk_uk;\\012\\012ALTER TABLE data_set_types\\012\\011DROP CONSTRAINT obty_dbin_fk;\\012\\012ALTER TABLE data_set_types\\012\\011ADD CONSTRAINT dsty_bk_uk UNIQUE (code, dbin_id);\\012\\012ALTER TABLE data_set_types\\012\\011ADD CONSTRAINT dsty_dbin_fk FOREIGN KEY (dbin_id) REFERENCES database_instances(id);\\012\\012DROP INDEX data_obty_fk_i;\\012\\012CREATE INDEX data_dsty_fk_i ON data(dsty_id);\\012	\N
+./sourceTest/sql/postgresql/049/.svn/text-base/017=database_version_logs.tsv.svn-base:030	source/sql/postgresql/migration/migration-029-030.sql	SUCCESS	2009-03-23 15:34:44.72	-- -------\\012-- add modification_timestamp field to allow edition with Hibernate\\012-- -------\\012ALTER TABLE data\\012\\011ADD COLUMN modification_timestamp TIME_STAMP DEFAULT CURRENT_TIMESTAMP;\\012ALTER TABLE experiment_types\\012\\011ADD COLUMN modification_timestamp TIME_STAMP DEFAULT CURRENT_TIMESTAMP;\\012ALTER TABLE sample_types\\012\\011ADD COLUMN modification_timestamp TIME_STAMP DEFAULT CURRENT_TIMESTAMP;\\012ALTER TABLE material_types\\012\\011ADD COLUMN modification_timestamp TIME_STAMP DEFAULT CURRENT_TIMESTAMP;\\012ALTER TABLE data_set_types\\012\\011ADD COLUMN modification_timestamp TIME_STAMP DEFAULT CURRENT_TIMESTAMP;\\012ALTER TABLE controlled_vocabularies\\012\\011ADD COLUMN modification_timestamp TIME_STAMP DEFAULT CURRENT_TIMESTAMP;\\012-- -------\\012-- add properties to data sets\\012-- -------\\012CREATE TABLE DATA_SET_PROPERTIES (ID TECH_ID NOT NULL,DS_ID TECH_ID NOT NULL,DSTPT_ID TECH_ID NOT NULL,VALUE GENERIC_VALUE,CVTE_ID TECH_ID, MATE_PROP_ID TECH_ID, PERS_ID_REGISTERER TECH_ID NOT NULL,REGISTRATION_TIMESTAMP TIME_STAMP_DFL NOT NULL DEFAULT CURRENT_TIMESTAMP, MODIFICATION_TIMESTAMP TIME_STAMP DEFAULT CURRENT_TIMESTAMP);\\012CREATE TABLE DATA_SET_TYPE_PROPERTY_TYPES (ID TECH_ID NOT NULL,DSTY_ID TECH_ID NOT NULL,PRTY_ID TECH_ID NOT NULL,IS_MANDATORY BOOLEAN_CHAR NOT NULL DEFAULT 'F',IS_MANAGED_INTERNALLY BOOLEAN_CHAR NOT NULL DEFAULT 'F',PERS_ID_REGISTERER TECH_ID NOT NULL,REGISTRATION_TIMESTAMP TIME_STAMP_DFL NOT NULL DEFAULT CURRENT_TIMESTAMP);\\012\\012CREATE SEQUENCE DATA_SET_PROPERTY_ID_SEQ;\\012CREATE SEQUENCE DSTPT_ID_SEQ;\\012\\012ALTER TABLE DATA_SET_TYPE_PROPERTY_TYPES ADD CONSTRAINT DSTPT_PK PRIMARY KEY(ID);\\012ALTER TABLE DATA_SET_PROPERTIES ADD CONSTRAINT DSPR_PK PRIMARY KEY(ID);\\012\\012ALTER TABLE DATA_SET_TYPE_PROPERTY_TYPES ADD CONSTRAINT DSTPT_BK_UK UNIQUE(DSTY_ID,PRTY_ID);\\012ALTER TABLE DATA_SET_PROPERTIES ADD CONSTRAINT DSPR_BK_UK UNIQUE(DS_ID,DSTPT_ID);\\012\\012\\012ALTER TABLE DATA_SET_TYPE_PROPERTY_TYPES ADD CONSTRAINT DSTPT_DSTY_FK FOREIGN KEY (DSTY_ID) REFERENCES DATA_SET_TYPES(ID);\\012ALTER TABLE DATA_SET_TYPE_PROPERTY_TYPES ADD CONSTRAINT DSTPT_PERS_FK FOREIGN KEY (PERS_ID_REGISTERER) REFERENCES PERSONS(ID);\\012ALTER TABLE DATA_SET_TYPE_PROPERTY_TYPES ADD CONSTRAINT DSTPT_PRTY_FK FOREIGN KEY (PRTY_ID) REFERENCES PROPERTY_TYPES(ID);\\012ALTER TABLE DATA_SET_PROPERTIES ADD CONSTRAINT DSPR_CVTE_FK FOREIGN KEY (CVTE_ID) REFERENCES CONTROLLED_VOCABULARY_TERMS(ID);\\012ALTER TABLE DATA_SET_PROPERTIES ADD CONSTRAINT DSPR_DSTPT_FK FOREIGN KEY (DSTPT_ID) REFERENCES DATA_SET_TYPE_PROPERTY_TYPES(ID) ON DELETE CASCADE;\\012ALTER TABLE DATA_SET_PROPERTIES ADD CONSTRAINT DSPR_DS_FK FOREIGN KEY (DS_ID) REFERENCES DATA(ID);\\012ALTER TABLE DATA_SET_PROPERTIES ADD CONSTRAINT DSPR_PERS_FK FOREIGN KEY (PERS_ID_REGISTERER) REFERENCES PERSONS(ID);\\012ALTER TABLE DATA_SET_PROPERTIES ADD CONSTRAINT DSPR_MAPR_FK FOREIGN KEY (MATE_PROP_ID) REFERENCES MATERIALS(ID);\\012\\012ALTER TABLE DATA_SET_PROPERTIES ADD CONSTRAINT DSPR_CK CHECK \\012\\011((VALUE IS NOT NULL AND CVTE_ID IS NULL AND MATE_PROP_ID IS NULL) OR \\012\\011 (VALUE IS NULL AND CVTE_ID IS NOT NULL AND MATE_PROP_ID IS NULL) OR\\012\\011 (VALUE IS NULL AND CVTE_ID IS NULL AND MATE_PROP_ID IS NOT NULL)\\012\\011);\\012\\012CREATE INDEX DSPR_CVTE_FK_I ON DATA_SET_PROPERTIES (CVTE_ID);\\012CREATE INDEX DSPR_DSTPT_FK_I ON DATA_SET_PROPERTIES (DSTPT_ID);\\012CREATE INDEX DSPR_DS_FK_I ON DATA_SET_PROPERTIES (DS_ID);\\012CREATE INDEX DSPR_PERS_FK_I ON DATA_SET_PROPERTIES (PERS_ID_REGISTERER);\\012CREATE INDEX DSTPT_DSTY_FK_I ON DATA_SET_TYPE_PROPERTY_TYPES (DSTY_ID);\\012CREATE INDEX DSTPT_PERS_FK_I ON DATA_SET_TYPE_PROPERTY_TYPES (PERS_ID_REGISTERER);\\012CREATE INDEX DSTPT_PRTY_FK_I ON DATA_SET_TYPE_PROPERTY_TYPES (PRTY_ID);\\012\\012CREATE OR REPLACE FUNCTION DATA_SET_PROPERTY_WITH_MATERIAL_DATA_TYPE_CHECK() RETURNS trigger AS $$\\012DECLARE\\012   v_type_id  CODE;\\012   v_type_id_prop  CODE;\\012BEGIN\\012   if NEW.mate_prop_id IS NOT NULL then\\012\\011\\011\\011-- find material type id of the property type \\012\\011\\011\\011select pt.maty_prop_id into v_type_id_prop \\012\\011\\011\\011  from data_set_type_property_types dstpt, property_types pt \\012\\011\\011\\011 where NEW.dstpt_id = dstpt.id AND dstpt.prty_id = pt.id;\\012\\011\\011\\012\\011\\011\\011if v_type_id_prop IS NOT NULL then\\012\\011\\011\\011\\011-- find material type id of the material which consists the entity's property value\\012\\011\\011\\011\\011select entity.maty_id into v_type_id \\012\\011\\011\\011\\011  from materials entity\\012\\011\\011\\011\\011 where NEW.mate_prop_id = entity.id;\\012\\011\\011\\011\\011if v_type_id != v_type_id_prop then\\012\\011\\011\\011\\011\\011RAISE EXCEPTION 'Insert/Update of property value referencing material (id: %) failed, as referenced material type is different than expected (id %, expected id: %).', \\012\\011\\011\\011\\011\\011\\011\\011\\011\\011\\011\\011\\011 NEW.mate_prop_id, v_type_id, v_type_id_prop;\\012\\011\\011\\011\\011end if;\\012\\011\\011\\011end if;\\012   end if;\\012   RETURN NEW;\\012END;\\012$$ LANGUAGE 'plpgsql';\\012\\012CREATE TRIGGER DATA_SET_PROPERTY_WITH_MATERIAL_DATA_TYPE_CHECK BEFORE INSERT OR UPDATE ON data_set_properties\\012    FOR EACH ROW EXECUTE PROCEDURE DATA_SET_PROPERTY_WITH_MATERIAL_DATA_TYPE_CHECK();   \\012	\N
+./sourceTest/sql/postgresql/049/.svn/text-base/017=database_version_logs.tsv.svn-base:032	source/sql/postgresql/migration/migration-031-032.sql	SUCCESS	2009-04-09 09:36:36.2	-- -------\\012-- Modify MATERIAL_BATCHES\\012-- -------\\012\\012ALTER TABLE material_batches\\012    DROP COLUMN proc_id;\\012\\012-- -------\\012-- Modify SAMPLES\\012-- -------\\012\\012ALTER TABLE samples\\012    ADD COLUMN expe_id tech_id;\\012\\012ALTER TABLE samples\\012    ADD CONSTRAINT samp_expe_fk FOREIGN KEY (expe_id) REFERENCES experiments(id);\\012\\012CREATE INDEX samp_expe_fk_i ON samples USING btree (expe_id);\\012\\012-- relink samples directly to experiments\\012\\012UPDATE samples\\012SET expe_id = (SELECT e.id FROM experiments e, procedures p, sample_inputs si \\012               WHERE si.samp_id = samples.id AND si.proc_id = p.id AND p.expe_id = e.id AND e.inva_id IS NULL);\\012\\012\\012-- -------\\012-- Modify DATA\\012-- -------\\012\\012ALTER TABLE data\\012    ADD COLUMN expe_id tech_id;\\012\\012ALTER TABLE data\\012    ADD CONSTRAINT data_expe_fk FOREIGN KEY (expe_id) REFERENCES experiments(id);\\012\\012CREATE INDEX data_expe_fk_i ON data USING btree (expe_id);\\012\\012UPDATE data\\012SET expe_id = (SELECT e.id FROM experiments e, procedures p \\012               WHERE data.proc_id_produced_by = p.id AND p.expe_id = e.id);\\012\\012ALTER TABLE data\\012    ALTER COLUMN expe_id SET NOT NULL;\\012\\012ALTER TABLE data\\012    DROP COLUMN proc_id_produced_by;\\012\\012-- -------\\012-- Drop PROCEDURES, PROCEDURE_TYPES, and SAMPLE_INPUTS\\012-- -------\\012\\012DROP TABLE sample_inputs;\\012DROP TABLE procedures;\\012DROP TABLE procedure_types;\\012\\012DROP SEQUENCE procedure_id_seq;\\012DROP SEQUENCE procedure_type_id_seq;\\012\\012-- -------\\012-- Add CODE_SEQ\\012-- -------\\012\\012CREATE SEQUENCE CODE_SEQ;\\012\\012-- -------\\012-- Add new columns to DATA_STORES\\012-- -------\\012\\012ALTER TABLE data_stores\\012    ADD COLUMN remote_url character varying(250),\\012    ADD COLUMN session_token character varying(50),\\012    ADD COLUMN modification_timestamp time_stamp DEFAULT now();\\012\\012UPDATE data_stores\\012SET remote_url = '', session_token='';\\012\\012ALTER TABLE data_stores\\012    ALTER COLUMN remote_url SET NOT NULL,\\012    ALTER COLUMN session_token SET NOT NULL;\\012\\012-- -------\\012-- Drop foreign keys onto DATA_STORES\\012-- -------\\012\\012ALTER TABLE database_instances\\012    DROP COLUMN dast_id;\\012\\012ALTER TABLE groups\\012    DROP COLUMN dast_id;\\012\\012ALTER TABLE projects\\012    DROP COLUMN dast_id;\\012\\012ALTER TABLE experiments\\012    DROP COLUMN dast_id;\\012\\012-- -------\\012-- Add foreign key from DATA onto DATA_STORES\\012-- -------\\012\\012ALTER TABLE data\\012    ADD COLUMN dast_id tech_id;\\012\\012ALTER TABLE data\\012    ADD CONSTRAINT data_dast_fk FOREIGN KEY (dast_id) REFERENCES data_stores(id);\\012\\012UPDATE data\\012SET dast_id = (select id from data_stores where code = 'STANDARD');\\012\\012ALTER TABLE data\\012    ALTER COLUMN dast_id SET NOT NULL;\\012\\012\\012------------------------------------------------------------------------------------\\012--  Purpose:  Replace trigger SAMPLE_CODE_UNIQUENESS_CHECK \\012------------------------------------------------------------------------------------\\012\\012CREATE OR REPLACE FUNCTION SAMPLE_CODE_UNIQUENESS_CHECK() RETURNS trigger AS $$\\012DECLARE\\012   counter  INTEGER;\\012BEGIN\\012    LOCK TABLE samples IN EXCLUSIVE MODE;\\012    IF (NEW.samp_id_part_of is NULL) THEN\\012        IF (NEW.dbin_id is not NULL) THEN\\012            SELECT count(*) into counter FROM samples \\012                where id != NEW.id and code = NEW.code and samp_id_part_of is NULL and dbin_id = NEW.dbin_id;\\012            IF (counter > 0) THEN\\012                RAISE EXCEPTION 'Insert/Update of Sample (Code: %) failed because database instance sample with the same code already exists.', NEW.code;\\012            END IF;\\012        ELSIF (NEW.grou_id is not NULL) THEN\\012            SELECT count(*) into counter FROM samples \\012                where id != NEW.id and code = NEW.code and samp_id_part_of is NULL and grou_id = NEW.grou_id;\\012            IF (counter > 0) THEN\\012                RAISE EXCEPTION 'Insert/Update of Sample (Code: %) failed because group sample with the same code already exists.', NEW.code;\\012            END IF;\\012        END IF;\\012        ELSE\\012        IF (NEW.dbin_id is not NULL) THEN\\012            SELECT count(*) into counter FROM samples \\012                where id != NEW.id and code = NEW.code and samp_id_part_of = NEW.samp_id_part_of and dbin_id = NEW.dbin_id;\\012            IF (counter > 0) THEN\\012                RAISE EXCEPTION 'Insert/Update of Sample (Code: %) failed because database instance sample with the same code and being the part of the same parent already exists.', NEW.code;\\012            END IF;\\012        ELSIF (NEW.grou_id is not NULL) THEN\\012            SELECT count(*) into counter FROM samples \\012                where id != NEW.id and code = NEW.code and samp_id_part_of = NEW.samp_id_part_of and grou_id = NEW.grou_id;\\012            IF (counter > 0) THEN\\012                RAISE EXCEPTION 'Insert/Update of Sample (Code: %) failed because group sample with the same code and being the part of the same parent already exists.', NEW.code;\\012            END IF;\\012        END IF;\\012        END IF;   \\012   RETURN NEW;\\012END;\\012$$ LANGUAGE 'plpgsql';\\012\\012\\012\\012	\N
+./sourceTest/sql/postgresql/049/.svn/text-base/017=database_version_logs.tsv.svn-base:034	source/sql/postgresql/migration/migration-033-034.sql	SUCCESS	2009-05-26 08:32:49.935	------------------------------------------------------------------------------------\\012-- Create sequence for generating permanent identifiers starting with nextval of existing dataset sequence.\\012------------------------------------------------------------------------------------\\012CREATE FUNCTION CREATE_SEQUENCE(EXISTING_SEQUENCE VARCHAR, NEW_SEQUENCE VARCHAR) RETURNS VOID AS $$\\012DECLARE\\012  CURR_SEQ_VAL   INTEGER;\\012BEGIN\\012  SELECT INTO CURR_SEQ_VAL NEXTVAL(EXISTING_SEQUENCE);\\012  EXECUTE 'CREATE SEQUENCE ' || NEW_SEQUENCE || ' START WITH ' || CURR_SEQ_VAL;\\012  RETURN;\\012END;\\012$$ LANGUAGE 'plpgsql';\\012\\012SELECT CREATE_SEQUENCE('DATA_ID_SEQ', 'PERM_ID_SEQ');\\012DROP FUNCTION CREATE_SEQUENCE(VARCHAR, VARCHAR);\\012\\012------------------------------------------------------------------------------------\\012-- Add perm_id columns to samples and experiments.\\012------------------------------------------------------------------------------------\\012ALTER TABLE SAMPLES ADD COLUMN PERM_ID CODE;\\012ALTER TABLE EXPERIMENTS ADD COLUMN PERM_ID CODE;\\012\\012UPDATE SAMPLES SET PERM_ID = to_char(registration_timestamp,'YYYYMMDDHHSSMS') || '-' || NEXTVAL('PERM_ID_SEQ');\\012UPDATE EXPERIMENTS SET PERM_ID = to_char(registration_timestamp,'YYYYMMDDHHSSMS') || '-' || NEXTVAL('PERM_ID_SEQ');\\012ALTER TABLE SAMPLES ALTER COLUMN PERM_ID SET NOT NULL;\\012ALTER TABLE EXPERIMENTS ALTER COLUMN PERM_ID SET NOT NULL;\\012ALTER TABLE SAMPLES ADD CONSTRAINT SAMP_PI_UK UNIQUE(PERM_ID);\\012ALTER TABLE EXPERIMENTS ADD CONSTRAINT EXPE_PI_UK UNIQUE(PERM_ID);\\012\\012\\012------------------------------------------------------------------------------------\\012-- Add column is_chosen_from_list to controlled_vocabularies.\\012------------------------------------------------------------------------------------\\012ALTER TABLE controlled_vocabularies ADD COLUMN is_chosen_from_list BOOLEAN_CHAR NOT NULL DEFAULT TRUE;\\012ALTER TABLE controlled_vocabularies ADD COLUMN source_uri CHARACTER VARYING(250);\\012------------------------------------------------------------------------------------\\012-- Modify Data table - remove arc connection between Sample and Data table, use a flag instead\\012------------------------------------------------------------------------------------\\012\\012-- add new columns\\012\\012ALTER TABLE data\\012    ADD COLUMN is_derived boolean_char;\\012ALTER TABLE data\\012    ADD COLUMN samp_id tech_id;\\012\\012-- update values in new columns\\012\\012UPDATE data\\012    SET is_derived = (samp_id_derived_from IS NOT NULL); \\012UPDATE data\\012    SET samp_id = samp_id_derived_from \\012    WHERE is_derived = 'TRUE';\\012UPDATE data\\012    SET samp_id = samp_id_acquired_from \\012    WHERE is_derived = 'FALSE';\\012\\012-- add constraints and indexes to new columns\\012\\012ALTER TABLE data\\012    ALTER COLUMN is_derived SET NOT NULL;\\012ALTER TABLE data\\012    ALTER COLUMN samp_id SET NOT NULL;   \\012ALTER TABLE data\\012    ADD CONSTRAINT data_samp_fk FOREIGN KEY (samp_id) REFERENCES samples (id);\\012CREATE INDEX data_samp_fk_i ON data USING btree (samp_id);\\012\\012-- remove old columns\\012\\012ALTER TABLE data\\012    DROP COLUMN samp_id_acquired_from;\\012ALTER TABLE data\\012    DROP COLUMN samp_id_derived_from;\\012    \\012------------------------------------------------------------------------------------\\012-- Granting SELECT privilege to group openbis_readonly\\012------------------------------------------------------------------------------------\\012\\012GRANT SELECT ON SEQUENCE attachment_content_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE attachment_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE code_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE controlled_vocabulary_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE cvte_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE data_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE data_set_property_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE data_set_relationship_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE data_set_type_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE data_store_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE data_type_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE database_instance_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE dstpt_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE etpt_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE event_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE experiment_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE experiment_property_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE experiment_type_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE file_format_type_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE group_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE invalidation_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE locator_type_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE material_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE material_property_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE material_type_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE mtpt_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE perm_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE person_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE project_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE property_type_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE role_assignment_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE sample_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE sample_property_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE sample_type_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE stpt_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE attachment_contents TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE attachments TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE controlled_vocabularies TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE controlled_vocabulary_terms TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE data TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE data_set_properties TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE data_set_relationships TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE data_set_type_property_types TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE data_set_types TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE data_stores TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE data_types TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE database_instances TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE database_version_logs TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE events TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE experiment_properties TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE experiment_type_property_types TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE experiment_types TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE experiments TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE external_data TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE file_format_types TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE groups TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE invalidations TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE locator_types TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE material_properties TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE material_type_property_types TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE material_types TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE materials TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE persons TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE projects TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE property_types TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE role_assignments TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE sample_properties TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE sample_type_property_types TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE sample_types TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE samples TO GROUP OPENBIS_READONLY;\\012\\012------------------------------------------------------------------------------------\\012-- Delete MATERIAL_BATCHES table\\012------------------------------------------------------------------------------------\\012\\012-- WARNING: Potential data lost!!!\\012-- WARNING: Potential data lost!!!\\012-- WARNING: Potential data lost!!!\\012\\012DROP TABLE SAMPLE_MATERIAL_BATCHES;\\012DROP TABLE MATERIAL_BATCHES;\\012DROP SEQUENCE MATERIAL_BATCH_ID_SEQ;\\012\\012------------------------------------------------------------------------------------\\012-- Delete MATE_ID_INHIBITOR_OF from table MATERIALS\\012------------------------------------------------------------------------------------\\012\\012-- WARNING: Potential data lost!!!\\012-- WARNING: Potential data lost!!!\\012-- WARNING: Potential data lost!!!\\012\\012ALTER TABLE MATERIALS DROP COLUMN MATE_ID_INHIBITOR_OF;\\012	\N
+./sourceTest/sql/postgresql/049/.svn/text-base/017=database_version_logs.tsv.svn-base:041	source/sql/postgresql/migration/migration-040-041.sql	SUCCESS	2009-09-14 13:48:57.539	-- Create FILTERS table\\012\\012CREATE TABLE FILTERS (ID TECH_ID NOT NULL, DBIN_ID TECH_ID NOT NULL, NAME VARCHAR(200) NOT NULL, DESCRIPTION DESCRIPTION_1000,REGISTRATION_TIMESTAMP TIME_STAMP_DFL NOT NULL DEFAULT CURRENT_TIMESTAMP, PERS_ID_REGISTERER TECH_ID NOT NULL, MODIFICATION_TIMESTAMP TIME_STAMP DEFAULT CURRENT_TIMESTAMP, EXPRESSION VARCHAR(2000) NOT NULL, IS_PUBLIC BOOLEAN NOT NULL, GRID_ID VARCHAR(200) NOT NULL);\\012CREATE SEQUENCE FILTER_ID_SEQ;\\012ALTER TABLE FILTERS ADD CONSTRAINT FILT_PK PRIMARY KEY(ID);\\012ALTER TABLE FILTERS ADD CONSTRAINT FILT_BK_UK UNIQUE(NAME, DBIN_ID, GRID_ID);\\012ALTER TABLE FILTERS ADD CONSTRAINT FILT_PERS_FK FOREIGN KEY (PERS_ID_REGISTERER) REFERENCES PERSONS(ID);\\012ALTER TABLE FILTERS ADD CONSTRAINT FILT_DBIN_FK FOREIGN KEY (DBIN_ID) REFERENCES DATABASE_INSTANCES(ID);\\012CREATE INDEX FILT_PERS_FK_I ON FILTERS (PERS_ID_REGISTERER);\\012CREATE INDEX FILT_DBIN_FK_I ON FILTERS (DBIN_ID);\\012GRANT SELECT ON SEQUENCE filter_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE filters TO GROUP OPENBIS_READONLY;\\012\\012-- Add missing foreign key to role assignments authorization group\\012ALTER TABLE ROLE_ASSIGNMENTS ADD CONSTRAINT ROAS_AG_FK_GRANTEE FOREIGN KEY (AG_ID_GRANTEE) REFERENCES AUTHORIZATION_GROUPS(ID);\\012\\012--------------------------------------------------------------------------------------------------\\012-- Modify dataset connections:\\012-- 1. connection with sample shouldn't be mandatory any more\\012-- 2. introduce an arc condition that dataset cannot be connected with a sample and a parent dataset at the same time\\012--------------------------------------------------------------------------------------------------\\012\\012-- Weaken data-sample connection constraint - allow dataset to have no connection with sample\\012ALTER TABLE data ALTER COLUMN samp_id DROP NOT NULL;\\012\\012-- Remove data-sample connection for datasets that have a parent\\012\\012UPDATE data \\012   SET samp_id = NULL \\012 WHERE id IN (SELECT DISTINCT data_id_child FROM data_set_relationships);\\012\\012-- With PostgreSQL 8.4 one can check that before migration there were no cycles in dataset relationships:\\012--\\012-- WITH RECURSIVE data_set_parents(id, parent_ids, cycle) AS (\\012--         SELECT  r.data_id_child AS id, \\012--                 ARRAY[CAST (r.data_id_parent AS bigint)] AS parent_ids, \\012--                 false AS cycle \\012--         FROM data_set_relationships r\\012--     UNION ALL\\012--         SELECT  r.data_id_child,\\012--                 CAST (r.data_id_parent AS bigint) || p.parent_ids,\\012--                 r.data_id_child = ANY(p.parent_ids)\\012--         FROM data_set_relationships r, data_set_parents p\\012--         WHERE r.data_id_parent = p.id AND NOT cycle\\012-- )\\012-- SELECT count(*) AS cycles FROM data_set_parents WHERE cycle = true;\\012\\012---------------------------------------------------------------------------------------------------\\012--  Purpose:  Create DEFERRED triggers:\\012--            * check_dataset_relationships_on_data_table_modification,\\012--            * check_dataset_relationships_on_relationships_table_modification.\\012--            They check that after all modifications of database (just before commit) \\012--            if 'data'/'data_set_relationships' tables are among modified tables \\012--            dataset is not connected with a sample and a parent dataset at the same time.\\012--            This connections are held in two different tables so simple immediate trigger \\012--            with arc check cannot be used and we need two deferred triggers.\\012----------------------------------------------------------------------------------------------------\\012\\012-- trigger for 'data' table\\012\\012CREATE OR REPLACE FUNCTION check_dataset_relationships_on_data_table_modification() RETURNS trigger AS $$\\012DECLARE\\012\\011counter\\011INTEGER;\\012BEGIN\\012\\011-- if there is a connection with a Sample there should not be any connection with a parent Data Set\\012\\011IF (NEW.samp_id IS NOT NULL) THEN\\012\\011\\011-- count number of parents\\012\\011\\011SELECT count(*) INTO counter \\012\\011\\011\\011FROM data_set_relationships \\012\\011\\011\\011WHERE data_id_child = OLD.id;\\012\\011\\011IF (counter > 0) THEN\\012\\011\\011\\011RAISE EXCEPTION 'Insert/Update of Data Set (Code: %) failed because it cannot be connected with a Sample and a parent Data Set at the same time.', OLD.code;\\012\\011\\011END IF;\\012\\011END IF;\\012  RETURN NEW;\\012END;\\012$$ LANGUAGE 'plpgsql';\\012\\012CREATE CONSTRAINT TRIGGER check_dataset_relationships_on_data_table_modification \\012  AFTER INSERT OR UPDATE ON data\\012\\011DEFERRABLE INITIALLY DEFERRED\\012\\011FOR EACH ROW \\012\\011EXECUTE PROCEDURE check_dataset_relationships_on_data_table_modification();\\012\\012-- trigger for 'data_set_relationships'\\012\\012CREATE OR REPLACE FUNCTION check_dataset_relationships_on_relationships_table_modification() RETURNS trigger AS $$\\012DECLARE\\012\\011counter\\011INTEGER;\\012\\011sample_id\\011TECH_ID;\\012\\011data_code\\011CODE;\\012BEGIN\\012\\011-- child will have a parent added so it should not be connected with any sample\\012\\011SELECT samp_id, code INTO sample_id, data_code \\012\\011\\011FROM data \\012\\011\\011WHERE id = NEW.data_id_child;\\012\\011IF (sample_id IS NOT NULL) THEN\\012\\011\\011RAISE EXCEPTION 'Insert/Update of Data Set (Code: %) failed because it cannot be connected to a Sample and to a parent Data Set at the same time.', data_code;\\012\\011END IF;\\012\\011RETURN NEW;\\012END;\\012$$ LANGUAGE 'plpgsql';\\012  \\012CREATE CONSTRAINT TRIGGER check_dataset_relationships_on_relationships_table_modification \\012  AFTER INSERT OR UPDATE ON data_set_relationships\\012\\011DEFERRABLE INITIALLY DEFERRED\\012\\011FOR EACH ROW \\012\\011EXECUTE PROCEDURE check_dataset_relationships_on_relationships_table_modification();\\012	\N
+./sourceTest/sql/postgresql/049/.svn/text-base/schema-049.sql.svn-base:    LANGUAGE plpgsql
+./sourceTest/sql/postgresql/049/.svn/text-base/schema-049.sql.svn-base:    LANGUAGE plpgsql
+./sourceTest/sql/postgresql/049/.svn/text-base/schema-049.sql.svn-base:    LANGUAGE plpgsql
+./sourceTest/sql/postgresql/049/.svn/text-base/schema-049.sql.svn-base:    LANGUAGE plpgsql
+./sourceTest/sql/postgresql/049/.svn/text-base/schema-049.sql.svn-base:    LANGUAGE plpgsql
+./sourceTest/sql/postgresql/049/.svn/text-base/schema-049.sql.svn-base:    LANGUAGE plpgsql
+./sourceTest/sql/postgresql/049/.svn/text-base/schema-049.sql.svn-base:    LANGUAGE plpgsql
+./sourceTest/sql/postgresql/049/.svn/text-base/schema-049.sql.svn-base:    LANGUAGE plpgsql
+./sourceTest/sql/postgresql/049/.svn/text-base/schema-049.sql.svn-base:    LANGUAGE plpgsql
+./sourceTest/sql/postgresql/049/.svn/text-base/schema-049.sql.svn-base:    LANGUAGE plpgsql
+./sourceTest/sql/postgresql/049/017=database_version_logs.tsv:027	D:\\User\\felmer\\dev-workspace\\openbis/source/sql/postgresql/027/function-027.sql	SUCCESS	2008-11-05 09:18:00.403	-- Creating Functions\\012\\012------------------------------------------------------------------------------------\\012--  Purpose:  Create function RENAME_SEQUENCE() that is required for renaming the sequences belonging to tables\\012------------------------------------------------------------------------------------\\012CREATE FUNCTION RENAME_SEQUENCE(OLD_NAME VARCHAR, NEW_NAME VARCHAR) RETURNS INTEGER AS $$\\012DECLARE\\012  CURR_SEQ_VAL   INTEGER;\\012BEGIN\\012  SELECT INTO CURR_SEQ_VAL NEXTVAL(OLD_NAME);\\012  EXECUTE 'CREATE SEQUENCE ' || NEW_NAME || ' START WITH ' || CURR_SEQ_VAL;\\012  EXECUTE 'DROP SEQUENCE ' || OLD_NAME;\\012  RETURN CURR_SEQ_VAL;\\012END;\\012$$ LANGUAGE 'plpgsql';\\012\\012\\012------------------------------------------------------------------------------------\\012--  Purpose:  Create trigger CONTROLLED_VOCABULARY_CHECK \\012------------------------------------------------------------------------------------\\012\\012CREATE OR REPLACE FUNCTION CONTROLLED_VOCABULARY_CHECK() RETURNS trigger AS $$\\012DECLARE\\012   v_code  CODE;\\012BEGIN\\012\\012   select code into v_code from data_types where id = NEW.daty_id;\\012\\012   -- Check if the data is of type "CONTROLLEDVOCABULARY"\\012   if v_code = 'CONTROLLEDVOCABULARY' then\\012      if NEW.covo_id IS NULL then\\012         RAISE EXCEPTION 'Insert/Update of Property Type (Code: %) failed, as its Data Type is CONTROLLEDVOCABULARY, but it is not linked to a Controlled Vocabulary.', NEW.code;\\012      end if;\\012   end if;\\012\\012   RETURN NEW;\\012\\012END;\\012$$ LANGUAGE 'plpgsql';\\012\\012CREATE TRIGGER CONTROLLED_VOCABULARY_CHECK BEFORE INSERT OR UPDATE ON PROPERTY_TYPES\\012    FOR EACH ROW EXECUTE PROCEDURE CONTROLLED_VOCABULARY_CHECK();\\012\\012\\012------------------------------------------------------------------------------------\\012--  Purpose:  Create trigger EXTERNAL_DATA_STORAGE_FORMAT_CHECK \\012------------------------------------------------------------------------------------\\012\\012CREATE OR REPLACE FUNCTION EXTERNAL_DATA_STORAGE_FORMAT_CHECK() RETURNS trigger AS $$\\012DECLARE\\012   v_covo_code  CODE;\\012   data_code CODE;\\012BEGIN\\012\\012   select code into v_covo_code from controlled_vocabularies\\012      where is_internal_namespace = true and \\012         id = (select covo_id from controlled_vocabulary_terms where id = NEW.cvte_id_stor_fmt);\\012   -- Check if the data storage format is a term of the controlled vocabulary "STORAGE_FORMAT"\\012   if v_covo_code != 'STORAGE_FORMAT' then\\012      select code into data_code from data where id = NEW.data_id; \\012      RAISE EXCEPTION 'Insert/Update of Data (Code: %) failed, as its Storage Format is %, but is required to be STORAGE_FORMAT.', data_code, v_covo_code;\\012   end if;\\012\\012   RETURN NEW;\\012\\012END;\\012$$ LANGUAGE 'plpgsql';\\012\\012CREATE TRIGGER EXTERNAL_DATA_STORAGE_FORMAT_CHECK BEFORE INSERT OR UPDATE ON EXTERNAL_DATA\\012    FOR EACH ROW EXECUTE PROCEDURE EXTERNAL_DATA_STORAGE_FORMAT_CHECK();\\012\\012------------------------------------------------------------------------------------\\012--  Purpose:  Create trigger SAMPLE_CODE_UNIQUENESS_CHECK \\012------------------------------------------------------------------------------------\\012\\012CREATE OR REPLACE FUNCTION SAMPLE_CODE_UNIQUENESS_CHECK() RETURNS trigger AS $$\\012DECLARE\\012   counter  INTEGER;\\012BEGIN\\012\\011IF (NEW.samp_id_part_of is NULL) THEN\\012\\011\\011IF (NEW.dbin_id is not NULL) THEN\\012\\011\\011\\011SELECT count(*) into counter FROM samples \\012\\011\\011\\011\\011where id != NEW.id and code = NEW.code and samp_id_part_of is NULL and dbin_id = NEW.dbin_id;\\012\\011\\011\\011IF (counter > 0) THEN\\012\\011\\011\\011\\011RAISE EXCEPTION 'Insert/Update of Sample (Code: %) failed because database instance sample with the same code already exists.', NEW.code;\\012\\011\\011\\011END IF;\\012\\011\\011ELSIF (NEW.grou_id is not NULL) THEN\\012\\011\\011\\011SELECT count(*) into counter FROM samples \\012\\011\\011\\011\\011where id != NEW.id and code = NEW.code and samp_id_part_of is NULL and grou_id = NEW.grou_id;\\012\\011\\011\\011IF (counter > 0) THEN\\012\\011\\011\\011\\011RAISE EXCEPTION 'Insert/Update of Sample (Code: %) failed because group sample with the same code already exists.', NEW.code;\\012\\011\\011\\011END IF;\\012\\011\\011END IF;\\012        ELSE\\012\\011\\011IF (NEW.dbin_id is not NULL) THEN\\012\\011\\011\\011SELECT count(*) into counter FROM samples \\012\\011\\011\\011\\011where id != NEW.id and code = NEW.code and samp_id_part_of = NEW.samp_id_part_of and dbin_id = NEW.dbin_id;\\012\\011\\011\\011IF (counter > 0) THEN\\012\\011\\011\\011\\011RAISE EXCEPTION 'Insert/Update of Sample (Code: %) failed because database instance sample with the same code and being the part of the same parent already exists.', NEW.code;\\012\\011\\011\\011END IF;\\012\\011\\011ELSIF (NEW.grou_id is not NULL) THEN\\012\\011\\011\\011SELECT count(*) into counter FROM samples \\012\\011\\011\\011\\011where id != NEW.id and code = NEW.code and samp_id_part_of = NEW.samp_id_part_of and grou_id = NEW.grou_id;\\012\\011\\011\\011IF (counter > 0) THEN\\012\\011\\011\\011\\011RAISE EXCEPTION 'Insert/Update of Sample (Code: %) failed because group sample with the same code and being the part of the same parent already exists.', NEW.code;\\012\\011\\011\\011END IF;\\012\\011\\011END IF;\\012        END IF;   \\012   RETURN NEW;\\012END;\\012$$ LANGUAGE 'plpgsql';\\012\\012CREATE TRIGGER SAMPLE_CODE_UNIQUENESS_CHECK BEFORE INSERT OR UPDATE ON SAMPLES\\012    FOR EACH ROW EXECUTE PROCEDURE SAMPLE_CODE_UNIQUENESS_CHECK();\\012	\N
+./sourceTest/sql/postgresql/049/017=database_version_logs.tsv:028	source/sql/postgresql/migration/migration-027-028.sql	SUCCESS	2008-11-18 13:24:17.508	-- Create EXPERIMENT_ATTACHMENT_CONTENTS.\\012CREATE TABLE EXPERIMENT_ATTACHMENT_CONTENTS (ID TECH_ID NOT NULL,VALUE FILE NOT NULL);\\012CREATE SEQUENCE EXPERIMENT_ATTACHMENT_CONTENT_ID_SEQ;\\012ALTER TABLE EXPERIMENT_ATTACHMENT_CONTENTS ADD CONSTRAINT EXAC_PK PRIMARY KEY(ID);\\012\\012-- Alter EXPERIMENT_ATTACHMENTS by adding the new column which has a NULL constraint.\\012-- The NOT NULL constraint is added later on.\\012ALTER TABLE EXPERIMENT_ATTACHMENTS ADD COLUMN EXAC_ID TECH_ID;\\012\\012-- Does the VALUE migration between EXPERIMENT_ATTACHMENTS to EXPERIMENT_ATTACHMENT_CONTENTS.\\012CREATE OR REPLACE FUNCTION move_exp_att_content() RETURNS integer AS $$\\012DECLARE\\012    rec RECORD;\\012    seq BIGINT;\\012BEGIN\\012  FOR rec IN SELECT id, value FROM EXPERIMENT_ATTACHMENTS LOOP\\012  \\011seq := nextval('EXPERIMENT_ATTACHMENT_CONTENT_ID_SEQ');\\012    INSERT INTO EXPERIMENT_ATTACHMENT_CONTENTS (id, value) VALUES (seq, rec.value);\\012    UPDATE EXPERIMENT_ATTACHMENTS SET exac_id = seq WHERE id = rec.id;\\012  END LOOP;\\012  RETURN 1;\\012END;\\012$$ LANGUAGE 'plpgsql';\\012\\012-- Call the function.\\012SELECT move_exp_att_content();\\012DROP FUNCTION move_exp_att_content();\\012\\012\\012-- Finish EXPERIMENT_ATTACHMENTS changes.\\012ALTER TABLE EXPERIMENT_ATTACHMENTS ADD CONSTRAINT EXAT_CONT_FK FOREIGN KEY (EXAC_ID) REFERENCES EXPERIMENT_ATTACHMENT_CONTENTS(ID);\\012ALTER TABLE EXPERIMENT_ATTACHMENTS DROP COLUMN VALUE;\\012ALTER TABLE EXPERIMENT_ATTACHMENTS ALTER COLUMN EXAC_ID SET NOT NULL;\\012	\N
+./sourceTest/sql/postgresql/049/017=database_version_logs.tsv:029	source/sql/postgresql/migration/migration-028-029.sql	SUCCESS	2009-03-18 10:50:20.105	-- -------\\012-- add modification_timestamp field to allow edition with Hibernate\\012-- -------\\012\\012ALTER TABLE samples\\012\\011ADD COLUMN modification_timestamp TIME_STAMP DEFAULT CURRENT_TIMESTAMP;\\012\\012ALTER TABLE experiments\\012\\011ADD COLUMN modification_timestamp TIME_STAMP DEFAULT CURRENT_TIMESTAMP;\\012\\012ALTER TABLE materials\\012\\011ADD COLUMN modification_timestamp TIME_STAMP DEFAULT CURRENT_TIMESTAMP;\\012\\012ALTER TABLE experiment_properties\\012\\011ADD COLUMN modification_timestamp TIME_STAMP DEFAULT CURRENT_TIMESTAMP;\\012\\012ALTER TABLE material_properties\\012\\011ADD COLUMN modification_timestamp TIME_STAMP DEFAULT CURRENT_TIMESTAMP;\\012\\012ALTER TABLE sample_properties\\012\\011ADD COLUMN modification_timestamp TIME_STAMP DEFAULT CURRENT_TIMESTAMP;\\012\\012-- -------\\012-- add property data type which references materials\\012-- -------\\012\\012ALTER TABLE property_types\\012\\011ADD COLUMN maty_prop_id tech_id;\\012\\012ALTER TABLE property_types\\012\\011ADD CONSTRAINT prty_maty_fk FOREIGN KEY (maty_prop_id) REFERENCES material_types(id);\\012\\012ALTER TABLE experiment_properties\\012\\011ADD COLUMN mate_prop_id tech_id;\\012\\012ALTER TABLE material_properties\\012\\011ADD COLUMN mate_prop_id tech_id;\\012\\012ALTER TABLE sample_properties\\012\\011ADD COLUMN mate_prop_id tech_id;\\012\\012ALTER TABLE experiment_properties\\012\\011ADD CONSTRAINT expr_mapr_fk FOREIGN KEY (mate_prop_id) REFERENCES materials(id);\\012\\012ALTER TABLE material_properties\\012\\011ADD CONSTRAINT mapr_mapr_fk FOREIGN KEY (mate_prop_id) REFERENCES materials(id);\\012\\012ALTER TABLE sample_properties\\012\\011ADD CONSTRAINT sapr_mapr_fk FOREIGN KEY (mate_prop_id) REFERENCES materials(id);\\012\\012insert into data_types\\012(id\\012 ,code\\012 ,description)\\012 values \\012 (nextval('DATA_TYPE_ID_SEQ')\\012 ,'MATERIAL'\\012 ,'Reference to a material'\\012);\\012\\012ALTER TABLE MATERIAL_PROPERTIES DROP CONSTRAINT MAPR_CK;\\012ALTER TABLE MATERIAL_PROPERTIES ADD CONSTRAINT MAPR_CK CHECK \\012\\011((VALUE IS NOT NULL AND CVTE_ID IS NULL AND MATE_PROP_ID IS NULL) OR \\012\\011 (VALUE IS NULL AND CVTE_ID IS NOT NULL AND MATE_PROP_ID IS NULL) OR\\012\\011 (VALUE IS NULL AND CVTE_ID IS NULL AND MATE_PROP_ID IS NOT NULL)\\012\\011);\\012\\012ALTER TABLE EXPERIMENT_PROPERTIES DROP CONSTRAINT EXPR_CK;\\012ALTER TABLE EXPERIMENT_PROPERTIES ADD CONSTRAINT EXPR_CK CHECK \\012\\011((VALUE IS NOT NULL AND CVTE_ID IS NULL AND MATE_PROP_ID IS NULL) OR \\012\\011 (VALUE IS NULL AND CVTE_ID IS NOT NULL AND MATE_PROP_ID IS NULL) OR\\012\\011 (VALUE IS NULL AND CVTE_ID IS NULL AND MATE_PROP_ID IS NOT NULL)\\012\\011);\\012\\012ALTER TABLE SAMPLE_PROPERTIES DROP CONSTRAINT SAPR_CK;\\012ALTER TABLE SAMPLE_PROPERTIES ADD CONSTRAINT SAPR_CK CHECK \\012\\011((VALUE IS NOT NULL AND CVTE_ID IS NULL AND MATE_PROP_ID IS NULL) OR \\012\\011 (VALUE IS NULL AND CVTE_ID IS NOT NULL AND MATE_PROP_ID IS NULL) OR\\012\\011 (VALUE IS NULL AND CVTE_ID IS NULL AND MATE_PROP_ID IS NOT NULL)\\012\\011);\\012\\012------------------------------------------------------------------------------------\\012--  Purpose:  Create trigger MATERIAL/SAMPLE/EXPERIMENT _PROPERTY_WITH_MATERIAL_DATA_TYPE_CHECK\\012--            It checks that if material property value is assigned to the entity,\\012--\\011\\011\\011\\011\\011\\011then the material type is equal to the one described by property type.\\012------------------------------------------------------------------------------------\\012\\012CREATE OR REPLACE FUNCTION MATERIAL_PROPERTY_WITH_MATERIAL_DATA_TYPE_CHECK() RETURNS trigger AS $$\\012DECLARE\\012   v_type_id  CODE;\\012   v_type_id_prop  CODE;\\012BEGIN\\012   if NEW.mate_prop_id IS NOT NULL then\\012\\011\\011\\011-- find material type id of the property type \\012\\011\\011\\011select pt.maty_prop_id into v_type_id_prop \\012\\011\\011\\011  from material_type_property_types etpt, property_types pt \\012\\011\\011\\011 where NEW.mtpt_id = etpt.id AND etpt.prty_id = pt.id;\\012\\011\\011\\012\\011\\011\\011if v_type_id_prop IS NOT NULL then\\012\\011\\011\\011\\011-- find material type id of the material which consists the entity's property value\\012\\011\\011\\011\\011select entity.maty_id into v_type_id \\012\\011\\011\\011\\011  from materials entity\\012\\011\\011\\011\\011 where NEW.mate_prop_id = entity.id;\\012\\011\\011\\011\\011if v_type_id != v_type_id_prop then\\012\\011\\011\\011\\011\\011RAISE EXCEPTION 'Insert/Update of property value referencing material (id: %) failed, as referenced material type is different than expected (id %, expected id: %).', \\012\\011\\011\\011\\011\\011\\011\\011 NEW.mate_prop_id, v_type_id, v_type_id_prop;\\012\\011\\011\\011\\011end if;\\012\\011\\011\\011end if;\\012   end if;\\012   RETURN NEW;\\012END;\\012$$ LANGUAGE 'plpgsql';\\012\\012CREATE TRIGGER MATERIAL_PROPERTY_WITH_MATERIAL_DATA_TYPE_CHECK BEFORE INSERT OR UPDATE ON material_properties\\012    FOR EACH ROW EXECUTE PROCEDURE MATERIAL_PROPERTY_WITH_MATERIAL_DATA_TYPE_CHECK();\\012    \\012CREATE OR REPLACE FUNCTION SAMPLE_PROPERTY_WITH_MATERIAL_DATA_TYPE_CHECK() RETURNS trigger AS $$\\012DECLARE\\012   v_type_id  CODE;\\012   v_type_id_prop  CODE;\\012BEGIN\\012   if NEW.mate_prop_id IS NOT NULL then\\012\\011\\011\\011-- find material type id of the property type \\012\\011\\011\\011select pt.maty_prop_id into v_type_id_prop \\012\\011\\011\\011  from sample_type_property_types etpt, property_types pt \\012\\011\\011\\011 where NEW.stpt_id = etpt.id AND etpt.prty_id = pt.id;\\012\\011\\011\\012\\011\\011\\011if v_type_id_prop IS NOT NULL then\\012\\011\\011\\011\\011-- find material type id of the material which consists the entity's property value\\012\\011\\011\\011\\011select entity.maty_id into v_type_id \\012\\011\\011\\011\\011  from materials entity\\012\\011\\011\\011\\011 where NEW.mate_prop_id = entity.id;\\012\\011\\011\\011\\011if v_type_id != v_type_id_prop then\\012\\011\\011\\011\\011\\011RAISE EXCEPTION 'Insert/Update of property value referencing material (id: %) failed, as referenced material type is different than expected (id %, expected id: %).', \\012\\011\\011\\011\\011\\011\\011\\011\\011\\011\\011\\011\\011 NEW.mate_prop_id, v_type_id, v_type_id_prop;\\012\\011\\011\\011\\011end if;\\012\\011\\011\\011end if;\\012   end if;\\012   RETURN NEW;\\012END;\\012$$ LANGUAGE 'plpgsql';\\012\\012CREATE TRIGGER SAMPLE_PROPERTY_WITH_MATERIAL_DATA_TYPE_CHECK BEFORE INSERT OR UPDATE ON sample_properties\\012    FOR EACH ROW EXECUTE PROCEDURE SAMPLE_PROPERTY_WITH_MATERIAL_DATA_TYPE_CHECK();\\012    \\012CREATE OR REPLACE FUNCTION EXPERIMENT_PROPERTY_WITH_MATERIAL_DATA_TYPE_CHECK() RETURNS trigger AS $$\\012DECLARE\\012   v_type_id  CODE;\\012   v_type_id_prop  CODE;\\012BEGIN\\012   if NEW.mate_prop_id IS NOT NULL then\\012\\011\\011\\011-- find material type id of the property type \\012\\011\\011\\011select pt.maty_prop_id into v_type_id_prop \\012\\011\\011\\011  from experiment_type_property_types etpt, property_types pt \\012\\011\\011\\011 where NEW.etpt_id = etpt.id AND etpt.prty_id = pt.id;\\012\\011\\011\\012\\011\\011\\011if v_type_id_prop IS NOT NULL then\\012\\011\\011\\011\\011-- find material type id of the material which consists the entity's property value\\012\\011\\011\\011\\011select entity.maty_id into v_type_id \\012\\011\\011\\011\\011  from materials entity\\012\\011\\011\\011\\011 where NEW.mate_prop_id = entity.id;\\012\\011\\011\\011\\011if v_type_id != v_type_id_prop then\\012\\011\\011\\011\\011\\011RAISE EXCEPTION 'Insert/Update of property value referencing material (id: %) failed, as referenced material type is different than expected (id %, expected id: %).', \\012\\011\\011\\011\\011\\011\\011\\011\\011\\011\\011\\011\\011 NEW.mate_prop_id, v_type_id, v_type_id_prop;\\012\\011\\011\\011\\011end if;\\012\\011\\011\\011end if;\\012   end if;\\012   RETURN NEW;\\012END;\\012$$ LANGUAGE 'plpgsql';\\012\\012CREATE TRIGGER EXPERIMENT_PROPERTY_WITH_MATERIAL_DATA_TYPE_CHECK BEFORE INSERT OR UPDATE ON experiment_properties\\012    FOR EACH ROW EXECUTE PROCEDURE EXPERIMENT_PROPERTY_WITH_MATERIAL_DATA_TYPE_CHECK();\\012       \\012-- -------\\012-- remove the reminescents of the OBSERVABLE_TYPE\\012-- -------\\012\\012ALTER TABLE data\\012\\011DROP CONSTRAINT data_obty_fk;\\012\\012ALTER TABLE data_set_types\\012\\011DROP CONSTRAINT obty_pk;\\012\\012ALTER TABLE data_set_types\\012\\011ADD CONSTRAINT dsty_pk PRIMARY KEY (id);\\012\\012ALTER TABLE data\\012\\011ADD CONSTRAINT data_dsty_fk FOREIGN KEY (dsty_id) REFERENCES data_set_types(id);\\012\\012ALTER TABLE data_set_types\\012\\011DROP CONSTRAINT obty_bk_uk;\\012\\012ALTER TABLE data_set_types\\012\\011DROP CONSTRAINT obty_dbin_fk;\\012\\012ALTER TABLE data_set_types\\012\\011ADD CONSTRAINT dsty_bk_uk UNIQUE (code, dbin_id);\\012\\012ALTER TABLE data_set_types\\012\\011ADD CONSTRAINT dsty_dbin_fk FOREIGN KEY (dbin_id) REFERENCES database_instances(id);\\012\\012DROP INDEX data_obty_fk_i;\\012\\012CREATE INDEX data_dsty_fk_i ON data(dsty_id);\\012	\N
+./sourceTest/sql/postgresql/049/017=database_version_logs.tsv:030	source/sql/postgresql/migration/migration-029-030.sql	SUCCESS	2009-03-23 15:34:44.72	-- -------\\012-- add modification_timestamp field to allow edition with Hibernate\\012-- -------\\012ALTER TABLE data\\012\\011ADD COLUMN modification_timestamp TIME_STAMP DEFAULT CURRENT_TIMESTAMP;\\012ALTER TABLE experiment_types\\012\\011ADD COLUMN modification_timestamp TIME_STAMP DEFAULT CURRENT_TIMESTAMP;\\012ALTER TABLE sample_types\\012\\011ADD COLUMN modification_timestamp TIME_STAMP DEFAULT CURRENT_TIMESTAMP;\\012ALTER TABLE material_types\\012\\011ADD COLUMN modification_timestamp TIME_STAMP DEFAULT CURRENT_TIMESTAMP;\\012ALTER TABLE data_set_types\\012\\011ADD COLUMN modification_timestamp TIME_STAMP DEFAULT CURRENT_TIMESTAMP;\\012ALTER TABLE controlled_vocabularies\\012\\011ADD COLUMN modification_timestamp TIME_STAMP DEFAULT CURRENT_TIMESTAMP;\\012-- -------\\012-- add properties to data sets\\012-- -------\\012CREATE TABLE DATA_SET_PROPERTIES (ID TECH_ID NOT NULL,DS_ID TECH_ID NOT NULL,DSTPT_ID TECH_ID NOT NULL,VALUE GENERIC_VALUE,CVTE_ID TECH_ID, MATE_PROP_ID TECH_ID, PERS_ID_REGISTERER TECH_ID NOT NULL,REGISTRATION_TIMESTAMP TIME_STAMP_DFL NOT NULL DEFAULT CURRENT_TIMESTAMP, MODIFICATION_TIMESTAMP TIME_STAMP DEFAULT CURRENT_TIMESTAMP);\\012CREATE TABLE DATA_SET_TYPE_PROPERTY_TYPES (ID TECH_ID NOT NULL,DSTY_ID TECH_ID NOT NULL,PRTY_ID TECH_ID NOT NULL,IS_MANDATORY BOOLEAN_CHAR NOT NULL DEFAULT 'F',IS_MANAGED_INTERNALLY BOOLEAN_CHAR NOT NULL DEFAULT 'F',PERS_ID_REGISTERER TECH_ID NOT NULL,REGISTRATION_TIMESTAMP TIME_STAMP_DFL NOT NULL DEFAULT CURRENT_TIMESTAMP);\\012\\012CREATE SEQUENCE DATA_SET_PROPERTY_ID_SEQ;\\012CREATE SEQUENCE DSTPT_ID_SEQ;\\012\\012ALTER TABLE DATA_SET_TYPE_PROPERTY_TYPES ADD CONSTRAINT DSTPT_PK PRIMARY KEY(ID);\\012ALTER TABLE DATA_SET_PROPERTIES ADD CONSTRAINT DSPR_PK PRIMARY KEY(ID);\\012\\012ALTER TABLE DATA_SET_TYPE_PROPERTY_TYPES ADD CONSTRAINT DSTPT_BK_UK UNIQUE(DSTY_ID,PRTY_ID);\\012ALTER TABLE DATA_SET_PROPERTIES ADD CONSTRAINT DSPR_BK_UK UNIQUE(DS_ID,DSTPT_ID);\\012\\012\\012ALTER TABLE DATA_SET_TYPE_PROPERTY_TYPES ADD CONSTRAINT DSTPT_DSTY_FK FOREIGN KEY (DSTY_ID) REFERENCES DATA_SET_TYPES(ID);\\012ALTER TABLE DATA_SET_TYPE_PROPERTY_TYPES ADD CONSTRAINT DSTPT_PERS_FK FOREIGN KEY (PERS_ID_REGISTERER) REFERENCES PERSONS(ID);\\012ALTER TABLE DATA_SET_TYPE_PROPERTY_TYPES ADD CONSTRAINT DSTPT_PRTY_FK FOREIGN KEY (PRTY_ID) REFERENCES PROPERTY_TYPES(ID);\\012ALTER TABLE DATA_SET_PROPERTIES ADD CONSTRAINT DSPR_CVTE_FK FOREIGN KEY (CVTE_ID) REFERENCES CONTROLLED_VOCABULARY_TERMS(ID);\\012ALTER TABLE DATA_SET_PROPERTIES ADD CONSTRAINT DSPR_DSTPT_FK FOREIGN KEY (DSTPT_ID) REFERENCES DATA_SET_TYPE_PROPERTY_TYPES(ID) ON DELETE CASCADE;\\012ALTER TABLE DATA_SET_PROPERTIES ADD CONSTRAINT DSPR_DS_FK FOREIGN KEY (DS_ID) REFERENCES DATA(ID);\\012ALTER TABLE DATA_SET_PROPERTIES ADD CONSTRAINT DSPR_PERS_FK FOREIGN KEY (PERS_ID_REGISTERER) REFERENCES PERSONS(ID);\\012ALTER TABLE DATA_SET_PROPERTIES ADD CONSTRAINT DSPR_MAPR_FK FOREIGN KEY (MATE_PROP_ID) REFERENCES MATERIALS(ID);\\012\\012ALTER TABLE DATA_SET_PROPERTIES ADD CONSTRAINT DSPR_CK CHECK \\012\\011((VALUE IS NOT NULL AND CVTE_ID IS NULL AND MATE_PROP_ID IS NULL) OR \\012\\011 (VALUE IS NULL AND CVTE_ID IS NOT NULL AND MATE_PROP_ID IS NULL) OR\\012\\011 (VALUE IS NULL AND CVTE_ID IS NULL AND MATE_PROP_ID IS NOT NULL)\\012\\011);\\012\\012CREATE INDEX DSPR_CVTE_FK_I ON DATA_SET_PROPERTIES (CVTE_ID);\\012CREATE INDEX DSPR_DSTPT_FK_I ON DATA_SET_PROPERTIES (DSTPT_ID);\\012CREATE INDEX DSPR_DS_FK_I ON DATA_SET_PROPERTIES (DS_ID);\\012CREATE INDEX DSPR_PERS_FK_I ON DATA_SET_PROPERTIES (PERS_ID_REGISTERER);\\012CREATE INDEX DSTPT_DSTY_FK_I ON DATA_SET_TYPE_PROPERTY_TYPES (DSTY_ID);\\012CREATE INDEX DSTPT_PERS_FK_I ON DATA_SET_TYPE_PROPERTY_TYPES (PERS_ID_REGISTERER);\\012CREATE INDEX DSTPT_PRTY_FK_I ON DATA_SET_TYPE_PROPERTY_TYPES (PRTY_ID);\\012\\012CREATE OR REPLACE FUNCTION DATA_SET_PROPERTY_WITH_MATERIAL_DATA_TYPE_CHECK() RETURNS trigger AS $$\\012DECLARE\\012   v_type_id  CODE;\\012   v_type_id_prop  CODE;\\012BEGIN\\012   if NEW.mate_prop_id IS NOT NULL then\\012\\011\\011\\011-- find material type id of the property type \\012\\011\\011\\011select pt.maty_prop_id into v_type_id_prop \\012\\011\\011\\011  from data_set_type_property_types dstpt, property_types pt \\012\\011\\011\\011 where NEW.dstpt_id = dstpt.id AND dstpt.prty_id = pt.id;\\012\\011\\011\\012\\011\\011\\011if v_type_id_prop IS NOT NULL then\\012\\011\\011\\011\\011-- find material type id of the material which consists the entity's property value\\012\\011\\011\\011\\011select entity.maty_id into v_type_id \\012\\011\\011\\011\\011  from materials entity\\012\\011\\011\\011\\011 where NEW.mate_prop_id = entity.id;\\012\\011\\011\\011\\011if v_type_id != v_type_id_prop then\\012\\011\\011\\011\\011\\011RAISE EXCEPTION 'Insert/Update of property value referencing material (id: %) failed, as referenced material type is different than expected (id %, expected id: %).', \\012\\011\\011\\011\\011\\011\\011\\011\\011\\011\\011\\011\\011 NEW.mate_prop_id, v_type_id, v_type_id_prop;\\012\\011\\011\\011\\011end if;\\012\\011\\011\\011end if;\\012   end if;\\012   RETURN NEW;\\012END;\\012$$ LANGUAGE 'plpgsql';\\012\\012CREATE TRIGGER DATA_SET_PROPERTY_WITH_MATERIAL_DATA_TYPE_CHECK BEFORE INSERT OR UPDATE ON data_set_properties\\012    FOR EACH ROW EXECUTE PROCEDURE DATA_SET_PROPERTY_WITH_MATERIAL_DATA_TYPE_CHECK();   \\012	\N
+./sourceTest/sql/postgresql/049/017=database_version_logs.tsv:032	source/sql/postgresql/migration/migration-031-032.sql	SUCCESS	2009-04-09 09:36:36.2	-- -------\\012-- Modify MATERIAL_BATCHES\\012-- -------\\012\\012ALTER TABLE material_batches\\012    DROP COLUMN proc_id;\\012\\012-- -------\\012-- Modify SAMPLES\\012-- -------\\012\\012ALTER TABLE samples\\012    ADD COLUMN expe_id tech_id;\\012\\012ALTER TABLE samples\\012    ADD CONSTRAINT samp_expe_fk FOREIGN KEY (expe_id) REFERENCES experiments(id);\\012\\012CREATE INDEX samp_expe_fk_i ON samples USING btree (expe_id);\\012\\012-- relink samples directly to experiments\\012\\012UPDATE samples\\012SET expe_id = (SELECT e.id FROM experiments e, procedures p, sample_inputs si \\012               WHERE si.samp_id = samples.id AND si.proc_id = p.id AND p.expe_id = e.id AND e.inva_id IS NULL);\\012\\012\\012-- -------\\012-- Modify DATA\\012-- -------\\012\\012ALTER TABLE data\\012    ADD COLUMN expe_id tech_id;\\012\\012ALTER TABLE data\\012    ADD CONSTRAINT data_expe_fk FOREIGN KEY (expe_id) REFERENCES experiments(id);\\012\\012CREATE INDEX data_expe_fk_i ON data USING btree (expe_id);\\012\\012UPDATE data\\012SET expe_id = (SELECT e.id FROM experiments e, procedures p \\012               WHERE data.proc_id_produced_by = p.id AND p.expe_id = e.id);\\012\\012ALTER TABLE data\\012    ALTER COLUMN expe_id SET NOT NULL;\\012\\012ALTER TABLE data\\012    DROP COLUMN proc_id_produced_by;\\012\\012-- -------\\012-- Drop PROCEDURES, PROCEDURE_TYPES, and SAMPLE_INPUTS\\012-- -------\\012\\012DROP TABLE sample_inputs;\\012DROP TABLE procedures;\\012DROP TABLE procedure_types;\\012\\012DROP SEQUENCE procedure_id_seq;\\012DROP SEQUENCE procedure_type_id_seq;\\012\\012-- -------\\012-- Add CODE_SEQ\\012-- -------\\012\\012CREATE SEQUENCE CODE_SEQ;\\012\\012-- -------\\012-- Add new columns to DATA_STORES\\012-- -------\\012\\012ALTER TABLE data_stores\\012    ADD COLUMN remote_url character varying(250),\\012    ADD COLUMN session_token character varying(50),\\012    ADD COLUMN modification_timestamp time_stamp DEFAULT now();\\012\\012UPDATE data_stores\\012SET remote_url = '', session_token='';\\012\\012ALTER TABLE data_stores\\012    ALTER COLUMN remote_url SET NOT NULL,\\012    ALTER COLUMN session_token SET NOT NULL;\\012\\012-- -------\\012-- Drop foreign keys onto DATA_STORES\\012-- -------\\012\\012ALTER TABLE database_instances\\012    DROP COLUMN dast_id;\\012\\012ALTER TABLE groups\\012    DROP COLUMN dast_id;\\012\\012ALTER TABLE projects\\012    DROP COLUMN dast_id;\\012\\012ALTER TABLE experiments\\012    DROP COLUMN dast_id;\\012\\012-- -------\\012-- Add foreign key from DATA onto DATA_STORES\\012-- -------\\012\\012ALTER TABLE data\\012    ADD COLUMN dast_id tech_id;\\012\\012ALTER TABLE data\\012    ADD CONSTRAINT data_dast_fk FOREIGN KEY (dast_id) REFERENCES data_stores(id);\\012\\012UPDATE data\\012SET dast_id = (select id from data_stores where code = 'STANDARD');\\012\\012ALTER TABLE data\\012    ALTER COLUMN dast_id SET NOT NULL;\\012\\012\\012------------------------------------------------------------------------------------\\012--  Purpose:  Replace trigger SAMPLE_CODE_UNIQUENESS_CHECK \\012------------------------------------------------------------------------------------\\012\\012CREATE OR REPLACE FUNCTION SAMPLE_CODE_UNIQUENESS_CHECK() RETURNS trigger AS $$\\012DECLARE\\012   counter  INTEGER;\\012BEGIN\\012    LOCK TABLE samples IN EXCLUSIVE MODE;\\012    IF (NEW.samp_id_part_of is NULL) THEN\\012        IF (NEW.dbin_id is not NULL) THEN\\012            SELECT count(*) into counter FROM samples \\012                where id != NEW.id and code = NEW.code and samp_id_part_of is NULL and dbin_id = NEW.dbin_id;\\012            IF (counter > 0) THEN\\012                RAISE EXCEPTION 'Insert/Update of Sample (Code: %) failed because database instance sample with the same code already exists.', NEW.code;\\012            END IF;\\012        ELSIF (NEW.grou_id is not NULL) THEN\\012            SELECT count(*) into counter FROM samples \\012                where id != NEW.id and code = NEW.code and samp_id_part_of is NULL and grou_id = NEW.grou_id;\\012            IF (counter > 0) THEN\\012                RAISE EXCEPTION 'Insert/Update of Sample (Code: %) failed because group sample with the same code already exists.', NEW.code;\\012            END IF;\\012        END IF;\\012        ELSE\\012        IF (NEW.dbin_id is not NULL) THEN\\012            SELECT count(*) into counter FROM samples \\012                where id != NEW.id and code = NEW.code and samp_id_part_of = NEW.samp_id_part_of and dbin_id = NEW.dbin_id;\\012            IF (counter > 0) THEN\\012                RAISE EXCEPTION 'Insert/Update of Sample (Code: %) failed because database instance sample with the same code and being the part of the same parent already exists.', NEW.code;\\012            END IF;\\012        ELSIF (NEW.grou_id is not NULL) THEN\\012            SELECT count(*) into counter FROM samples \\012                where id != NEW.id and code = NEW.code and samp_id_part_of = NEW.samp_id_part_of and grou_id = NEW.grou_id;\\012            IF (counter > 0) THEN\\012                RAISE EXCEPTION 'Insert/Update of Sample (Code: %) failed because group sample with the same code and being the part of the same parent already exists.', NEW.code;\\012            END IF;\\012        END IF;\\012        END IF;   \\012   RETURN NEW;\\012END;\\012$$ LANGUAGE 'plpgsql';\\012\\012\\012\\012	\N
+./sourceTest/sql/postgresql/049/017=database_version_logs.tsv:034	source/sql/postgresql/migration/migration-033-034.sql	SUCCESS	2009-05-26 08:32:49.935	------------------------------------------------------------------------------------\\012-- Create sequence for generating permanent identifiers starting with nextval of existing dataset sequence.\\012------------------------------------------------------------------------------------\\012CREATE FUNCTION CREATE_SEQUENCE(EXISTING_SEQUENCE VARCHAR, NEW_SEQUENCE VARCHAR) RETURNS VOID AS $$\\012DECLARE\\012  CURR_SEQ_VAL   INTEGER;\\012BEGIN\\012  SELECT INTO CURR_SEQ_VAL NEXTVAL(EXISTING_SEQUENCE);\\012  EXECUTE 'CREATE SEQUENCE ' || NEW_SEQUENCE || ' START WITH ' || CURR_SEQ_VAL;\\012  RETURN;\\012END;\\012$$ LANGUAGE 'plpgsql';\\012\\012SELECT CREATE_SEQUENCE('DATA_ID_SEQ', 'PERM_ID_SEQ');\\012DROP FUNCTION CREATE_SEQUENCE(VARCHAR, VARCHAR);\\012\\012------------------------------------------------------------------------------------\\012-- Add perm_id columns to samples and experiments.\\012------------------------------------------------------------------------------------\\012ALTER TABLE SAMPLES ADD COLUMN PERM_ID CODE;\\012ALTER TABLE EXPERIMENTS ADD COLUMN PERM_ID CODE;\\012\\012UPDATE SAMPLES SET PERM_ID = to_char(registration_timestamp,'YYYYMMDDHHSSMS') || '-' || NEXTVAL('PERM_ID_SEQ');\\012UPDATE EXPERIMENTS SET PERM_ID = to_char(registration_timestamp,'YYYYMMDDHHSSMS') || '-' || NEXTVAL('PERM_ID_SEQ');\\012ALTER TABLE SAMPLES ALTER COLUMN PERM_ID SET NOT NULL;\\012ALTER TABLE EXPERIMENTS ALTER COLUMN PERM_ID SET NOT NULL;\\012ALTER TABLE SAMPLES ADD CONSTRAINT SAMP_PI_UK UNIQUE(PERM_ID);\\012ALTER TABLE EXPERIMENTS ADD CONSTRAINT EXPE_PI_UK UNIQUE(PERM_ID);\\012\\012\\012------------------------------------------------------------------------------------\\012-- Add column is_chosen_from_list to controlled_vocabularies.\\012------------------------------------------------------------------------------------\\012ALTER TABLE controlled_vocabularies ADD COLUMN is_chosen_from_list BOOLEAN_CHAR NOT NULL DEFAULT TRUE;\\012ALTER TABLE controlled_vocabularies ADD COLUMN source_uri CHARACTER VARYING(250);\\012------------------------------------------------------------------------------------\\012-- Modify Data table - remove arc connection between Sample and Data table, use a flag instead\\012------------------------------------------------------------------------------------\\012\\012-- add new columns\\012\\012ALTER TABLE data\\012    ADD COLUMN is_derived boolean_char;\\012ALTER TABLE data\\012    ADD COLUMN samp_id tech_id;\\012\\012-- update values in new columns\\012\\012UPDATE data\\012    SET is_derived = (samp_id_derived_from IS NOT NULL); \\012UPDATE data\\012    SET samp_id = samp_id_derived_from \\012    WHERE is_derived = 'TRUE';\\012UPDATE data\\012    SET samp_id = samp_id_acquired_from \\012    WHERE is_derived = 'FALSE';\\012\\012-- add constraints and indexes to new columns\\012\\012ALTER TABLE data\\012    ALTER COLUMN is_derived SET NOT NULL;\\012ALTER TABLE data\\012    ALTER COLUMN samp_id SET NOT NULL;   \\012ALTER TABLE data\\012    ADD CONSTRAINT data_samp_fk FOREIGN KEY (samp_id) REFERENCES samples (id);\\012CREATE INDEX data_samp_fk_i ON data USING btree (samp_id);\\012\\012-- remove old columns\\012\\012ALTER TABLE data\\012    DROP COLUMN samp_id_acquired_from;\\012ALTER TABLE data\\012    DROP COLUMN samp_id_derived_from;\\012    \\012------------------------------------------------------------------------------------\\012-- Granting SELECT privilege to group openbis_readonly\\012------------------------------------------------------------------------------------\\012\\012GRANT SELECT ON SEQUENCE attachment_content_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE attachment_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE code_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE controlled_vocabulary_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE cvte_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE data_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE data_set_property_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE data_set_relationship_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE data_set_type_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE data_store_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE data_type_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE database_instance_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE dstpt_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE etpt_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE event_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE experiment_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE experiment_property_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE experiment_type_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE file_format_type_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE group_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE invalidation_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE locator_type_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE material_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE material_property_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE material_type_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE mtpt_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE perm_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE person_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE project_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE property_type_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE role_assignment_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE sample_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE sample_property_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE sample_type_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE stpt_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE attachment_contents TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE attachments TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE controlled_vocabularies TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE controlled_vocabulary_terms TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE data TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE data_set_properties TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE data_set_relationships TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE data_set_type_property_types TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE data_set_types TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE data_stores TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE data_types TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE database_instances TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE database_version_logs TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE events TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE experiment_properties TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE experiment_type_property_types TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE experiment_types TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE experiments TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE external_data TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE file_format_types TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE groups TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE invalidations TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE locator_types TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE material_properties TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE material_type_property_types TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE material_types TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE materials TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE persons TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE projects TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE property_types TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE role_assignments TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE sample_properties TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE sample_type_property_types TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE sample_types TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE samples TO GROUP OPENBIS_READONLY;\\012\\012------------------------------------------------------------------------------------\\012-- Delete MATERIAL_BATCHES table\\012------------------------------------------------------------------------------------\\012\\012-- WARNING: Potential data lost!!!\\012-- WARNING: Potential data lost!!!\\012-- WARNING: Potential data lost!!!\\012\\012DROP TABLE SAMPLE_MATERIAL_BATCHES;\\012DROP TABLE MATERIAL_BATCHES;\\012DROP SEQUENCE MATERIAL_BATCH_ID_SEQ;\\012\\012------------------------------------------------------------------------------------\\012-- Delete MATE_ID_INHIBITOR_OF from table MATERIALS\\012------------------------------------------------------------------------------------\\012\\012-- WARNING: Potential data lost!!!\\012-- WARNING: Potential data lost!!!\\012-- WARNING: Potential data lost!!!\\012\\012ALTER TABLE MATERIALS DROP COLUMN MATE_ID_INHIBITOR_OF;\\012	\N
+./sourceTest/sql/postgresql/049/017=database_version_logs.tsv:041	source/sql/postgresql/migration/migration-040-041.sql	SUCCESS	2009-09-14 13:48:57.539	-- Create FILTERS table\\012\\012CREATE TABLE FILTERS (ID TECH_ID NOT NULL, DBIN_ID TECH_ID NOT NULL, NAME VARCHAR(200) NOT NULL, DESCRIPTION DESCRIPTION_1000,REGISTRATION_TIMESTAMP TIME_STAMP_DFL NOT NULL DEFAULT CURRENT_TIMESTAMP, PERS_ID_REGISTERER TECH_ID NOT NULL, MODIFICATION_TIMESTAMP TIME_STAMP DEFAULT CURRENT_TIMESTAMP, EXPRESSION VARCHAR(2000) NOT NULL, IS_PUBLIC BOOLEAN NOT NULL, GRID_ID VARCHAR(200) NOT NULL);\\012CREATE SEQUENCE FILTER_ID_SEQ;\\012ALTER TABLE FILTERS ADD CONSTRAINT FILT_PK PRIMARY KEY(ID);\\012ALTER TABLE FILTERS ADD CONSTRAINT FILT_BK_UK UNIQUE(NAME, DBIN_ID, GRID_ID);\\012ALTER TABLE FILTERS ADD CONSTRAINT FILT_PERS_FK FOREIGN KEY (PERS_ID_REGISTERER) REFERENCES PERSONS(ID);\\012ALTER TABLE FILTERS ADD CONSTRAINT FILT_DBIN_FK FOREIGN KEY (DBIN_ID) REFERENCES DATABASE_INSTANCES(ID);\\012CREATE INDEX FILT_PERS_FK_I ON FILTERS (PERS_ID_REGISTERER);\\012CREATE INDEX FILT_DBIN_FK_I ON FILTERS (DBIN_ID);\\012GRANT SELECT ON SEQUENCE filter_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE filters TO GROUP OPENBIS_READONLY;\\012\\012-- Add missing foreign key to role assignments authorization group\\012ALTER TABLE ROLE_ASSIGNMENTS ADD CONSTRAINT ROAS_AG_FK_GRANTEE FOREIGN KEY (AG_ID_GRANTEE) REFERENCES AUTHORIZATION_GROUPS(ID);\\012\\012--------------------------------------------------------------------------------------------------\\012-- Modify dataset connections:\\012-- 1. connection with sample shouldn't be mandatory any more\\012-- 2. introduce an arc condition that dataset cannot be connected with a sample and a parent dataset at the same time\\012--------------------------------------------------------------------------------------------------\\012\\012-- Weaken data-sample connection constraint - allow dataset to have no connection with sample\\012ALTER TABLE data ALTER COLUMN samp_id DROP NOT NULL;\\012\\012-- Remove data-sample connection for datasets that have a parent\\012\\012UPDATE data \\012   SET samp_id = NULL \\012 WHERE id IN (SELECT DISTINCT data_id_child FROM data_set_relationships);\\012\\012-- With PostgreSQL 8.4 one can check that before migration there were no cycles in dataset relationships:\\012--\\012-- WITH RECURSIVE data_set_parents(id, parent_ids, cycle) AS (\\012--         SELECT  r.data_id_child AS id, \\012--                 ARRAY[CAST (r.data_id_parent AS bigint)] AS parent_ids, \\012--                 false AS cycle \\012--         FROM data_set_relationships r\\012--     UNION ALL\\012--         SELECT  r.data_id_child,\\012--                 CAST (r.data_id_parent AS bigint) || p.parent_ids,\\012--                 r.data_id_child = ANY(p.parent_ids)\\012--         FROM data_set_relationships r, data_set_parents p\\012--         WHERE r.data_id_parent = p.id AND NOT cycle\\012-- )\\012-- SELECT count(*) AS cycles FROM data_set_parents WHERE cycle = true;\\012\\012---------------------------------------------------------------------------------------------------\\012--  Purpose:  Create DEFERRED triggers:\\012--            * check_dataset_relationships_on_data_table_modification,\\012--            * check_dataset_relationships_on_relationships_table_modification.\\012--            They check that after all modifications of database (just before commit) \\012--            if 'data'/'data_set_relationships' tables are among modified tables \\012--            dataset is not connected with a sample and a parent dataset at the same time.\\012--            This connections are held in two different tables so simple immediate trigger \\012--            with arc check cannot be used and we need two deferred triggers.\\012----------------------------------------------------------------------------------------------------\\012\\012-- trigger for 'data' table\\012\\012CREATE OR REPLACE FUNCTION check_dataset_relationships_on_data_table_modification() RETURNS trigger AS $$\\012DECLARE\\012\\011counter\\011INTEGER;\\012BEGIN\\012\\011-- if there is a connection with a Sample there should not be any connection with a parent Data Set\\012\\011IF (NEW.samp_id IS NOT NULL) THEN\\012\\011\\011-- count number of parents\\012\\011\\011SELECT count(*) INTO counter \\012\\011\\011\\011FROM data_set_relationships \\012\\011\\011\\011WHERE data_id_child = OLD.id;\\012\\011\\011IF (counter > 0) THEN\\012\\011\\011\\011RAISE EXCEPTION 'Insert/Update of Data Set (Code: %) failed because it cannot be connected with a Sample and a parent Data Set at the same time.', OLD.code;\\012\\011\\011END IF;\\012\\011END IF;\\012  RETURN NEW;\\012END;\\012$$ LANGUAGE 'plpgsql';\\012\\012CREATE CONSTRAINT TRIGGER check_dataset_relationships_on_data_table_modification \\012  AFTER INSERT OR UPDATE ON data\\012\\011DEFERRABLE INITIALLY DEFERRED\\012\\011FOR EACH ROW \\012\\011EXECUTE PROCEDURE check_dataset_relationships_on_data_table_modification();\\012\\012-- trigger for 'data_set_relationships'\\012\\012CREATE OR REPLACE FUNCTION check_dataset_relationships_on_relationships_table_modification() RETURNS trigger AS $$\\012DECLARE\\012\\011counter\\011INTEGER;\\012\\011sample_id\\011TECH_ID;\\012\\011data_code\\011CODE;\\012BEGIN\\012\\011-- child will have a parent added so it should not be connected with any sample\\012\\011SELECT samp_id, code INTO sample_id, data_code \\012\\011\\011FROM data \\012\\011\\011WHERE id = NEW.data_id_child;\\012\\011IF (sample_id IS NOT NULL) THEN\\012\\011\\011RAISE EXCEPTION 'Insert/Update of Data Set (Code: %) failed because it cannot be connected to a Sample and to a parent Data Set at the same time.', data_code;\\012\\011END IF;\\012\\011RETURN NEW;\\012END;\\012$$ LANGUAGE 'plpgsql';\\012  \\012CREATE CONSTRAINT TRIGGER check_dataset_relationships_on_relationships_table_modification \\012  AFTER INSERT OR UPDATE ON data_set_relationships\\012\\011DEFERRABLE INITIALLY DEFERRED\\012\\011FOR EACH ROW \\012\\011EXECUTE PROCEDURE check_dataset_relationships_on_relationships_table_modification();\\012	\N
+./sourceTest/sql/postgresql/049/schema-049.sql:    LANGUAGE plpgsql
+./sourceTest/sql/postgresql/049/schema-049.sql:    LANGUAGE plpgsql
+./sourceTest/sql/postgresql/049/schema-049.sql:    LANGUAGE plpgsql
+./sourceTest/sql/postgresql/049/schema-049.sql:    LANGUAGE plpgsql
+./sourceTest/sql/postgresql/049/schema-049.sql:    LANGUAGE plpgsql
+./sourceTest/sql/postgresql/049/schema-049.sql:    LANGUAGE plpgsql
+./sourceTest/sql/postgresql/049/schema-049.sql:    LANGUAGE plpgsql
+./sourceTest/sql/postgresql/049/schema-049.sql:    LANGUAGE plpgsql
+./sourceTest/sql/postgresql/049/schema-049.sql:    LANGUAGE plpgsql
+./sourceTest/sql/postgresql/049/schema-049.sql:    LANGUAGE plpgsql
+./sourceTest/sql/postgresql/050/.svn/text-base/017=database_version_logs.tsv.svn-base:027	D:\\User\\felmer\\dev-workspace\\openbis/source/sql/postgresql/027/function-027.sql	SUCCESS	2008-11-05 09:18:00.403	-- Creating Functions\\012\\012------------------------------------------------------------------------------------\\012--  Purpose:  Create function RENAME_SEQUENCE() that is required for renaming the sequences belonging to tables\\012------------------------------------------------------------------------------------\\012CREATE FUNCTION RENAME_SEQUENCE(OLD_NAME VARCHAR, NEW_NAME VARCHAR) RETURNS INTEGER AS $$\\012DECLARE\\012  CURR_SEQ_VAL   INTEGER;\\012BEGIN\\012  SELECT INTO CURR_SEQ_VAL NEXTVAL(OLD_NAME);\\012  EXECUTE 'CREATE SEQUENCE ' || NEW_NAME || ' START WITH ' || CURR_SEQ_VAL;\\012  EXECUTE 'DROP SEQUENCE ' || OLD_NAME;\\012  RETURN CURR_SEQ_VAL;\\012END;\\012$$ LANGUAGE 'plpgsql';\\012\\012\\012------------------------------------------------------------------------------------\\012--  Purpose:  Create trigger CONTROLLED_VOCABULARY_CHECK \\012------------------------------------------------------------------------------------\\012\\012CREATE OR REPLACE FUNCTION CONTROLLED_VOCABULARY_CHECK() RETURNS trigger AS $$\\012DECLARE\\012   v_code  CODE;\\012BEGIN\\012\\012   select code into v_code from data_types where id = NEW.daty_id;\\012\\012   -- Check if the data is of type "CONTROLLEDVOCABULARY"\\012   if v_code = 'CONTROLLEDVOCABULARY' then\\012      if NEW.covo_id IS NULL then\\012         RAISE EXCEPTION 'Insert/Update of Property Type (Code: %) failed, as its Data Type is CONTROLLEDVOCABULARY, but it is not linked to a Controlled Vocabulary.', NEW.code;\\012      end if;\\012   end if;\\012\\012   RETURN NEW;\\012\\012END;\\012$$ LANGUAGE 'plpgsql';\\012\\012CREATE TRIGGER CONTROLLED_VOCABULARY_CHECK BEFORE INSERT OR UPDATE ON PROPERTY_TYPES\\012    FOR EACH ROW EXECUTE PROCEDURE CONTROLLED_VOCABULARY_CHECK();\\012\\012\\012------------------------------------------------------------------------------------\\012--  Purpose:  Create trigger EXTERNAL_DATA_STORAGE_FORMAT_CHECK \\012------------------------------------------------------------------------------------\\012\\012CREATE OR REPLACE FUNCTION EXTERNAL_DATA_STORAGE_FORMAT_CHECK() RETURNS trigger AS $$\\012DECLARE\\012   v_covo_code  CODE;\\012   data_code CODE;\\012BEGIN\\012\\012   select code into v_covo_code from controlled_vocabularies\\012      where is_internal_namespace = true and \\012         id = (select covo_id from controlled_vocabulary_terms where id = NEW.cvte_id_stor_fmt);\\012   -- Check if the data storage format is a term of the controlled vocabulary "STORAGE_FORMAT"\\012   if v_covo_code != 'STORAGE_FORMAT' then\\012      select code into data_code from data where id = NEW.data_id; \\012      RAISE EXCEPTION 'Insert/Update of Data (Code: %) failed, as its Storage Format is %, but is required to be STORAGE_FORMAT.', data_code, v_covo_code;\\012   end if;\\012\\012   RETURN NEW;\\012\\012END;\\012$$ LANGUAGE 'plpgsql';\\012\\012CREATE TRIGGER EXTERNAL_DATA_STORAGE_FORMAT_CHECK BEFORE INSERT OR UPDATE ON EXTERNAL_DATA\\012    FOR EACH ROW EXECUTE PROCEDURE EXTERNAL_DATA_STORAGE_FORMAT_CHECK();\\012\\012------------------------------------------------------------------------------------\\012--  Purpose:  Create trigger SAMPLE_CODE_UNIQUENESS_CHECK \\012------------------------------------------------------------------------------------\\012\\012CREATE OR REPLACE FUNCTION SAMPLE_CODE_UNIQUENESS_CHECK() RETURNS trigger AS $$\\012DECLARE\\012   counter  INTEGER;\\012BEGIN\\012\\011IF (NEW.samp_id_part_of is NULL) THEN\\012\\011\\011IF (NEW.dbin_id is not NULL) THEN\\012\\011\\011\\011SELECT count(*) into counter FROM samples \\012\\011\\011\\011\\011where id != NEW.id and code = NEW.code and samp_id_part_of is NULL and dbin_id = NEW.dbin_id;\\012\\011\\011\\011IF (counter > 0) THEN\\012\\011\\011\\011\\011RAISE EXCEPTION 'Insert/Update of Sample (Code: %) failed because database instance sample with the same code already exists.', NEW.code;\\012\\011\\011\\011END IF;\\012\\011\\011ELSIF (NEW.grou_id is not NULL) THEN\\012\\011\\011\\011SELECT count(*) into counter FROM samples \\012\\011\\011\\011\\011where id != NEW.id and code = NEW.code and samp_id_part_of is NULL and grou_id = NEW.grou_id;\\012\\011\\011\\011IF (counter > 0) THEN\\012\\011\\011\\011\\011RAISE EXCEPTION 'Insert/Update of Sample (Code: %) failed because group sample with the same code already exists.', NEW.code;\\012\\011\\011\\011END IF;\\012\\011\\011END IF;\\012        ELSE\\012\\011\\011IF (NEW.dbin_id is not NULL) THEN\\012\\011\\011\\011SELECT count(*) into counter FROM samples \\012\\011\\011\\011\\011where id != NEW.id and code = NEW.code and samp_id_part_of = NEW.samp_id_part_of and dbin_id = NEW.dbin_id;\\012\\011\\011\\011IF (counter > 0) THEN\\012\\011\\011\\011\\011RAISE EXCEPTION 'Insert/Update of Sample (Code: %) failed because database instance sample with the same code and being the part of the same parent already exists.', NEW.code;\\012\\011\\011\\011END IF;\\012\\011\\011ELSIF (NEW.grou_id is not NULL) THEN\\012\\011\\011\\011SELECT count(*) into counter FROM samples \\012\\011\\011\\011\\011where id != NEW.id and code = NEW.code and samp_id_part_of = NEW.samp_id_part_of and grou_id = NEW.grou_id;\\012\\011\\011\\011IF (counter > 0) THEN\\012\\011\\011\\011\\011RAISE EXCEPTION 'Insert/Update of Sample (Code: %) failed because group sample with the same code and being the part of the same parent already exists.', NEW.code;\\012\\011\\011\\011END IF;\\012\\011\\011END IF;\\012        END IF;   \\012   RETURN NEW;\\012END;\\012$$ LANGUAGE 'plpgsql';\\012\\012CREATE TRIGGER SAMPLE_CODE_UNIQUENESS_CHECK BEFORE INSERT OR UPDATE ON SAMPLES\\012    FOR EACH ROW EXECUTE PROCEDURE SAMPLE_CODE_UNIQUENESS_CHECK();\\012	\N
+./sourceTest/sql/postgresql/050/.svn/text-base/017=database_version_logs.tsv.svn-base:028	source/sql/postgresql/migration/migration-027-028.sql	SUCCESS	2008-11-18 13:24:17.508	-- Create EXPERIMENT_ATTACHMENT_CONTENTS.\\012CREATE TABLE EXPERIMENT_ATTACHMENT_CONTENTS (ID TECH_ID NOT NULL,VALUE FILE NOT NULL);\\012CREATE SEQUENCE EXPERIMENT_ATTACHMENT_CONTENT_ID_SEQ;\\012ALTER TABLE EXPERIMENT_ATTACHMENT_CONTENTS ADD CONSTRAINT EXAC_PK PRIMARY KEY(ID);\\012\\012-- Alter EXPERIMENT_ATTACHMENTS by adding the new column which has a NULL constraint.\\012-- The NOT NULL constraint is added later on.\\012ALTER TABLE EXPERIMENT_ATTACHMENTS ADD COLUMN EXAC_ID TECH_ID;\\012\\012-- Does the VALUE migration between EXPERIMENT_ATTACHMENTS to EXPERIMENT_ATTACHMENT_CONTENTS.\\012CREATE OR REPLACE FUNCTION move_exp_att_content() RETURNS integer AS $$\\012DECLARE\\012    rec RECORD;\\012    seq BIGINT;\\012BEGIN\\012  FOR rec IN SELECT id, value FROM EXPERIMENT_ATTACHMENTS LOOP\\012  \\011seq := nextval('EXPERIMENT_ATTACHMENT_CONTENT_ID_SEQ');\\012    INSERT INTO EXPERIMENT_ATTACHMENT_CONTENTS (id, value) VALUES (seq, rec.value);\\012    UPDATE EXPERIMENT_ATTACHMENTS SET exac_id = seq WHERE id = rec.id;\\012  END LOOP;\\012  RETURN 1;\\012END;\\012$$ LANGUAGE 'plpgsql';\\012\\012-- Call the function.\\012SELECT move_exp_att_content();\\012DROP FUNCTION move_exp_att_content();\\012\\012\\012-- Finish EXPERIMENT_ATTACHMENTS changes.\\012ALTER TABLE EXPERIMENT_ATTACHMENTS ADD CONSTRAINT EXAT_CONT_FK FOREIGN KEY (EXAC_ID) REFERENCES EXPERIMENT_ATTACHMENT_CONTENTS(ID);\\012ALTER TABLE EXPERIMENT_ATTACHMENTS DROP COLUMN VALUE;\\012ALTER TABLE EXPERIMENT_ATTACHMENTS ALTER COLUMN EXAC_ID SET NOT NULL;\\012	\N
+./sourceTest/sql/postgresql/050/.svn/text-base/017=database_version_logs.tsv.svn-base:029	source/sql/postgresql/migration/migration-028-029.sql	SUCCESS	2009-03-18 10:50:20.105	-- -------\\012-- add modification_timestamp field to allow edition with Hibernate\\012-- -------\\012\\012ALTER TABLE samples\\012\\011ADD COLUMN modification_timestamp TIME_STAMP DEFAULT CURRENT_TIMESTAMP;\\012\\012ALTER TABLE experiments\\012\\011ADD COLUMN modification_timestamp TIME_STAMP DEFAULT CURRENT_TIMESTAMP;\\012\\012ALTER TABLE materials\\012\\011ADD COLUMN modification_timestamp TIME_STAMP DEFAULT CURRENT_TIMESTAMP;\\012\\012ALTER TABLE experiment_properties\\012\\011ADD COLUMN modification_timestamp TIME_STAMP DEFAULT CURRENT_TIMESTAMP;\\012\\012ALTER TABLE material_properties\\012\\011ADD COLUMN modification_timestamp TIME_STAMP DEFAULT CURRENT_TIMESTAMP;\\012\\012ALTER TABLE sample_properties\\012\\011ADD COLUMN modification_timestamp TIME_STAMP DEFAULT CURRENT_TIMESTAMP;\\012\\012-- -------\\012-- add property data type which references materials\\012-- -------\\012\\012ALTER TABLE property_types\\012\\011ADD COLUMN maty_prop_id tech_id;\\012\\012ALTER TABLE property_types\\012\\011ADD CONSTRAINT prty_maty_fk FOREIGN KEY (maty_prop_id) REFERENCES material_types(id);\\012\\012ALTER TABLE experiment_properties\\012\\011ADD COLUMN mate_prop_id tech_id;\\012\\012ALTER TABLE material_properties\\012\\011ADD COLUMN mate_prop_id tech_id;\\012\\012ALTER TABLE sample_properties\\012\\011ADD COLUMN mate_prop_id tech_id;\\012\\012ALTER TABLE experiment_properties\\012\\011ADD CONSTRAINT expr_mapr_fk FOREIGN KEY (mate_prop_id) REFERENCES materials(id);\\012\\012ALTER TABLE material_properties\\012\\011ADD CONSTRAINT mapr_mapr_fk FOREIGN KEY (mate_prop_id) REFERENCES materials(id);\\012\\012ALTER TABLE sample_properties\\012\\011ADD CONSTRAINT sapr_mapr_fk FOREIGN KEY (mate_prop_id) REFERENCES materials(id);\\012\\012insert into data_types\\012(id\\012 ,code\\012 ,description)\\012 values \\012 (nextval('DATA_TYPE_ID_SEQ')\\012 ,'MATERIAL'\\012 ,'Reference to a material'\\012);\\012\\012ALTER TABLE MATERIAL_PROPERTIES DROP CONSTRAINT MAPR_CK;\\012ALTER TABLE MATERIAL_PROPERTIES ADD CONSTRAINT MAPR_CK CHECK \\012\\011((VALUE IS NOT NULL AND CVTE_ID IS NULL AND MATE_PROP_ID IS NULL) OR \\012\\011 (VALUE IS NULL AND CVTE_ID IS NOT NULL AND MATE_PROP_ID IS NULL) OR\\012\\011 (VALUE IS NULL AND CVTE_ID IS NULL AND MATE_PROP_ID IS NOT NULL)\\012\\011);\\012\\012ALTER TABLE EXPERIMENT_PROPERTIES DROP CONSTRAINT EXPR_CK;\\012ALTER TABLE EXPERIMENT_PROPERTIES ADD CONSTRAINT EXPR_CK CHECK \\012\\011((VALUE IS NOT NULL AND CVTE_ID IS NULL AND MATE_PROP_ID IS NULL) OR \\012\\011 (VALUE IS NULL AND CVTE_ID IS NOT NULL AND MATE_PROP_ID IS NULL) OR\\012\\011 (VALUE IS NULL AND CVTE_ID IS NULL AND MATE_PROP_ID IS NOT NULL)\\012\\011);\\012\\012ALTER TABLE SAMPLE_PROPERTIES DROP CONSTRAINT SAPR_CK;\\012ALTER TABLE SAMPLE_PROPERTIES ADD CONSTRAINT SAPR_CK CHECK \\012\\011((VALUE IS NOT NULL AND CVTE_ID IS NULL AND MATE_PROP_ID IS NULL) OR \\012\\011 (VALUE IS NULL AND CVTE_ID IS NOT NULL AND MATE_PROP_ID IS NULL) OR\\012\\011 (VALUE IS NULL AND CVTE_ID IS NULL AND MATE_PROP_ID IS NOT NULL)\\012\\011);\\012\\012------------------------------------------------------------------------------------\\012--  Purpose:  Create trigger MATERIAL/SAMPLE/EXPERIMENT _PROPERTY_WITH_MATERIAL_DATA_TYPE_CHECK\\012--            It checks that if material property value is assigned to the entity,\\012--\\011\\011\\011\\011\\011\\011then the material type is equal to the one described by property type.\\012------------------------------------------------------------------------------------\\012\\012CREATE OR REPLACE FUNCTION MATERIAL_PROPERTY_WITH_MATERIAL_DATA_TYPE_CHECK() RETURNS trigger AS $$\\012DECLARE\\012   v_type_id  CODE;\\012   v_type_id_prop  CODE;\\012BEGIN\\012   if NEW.mate_prop_id IS NOT NULL then\\012\\011\\011\\011-- find material type id of the property type \\012\\011\\011\\011select pt.maty_prop_id into v_type_id_prop \\012\\011\\011\\011  from material_type_property_types etpt, property_types pt \\012\\011\\011\\011 where NEW.mtpt_id = etpt.id AND etpt.prty_id = pt.id;\\012\\011\\011\\012\\011\\011\\011if v_type_id_prop IS NOT NULL then\\012\\011\\011\\011\\011-- find material type id of the material which consists the entity's property value\\012\\011\\011\\011\\011select entity.maty_id into v_type_id \\012\\011\\011\\011\\011  from materials entity\\012\\011\\011\\011\\011 where NEW.mate_prop_id = entity.id;\\012\\011\\011\\011\\011if v_type_id != v_type_id_prop then\\012\\011\\011\\011\\011\\011RAISE EXCEPTION 'Insert/Update of property value referencing material (id: %) failed, as referenced material type is different than expected (id %, expected id: %).', \\012\\011\\011\\011\\011\\011\\011\\011 NEW.mate_prop_id, v_type_id, v_type_id_prop;\\012\\011\\011\\011\\011end if;\\012\\011\\011\\011end if;\\012   end if;\\012   RETURN NEW;\\012END;\\012$$ LANGUAGE 'plpgsql';\\012\\012CREATE TRIGGER MATERIAL_PROPERTY_WITH_MATERIAL_DATA_TYPE_CHECK BEFORE INSERT OR UPDATE ON material_properties\\012    FOR EACH ROW EXECUTE PROCEDURE MATERIAL_PROPERTY_WITH_MATERIAL_DATA_TYPE_CHECK();\\012    \\012CREATE OR REPLACE FUNCTION SAMPLE_PROPERTY_WITH_MATERIAL_DATA_TYPE_CHECK() RETURNS trigger AS $$\\012DECLARE\\012   v_type_id  CODE;\\012   v_type_id_prop  CODE;\\012BEGIN\\012   if NEW.mate_prop_id IS NOT NULL then\\012\\011\\011\\011-- find material type id of the property type \\012\\011\\011\\011select pt.maty_prop_id into v_type_id_prop \\012\\011\\011\\011  from sample_type_property_types etpt, property_types pt \\012\\011\\011\\011 where NEW.stpt_id = etpt.id AND etpt.prty_id = pt.id;\\012\\011\\011\\012\\011\\011\\011if v_type_id_prop IS NOT NULL then\\012\\011\\011\\011\\011-- find material type id of the material which consists the entity's property value\\012\\011\\011\\011\\011select entity.maty_id into v_type_id \\012\\011\\011\\011\\011  from materials entity\\012\\011\\011\\011\\011 where NEW.mate_prop_id = entity.id;\\012\\011\\011\\011\\011if v_type_id != v_type_id_prop then\\012\\011\\011\\011\\011\\011RAISE EXCEPTION 'Insert/Update of property value referencing material (id: %) failed, as referenced material type is different than expected (id %, expected id: %).', \\012\\011\\011\\011\\011\\011\\011\\011\\011\\011\\011\\011\\011 NEW.mate_prop_id, v_type_id, v_type_id_prop;\\012\\011\\011\\011\\011end if;\\012\\011\\011\\011end if;\\012   end if;\\012   RETURN NEW;\\012END;\\012$$ LANGUAGE 'plpgsql';\\012\\012CREATE TRIGGER SAMPLE_PROPERTY_WITH_MATERIAL_DATA_TYPE_CHECK BEFORE INSERT OR UPDATE ON sample_properties\\012    FOR EACH ROW EXECUTE PROCEDURE SAMPLE_PROPERTY_WITH_MATERIAL_DATA_TYPE_CHECK();\\012    \\012CREATE OR REPLACE FUNCTION EXPERIMENT_PROPERTY_WITH_MATERIAL_DATA_TYPE_CHECK() RETURNS trigger AS $$\\012DECLARE\\012   v_type_id  CODE;\\012   v_type_id_prop  CODE;\\012BEGIN\\012   if NEW.mate_prop_id IS NOT NULL then\\012\\011\\011\\011-- find material type id of the property type \\012\\011\\011\\011select pt.maty_prop_id into v_type_id_prop \\012\\011\\011\\011  from experiment_type_property_types etpt, property_types pt \\012\\011\\011\\011 where NEW.etpt_id = etpt.id AND etpt.prty_id = pt.id;\\012\\011\\011\\012\\011\\011\\011if v_type_id_prop IS NOT NULL then\\012\\011\\011\\011\\011-- find material type id of the material which consists the entity's property value\\012\\011\\011\\011\\011select entity.maty_id into v_type_id \\012\\011\\011\\011\\011  from materials entity\\012\\011\\011\\011\\011 where NEW.mate_prop_id = entity.id;\\012\\011\\011\\011\\011if v_type_id != v_type_id_prop then\\012\\011\\011\\011\\011\\011RAISE EXCEPTION 'Insert/Update of property value referencing material (id: %) failed, as referenced material type is different than expected (id %, expected id: %).', \\012\\011\\011\\011\\011\\011\\011\\011\\011\\011\\011\\011\\011 NEW.mate_prop_id, v_type_id, v_type_id_prop;\\012\\011\\011\\011\\011end if;\\012\\011\\011\\011end if;\\012   end if;\\012   RETURN NEW;\\012END;\\012$$ LANGUAGE 'plpgsql';\\012\\012CREATE TRIGGER EXPERIMENT_PROPERTY_WITH_MATERIAL_DATA_TYPE_CHECK BEFORE INSERT OR UPDATE ON experiment_properties\\012    FOR EACH ROW EXECUTE PROCEDURE EXPERIMENT_PROPERTY_WITH_MATERIAL_DATA_TYPE_CHECK();\\012       \\012-- -------\\012-- remove the reminescents of the OBSERVABLE_TYPE\\012-- -------\\012\\012ALTER TABLE data\\012\\011DROP CONSTRAINT data_obty_fk;\\012\\012ALTER TABLE data_set_types\\012\\011DROP CONSTRAINT obty_pk;\\012\\012ALTER TABLE data_set_types\\012\\011ADD CONSTRAINT dsty_pk PRIMARY KEY (id);\\012\\012ALTER TABLE data\\012\\011ADD CONSTRAINT data_dsty_fk FOREIGN KEY (dsty_id) REFERENCES data_set_types(id);\\012\\012ALTER TABLE data_set_types\\012\\011DROP CONSTRAINT obty_bk_uk;\\012\\012ALTER TABLE data_set_types\\012\\011DROP CONSTRAINT obty_dbin_fk;\\012\\012ALTER TABLE data_set_types\\012\\011ADD CONSTRAINT dsty_bk_uk UNIQUE (code, dbin_id);\\012\\012ALTER TABLE data_set_types\\012\\011ADD CONSTRAINT dsty_dbin_fk FOREIGN KEY (dbin_id) REFERENCES database_instances(id);\\012\\012DROP INDEX data_obty_fk_i;\\012\\012CREATE INDEX data_dsty_fk_i ON data(dsty_id);\\012	\N
+./sourceTest/sql/postgresql/050/.svn/text-base/017=database_version_logs.tsv.svn-base:030	source/sql/postgresql/migration/migration-029-030.sql	SUCCESS	2009-03-23 15:34:44.72	-- -------\\012-- add modification_timestamp field to allow edition with Hibernate\\012-- -------\\012ALTER TABLE data\\012\\011ADD COLUMN modification_timestamp TIME_STAMP DEFAULT CURRENT_TIMESTAMP;\\012ALTER TABLE experiment_types\\012\\011ADD COLUMN modification_timestamp TIME_STAMP DEFAULT CURRENT_TIMESTAMP;\\012ALTER TABLE sample_types\\012\\011ADD COLUMN modification_timestamp TIME_STAMP DEFAULT CURRENT_TIMESTAMP;\\012ALTER TABLE material_types\\012\\011ADD COLUMN modification_timestamp TIME_STAMP DEFAULT CURRENT_TIMESTAMP;\\012ALTER TABLE data_set_types\\012\\011ADD COLUMN modification_timestamp TIME_STAMP DEFAULT CURRENT_TIMESTAMP;\\012ALTER TABLE controlled_vocabularies\\012\\011ADD COLUMN modification_timestamp TIME_STAMP DEFAULT CURRENT_TIMESTAMP;\\012-- -------\\012-- add properties to data sets\\012-- -------\\012CREATE TABLE DATA_SET_PROPERTIES (ID TECH_ID NOT NULL,DS_ID TECH_ID NOT NULL,DSTPT_ID TECH_ID NOT NULL,VALUE GENERIC_VALUE,CVTE_ID TECH_ID, MATE_PROP_ID TECH_ID, PERS_ID_REGISTERER TECH_ID NOT NULL,REGISTRATION_TIMESTAMP TIME_STAMP_DFL NOT NULL DEFAULT CURRENT_TIMESTAMP, MODIFICATION_TIMESTAMP TIME_STAMP DEFAULT CURRENT_TIMESTAMP);\\012CREATE TABLE DATA_SET_TYPE_PROPERTY_TYPES (ID TECH_ID NOT NULL,DSTY_ID TECH_ID NOT NULL,PRTY_ID TECH_ID NOT NULL,IS_MANDATORY BOOLEAN_CHAR NOT NULL DEFAULT 'F',IS_MANAGED_INTERNALLY BOOLEAN_CHAR NOT NULL DEFAULT 'F',PERS_ID_REGISTERER TECH_ID NOT NULL,REGISTRATION_TIMESTAMP TIME_STAMP_DFL NOT NULL DEFAULT CURRENT_TIMESTAMP);\\012\\012CREATE SEQUENCE DATA_SET_PROPERTY_ID_SEQ;\\012CREATE SEQUENCE DSTPT_ID_SEQ;\\012\\012ALTER TABLE DATA_SET_TYPE_PROPERTY_TYPES ADD CONSTRAINT DSTPT_PK PRIMARY KEY(ID);\\012ALTER TABLE DATA_SET_PROPERTIES ADD CONSTRAINT DSPR_PK PRIMARY KEY(ID);\\012\\012ALTER TABLE DATA_SET_TYPE_PROPERTY_TYPES ADD CONSTRAINT DSTPT_BK_UK UNIQUE(DSTY_ID,PRTY_ID);\\012ALTER TABLE DATA_SET_PROPERTIES ADD CONSTRAINT DSPR_BK_UK UNIQUE(DS_ID,DSTPT_ID);\\012\\012\\012ALTER TABLE DATA_SET_TYPE_PROPERTY_TYPES ADD CONSTRAINT DSTPT_DSTY_FK FOREIGN KEY (DSTY_ID) REFERENCES DATA_SET_TYPES(ID);\\012ALTER TABLE DATA_SET_TYPE_PROPERTY_TYPES ADD CONSTRAINT DSTPT_PERS_FK FOREIGN KEY (PERS_ID_REGISTERER) REFERENCES PERSONS(ID);\\012ALTER TABLE DATA_SET_TYPE_PROPERTY_TYPES ADD CONSTRAINT DSTPT_PRTY_FK FOREIGN KEY (PRTY_ID) REFERENCES PROPERTY_TYPES(ID);\\012ALTER TABLE DATA_SET_PROPERTIES ADD CONSTRAINT DSPR_CVTE_FK FOREIGN KEY (CVTE_ID) REFERENCES CONTROLLED_VOCABULARY_TERMS(ID);\\012ALTER TABLE DATA_SET_PROPERTIES ADD CONSTRAINT DSPR_DSTPT_FK FOREIGN KEY (DSTPT_ID) REFERENCES DATA_SET_TYPE_PROPERTY_TYPES(ID) ON DELETE CASCADE;\\012ALTER TABLE DATA_SET_PROPERTIES ADD CONSTRAINT DSPR_DS_FK FOREIGN KEY (DS_ID) REFERENCES DATA(ID);\\012ALTER TABLE DATA_SET_PROPERTIES ADD CONSTRAINT DSPR_PERS_FK FOREIGN KEY (PERS_ID_REGISTERER) REFERENCES PERSONS(ID);\\012ALTER TABLE DATA_SET_PROPERTIES ADD CONSTRAINT DSPR_MAPR_FK FOREIGN KEY (MATE_PROP_ID) REFERENCES MATERIALS(ID);\\012\\012ALTER TABLE DATA_SET_PROPERTIES ADD CONSTRAINT DSPR_CK CHECK \\012\\011((VALUE IS NOT NULL AND CVTE_ID IS NULL AND MATE_PROP_ID IS NULL) OR \\012\\011 (VALUE IS NULL AND CVTE_ID IS NOT NULL AND MATE_PROP_ID IS NULL) OR\\012\\011 (VALUE IS NULL AND CVTE_ID IS NULL AND MATE_PROP_ID IS NOT NULL)\\012\\011);\\012\\012CREATE INDEX DSPR_CVTE_FK_I ON DATA_SET_PROPERTIES (CVTE_ID);\\012CREATE INDEX DSPR_DSTPT_FK_I ON DATA_SET_PROPERTIES (DSTPT_ID);\\012CREATE INDEX DSPR_DS_FK_I ON DATA_SET_PROPERTIES (DS_ID);\\012CREATE INDEX DSPR_PERS_FK_I ON DATA_SET_PROPERTIES (PERS_ID_REGISTERER);\\012CREATE INDEX DSTPT_DSTY_FK_I ON DATA_SET_TYPE_PROPERTY_TYPES (DSTY_ID);\\012CREATE INDEX DSTPT_PERS_FK_I ON DATA_SET_TYPE_PROPERTY_TYPES (PERS_ID_REGISTERER);\\012CREATE INDEX DSTPT_PRTY_FK_I ON DATA_SET_TYPE_PROPERTY_TYPES (PRTY_ID);\\012\\012CREATE OR REPLACE FUNCTION DATA_SET_PROPERTY_WITH_MATERIAL_DATA_TYPE_CHECK() RETURNS trigger AS $$\\012DECLARE\\012   v_type_id  CODE;\\012   v_type_id_prop  CODE;\\012BEGIN\\012   if NEW.mate_prop_id IS NOT NULL then\\012\\011\\011\\011-- find material type id of the property type \\012\\011\\011\\011select pt.maty_prop_id into v_type_id_prop \\012\\011\\011\\011  from data_set_type_property_types dstpt, property_types pt \\012\\011\\011\\011 where NEW.dstpt_id = dstpt.id AND dstpt.prty_id = pt.id;\\012\\011\\011\\012\\011\\011\\011if v_type_id_prop IS NOT NULL then\\012\\011\\011\\011\\011-- find material type id of the material which consists the entity's property value\\012\\011\\011\\011\\011select entity.maty_id into v_type_id \\012\\011\\011\\011\\011  from materials entity\\012\\011\\011\\011\\011 where NEW.mate_prop_id = entity.id;\\012\\011\\011\\011\\011if v_type_id != v_type_id_prop then\\012\\011\\011\\011\\011\\011RAISE EXCEPTION 'Insert/Update of property value referencing material (id: %) failed, as referenced material type is different than expected (id %, expected id: %).', \\012\\011\\011\\011\\011\\011\\011\\011\\011\\011\\011\\011\\011 NEW.mate_prop_id, v_type_id, v_type_id_prop;\\012\\011\\011\\011\\011end if;\\012\\011\\011\\011end if;\\012   end if;\\012   RETURN NEW;\\012END;\\012$$ LANGUAGE 'plpgsql';\\012\\012CREATE TRIGGER DATA_SET_PROPERTY_WITH_MATERIAL_DATA_TYPE_CHECK BEFORE INSERT OR UPDATE ON data_set_properties\\012    FOR EACH ROW EXECUTE PROCEDURE DATA_SET_PROPERTY_WITH_MATERIAL_DATA_TYPE_CHECK();   \\012	\N
+./sourceTest/sql/postgresql/050/.svn/text-base/017=database_version_logs.tsv.svn-base:032	source/sql/postgresql/migration/migration-031-032.sql	SUCCESS	2009-04-09 09:36:36.2	-- -------\\012-- Modify MATERIAL_BATCHES\\012-- -------\\012\\012ALTER TABLE material_batches\\012    DROP COLUMN proc_id;\\012\\012-- -------\\012-- Modify SAMPLES\\012-- -------\\012\\012ALTER TABLE samples\\012    ADD COLUMN expe_id tech_id;\\012\\012ALTER TABLE samples\\012    ADD CONSTRAINT samp_expe_fk FOREIGN KEY (expe_id) REFERENCES experiments(id);\\012\\012CREATE INDEX samp_expe_fk_i ON samples USING btree (expe_id);\\012\\012-- relink samples directly to experiments\\012\\012UPDATE samples\\012SET expe_id = (SELECT e.id FROM experiments e, procedures p, sample_inputs si \\012               WHERE si.samp_id = samples.id AND si.proc_id = p.id AND p.expe_id = e.id AND e.inva_id IS NULL);\\012\\012\\012-- -------\\012-- Modify DATA\\012-- -------\\012\\012ALTER TABLE data\\012    ADD COLUMN expe_id tech_id;\\012\\012ALTER TABLE data\\012    ADD CONSTRAINT data_expe_fk FOREIGN KEY (expe_id) REFERENCES experiments(id);\\012\\012CREATE INDEX data_expe_fk_i ON data USING btree (expe_id);\\012\\012UPDATE data\\012SET expe_id = (SELECT e.id FROM experiments e, procedures p \\012               WHERE data.proc_id_produced_by = p.id AND p.expe_id = e.id);\\012\\012ALTER TABLE data\\012    ALTER COLUMN expe_id SET NOT NULL;\\012\\012ALTER TABLE data\\012    DROP COLUMN proc_id_produced_by;\\012\\012-- -------\\012-- Drop PROCEDURES, PROCEDURE_TYPES, and SAMPLE_INPUTS\\012-- -------\\012\\012DROP TABLE sample_inputs;\\012DROP TABLE procedures;\\012DROP TABLE procedure_types;\\012\\012DROP SEQUENCE procedure_id_seq;\\012DROP SEQUENCE procedure_type_id_seq;\\012\\012-- -------\\012-- Add CODE_SEQ\\012-- -------\\012\\012CREATE SEQUENCE CODE_SEQ;\\012\\012-- -------\\012-- Add new columns to DATA_STORES\\012-- -------\\012\\012ALTER TABLE data_stores\\012    ADD COLUMN remote_url character varying(250),\\012    ADD COLUMN session_token character varying(50),\\012    ADD COLUMN modification_timestamp time_stamp DEFAULT now();\\012\\012UPDATE data_stores\\012SET remote_url = '', session_token='';\\012\\012ALTER TABLE data_stores\\012    ALTER COLUMN remote_url SET NOT NULL,\\012    ALTER COLUMN session_token SET NOT NULL;\\012\\012-- -------\\012-- Drop foreign keys onto DATA_STORES\\012-- -------\\012\\012ALTER TABLE database_instances\\012    DROP COLUMN dast_id;\\012\\012ALTER TABLE groups\\012    DROP COLUMN dast_id;\\012\\012ALTER TABLE projects\\012    DROP COLUMN dast_id;\\012\\012ALTER TABLE experiments\\012    DROP COLUMN dast_id;\\012\\012-- -------\\012-- Add foreign key from DATA onto DATA_STORES\\012-- -------\\012\\012ALTER TABLE data\\012    ADD COLUMN dast_id tech_id;\\012\\012ALTER TABLE data\\012    ADD CONSTRAINT data_dast_fk FOREIGN KEY (dast_id) REFERENCES data_stores(id);\\012\\012UPDATE data\\012SET dast_id = (select id from data_stores where code = 'STANDARD');\\012\\012ALTER TABLE data\\012    ALTER COLUMN dast_id SET NOT NULL;\\012\\012\\012------------------------------------------------------------------------------------\\012--  Purpose:  Replace trigger SAMPLE_CODE_UNIQUENESS_CHECK \\012------------------------------------------------------------------------------------\\012\\012CREATE OR REPLACE FUNCTION SAMPLE_CODE_UNIQUENESS_CHECK() RETURNS trigger AS $$\\012DECLARE\\012   counter  INTEGER;\\012BEGIN\\012    LOCK TABLE samples IN EXCLUSIVE MODE;\\012    IF (NEW.samp_id_part_of is NULL) THEN\\012        IF (NEW.dbin_id is not NULL) THEN\\012            SELECT count(*) into counter FROM samples \\012                where id != NEW.id and code = NEW.code and samp_id_part_of is NULL and dbin_id = NEW.dbin_id;\\012            IF (counter > 0) THEN\\012                RAISE EXCEPTION 'Insert/Update of Sample (Code: %) failed because database instance sample with the same code already exists.', NEW.code;\\012            END IF;\\012        ELSIF (NEW.grou_id is not NULL) THEN\\012            SELECT count(*) into counter FROM samples \\012                where id != NEW.id and code = NEW.code and samp_id_part_of is NULL and grou_id = NEW.grou_id;\\012            IF (counter > 0) THEN\\012                RAISE EXCEPTION 'Insert/Update of Sample (Code: %) failed because group sample with the same code already exists.', NEW.code;\\012            END IF;\\012        END IF;\\012        ELSE\\012        IF (NEW.dbin_id is not NULL) THEN\\012            SELECT count(*) into counter FROM samples \\012                where id != NEW.id and code = NEW.code and samp_id_part_of = NEW.samp_id_part_of and dbin_id = NEW.dbin_id;\\012            IF (counter > 0) THEN\\012                RAISE EXCEPTION 'Insert/Update of Sample (Code: %) failed because database instance sample with the same code and being the part of the same parent already exists.', NEW.code;\\012            END IF;\\012        ELSIF (NEW.grou_id is not NULL) THEN\\012            SELECT count(*) into counter FROM samples \\012                where id != NEW.id and code = NEW.code and samp_id_part_of = NEW.samp_id_part_of and grou_id = NEW.grou_id;\\012            IF (counter > 0) THEN\\012                RAISE EXCEPTION 'Insert/Update of Sample (Code: %) failed because group sample with the same code and being the part of the same parent already exists.', NEW.code;\\012            END IF;\\012        END IF;\\012        END IF;   \\012   RETURN NEW;\\012END;\\012$$ LANGUAGE 'plpgsql';\\012\\012\\012\\012	\N
+./sourceTest/sql/postgresql/050/.svn/text-base/017=database_version_logs.tsv.svn-base:034	source/sql/postgresql/migration/migration-033-034.sql	SUCCESS	2009-05-26 08:32:49.935	------------------------------------------------------------------------------------\\012-- Create sequence for generating permanent identifiers starting with nextval of existing dataset sequence.\\012------------------------------------------------------------------------------------\\012CREATE FUNCTION CREATE_SEQUENCE(EXISTING_SEQUENCE VARCHAR, NEW_SEQUENCE VARCHAR) RETURNS VOID AS $$\\012DECLARE\\012  CURR_SEQ_VAL   INTEGER;\\012BEGIN\\012  SELECT INTO CURR_SEQ_VAL NEXTVAL(EXISTING_SEQUENCE);\\012  EXECUTE 'CREATE SEQUENCE ' || NEW_SEQUENCE || ' START WITH ' || CURR_SEQ_VAL;\\012  RETURN;\\012END;\\012$$ LANGUAGE 'plpgsql';\\012\\012SELECT CREATE_SEQUENCE('DATA_ID_SEQ', 'PERM_ID_SEQ');\\012DROP FUNCTION CREATE_SEQUENCE(VARCHAR, VARCHAR);\\012\\012------------------------------------------------------------------------------------\\012-- Add perm_id columns to samples and experiments.\\012------------------------------------------------------------------------------------\\012ALTER TABLE SAMPLES ADD COLUMN PERM_ID CODE;\\012ALTER TABLE EXPERIMENTS ADD COLUMN PERM_ID CODE;\\012\\012UPDATE SAMPLES SET PERM_ID = to_char(registration_timestamp,'YYYYMMDDHHSSMS') || '-' || NEXTVAL('PERM_ID_SEQ');\\012UPDATE EXPERIMENTS SET PERM_ID = to_char(registration_timestamp,'YYYYMMDDHHSSMS') || '-' || NEXTVAL('PERM_ID_SEQ');\\012ALTER TABLE SAMPLES ALTER COLUMN PERM_ID SET NOT NULL;\\012ALTER TABLE EXPERIMENTS ALTER COLUMN PERM_ID SET NOT NULL;\\012ALTER TABLE SAMPLES ADD CONSTRAINT SAMP_PI_UK UNIQUE(PERM_ID);\\012ALTER TABLE EXPERIMENTS ADD CONSTRAINT EXPE_PI_UK UNIQUE(PERM_ID);\\012\\012\\012------------------------------------------------------------------------------------\\012-- Add column is_chosen_from_list to controlled_vocabularies.\\012------------------------------------------------------------------------------------\\012ALTER TABLE controlled_vocabularies ADD COLUMN is_chosen_from_list BOOLEAN_CHAR NOT NULL DEFAULT TRUE;\\012ALTER TABLE controlled_vocabularies ADD COLUMN source_uri CHARACTER VARYING(250);\\012------------------------------------------------------------------------------------\\012-- Modify Data table - remove arc connection between Sample and Data table, use a flag instead\\012------------------------------------------------------------------------------------\\012\\012-- add new columns\\012\\012ALTER TABLE data\\012    ADD COLUMN is_derived boolean_char;\\012ALTER TABLE data\\012    ADD COLUMN samp_id tech_id;\\012\\012-- update values in new columns\\012\\012UPDATE data\\012    SET is_derived = (samp_id_derived_from IS NOT NULL); \\012UPDATE data\\012    SET samp_id = samp_id_derived_from \\012    WHERE is_derived = 'TRUE';\\012UPDATE data\\012    SET samp_id = samp_id_acquired_from \\012    WHERE is_derived = 'FALSE';\\012\\012-- add constraints and indexes to new columns\\012\\012ALTER TABLE data\\012    ALTER COLUMN is_derived SET NOT NULL;\\012ALTER TABLE data\\012    ALTER COLUMN samp_id SET NOT NULL;   \\012ALTER TABLE data\\012    ADD CONSTRAINT data_samp_fk FOREIGN KEY (samp_id) REFERENCES samples (id);\\012CREATE INDEX data_samp_fk_i ON data USING btree (samp_id);\\012\\012-- remove old columns\\012\\012ALTER TABLE data\\012    DROP COLUMN samp_id_acquired_from;\\012ALTER TABLE data\\012    DROP COLUMN samp_id_derived_from;\\012    \\012------------------------------------------------------------------------------------\\012-- Granting SELECT privilege to group openbis_readonly\\012------------------------------------------------------------------------------------\\012\\012GRANT SELECT ON SEQUENCE attachment_content_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE attachment_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE code_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE controlled_vocabulary_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE cvte_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE data_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE data_set_property_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE data_set_relationship_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE data_set_type_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE data_store_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE data_type_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE database_instance_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE dstpt_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE etpt_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE event_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE experiment_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE experiment_property_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE experiment_type_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE file_format_type_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE group_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE invalidation_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE locator_type_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE material_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE material_property_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE material_type_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE mtpt_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE perm_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE person_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE project_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE property_type_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE role_assignment_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE sample_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE sample_property_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE sample_type_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE stpt_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE attachment_contents TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE attachments TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE controlled_vocabularies TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE controlled_vocabulary_terms TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE data TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE data_set_properties TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE data_set_relationships TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE data_set_type_property_types TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE data_set_types TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE data_stores TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE data_types TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE database_instances TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE database_version_logs TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE events TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE experiment_properties TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE experiment_type_property_types TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE experiment_types TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE experiments TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE external_data TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE file_format_types TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE groups TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE invalidations TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE locator_types TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE material_properties TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE material_type_property_types TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE material_types TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE materials TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE persons TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE projects TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE property_types TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE role_assignments TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE sample_properties TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE sample_type_property_types TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE sample_types TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE samples TO GROUP OPENBIS_READONLY;\\012\\012------------------------------------------------------------------------------------\\012-- Delete MATERIAL_BATCHES table\\012------------------------------------------------------------------------------------\\012\\012-- WARNING: Potential data lost!!!\\012-- WARNING: Potential data lost!!!\\012-- WARNING: Potential data lost!!!\\012\\012DROP TABLE SAMPLE_MATERIAL_BATCHES;\\012DROP TABLE MATERIAL_BATCHES;\\012DROP SEQUENCE MATERIAL_BATCH_ID_SEQ;\\012\\012------------------------------------------------------------------------------------\\012-- Delete MATE_ID_INHIBITOR_OF from table MATERIALS\\012------------------------------------------------------------------------------------\\012\\012-- WARNING: Potential data lost!!!\\012-- WARNING: Potential data lost!!!\\012-- WARNING: Potential data lost!!!\\012\\012ALTER TABLE MATERIALS DROP COLUMN MATE_ID_INHIBITOR_OF;\\012	\N
+./sourceTest/sql/postgresql/050/.svn/text-base/017=database_version_logs.tsv.svn-base:041	source/sql/postgresql/migration/migration-040-041.sql	SUCCESS	2009-09-14 13:48:57.539	-- Create FILTERS table\\012\\012CREATE TABLE FILTERS (ID TECH_ID NOT NULL, DBIN_ID TECH_ID NOT NULL, NAME VARCHAR(200) NOT NULL, DESCRIPTION DESCRIPTION_1000,REGISTRATION_TIMESTAMP TIME_STAMP_DFL NOT NULL DEFAULT CURRENT_TIMESTAMP, PERS_ID_REGISTERER TECH_ID NOT NULL, MODIFICATION_TIMESTAMP TIME_STAMP DEFAULT CURRENT_TIMESTAMP, EXPRESSION VARCHAR(2000) NOT NULL, IS_PUBLIC BOOLEAN NOT NULL, GRID_ID VARCHAR(200) NOT NULL);\\012CREATE SEQUENCE FILTER_ID_SEQ;\\012ALTER TABLE FILTERS ADD CONSTRAINT FILT_PK PRIMARY KEY(ID);\\012ALTER TABLE FILTERS ADD CONSTRAINT FILT_BK_UK UNIQUE(NAME, DBIN_ID, GRID_ID);\\012ALTER TABLE FILTERS ADD CONSTRAINT FILT_PERS_FK FOREIGN KEY (PERS_ID_REGISTERER) REFERENCES PERSONS(ID);\\012ALTER TABLE FILTERS ADD CONSTRAINT FILT_DBIN_FK FOREIGN KEY (DBIN_ID) REFERENCES DATABASE_INSTANCES(ID);\\012CREATE INDEX FILT_PERS_FK_I ON FILTERS (PERS_ID_REGISTERER);\\012CREATE INDEX FILT_DBIN_FK_I ON FILTERS (DBIN_ID);\\012GRANT SELECT ON SEQUENCE filter_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE filters TO GROUP OPENBIS_READONLY;\\012\\012-- Add missing foreign key to role assignments authorization group\\012ALTER TABLE ROLE_ASSIGNMENTS ADD CONSTRAINT ROAS_AG_FK_GRANTEE FOREIGN KEY (AG_ID_GRANTEE) REFERENCES AUTHORIZATION_GROUPS(ID);\\012\\012--------------------------------------------------------------------------------------------------\\012-- Modify dataset connections:\\012-- 1. connection with sample shouldn't be mandatory any more\\012-- 2. introduce an arc condition that dataset cannot be connected with a sample and a parent dataset at the same time\\012--------------------------------------------------------------------------------------------------\\012\\012-- Weaken data-sample connection constraint - allow dataset to have no connection with sample\\012ALTER TABLE data ALTER COLUMN samp_id DROP NOT NULL;\\012\\012-- Remove data-sample connection for datasets that have a parent\\012\\012UPDATE data \\012   SET samp_id = NULL \\012 WHERE id IN (SELECT DISTINCT data_id_child FROM data_set_relationships);\\012\\012-- With PostgreSQL 8.4 one can check that before migration there were no cycles in dataset relationships:\\012--\\012-- WITH RECURSIVE data_set_parents(id, parent_ids, cycle) AS (\\012--         SELECT  r.data_id_child AS id, \\012--                 ARRAY[CAST (r.data_id_parent AS bigint)] AS parent_ids, \\012--                 false AS cycle \\012--         FROM data_set_relationships r\\012--     UNION ALL\\012--         SELECT  r.data_id_child,\\012--                 CAST (r.data_id_parent AS bigint) || p.parent_ids,\\012--                 r.data_id_child = ANY(p.parent_ids)\\012--         FROM data_set_relationships r, data_set_parents p\\012--         WHERE r.data_id_parent = p.id AND NOT cycle\\012-- )\\012-- SELECT count(*) AS cycles FROM data_set_parents WHERE cycle = true;\\012\\012---------------------------------------------------------------------------------------------------\\012--  Purpose:  Create DEFERRED triggers:\\012--            * check_dataset_relationships_on_data_table_modification,\\012--            * check_dataset_relationships_on_relationships_table_modification.\\012--            They check that after all modifications of database (just before commit) \\012--            if 'data'/'data_set_relationships' tables are among modified tables \\012--            dataset is not connected with a sample and a parent dataset at the same time.\\012--            This connections are held in two different tables so simple immediate trigger \\012--            with arc check cannot be used and we need two deferred triggers.\\012----------------------------------------------------------------------------------------------------\\012\\012-- trigger for 'data' table\\012\\012CREATE OR REPLACE FUNCTION check_dataset_relationships_on_data_table_modification() RETURNS trigger AS $$\\012DECLARE\\012\\011counter\\011INTEGER;\\012BEGIN\\012\\011-- if there is a connection with a Sample there should not be any connection with a parent Data Set\\012\\011IF (NEW.samp_id IS NOT NULL) THEN\\012\\011\\011-- count number of parents\\012\\011\\011SELECT count(*) INTO counter \\012\\011\\011\\011FROM data_set_relationships \\012\\011\\011\\011WHERE data_id_child = OLD.id;\\012\\011\\011IF (counter > 0) THEN\\012\\011\\011\\011RAISE EXCEPTION 'Insert/Update of Data Set (Code: %) failed because it cannot be connected with a Sample and a parent Data Set at the same time.', OLD.code;\\012\\011\\011END IF;\\012\\011END IF;\\012  RETURN NEW;\\012END;\\012$$ LANGUAGE 'plpgsql';\\012\\012CREATE CONSTRAINT TRIGGER check_dataset_relationships_on_data_table_modification \\012  AFTER INSERT OR UPDATE ON data\\012\\011DEFERRABLE INITIALLY DEFERRED\\012\\011FOR EACH ROW \\012\\011EXECUTE PROCEDURE check_dataset_relationships_on_data_table_modification();\\012\\012-- trigger for 'data_set_relationships'\\012\\012CREATE OR REPLACE FUNCTION check_dataset_relationships_on_relationships_table_modification() RETURNS trigger AS $$\\012DECLARE\\012\\011counter\\011INTEGER;\\012\\011sample_id\\011TECH_ID;\\012\\011data_code\\011CODE;\\012BEGIN\\012\\011-- child will have a parent added so it should not be connected with any sample\\012\\011SELECT samp_id, code INTO sample_id, data_code \\012\\011\\011FROM data \\012\\011\\011WHERE id = NEW.data_id_child;\\012\\011IF (sample_id IS NOT NULL) THEN\\012\\011\\011RAISE EXCEPTION 'Insert/Update of Data Set (Code: %) failed because it cannot be connected to a Sample and to a parent Data Set at the same time.', data_code;\\012\\011END IF;\\012\\011RETURN NEW;\\012END;\\012$$ LANGUAGE 'plpgsql';\\012  \\012CREATE CONSTRAINT TRIGGER check_dataset_relationships_on_relationships_table_modification \\012  AFTER INSERT OR UPDATE ON data_set_relationships\\012\\011DEFERRABLE INITIALLY DEFERRED\\012\\011FOR EACH ROW \\012\\011EXECUTE PROCEDURE check_dataset_relationships_on_relationships_table_modification();\\012	\N
+./sourceTest/sql/postgresql/050/.svn/text-base/schema-050.sql.svn-base:    LANGUAGE plpgsql
+./sourceTest/sql/postgresql/050/.svn/text-base/schema-050.sql.svn-base:    LANGUAGE plpgsql
+./sourceTest/sql/postgresql/050/.svn/text-base/schema-050.sql.svn-base:    LANGUAGE plpgsql
+./sourceTest/sql/postgresql/050/.svn/text-base/schema-050.sql.svn-base:    LANGUAGE plpgsql
+./sourceTest/sql/postgresql/050/.svn/text-base/schema-050.sql.svn-base:    LANGUAGE plpgsql
+./sourceTest/sql/postgresql/050/.svn/text-base/schema-050.sql.svn-base:    LANGUAGE plpgsql
+./sourceTest/sql/postgresql/050/.svn/text-base/schema-050.sql.svn-base:    LANGUAGE plpgsql
+./sourceTest/sql/postgresql/050/.svn/text-base/schema-050.sql.svn-base:    LANGUAGE plpgsql
+./sourceTest/sql/postgresql/050/.svn/text-base/schema-050.sql.svn-base:    LANGUAGE plpgsql
+./sourceTest/sql/postgresql/050/.svn/text-base/schema-050.sql.svn-base:    LANGUAGE plpgsql
+./sourceTest/sql/postgresql/050/017=database_version_logs.tsv:027	D:\\User\\felmer\\dev-workspace\\openbis/source/sql/postgresql/027/function-027.sql	SUCCESS	2008-11-05 09:18:00.403	-- Creating Functions\\012\\012------------------------------------------------------------------------------------\\012--  Purpose:  Create function RENAME_SEQUENCE() that is required for renaming the sequences belonging to tables\\012------------------------------------------------------------------------------------\\012CREATE FUNCTION RENAME_SEQUENCE(OLD_NAME VARCHAR, NEW_NAME VARCHAR) RETURNS INTEGER AS $$\\012DECLARE\\012  CURR_SEQ_VAL   INTEGER;\\012BEGIN\\012  SELECT INTO CURR_SEQ_VAL NEXTVAL(OLD_NAME);\\012  EXECUTE 'CREATE SEQUENCE ' || NEW_NAME || ' START WITH ' || CURR_SEQ_VAL;\\012  EXECUTE 'DROP SEQUENCE ' || OLD_NAME;\\012  RETURN CURR_SEQ_VAL;\\012END;\\012$$ LANGUAGE 'plpgsql';\\012\\012\\012------------------------------------------------------------------------------------\\012--  Purpose:  Create trigger CONTROLLED_VOCABULARY_CHECK \\012------------------------------------------------------------------------------------\\012\\012CREATE OR REPLACE FUNCTION CONTROLLED_VOCABULARY_CHECK() RETURNS trigger AS $$\\012DECLARE\\012   v_code  CODE;\\012BEGIN\\012\\012   select code into v_code from data_types where id = NEW.daty_id;\\012\\012   -- Check if the data is of type "CONTROLLEDVOCABULARY"\\012   if v_code = 'CONTROLLEDVOCABULARY' then\\012      if NEW.covo_id IS NULL then\\012         RAISE EXCEPTION 'Insert/Update of Property Type (Code: %) failed, as its Data Type is CONTROLLEDVOCABULARY, but it is not linked to a Controlled Vocabulary.', NEW.code;\\012      end if;\\012   end if;\\012\\012   RETURN NEW;\\012\\012END;\\012$$ LANGUAGE 'plpgsql';\\012\\012CREATE TRIGGER CONTROLLED_VOCABULARY_CHECK BEFORE INSERT OR UPDATE ON PROPERTY_TYPES\\012    FOR EACH ROW EXECUTE PROCEDURE CONTROLLED_VOCABULARY_CHECK();\\012\\012\\012------------------------------------------------------------------------------------\\012--  Purpose:  Create trigger EXTERNAL_DATA_STORAGE_FORMAT_CHECK \\012------------------------------------------------------------------------------------\\012\\012CREATE OR REPLACE FUNCTION EXTERNAL_DATA_STORAGE_FORMAT_CHECK() RETURNS trigger AS $$\\012DECLARE\\012   v_covo_code  CODE;\\012   data_code CODE;\\012BEGIN\\012\\012   select code into v_covo_code from controlled_vocabularies\\012      where is_internal_namespace = true and \\012         id = (select covo_id from controlled_vocabulary_terms where id = NEW.cvte_id_stor_fmt);\\012   -- Check if the data storage format is a term of the controlled vocabulary "STORAGE_FORMAT"\\012   if v_covo_code != 'STORAGE_FORMAT' then\\012      select code into data_code from data where id = NEW.data_id; \\012      RAISE EXCEPTION 'Insert/Update of Data (Code: %) failed, as its Storage Format is %, but is required to be STORAGE_FORMAT.', data_code, v_covo_code;\\012   end if;\\012\\012   RETURN NEW;\\012\\012END;\\012$$ LANGUAGE 'plpgsql';\\012\\012CREATE TRIGGER EXTERNAL_DATA_STORAGE_FORMAT_CHECK BEFORE INSERT OR UPDATE ON EXTERNAL_DATA\\012    FOR EACH ROW EXECUTE PROCEDURE EXTERNAL_DATA_STORAGE_FORMAT_CHECK();\\012\\012------------------------------------------------------------------------------------\\012--  Purpose:  Create trigger SAMPLE_CODE_UNIQUENESS_CHECK \\012------------------------------------------------------------------------------------\\012\\012CREATE OR REPLACE FUNCTION SAMPLE_CODE_UNIQUENESS_CHECK() RETURNS trigger AS $$\\012DECLARE\\012   counter  INTEGER;\\012BEGIN\\012\\011IF (NEW.samp_id_part_of is NULL) THEN\\012\\011\\011IF (NEW.dbin_id is not NULL) THEN\\012\\011\\011\\011SELECT count(*) into counter FROM samples \\012\\011\\011\\011\\011where id != NEW.id and code = NEW.code and samp_id_part_of is NULL and dbin_id = NEW.dbin_id;\\012\\011\\011\\011IF (counter > 0) THEN\\012\\011\\011\\011\\011RAISE EXCEPTION 'Insert/Update of Sample (Code: %) failed because database instance sample with the same code already exists.', NEW.code;\\012\\011\\011\\011END IF;\\012\\011\\011ELSIF (NEW.grou_id is not NULL) THEN\\012\\011\\011\\011SELECT count(*) into counter FROM samples \\012\\011\\011\\011\\011where id != NEW.id and code = NEW.code and samp_id_part_of is NULL and grou_id = NEW.grou_id;\\012\\011\\011\\011IF (counter > 0) THEN\\012\\011\\011\\011\\011RAISE EXCEPTION 'Insert/Update of Sample (Code: %) failed because group sample with the same code already exists.', NEW.code;\\012\\011\\011\\011END IF;\\012\\011\\011END IF;\\012        ELSE\\012\\011\\011IF (NEW.dbin_id is not NULL) THEN\\012\\011\\011\\011SELECT count(*) into counter FROM samples \\012\\011\\011\\011\\011where id != NEW.id and code = NEW.code and samp_id_part_of = NEW.samp_id_part_of and dbin_id = NEW.dbin_id;\\012\\011\\011\\011IF (counter > 0) THEN\\012\\011\\011\\011\\011RAISE EXCEPTION 'Insert/Update of Sample (Code: %) failed because database instance sample with the same code and being the part of the same parent already exists.', NEW.code;\\012\\011\\011\\011END IF;\\012\\011\\011ELSIF (NEW.grou_id is not NULL) THEN\\012\\011\\011\\011SELECT count(*) into counter FROM samples \\012\\011\\011\\011\\011where id != NEW.id and code = NEW.code and samp_id_part_of = NEW.samp_id_part_of and grou_id = NEW.grou_id;\\012\\011\\011\\011IF (counter > 0) THEN\\012\\011\\011\\011\\011RAISE EXCEPTION 'Insert/Update of Sample (Code: %) failed because group sample with the same code and being the part of the same parent already exists.', NEW.code;\\012\\011\\011\\011END IF;\\012\\011\\011END IF;\\012        END IF;   \\012   RETURN NEW;\\012END;\\012$$ LANGUAGE 'plpgsql';\\012\\012CREATE TRIGGER SAMPLE_CODE_UNIQUENESS_CHECK BEFORE INSERT OR UPDATE ON SAMPLES\\012    FOR EACH ROW EXECUTE PROCEDURE SAMPLE_CODE_UNIQUENESS_CHECK();\\012	\N
+./sourceTest/sql/postgresql/050/017=database_version_logs.tsv:028	source/sql/postgresql/migration/migration-027-028.sql	SUCCESS	2008-11-18 13:24:17.508	-- Create EXPERIMENT_ATTACHMENT_CONTENTS.\\012CREATE TABLE EXPERIMENT_ATTACHMENT_CONTENTS (ID TECH_ID NOT NULL,VALUE FILE NOT NULL);\\012CREATE SEQUENCE EXPERIMENT_ATTACHMENT_CONTENT_ID_SEQ;\\012ALTER TABLE EXPERIMENT_ATTACHMENT_CONTENTS ADD CONSTRAINT EXAC_PK PRIMARY KEY(ID);\\012\\012-- Alter EXPERIMENT_ATTACHMENTS by adding the new column which has a NULL constraint.\\012-- The NOT NULL constraint is added later on.\\012ALTER TABLE EXPERIMENT_ATTACHMENTS ADD COLUMN EXAC_ID TECH_ID;\\012\\012-- Does the VALUE migration between EXPERIMENT_ATTACHMENTS to EXPERIMENT_ATTACHMENT_CONTENTS.\\012CREATE OR REPLACE FUNCTION move_exp_att_content() RETURNS integer AS $$\\012DECLARE\\012    rec RECORD;\\012    seq BIGINT;\\012BEGIN\\012  FOR rec IN SELECT id, value FROM EXPERIMENT_ATTACHMENTS LOOP\\012  \\011seq := nextval('EXPERIMENT_ATTACHMENT_CONTENT_ID_SEQ');\\012    INSERT INTO EXPERIMENT_ATTACHMENT_CONTENTS (id, value) VALUES (seq, rec.value);\\012    UPDATE EXPERIMENT_ATTACHMENTS SET exac_id = seq WHERE id = rec.id;\\012  END LOOP;\\012  RETURN 1;\\012END;\\012$$ LANGUAGE 'plpgsql';\\012\\012-- Call the function.\\012SELECT move_exp_att_content();\\012DROP FUNCTION move_exp_att_content();\\012\\012\\012-- Finish EXPERIMENT_ATTACHMENTS changes.\\012ALTER TABLE EXPERIMENT_ATTACHMENTS ADD CONSTRAINT EXAT_CONT_FK FOREIGN KEY (EXAC_ID) REFERENCES EXPERIMENT_ATTACHMENT_CONTENTS(ID);\\012ALTER TABLE EXPERIMENT_ATTACHMENTS DROP COLUMN VALUE;\\012ALTER TABLE EXPERIMENT_ATTACHMENTS ALTER COLUMN EXAC_ID SET NOT NULL;\\012	\N
+./sourceTest/sql/postgresql/050/017=database_version_logs.tsv:029	source/sql/postgresql/migration/migration-028-029.sql	SUCCESS	2009-03-18 10:50:20.105	-- -------\\012-- add modification_timestamp field to allow edition with Hibernate\\012-- -------\\012\\012ALTER TABLE samples\\012\\011ADD COLUMN modification_timestamp TIME_STAMP DEFAULT CURRENT_TIMESTAMP;\\012\\012ALTER TABLE experiments\\012\\011ADD COLUMN modification_timestamp TIME_STAMP DEFAULT CURRENT_TIMESTAMP;\\012\\012ALTER TABLE materials\\012\\011ADD COLUMN modification_timestamp TIME_STAMP DEFAULT CURRENT_TIMESTAMP;\\012\\012ALTER TABLE experiment_properties\\012\\011ADD COLUMN modification_timestamp TIME_STAMP DEFAULT CURRENT_TIMESTAMP;\\012\\012ALTER TABLE material_properties\\012\\011ADD COLUMN modification_timestamp TIME_STAMP DEFAULT CURRENT_TIMESTAMP;\\012\\012ALTER TABLE sample_properties\\012\\011ADD COLUMN modification_timestamp TIME_STAMP DEFAULT CURRENT_TIMESTAMP;\\012\\012-- -------\\012-- add property data type which references materials\\012-- -------\\012\\012ALTER TABLE property_types\\012\\011ADD COLUMN maty_prop_id tech_id;\\012\\012ALTER TABLE property_types\\012\\011ADD CONSTRAINT prty_maty_fk FOREIGN KEY (maty_prop_id) REFERENCES material_types(id);\\012\\012ALTER TABLE experiment_properties\\012\\011ADD COLUMN mate_prop_id tech_id;\\012\\012ALTER TABLE material_properties\\012\\011ADD COLUMN mate_prop_id tech_id;\\012\\012ALTER TABLE sample_properties\\012\\011ADD COLUMN mate_prop_id tech_id;\\012\\012ALTER TABLE experiment_properties\\012\\011ADD CONSTRAINT expr_mapr_fk FOREIGN KEY (mate_prop_id) REFERENCES materials(id);\\012\\012ALTER TABLE material_properties\\012\\011ADD CONSTRAINT mapr_mapr_fk FOREIGN KEY (mate_prop_id) REFERENCES materials(id);\\012\\012ALTER TABLE sample_properties\\012\\011ADD CONSTRAINT sapr_mapr_fk FOREIGN KEY (mate_prop_id) REFERENCES materials(id);\\012\\012insert into data_types\\012(id\\012 ,code\\012 ,description)\\012 values \\012 (nextval('DATA_TYPE_ID_SEQ')\\012 ,'MATERIAL'\\012 ,'Reference to a material'\\012);\\012\\012ALTER TABLE MATERIAL_PROPERTIES DROP CONSTRAINT MAPR_CK;\\012ALTER TABLE MATERIAL_PROPERTIES ADD CONSTRAINT MAPR_CK CHECK \\012\\011((VALUE IS NOT NULL AND CVTE_ID IS NULL AND MATE_PROP_ID IS NULL) OR \\012\\011 (VALUE IS NULL AND CVTE_ID IS NOT NULL AND MATE_PROP_ID IS NULL) OR\\012\\011 (VALUE IS NULL AND CVTE_ID IS NULL AND MATE_PROP_ID IS NOT NULL)\\012\\011);\\012\\012ALTER TABLE EXPERIMENT_PROPERTIES DROP CONSTRAINT EXPR_CK;\\012ALTER TABLE EXPERIMENT_PROPERTIES ADD CONSTRAINT EXPR_CK CHECK \\012\\011((VALUE IS NOT NULL AND CVTE_ID IS NULL AND MATE_PROP_ID IS NULL) OR \\012\\011 (VALUE IS NULL AND CVTE_ID IS NOT NULL AND MATE_PROP_ID IS NULL) OR\\012\\011 (VALUE IS NULL AND CVTE_ID IS NULL AND MATE_PROP_ID IS NOT NULL)\\012\\011);\\012\\012ALTER TABLE SAMPLE_PROPERTIES DROP CONSTRAINT SAPR_CK;\\012ALTER TABLE SAMPLE_PROPERTIES ADD CONSTRAINT SAPR_CK CHECK \\012\\011((VALUE IS NOT NULL AND CVTE_ID IS NULL AND MATE_PROP_ID IS NULL) OR \\012\\011 (VALUE IS NULL AND CVTE_ID IS NOT NULL AND MATE_PROP_ID IS NULL) OR\\012\\011 (VALUE IS NULL AND CVTE_ID IS NULL AND MATE_PROP_ID IS NOT NULL)\\012\\011);\\012\\012------------------------------------------------------------------------------------\\012--  Purpose:  Create trigger MATERIAL/SAMPLE/EXPERIMENT _PROPERTY_WITH_MATERIAL_DATA_TYPE_CHECK\\012--            It checks that if material property value is assigned to the entity,\\012--\\011\\011\\011\\011\\011\\011then the material type is equal to the one described by property type.\\012------------------------------------------------------------------------------------\\012\\012CREATE OR REPLACE FUNCTION MATERIAL_PROPERTY_WITH_MATERIAL_DATA_TYPE_CHECK() RETURNS trigger AS $$\\012DECLARE\\012   v_type_id  CODE;\\012   v_type_id_prop  CODE;\\012BEGIN\\012   if NEW.mate_prop_id IS NOT NULL then\\012\\011\\011\\011-- find material type id of the property type \\012\\011\\011\\011select pt.maty_prop_id into v_type_id_prop \\012\\011\\011\\011  from material_type_property_types etpt, property_types pt \\012\\011\\011\\011 where NEW.mtpt_id = etpt.id AND etpt.prty_id = pt.id;\\012\\011\\011\\012\\011\\011\\011if v_type_id_prop IS NOT NULL then\\012\\011\\011\\011\\011-- find material type id of the material which consists the entity's property value\\012\\011\\011\\011\\011select entity.maty_id into v_type_id \\012\\011\\011\\011\\011  from materials entity\\012\\011\\011\\011\\011 where NEW.mate_prop_id = entity.id;\\012\\011\\011\\011\\011if v_type_id != v_type_id_prop then\\012\\011\\011\\011\\011\\011RAISE EXCEPTION 'Insert/Update of property value referencing material (id: %) failed, as referenced material type is different than expected (id %, expected id: %).', \\012\\011\\011\\011\\011\\011\\011\\011 NEW.mate_prop_id, v_type_id, v_type_id_prop;\\012\\011\\011\\011\\011end if;\\012\\011\\011\\011end if;\\012   end if;\\012   RETURN NEW;\\012END;\\012$$ LANGUAGE 'plpgsql';\\012\\012CREATE TRIGGER MATERIAL_PROPERTY_WITH_MATERIAL_DATA_TYPE_CHECK BEFORE INSERT OR UPDATE ON material_properties\\012    FOR EACH ROW EXECUTE PROCEDURE MATERIAL_PROPERTY_WITH_MATERIAL_DATA_TYPE_CHECK();\\012    \\012CREATE OR REPLACE FUNCTION SAMPLE_PROPERTY_WITH_MATERIAL_DATA_TYPE_CHECK() RETURNS trigger AS $$\\012DECLARE\\012   v_type_id  CODE;\\012   v_type_id_prop  CODE;\\012BEGIN\\012   if NEW.mate_prop_id IS NOT NULL then\\012\\011\\011\\011-- find material type id of the property type \\012\\011\\011\\011select pt.maty_prop_id into v_type_id_prop \\012\\011\\011\\011  from sample_type_property_types etpt, property_types pt \\012\\011\\011\\011 where NEW.stpt_id = etpt.id AND etpt.prty_id = pt.id;\\012\\011\\011\\012\\011\\011\\011if v_type_id_prop IS NOT NULL then\\012\\011\\011\\011\\011-- find material type id of the material which consists the entity's property value\\012\\011\\011\\011\\011select entity.maty_id into v_type_id \\012\\011\\011\\011\\011  from materials entity\\012\\011\\011\\011\\011 where NEW.mate_prop_id = entity.id;\\012\\011\\011\\011\\011if v_type_id != v_type_id_prop then\\012\\011\\011\\011\\011\\011RAISE EXCEPTION 'Insert/Update of property value referencing material (id: %) failed, as referenced material type is different than expected (id %, expected id: %).', \\012\\011\\011\\011\\011\\011\\011\\011\\011\\011\\011\\011\\011 NEW.mate_prop_id, v_type_id, v_type_id_prop;\\012\\011\\011\\011\\011end if;\\012\\011\\011\\011end if;\\012   end if;\\012   RETURN NEW;\\012END;\\012$$ LANGUAGE 'plpgsql';\\012\\012CREATE TRIGGER SAMPLE_PROPERTY_WITH_MATERIAL_DATA_TYPE_CHECK BEFORE INSERT OR UPDATE ON sample_properties\\012    FOR EACH ROW EXECUTE PROCEDURE SAMPLE_PROPERTY_WITH_MATERIAL_DATA_TYPE_CHECK();\\012    \\012CREATE OR REPLACE FUNCTION EXPERIMENT_PROPERTY_WITH_MATERIAL_DATA_TYPE_CHECK() RETURNS trigger AS $$\\012DECLARE\\012   v_type_id  CODE;\\012   v_type_id_prop  CODE;\\012BEGIN\\012   if NEW.mate_prop_id IS NOT NULL then\\012\\011\\011\\011-- find material type id of the property type \\012\\011\\011\\011select pt.maty_prop_id into v_type_id_prop \\012\\011\\011\\011  from experiment_type_property_types etpt, property_types pt \\012\\011\\011\\011 where NEW.etpt_id = etpt.id AND etpt.prty_id = pt.id;\\012\\011\\011\\012\\011\\011\\011if v_type_id_prop IS NOT NULL then\\012\\011\\011\\011\\011-- find material type id of the material which consists the entity's property value\\012\\011\\011\\011\\011select entity.maty_id into v_type_id \\012\\011\\011\\011\\011  from materials entity\\012\\011\\011\\011\\011 where NEW.mate_prop_id = entity.id;\\012\\011\\011\\011\\011if v_type_id != v_type_id_prop then\\012\\011\\011\\011\\011\\011RAISE EXCEPTION 'Insert/Update of property value referencing material (id: %) failed, as referenced material type is different than expected (id %, expected id: %).', \\012\\011\\011\\011\\011\\011\\011\\011\\011\\011\\011\\011\\011 NEW.mate_prop_id, v_type_id, v_type_id_prop;\\012\\011\\011\\011\\011end if;\\012\\011\\011\\011end if;\\012   end if;\\012   RETURN NEW;\\012END;\\012$$ LANGUAGE 'plpgsql';\\012\\012CREATE TRIGGER EXPERIMENT_PROPERTY_WITH_MATERIAL_DATA_TYPE_CHECK BEFORE INSERT OR UPDATE ON experiment_properties\\012    FOR EACH ROW EXECUTE PROCEDURE EXPERIMENT_PROPERTY_WITH_MATERIAL_DATA_TYPE_CHECK();\\012       \\012-- -------\\012-- remove the reminescents of the OBSERVABLE_TYPE\\012-- -------\\012\\012ALTER TABLE data\\012\\011DROP CONSTRAINT data_obty_fk;\\012\\012ALTER TABLE data_set_types\\012\\011DROP CONSTRAINT obty_pk;\\012\\012ALTER TABLE data_set_types\\012\\011ADD CONSTRAINT dsty_pk PRIMARY KEY (id);\\012\\012ALTER TABLE data\\012\\011ADD CONSTRAINT data_dsty_fk FOREIGN KEY (dsty_id) REFERENCES data_set_types(id);\\012\\012ALTER TABLE data_set_types\\012\\011DROP CONSTRAINT obty_bk_uk;\\012\\012ALTER TABLE data_set_types\\012\\011DROP CONSTRAINT obty_dbin_fk;\\012\\012ALTER TABLE data_set_types\\012\\011ADD CONSTRAINT dsty_bk_uk UNIQUE (code, dbin_id);\\012\\012ALTER TABLE data_set_types\\012\\011ADD CONSTRAINT dsty_dbin_fk FOREIGN KEY (dbin_id) REFERENCES database_instances(id);\\012\\012DROP INDEX data_obty_fk_i;\\012\\012CREATE INDEX data_dsty_fk_i ON data(dsty_id);\\012	\N
+./sourceTest/sql/postgresql/050/017=database_version_logs.tsv:030	source/sql/postgresql/migration/migration-029-030.sql	SUCCESS	2009-03-23 15:34:44.72	-- -------\\012-- add modification_timestamp field to allow edition with Hibernate\\012-- -------\\012ALTER TABLE data\\012\\011ADD COLUMN modification_timestamp TIME_STAMP DEFAULT CURRENT_TIMESTAMP;\\012ALTER TABLE experiment_types\\012\\011ADD COLUMN modification_timestamp TIME_STAMP DEFAULT CURRENT_TIMESTAMP;\\012ALTER TABLE sample_types\\012\\011ADD COLUMN modification_timestamp TIME_STAMP DEFAULT CURRENT_TIMESTAMP;\\012ALTER TABLE material_types\\012\\011ADD COLUMN modification_timestamp TIME_STAMP DEFAULT CURRENT_TIMESTAMP;\\012ALTER TABLE data_set_types\\012\\011ADD COLUMN modification_timestamp TIME_STAMP DEFAULT CURRENT_TIMESTAMP;\\012ALTER TABLE controlled_vocabularies\\012\\011ADD COLUMN modification_timestamp TIME_STAMP DEFAULT CURRENT_TIMESTAMP;\\012-- -------\\012-- add properties to data sets\\012-- -------\\012CREATE TABLE DATA_SET_PROPERTIES (ID TECH_ID NOT NULL,DS_ID TECH_ID NOT NULL,DSTPT_ID TECH_ID NOT NULL,VALUE GENERIC_VALUE,CVTE_ID TECH_ID, MATE_PROP_ID TECH_ID, PERS_ID_REGISTERER TECH_ID NOT NULL,REGISTRATION_TIMESTAMP TIME_STAMP_DFL NOT NULL DEFAULT CURRENT_TIMESTAMP, MODIFICATION_TIMESTAMP TIME_STAMP DEFAULT CURRENT_TIMESTAMP);\\012CREATE TABLE DATA_SET_TYPE_PROPERTY_TYPES (ID TECH_ID NOT NULL,DSTY_ID TECH_ID NOT NULL,PRTY_ID TECH_ID NOT NULL,IS_MANDATORY BOOLEAN_CHAR NOT NULL DEFAULT 'F',IS_MANAGED_INTERNALLY BOOLEAN_CHAR NOT NULL DEFAULT 'F',PERS_ID_REGISTERER TECH_ID NOT NULL,REGISTRATION_TIMESTAMP TIME_STAMP_DFL NOT NULL DEFAULT CURRENT_TIMESTAMP);\\012\\012CREATE SEQUENCE DATA_SET_PROPERTY_ID_SEQ;\\012CREATE SEQUENCE DSTPT_ID_SEQ;\\012\\012ALTER TABLE DATA_SET_TYPE_PROPERTY_TYPES ADD CONSTRAINT DSTPT_PK PRIMARY KEY(ID);\\012ALTER TABLE DATA_SET_PROPERTIES ADD CONSTRAINT DSPR_PK PRIMARY KEY(ID);\\012\\012ALTER TABLE DATA_SET_TYPE_PROPERTY_TYPES ADD CONSTRAINT DSTPT_BK_UK UNIQUE(DSTY_ID,PRTY_ID);\\012ALTER TABLE DATA_SET_PROPERTIES ADD CONSTRAINT DSPR_BK_UK UNIQUE(DS_ID,DSTPT_ID);\\012\\012\\012ALTER TABLE DATA_SET_TYPE_PROPERTY_TYPES ADD CONSTRAINT DSTPT_DSTY_FK FOREIGN KEY (DSTY_ID) REFERENCES DATA_SET_TYPES(ID);\\012ALTER TABLE DATA_SET_TYPE_PROPERTY_TYPES ADD CONSTRAINT DSTPT_PERS_FK FOREIGN KEY (PERS_ID_REGISTERER) REFERENCES PERSONS(ID);\\012ALTER TABLE DATA_SET_TYPE_PROPERTY_TYPES ADD CONSTRAINT DSTPT_PRTY_FK FOREIGN KEY (PRTY_ID) REFERENCES PROPERTY_TYPES(ID);\\012ALTER TABLE DATA_SET_PROPERTIES ADD CONSTRAINT DSPR_CVTE_FK FOREIGN KEY (CVTE_ID) REFERENCES CONTROLLED_VOCABULARY_TERMS(ID);\\012ALTER TABLE DATA_SET_PROPERTIES ADD CONSTRAINT DSPR_DSTPT_FK FOREIGN KEY (DSTPT_ID) REFERENCES DATA_SET_TYPE_PROPERTY_TYPES(ID) ON DELETE CASCADE;\\012ALTER TABLE DATA_SET_PROPERTIES ADD CONSTRAINT DSPR_DS_FK FOREIGN KEY (DS_ID) REFERENCES DATA(ID);\\012ALTER TABLE DATA_SET_PROPERTIES ADD CONSTRAINT DSPR_PERS_FK FOREIGN KEY (PERS_ID_REGISTERER) REFERENCES PERSONS(ID);\\012ALTER TABLE DATA_SET_PROPERTIES ADD CONSTRAINT DSPR_MAPR_FK FOREIGN KEY (MATE_PROP_ID) REFERENCES MATERIALS(ID);\\012\\012ALTER TABLE DATA_SET_PROPERTIES ADD CONSTRAINT DSPR_CK CHECK \\012\\011((VALUE IS NOT NULL AND CVTE_ID IS NULL AND MATE_PROP_ID IS NULL) OR \\012\\011 (VALUE IS NULL AND CVTE_ID IS NOT NULL AND MATE_PROP_ID IS NULL) OR\\012\\011 (VALUE IS NULL AND CVTE_ID IS NULL AND MATE_PROP_ID IS NOT NULL)\\012\\011);\\012\\012CREATE INDEX DSPR_CVTE_FK_I ON DATA_SET_PROPERTIES (CVTE_ID);\\012CREATE INDEX DSPR_DSTPT_FK_I ON DATA_SET_PROPERTIES (DSTPT_ID);\\012CREATE INDEX DSPR_DS_FK_I ON DATA_SET_PROPERTIES (DS_ID);\\012CREATE INDEX DSPR_PERS_FK_I ON DATA_SET_PROPERTIES (PERS_ID_REGISTERER);\\012CREATE INDEX DSTPT_DSTY_FK_I ON DATA_SET_TYPE_PROPERTY_TYPES (DSTY_ID);\\012CREATE INDEX DSTPT_PERS_FK_I ON DATA_SET_TYPE_PROPERTY_TYPES (PERS_ID_REGISTERER);\\012CREATE INDEX DSTPT_PRTY_FK_I ON DATA_SET_TYPE_PROPERTY_TYPES (PRTY_ID);\\012\\012CREATE OR REPLACE FUNCTION DATA_SET_PROPERTY_WITH_MATERIAL_DATA_TYPE_CHECK() RETURNS trigger AS $$\\012DECLARE\\012   v_type_id  CODE;\\012   v_type_id_prop  CODE;\\012BEGIN\\012   if NEW.mate_prop_id IS NOT NULL then\\012\\011\\011\\011-- find material type id of the property type \\012\\011\\011\\011select pt.maty_prop_id into v_type_id_prop \\012\\011\\011\\011  from data_set_type_property_types dstpt, property_types pt \\012\\011\\011\\011 where NEW.dstpt_id = dstpt.id AND dstpt.prty_id = pt.id;\\012\\011\\011\\012\\011\\011\\011if v_type_id_prop IS NOT NULL then\\012\\011\\011\\011\\011-- find material type id of the material which consists the entity's property value\\012\\011\\011\\011\\011select entity.maty_id into v_type_id \\012\\011\\011\\011\\011  from materials entity\\012\\011\\011\\011\\011 where NEW.mate_prop_id = entity.id;\\012\\011\\011\\011\\011if v_type_id != v_type_id_prop then\\012\\011\\011\\011\\011\\011RAISE EXCEPTION 'Insert/Update of property value referencing material (id: %) failed, as referenced material type is different than expected (id %, expected id: %).', \\012\\011\\011\\011\\011\\011\\011\\011\\011\\011\\011\\011\\011 NEW.mate_prop_id, v_type_id, v_type_id_prop;\\012\\011\\011\\011\\011end if;\\012\\011\\011\\011end if;\\012   end if;\\012   RETURN NEW;\\012END;\\012$$ LANGUAGE 'plpgsql';\\012\\012CREATE TRIGGER DATA_SET_PROPERTY_WITH_MATERIAL_DATA_TYPE_CHECK BEFORE INSERT OR UPDATE ON data_set_properties\\012    FOR EACH ROW EXECUTE PROCEDURE DATA_SET_PROPERTY_WITH_MATERIAL_DATA_TYPE_CHECK();   \\012	\N
+./sourceTest/sql/postgresql/050/017=database_version_logs.tsv:032	source/sql/postgresql/migration/migration-031-032.sql	SUCCESS	2009-04-09 09:36:36.2	-- -------\\012-- Modify MATERIAL_BATCHES\\012-- -------\\012\\012ALTER TABLE material_batches\\012    DROP COLUMN proc_id;\\012\\012-- -------\\012-- Modify SAMPLES\\012-- -------\\012\\012ALTER TABLE samples\\012    ADD COLUMN expe_id tech_id;\\012\\012ALTER TABLE samples\\012    ADD CONSTRAINT samp_expe_fk FOREIGN KEY (expe_id) REFERENCES experiments(id);\\012\\012CREATE INDEX samp_expe_fk_i ON samples USING btree (expe_id);\\012\\012-- relink samples directly to experiments\\012\\012UPDATE samples\\012SET expe_id = (SELECT e.id FROM experiments e, procedures p, sample_inputs si \\012               WHERE si.samp_id = samples.id AND si.proc_id = p.id AND p.expe_id = e.id AND e.inva_id IS NULL);\\012\\012\\012-- -------\\012-- Modify DATA\\012-- -------\\012\\012ALTER TABLE data\\012    ADD COLUMN expe_id tech_id;\\012\\012ALTER TABLE data\\012    ADD CONSTRAINT data_expe_fk FOREIGN KEY (expe_id) REFERENCES experiments(id);\\012\\012CREATE INDEX data_expe_fk_i ON data USING btree (expe_id);\\012\\012UPDATE data\\012SET expe_id = (SELECT e.id FROM experiments e, procedures p \\012               WHERE data.proc_id_produced_by = p.id AND p.expe_id = e.id);\\012\\012ALTER TABLE data\\012    ALTER COLUMN expe_id SET NOT NULL;\\012\\012ALTER TABLE data\\012    DROP COLUMN proc_id_produced_by;\\012\\012-- -------\\012-- Drop PROCEDURES, PROCEDURE_TYPES, and SAMPLE_INPUTS\\012-- -------\\012\\012DROP TABLE sample_inputs;\\012DROP TABLE procedures;\\012DROP TABLE procedure_types;\\012\\012DROP SEQUENCE procedure_id_seq;\\012DROP SEQUENCE procedure_type_id_seq;\\012\\012-- -------\\012-- Add CODE_SEQ\\012-- -------\\012\\012CREATE SEQUENCE CODE_SEQ;\\012\\012-- -------\\012-- Add new columns to DATA_STORES\\012-- -------\\012\\012ALTER TABLE data_stores\\012    ADD COLUMN remote_url character varying(250),\\012    ADD COLUMN session_token character varying(50),\\012    ADD COLUMN modification_timestamp time_stamp DEFAULT now();\\012\\012UPDATE data_stores\\012SET remote_url = '', session_token='';\\012\\012ALTER TABLE data_stores\\012    ALTER COLUMN remote_url SET NOT NULL,\\012    ALTER COLUMN session_token SET NOT NULL;\\012\\012-- -------\\012-- Drop foreign keys onto DATA_STORES\\012-- -------\\012\\012ALTER TABLE database_instances\\012    DROP COLUMN dast_id;\\012\\012ALTER TABLE groups\\012    DROP COLUMN dast_id;\\012\\012ALTER TABLE projects\\012    DROP COLUMN dast_id;\\012\\012ALTER TABLE experiments\\012    DROP COLUMN dast_id;\\012\\012-- -------\\012-- Add foreign key from DATA onto DATA_STORES\\012-- -------\\012\\012ALTER TABLE data\\012    ADD COLUMN dast_id tech_id;\\012\\012ALTER TABLE data\\012    ADD CONSTRAINT data_dast_fk FOREIGN KEY (dast_id) REFERENCES data_stores(id);\\012\\012UPDATE data\\012SET dast_id = (select id from data_stores where code = 'STANDARD');\\012\\012ALTER TABLE data\\012    ALTER COLUMN dast_id SET NOT NULL;\\012\\012\\012------------------------------------------------------------------------------------\\012--  Purpose:  Replace trigger SAMPLE_CODE_UNIQUENESS_CHECK \\012------------------------------------------------------------------------------------\\012\\012CREATE OR REPLACE FUNCTION SAMPLE_CODE_UNIQUENESS_CHECK() RETURNS trigger AS $$\\012DECLARE\\012   counter  INTEGER;\\012BEGIN\\012    LOCK TABLE samples IN EXCLUSIVE MODE;\\012    IF (NEW.samp_id_part_of is NULL) THEN\\012        IF (NEW.dbin_id is not NULL) THEN\\012            SELECT count(*) into counter FROM samples \\012                where id != NEW.id and code = NEW.code and samp_id_part_of is NULL and dbin_id = NEW.dbin_id;\\012            IF (counter > 0) THEN\\012                RAISE EXCEPTION 'Insert/Update of Sample (Code: %) failed because database instance sample with the same code already exists.', NEW.code;\\012            END IF;\\012        ELSIF (NEW.grou_id is not NULL) THEN\\012            SELECT count(*) into counter FROM samples \\012                where id != NEW.id and code = NEW.code and samp_id_part_of is NULL and grou_id = NEW.grou_id;\\012            IF (counter > 0) THEN\\012                RAISE EXCEPTION 'Insert/Update of Sample (Code: %) failed because group sample with the same code already exists.', NEW.code;\\012            END IF;\\012        END IF;\\012        ELSE\\012        IF (NEW.dbin_id is not NULL) THEN\\012            SELECT count(*) into counter FROM samples \\012                where id != NEW.id and code = NEW.code and samp_id_part_of = NEW.samp_id_part_of and dbin_id = NEW.dbin_id;\\012            IF (counter > 0) THEN\\012                RAISE EXCEPTION 'Insert/Update of Sample (Code: %) failed because database instance sample with the same code and being the part of the same parent already exists.', NEW.code;\\012            END IF;\\012        ELSIF (NEW.grou_id is not NULL) THEN\\012            SELECT count(*) into counter FROM samples \\012                where id != NEW.id and code = NEW.code and samp_id_part_of = NEW.samp_id_part_of and grou_id = NEW.grou_id;\\012            IF (counter > 0) THEN\\012                RAISE EXCEPTION 'Insert/Update of Sample (Code: %) failed because group sample with the same code and being the part of the same parent already exists.', NEW.code;\\012            END IF;\\012        END IF;\\012        END IF;   \\012   RETURN NEW;\\012END;\\012$$ LANGUAGE 'plpgsql';\\012\\012\\012\\012	\N
+./sourceTest/sql/postgresql/050/017=database_version_logs.tsv:034	source/sql/postgresql/migration/migration-033-034.sql	SUCCESS	2009-05-26 08:32:49.935	------------------------------------------------------------------------------------\\012-- Create sequence for generating permanent identifiers starting with nextval of existing dataset sequence.\\012------------------------------------------------------------------------------------\\012CREATE FUNCTION CREATE_SEQUENCE(EXISTING_SEQUENCE VARCHAR, NEW_SEQUENCE VARCHAR) RETURNS VOID AS $$\\012DECLARE\\012  CURR_SEQ_VAL   INTEGER;\\012BEGIN\\012  SELECT INTO CURR_SEQ_VAL NEXTVAL(EXISTING_SEQUENCE);\\012  EXECUTE 'CREATE SEQUENCE ' || NEW_SEQUENCE || ' START WITH ' || CURR_SEQ_VAL;\\012  RETURN;\\012END;\\012$$ LANGUAGE 'plpgsql';\\012\\012SELECT CREATE_SEQUENCE('DATA_ID_SEQ', 'PERM_ID_SEQ');\\012DROP FUNCTION CREATE_SEQUENCE(VARCHAR, VARCHAR);\\012\\012------------------------------------------------------------------------------------\\012-- Add perm_id columns to samples and experiments.\\012------------------------------------------------------------------------------------\\012ALTER TABLE SAMPLES ADD COLUMN PERM_ID CODE;\\012ALTER TABLE EXPERIMENTS ADD COLUMN PERM_ID CODE;\\012\\012UPDATE SAMPLES SET PERM_ID = to_char(registration_timestamp,'YYYYMMDDHHSSMS') || '-' || NEXTVAL('PERM_ID_SEQ');\\012UPDATE EXPERIMENTS SET PERM_ID = to_char(registration_timestamp,'YYYYMMDDHHSSMS') || '-' || NEXTVAL('PERM_ID_SEQ');\\012ALTER TABLE SAMPLES ALTER COLUMN PERM_ID SET NOT NULL;\\012ALTER TABLE EXPERIMENTS ALTER COLUMN PERM_ID SET NOT NULL;\\012ALTER TABLE SAMPLES ADD CONSTRAINT SAMP_PI_UK UNIQUE(PERM_ID);\\012ALTER TABLE EXPERIMENTS ADD CONSTRAINT EXPE_PI_UK UNIQUE(PERM_ID);\\012\\012\\012------------------------------------------------------------------------------------\\012-- Add column is_chosen_from_list to controlled_vocabularies.\\012------------------------------------------------------------------------------------\\012ALTER TABLE controlled_vocabularies ADD COLUMN is_chosen_from_list BOOLEAN_CHAR NOT NULL DEFAULT TRUE;\\012ALTER TABLE controlled_vocabularies ADD COLUMN source_uri CHARACTER VARYING(250);\\012------------------------------------------------------------------------------------\\012-- Modify Data table - remove arc connection between Sample and Data table, use a flag instead\\012------------------------------------------------------------------------------------\\012\\012-- add new columns\\012\\012ALTER TABLE data\\012    ADD COLUMN is_derived boolean_char;\\012ALTER TABLE data\\012    ADD COLUMN samp_id tech_id;\\012\\012-- update values in new columns\\012\\012UPDATE data\\012    SET is_derived = (samp_id_derived_from IS NOT NULL); \\012UPDATE data\\012    SET samp_id = samp_id_derived_from \\012    WHERE is_derived = 'TRUE';\\012UPDATE data\\012    SET samp_id = samp_id_acquired_from \\012    WHERE is_derived = 'FALSE';\\012\\012-- add constraints and indexes to new columns\\012\\012ALTER TABLE data\\012    ALTER COLUMN is_derived SET NOT NULL;\\012ALTER TABLE data\\012    ALTER COLUMN samp_id SET NOT NULL;   \\012ALTER TABLE data\\012    ADD CONSTRAINT data_samp_fk FOREIGN KEY (samp_id) REFERENCES samples (id);\\012CREATE INDEX data_samp_fk_i ON data USING btree (samp_id);\\012\\012-- remove old columns\\012\\012ALTER TABLE data\\012    DROP COLUMN samp_id_acquired_from;\\012ALTER TABLE data\\012    DROP COLUMN samp_id_derived_from;\\012    \\012------------------------------------------------------------------------------------\\012-- Granting SELECT privilege to group openbis_readonly\\012------------------------------------------------------------------------------------\\012\\012GRANT SELECT ON SEQUENCE attachment_content_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE attachment_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE code_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE controlled_vocabulary_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE cvte_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE data_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE data_set_property_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE data_set_relationship_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE data_set_type_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE data_store_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE data_type_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE database_instance_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE dstpt_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE etpt_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE event_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE experiment_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE experiment_property_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE experiment_type_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE file_format_type_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE group_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE invalidation_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE locator_type_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE material_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE material_property_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE material_type_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE mtpt_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE perm_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE person_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE project_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE property_type_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE role_assignment_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE sample_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE sample_property_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE sample_type_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE stpt_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE attachment_contents TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE attachments TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE controlled_vocabularies TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE controlled_vocabulary_terms TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE data TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE data_set_properties TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE data_set_relationships TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE data_set_type_property_types TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE data_set_types TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE data_stores TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE data_types TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE database_instances TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE database_version_logs TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE events TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE experiment_properties TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE experiment_type_property_types TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE experiment_types TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE experiments TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE external_data TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE file_format_types TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE groups TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE invalidations TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE locator_types TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE material_properties TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE material_type_property_types TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE material_types TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE materials TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE persons TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE projects TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE property_types TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE role_assignments TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE sample_properties TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE sample_type_property_types TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE sample_types TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE samples TO GROUP OPENBIS_READONLY;\\012\\012------------------------------------------------------------------------------------\\012-- Delete MATERIAL_BATCHES table\\012------------------------------------------------------------------------------------\\012\\012-- WARNING: Potential data lost!!!\\012-- WARNING: Potential data lost!!!\\012-- WARNING: Potential data lost!!!\\012\\012DROP TABLE SAMPLE_MATERIAL_BATCHES;\\012DROP TABLE MATERIAL_BATCHES;\\012DROP SEQUENCE MATERIAL_BATCH_ID_SEQ;\\012\\012------------------------------------------------------------------------------------\\012-- Delete MATE_ID_INHIBITOR_OF from table MATERIALS\\012------------------------------------------------------------------------------------\\012\\012-- WARNING: Potential data lost!!!\\012-- WARNING: Potential data lost!!!\\012-- WARNING: Potential data lost!!!\\012\\012ALTER TABLE MATERIALS DROP COLUMN MATE_ID_INHIBITOR_OF;\\012	\N
+./sourceTest/sql/postgresql/050/017=database_version_logs.tsv:041	source/sql/postgresql/migration/migration-040-041.sql	SUCCESS	2009-09-14 13:48:57.539	-- Create FILTERS table\\012\\012CREATE TABLE FILTERS (ID TECH_ID NOT NULL, DBIN_ID TECH_ID NOT NULL, NAME VARCHAR(200) NOT NULL, DESCRIPTION DESCRIPTION_1000,REGISTRATION_TIMESTAMP TIME_STAMP_DFL NOT NULL DEFAULT CURRENT_TIMESTAMP, PERS_ID_REGISTERER TECH_ID NOT NULL, MODIFICATION_TIMESTAMP TIME_STAMP DEFAULT CURRENT_TIMESTAMP, EXPRESSION VARCHAR(2000) NOT NULL, IS_PUBLIC BOOLEAN NOT NULL, GRID_ID VARCHAR(200) NOT NULL);\\012CREATE SEQUENCE FILTER_ID_SEQ;\\012ALTER TABLE FILTERS ADD CONSTRAINT FILT_PK PRIMARY KEY(ID);\\012ALTER TABLE FILTERS ADD CONSTRAINT FILT_BK_UK UNIQUE(NAME, DBIN_ID, GRID_ID);\\012ALTER TABLE FILTERS ADD CONSTRAINT FILT_PERS_FK FOREIGN KEY (PERS_ID_REGISTERER) REFERENCES PERSONS(ID);\\012ALTER TABLE FILTERS ADD CONSTRAINT FILT_DBIN_FK FOREIGN KEY (DBIN_ID) REFERENCES DATABASE_INSTANCES(ID);\\012CREATE INDEX FILT_PERS_FK_I ON FILTERS (PERS_ID_REGISTERER);\\012CREATE INDEX FILT_DBIN_FK_I ON FILTERS (DBIN_ID);\\012GRANT SELECT ON SEQUENCE filter_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE filters TO GROUP OPENBIS_READONLY;\\012\\012-- Add missing foreign key to role assignments authorization group\\012ALTER TABLE ROLE_ASSIGNMENTS ADD CONSTRAINT ROAS_AG_FK_GRANTEE FOREIGN KEY (AG_ID_GRANTEE) REFERENCES AUTHORIZATION_GROUPS(ID);\\012\\012--------------------------------------------------------------------------------------------------\\012-- Modify dataset connections:\\012-- 1. connection with sample shouldn't be mandatory any more\\012-- 2. introduce an arc condition that dataset cannot be connected with a sample and a parent dataset at the same time\\012--------------------------------------------------------------------------------------------------\\012\\012-- Weaken data-sample connection constraint - allow dataset to have no connection with sample\\012ALTER TABLE data ALTER COLUMN samp_id DROP NOT NULL;\\012\\012-- Remove data-sample connection for datasets that have a parent\\012\\012UPDATE data \\012   SET samp_id = NULL \\012 WHERE id IN (SELECT DISTINCT data_id_child FROM data_set_relationships);\\012\\012-- With PostgreSQL 8.4 one can check that before migration there were no cycles in dataset relationships:\\012--\\012-- WITH RECURSIVE data_set_parents(id, parent_ids, cycle) AS (\\012--         SELECT  r.data_id_child AS id, \\012--                 ARRAY[CAST (r.data_id_parent AS bigint)] AS parent_ids, \\012--                 false AS cycle \\012--         FROM data_set_relationships r\\012--     UNION ALL\\012--         SELECT  r.data_id_child,\\012--                 CAST (r.data_id_parent AS bigint) || p.parent_ids,\\012--                 r.data_id_child = ANY(p.parent_ids)\\012--         FROM data_set_relationships r, data_set_parents p\\012--         WHERE r.data_id_parent = p.id AND NOT cycle\\012-- )\\012-- SELECT count(*) AS cycles FROM data_set_parents WHERE cycle = true;\\012\\012---------------------------------------------------------------------------------------------------\\012--  Purpose:  Create DEFERRED triggers:\\012--            * check_dataset_relationships_on_data_table_modification,\\012--            * check_dataset_relationships_on_relationships_table_modification.\\012--            They check that after all modifications of database (just before commit) \\012--            if 'data'/'data_set_relationships' tables are among modified tables \\012--            dataset is not connected with a sample and a parent dataset at the same time.\\012--            This connections are held in two different tables so simple immediate trigger \\012--            with arc check cannot be used and we need two deferred triggers.\\012----------------------------------------------------------------------------------------------------\\012\\012-- trigger for 'data' table\\012\\012CREATE OR REPLACE FUNCTION check_dataset_relationships_on_data_table_modification() RETURNS trigger AS $$\\012DECLARE\\012\\011counter\\011INTEGER;\\012BEGIN\\012\\011-- if there is a connection with a Sample there should not be any connection with a parent Data Set\\012\\011IF (NEW.samp_id IS NOT NULL) THEN\\012\\011\\011-- count number of parents\\012\\011\\011SELECT count(*) INTO counter \\012\\011\\011\\011FROM data_set_relationships \\012\\011\\011\\011WHERE data_id_child = OLD.id;\\012\\011\\011IF (counter > 0) THEN\\012\\011\\011\\011RAISE EXCEPTION 'Insert/Update of Data Set (Code: %) failed because it cannot be connected with a Sample and a parent Data Set at the same time.', OLD.code;\\012\\011\\011END IF;\\012\\011END IF;\\012  RETURN NEW;\\012END;\\012$$ LANGUAGE 'plpgsql';\\012\\012CREATE CONSTRAINT TRIGGER check_dataset_relationships_on_data_table_modification \\012  AFTER INSERT OR UPDATE ON data\\012\\011DEFERRABLE INITIALLY DEFERRED\\012\\011FOR EACH ROW \\012\\011EXECUTE PROCEDURE check_dataset_relationships_on_data_table_modification();\\012\\012-- trigger for 'data_set_relationships'\\012\\012CREATE OR REPLACE FUNCTION check_dataset_relationships_on_relationships_table_modification() RETURNS trigger AS $$\\012DECLARE\\012\\011counter\\011INTEGER;\\012\\011sample_id\\011TECH_ID;\\012\\011data_code\\011CODE;\\012BEGIN\\012\\011-- child will have a parent added so it should not be connected with any sample\\012\\011SELECT samp_id, code INTO sample_id, data_code \\012\\011\\011FROM data \\012\\011\\011WHERE id = NEW.data_id_child;\\012\\011IF (sample_id IS NOT NULL) THEN\\012\\011\\011RAISE EXCEPTION 'Insert/Update of Data Set (Code: %) failed because it cannot be connected to a Sample and to a parent Data Set at the same time.', data_code;\\012\\011END IF;\\012\\011RETURN NEW;\\012END;\\012$$ LANGUAGE 'plpgsql';\\012  \\012CREATE CONSTRAINT TRIGGER check_dataset_relationships_on_relationships_table_modification \\012  AFTER INSERT OR UPDATE ON data_set_relationships\\012\\011DEFERRABLE INITIALLY DEFERRED\\012\\011FOR EACH ROW \\012\\011EXECUTE PROCEDURE check_dataset_relationships_on_relationships_table_modification();\\012	\N
+./sourceTest/sql/postgresql/050/schema-050.sql:    LANGUAGE plpgsql
+./sourceTest/sql/postgresql/050/schema-050.sql:    LANGUAGE plpgsql
+./sourceTest/sql/postgresql/050/schema-050.sql:    LANGUAGE plpgsql
+./sourceTest/sql/postgresql/050/schema-050.sql:    LANGUAGE plpgsql
+./sourceTest/sql/postgresql/050/schema-050.sql:    LANGUAGE plpgsql
+./sourceTest/sql/postgresql/050/schema-050.sql:    LANGUAGE plpgsql
+./sourceTest/sql/postgresql/050/schema-050.sql:    LANGUAGE plpgsql
+./sourceTest/sql/postgresql/050/schema-050.sql:    LANGUAGE plpgsql
+./sourceTest/sql/postgresql/050/schema-050.sql:    LANGUAGE plpgsql
+./sourceTest/sql/postgresql/050/schema-050.sql:    LANGUAGE plpgsql
+./sourceTest/sql/postgresql/051/.svn/text-base/017=database_version_logs.tsv.svn-base:027	D:\\User\\felmer\\dev-workspace\\openbis/source/sql/postgresql/027/function-027.sql	SUCCESS	2008-11-05 09:18:00.403	-- Creating Functions\\012\\012------------------------------------------------------------------------------------\\012--  Purpose:  Create function RENAME_SEQUENCE() that is required for renaming the sequences belonging to tables\\012------------------------------------------------------------------------------------\\012CREATE FUNCTION RENAME_SEQUENCE(OLD_NAME VARCHAR, NEW_NAME VARCHAR) RETURNS INTEGER AS $$\\012DECLARE\\012  CURR_SEQ_VAL   INTEGER;\\012BEGIN\\012  SELECT INTO CURR_SEQ_VAL NEXTVAL(OLD_NAME);\\012  EXECUTE 'CREATE SEQUENCE ' || NEW_NAME || ' START WITH ' || CURR_SEQ_VAL;\\012  EXECUTE 'DROP SEQUENCE ' || OLD_NAME;\\012  RETURN CURR_SEQ_VAL;\\012END;\\012$$ LANGUAGE 'plpgsql';\\012\\012\\012------------------------------------------------------------------------------------\\012--  Purpose:  Create trigger CONTROLLED_VOCABULARY_CHECK \\012------------------------------------------------------------------------------------\\012\\012CREATE OR REPLACE FUNCTION CONTROLLED_VOCABULARY_CHECK() RETURNS trigger AS $$\\012DECLARE\\012   v_code  CODE;\\012BEGIN\\012\\012   select code into v_code from data_types where id = NEW.daty_id;\\012\\012   -- Check if the data is of type "CONTROLLEDVOCABULARY"\\012   if v_code = 'CONTROLLEDVOCABULARY' then\\012      if NEW.covo_id IS NULL then\\012         RAISE EXCEPTION 'Insert/Update of Property Type (Code: %) failed, as its Data Type is CONTROLLEDVOCABULARY, but it is not linked to a Controlled Vocabulary.', NEW.code;\\012      end if;\\012   end if;\\012\\012   RETURN NEW;\\012\\012END;\\012$$ LANGUAGE 'plpgsql';\\012\\012CREATE TRIGGER CONTROLLED_VOCABULARY_CHECK BEFORE INSERT OR UPDATE ON PROPERTY_TYPES\\012    FOR EACH ROW EXECUTE PROCEDURE CONTROLLED_VOCABULARY_CHECK();\\012\\012\\012------------------------------------------------------------------------------------\\012--  Purpose:  Create trigger EXTERNAL_DATA_STORAGE_FORMAT_CHECK \\012------------------------------------------------------------------------------------\\012\\012CREATE OR REPLACE FUNCTION EXTERNAL_DATA_STORAGE_FORMAT_CHECK() RETURNS trigger AS $$\\012DECLARE\\012   v_covo_code  CODE;\\012   data_code CODE;\\012BEGIN\\012\\012   select code into v_covo_code from controlled_vocabularies\\012      where is_internal_namespace = true and \\012         id = (select covo_id from controlled_vocabulary_terms where id = NEW.cvte_id_stor_fmt);\\012   -- Check if the data storage format is a term of the controlled vocabulary "STORAGE_FORMAT"\\012   if v_covo_code != 'STORAGE_FORMAT' then\\012      select code into data_code from data where id = NEW.data_id; \\012      RAISE EXCEPTION 'Insert/Update of Data (Code: %) failed, as its Storage Format is %, but is required to be STORAGE_FORMAT.', data_code, v_covo_code;\\012   end if;\\012\\012   RETURN NEW;\\012\\012END;\\012$$ LANGUAGE 'plpgsql';\\012\\012CREATE TRIGGER EXTERNAL_DATA_STORAGE_FORMAT_CHECK BEFORE INSERT OR UPDATE ON EXTERNAL_DATA\\012    FOR EACH ROW EXECUTE PROCEDURE EXTERNAL_DATA_STORAGE_FORMAT_CHECK();\\012\\012------------------------------------------------------------------------------------\\012--  Purpose:  Create trigger SAMPLE_CODE_UNIQUENESS_CHECK \\012------------------------------------------------------------------------------------\\012\\012CREATE OR REPLACE FUNCTION SAMPLE_CODE_UNIQUENESS_CHECK() RETURNS trigger AS $$\\012DECLARE\\012   counter  INTEGER;\\012BEGIN\\012\\011IF (NEW.samp_id_part_of is NULL) THEN\\012\\011\\011IF (NEW.dbin_id is not NULL) THEN\\012\\011\\011\\011SELECT count(*) into counter FROM samples \\012\\011\\011\\011\\011where id != NEW.id and code = NEW.code and samp_id_part_of is NULL and dbin_id = NEW.dbin_id;\\012\\011\\011\\011IF (counter > 0) THEN\\012\\011\\011\\011\\011RAISE EXCEPTION 'Insert/Update of Sample (Code: %) failed because database instance sample with the same code already exists.', NEW.code;\\012\\011\\011\\011END IF;\\012\\011\\011ELSIF (NEW.grou_id is not NULL) THEN\\012\\011\\011\\011SELECT count(*) into counter FROM samples \\012\\011\\011\\011\\011where id != NEW.id and code = NEW.code and samp_id_part_of is NULL and grou_id = NEW.grou_id;\\012\\011\\011\\011IF (counter > 0) THEN\\012\\011\\011\\011\\011RAISE EXCEPTION 'Insert/Update of Sample (Code: %) failed because group sample with the same code already exists.', NEW.code;\\012\\011\\011\\011END IF;\\012\\011\\011END IF;\\012        ELSE\\012\\011\\011IF (NEW.dbin_id is not NULL) THEN\\012\\011\\011\\011SELECT count(*) into counter FROM samples \\012\\011\\011\\011\\011where id != NEW.id and code = NEW.code and samp_id_part_of = NEW.samp_id_part_of and dbin_id = NEW.dbin_id;\\012\\011\\011\\011IF (counter > 0) THEN\\012\\011\\011\\011\\011RAISE EXCEPTION 'Insert/Update of Sample (Code: %) failed because database instance sample with the same code and being the part of the same parent already exists.', NEW.code;\\012\\011\\011\\011END IF;\\012\\011\\011ELSIF (NEW.grou_id is not NULL) THEN\\012\\011\\011\\011SELECT count(*) into counter FROM samples \\012\\011\\011\\011\\011where id != NEW.id and code = NEW.code and samp_id_part_of = NEW.samp_id_part_of and grou_id = NEW.grou_id;\\012\\011\\011\\011IF (counter > 0) THEN\\012\\011\\011\\011\\011RAISE EXCEPTION 'Insert/Update of Sample (Code: %) failed because group sample with the same code and being the part of the same parent already exists.', NEW.code;\\012\\011\\011\\011END IF;\\012\\011\\011END IF;\\012        END IF;   \\012   RETURN NEW;\\012END;\\012$$ LANGUAGE 'plpgsql';\\012\\012CREATE TRIGGER SAMPLE_CODE_UNIQUENESS_CHECK BEFORE INSERT OR UPDATE ON SAMPLES\\012    FOR EACH ROW EXECUTE PROCEDURE SAMPLE_CODE_UNIQUENESS_CHECK();\\012	\N
+./sourceTest/sql/postgresql/051/.svn/text-base/017=database_version_logs.tsv.svn-base:028	source/sql/postgresql/migration/migration-027-028.sql	SUCCESS	2008-11-18 13:24:17.508	-- Create EXPERIMENT_ATTACHMENT_CONTENTS.\\012CREATE TABLE EXPERIMENT_ATTACHMENT_CONTENTS (ID TECH_ID NOT NULL,VALUE FILE NOT NULL);\\012CREATE SEQUENCE EXPERIMENT_ATTACHMENT_CONTENT_ID_SEQ;\\012ALTER TABLE EXPERIMENT_ATTACHMENT_CONTENTS ADD CONSTRAINT EXAC_PK PRIMARY KEY(ID);\\012\\012-- Alter EXPERIMENT_ATTACHMENTS by adding the new column which has a NULL constraint.\\012-- The NOT NULL constraint is added later on.\\012ALTER TABLE EXPERIMENT_ATTACHMENTS ADD COLUMN EXAC_ID TECH_ID;\\012\\012-- Does the VALUE migration between EXPERIMENT_ATTACHMENTS to EXPERIMENT_ATTACHMENT_CONTENTS.\\012CREATE OR REPLACE FUNCTION move_exp_att_content() RETURNS integer AS $$\\012DECLARE\\012    rec RECORD;\\012    seq BIGINT;\\012BEGIN\\012  FOR rec IN SELECT id, value FROM EXPERIMENT_ATTACHMENTS LOOP\\012  \\011seq := nextval('EXPERIMENT_ATTACHMENT_CONTENT_ID_SEQ');\\012    INSERT INTO EXPERIMENT_ATTACHMENT_CONTENTS (id, value) VALUES (seq, rec.value);\\012    UPDATE EXPERIMENT_ATTACHMENTS SET exac_id = seq WHERE id = rec.id;\\012  END LOOP;\\012  RETURN 1;\\012END;\\012$$ LANGUAGE 'plpgsql';\\012\\012-- Call the function.\\012SELECT move_exp_att_content();\\012DROP FUNCTION move_exp_att_content();\\012\\012\\012-- Finish EXPERIMENT_ATTACHMENTS changes.\\012ALTER TABLE EXPERIMENT_ATTACHMENTS ADD CONSTRAINT EXAT_CONT_FK FOREIGN KEY (EXAC_ID) REFERENCES EXPERIMENT_ATTACHMENT_CONTENTS(ID);\\012ALTER TABLE EXPERIMENT_ATTACHMENTS DROP COLUMN VALUE;\\012ALTER TABLE EXPERIMENT_ATTACHMENTS ALTER COLUMN EXAC_ID SET NOT NULL;\\012	\N
+./sourceTest/sql/postgresql/051/.svn/text-base/017=database_version_logs.tsv.svn-base:029	source/sql/postgresql/migration/migration-028-029.sql	SUCCESS	2009-03-18 10:50:20.105	-- -------\\012-- add modification_timestamp field to allow edition with Hibernate\\012-- -------\\012\\012ALTER TABLE samples\\012\\011ADD COLUMN modification_timestamp TIME_STAMP DEFAULT CURRENT_TIMESTAMP;\\012\\012ALTER TABLE experiments\\012\\011ADD COLUMN modification_timestamp TIME_STAMP DEFAULT CURRENT_TIMESTAMP;\\012\\012ALTER TABLE materials\\012\\011ADD COLUMN modification_timestamp TIME_STAMP DEFAULT CURRENT_TIMESTAMP;\\012\\012ALTER TABLE experiment_properties\\012\\011ADD COLUMN modification_timestamp TIME_STAMP DEFAULT CURRENT_TIMESTAMP;\\012\\012ALTER TABLE material_properties\\012\\011ADD COLUMN modification_timestamp TIME_STAMP DEFAULT CURRENT_TIMESTAMP;\\012\\012ALTER TABLE sample_properties\\012\\011ADD COLUMN modification_timestamp TIME_STAMP DEFAULT CURRENT_TIMESTAMP;\\012\\012-- -------\\012-- add property data type which references materials\\012-- -------\\012\\012ALTER TABLE property_types\\012\\011ADD COLUMN maty_prop_id tech_id;\\012\\012ALTER TABLE property_types\\012\\011ADD CONSTRAINT prty_maty_fk FOREIGN KEY (maty_prop_id) REFERENCES material_types(id);\\012\\012ALTER TABLE experiment_properties\\012\\011ADD COLUMN mate_prop_id tech_id;\\012\\012ALTER TABLE material_properties\\012\\011ADD COLUMN mate_prop_id tech_id;\\012\\012ALTER TABLE sample_properties\\012\\011ADD COLUMN mate_prop_id tech_id;\\012\\012ALTER TABLE experiment_properties\\012\\011ADD CONSTRAINT expr_mapr_fk FOREIGN KEY (mate_prop_id) REFERENCES materials(id);\\012\\012ALTER TABLE material_properties\\012\\011ADD CONSTRAINT mapr_mapr_fk FOREIGN KEY (mate_prop_id) REFERENCES materials(id);\\012\\012ALTER TABLE sample_properties\\012\\011ADD CONSTRAINT sapr_mapr_fk FOREIGN KEY (mate_prop_id) REFERENCES materials(id);\\012\\012insert into data_types\\012(id\\012 ,code\\012 ,description)\\012 values \\012 (nextval('DATA_TYPE_ID_SEQ')\\012 ,'MATERIAL'\\012 ,'Reference to a material'\\012);\\012\\012ALTER TABLE MATERIAL_PROPERTIES DROP CONSTRAINT MAPR_CK;\\012ALTER TABLE MATERIAL_PROPERTIES ADD CONSTRAINT MAPR_CK CHECK \\012\\011((VALUE IS NOT NULL AND CVTE_ID IS NULL AND MATE_PROP_ID IS NULL) OR \\012\\011 (VALUE IS NULL AND CVTE_ID IS NOT NULL AND MATE_PROP_ID IS NULL) OR\\012\\011 (VALUE IS NULL AND CVTE_ID IS NULL AND MATE_PROP_ID IS NOT NULL)\\012\\011);\\012\\012ALTER TABLE EXPERIMENT_PROPERTIES DROP CONSTRAINT EXPR_CK;\\012ALTER TABLE EXPERIMENT_PROPERTIES ADD CONSTRAINT EXPR_CK CHECK \\012\\011((VALUE IS NOT NULL AND CVTE_ID IS NULL AND MATE_PROP_ID IS NULL) OR \\012\\011 (VALUE IS NULL AND CVTE_ID IS NOT NULL AND MATE_PROP_ID IS NULL) OR\\012\\011 (VALUE IS NULL AND CVTE_ID IS NULL AND MATE_PROP_ID IS NOT NULL)\\012\\011);\\012\\012ALTER TABLE SAMPLE_PROPERTIES DROP CONSTRAINT SAPR_CK;\\012ALTER TABLE SAMPLE_PROPERTIES ADD CONSTRAINT SAPR_CK CHECK \\012\\011((VALUE IS NOT NULL AND CVTE_ID IS NULL AND MATE_PROP_ID IS NULL) OR \\012\\011 (VALUE IS NULL AND CVTE_ID IS NOT NULL AND MATE_PROP_ID IS NULL) OR\\012\\011 (VALUE IS NULL AND CVTE_ID IS NULL AND MATE_PROP_ID IS NOT NULL)\\012\\011);\\012\\012------------------------------------------------------------------------------------\\012--  Purpose:  Create trigger MATERIAL/SAMPLE/EXPERIMENT _PROPERTY_WITH_MATERIAL_DATA_TYPE_CHECK\\012--            It checks that if material property value is assigned to the entity,\\012--\\011\\011\\011\\011\\011\\011then the material type is equal to the one described by property type.\\012------------------------------------------------------------------------------------\\012\\012CREATE OR REPLACE FUNCTION MATERIAL_PROPERTY_WITH_MATERIAL_DATA_TYPE_CHECK() RETURNS trigger AS $$\\012DECLARE\\012   v_type_id  CODE;\\012   v_type_id_prop  CODE;\\012BEGIN\\012   if NEW.mate_prop_id IS NOT NULL then\\012\\011\\011\\011-- find material type id of the property type \\012\\011\\011\\011select pt.maty_prop_id into v_type_id_prop \\012\\011\\011\\011  from material_type_property_types etpt, property_types pt \\012\\011\\011\\011 where NEW.mtpt_id = etpt.id AND etpt.prty_id = pt.id;\\012\\011\\011\\012\\011\\011\\011if v_type_id_prop IS NOT NULL then\\012\\011\\011\\011\\011-- find material type id of the material which consists the entity's property value\\012\\011\\011\\011\\011select entity.maty_id into v_type_id \\012\\011\\011\\011\\011  from materials entity\\012\\011\\011\\011\\011 where NEW.mate_prop_id = entity.id;\\012\\011\\011\\011\\011if v_type_id != v_type_id_prop then\\012\\011\\011\\011\\011\\011RAISE EXCEPTION 'Insert/Update of property value referencing material (id: %) failed, as referenced material type is different than expected (id %, expected id: %).', \\012\\011\\011\\011\\011\\011\\011\\011 NEW.mate_prop_id, v_type_id, v_type_id_prop;\\012\\011\\011\\011\\011end if;\\012\\011\\011\\011end if;\\012   end if;\\012   RETURN NEW;\\012END;\\012$$ LANGUAGE 'plpgsql';\\012\\012CREATE TRIGGER MATERIAL_PROPERTY_WITH_MATERIAL_DATA_TYPE_CHECK BEFORE INSERT OR UPDATE ON material_properties\\012    FOR EACH ROW EXECUTE PROCEDURE MATERIAL_PROPERTY_WITH_MATERIAL_DATA_TYPE_CHECK();\\012    \\012CREATE OR REPLACE FUNCTION SAMPLE_PROPERTY_WITH_MATERIAL_DATA_TYPE_CHECK() RETURNS trigger AS $$\\012DECLARE\\012   v_type_id  CODE;\\012   v_type_id_prop  CODE;\\012BEGIN\\012   if NEW.mate_prop_id IS NOT NULL then\\012\\011\\011\\011-- find material type id of the property type \\012\\011\\011\\011select pt.maty_prop_id into v_type_id_prop \\012\\011\\011\\011  from sample_type_property_types etpt, property_types pt \\012\\011\\011\\011 where NEW.stpt_id = etpt.id AND etpt.prty_id = pt.id;\\012\\011\\011\\012\\011\\011\\011if v_type_id_prop IS NOT NULL then\\012\\011\\011\\011\\011-- find material type id of the material which consists the entity's property value\\012\\011\\011\\011\\011select entity.maty_id into v_type_id \\012\\011\\011\\011\\011  from materials entity\\012\\011\\011\\011\\011 where NEW.mate_prop_id = entity.id;\\012\\011\\011\\011\\011if v_type_id != v_type_id_prop then\\012\\011\\011\\011\\011\\011RAISE EXCEPTION 'Insert/Update of property value referencing material (id: %) failed, as referenced material type is different than expected (id %, expected id: %).', \\012\\011\\011\\011\\011\\011\\011\\011\\011\\011\\011\\011\\011 NEW.mate_prop_id, v_type_id, v_type_id_prop;\\012\\011\\011\\011\\011end if;\\012\\011\\011\\011end if;\\012   end if;\\012   RETURN NEW;\\012END;\\012$$ LANGUAGE 'plpgsql';\\012\\012CREATE TRIGGER SAMPLE_PROPERTY_WITH_MATERIAL_DATA_TYPE_CHECK BEFORE INSERT OR UPDATE ON sample_properties\\012    FOR EACH ROW EXECUTE PROCEDURE SAMPLE_PROPERTY_WITH_MATERIAL_DATA_TYPE_CHECK();\\012    \\012CREATE OR REPLACE FUNCTION EXPERIMENT_PROPERTY_WITH_MATERIAL_DATA_TYPE_CHECK() RETURNS trigger AS $$\\012DECLARE\\012   v_type_id  CODE;\\012   v_type_id_prop  CODE;\\012BEGIN\\012   if NEW.mate_prop_id IS NOT NULL then\\012\\011\\011\\011-- find material type id of the property type \\012\\011\\011\\011select pt.maty_prop_id into v_type_id_prop \\012\\011\\011\\011  from experiment_type_property_types etpt, property_types pt \\012\\011\\011\\011 where NEW.etpt_id = etpt.id AND etpt.prty_id = pt.id;\\012\\011\\011\\012\\011\\011\\011if v_type_id_prop IS NOT NULL then\\012\\011\\011\\011\\011-- find material type id of the material which consists the entity's property value\\012\\011\\011\\011\\011select entity.maty_id into v_type_id \\012\\011\\011\\011\\011  from materials entity\\012\\011\\011\\011\\011 where NEW.mate_prop_id = entity.id;\\012\\011\\011\\011\\011if v_type_id != v_type_id_prop then\\012\\011\\011\\011\\011\\011RAISE EXCEPTION 'Insert/Update of property value referencing material (id: %) failed, as referenced material type is different than expected (id %, expected id: %).', \\012\\011\\011\\011\\011\\011\\011\\011\\011\\011\\011\\011\\011 NEW.mate_prop_id, v_type_id, v_type_id_prop;\\012\\011\\011\\011\\011end if;\\012\\011\\011\\011end if;\\012   end if;\\012   RETURN NEW;\\012END;\\012$$ LANGUAGE 'plpgsql';\\012\\012CREATE TRIGGER EXPERIMENT_PROPERTY_WITH_MATERIAL_DATA_TYPE_CHECK BEFORE INSERT OR UPDATE ON experiment_properties\\012    FOR EACH ROW EXECUTE PROCEDURE EXPERIMENT_PROPERTY_WITH_MATERIAL_DATA_TYPE_CHECK();\\012       \\012-- -------\\012-- remove the reminescents of the OBSERVABLE_TYPE\\012-- -------\\012\\012ALTER TABLE data\\012\\011DROP CONSTRAINT data_obty_fk;\\012\\012ALTER TABLE data_set_types\\012\\011DROP CONSTRAINT obty_pk;\\012\\012ALTER TABLE data_set_types\\012\\011ADD CONSTRAINT dsty_pk PRIMARY KEY (id);\\012\\012ALTER TABLE data\\012\\011ADD CONSTRAINT data_dsty_fk FOREIGN KEY (dsty_id) REFERENCES data_set_types(id);\\012\\012ALTER TABLE data_set_types\\012\\011DROP CONSTRAINT obty_bk_uk;\\012\\012ALTER TABLE data_set_types\\012\\011DROP CONSTRAINT obty_dbin_fk;\\012\\012ALTER TABLE data_set_types\\012\\011ADD CONSTRAINT dsty_bk_uk UNIQUE (code, dbin_id);\\012\\012ALTER TABLE data_set_types\\012\\011ADD CONSTRAINT dsty_dbin_fk FOREIGN KEY (dbin_id) REFERENCES database_instances(id);\\012\\012DROP INDEX data_obty_fk_i;\\012\\012CREATE INDEX data_dsty_fk_i ON data(dsty_id);\\012	\N
+./sourceTest/sql/postgresql/051/.svn/text-base/017=database_version_logs.tsv.svn-base:030	source/sql/postgresql/migration/migration-029-030.sql	SUCCESS	2009-03-23 15:34:44.72	-- -------\\012-- add modification_timestamp field to allow edition with Hibernate\\012-- -------\\012ALTER TABLE data\\012\\011ADD COLUMN modification_timestamp TIME_STAMP DEFAULT CURRENT_TIMESTAMP;\\012ALTER TABLE experiment_types\\012\\011ADD COLUMN modification_timestamp TIME_STAMP DEFAULT CURRENT_TIMESTAMP;\\012ALTER TABLE sample_types\\012\\011ADD COLUMN modification_timestamp TIME_STAMP DEFAULT CURRENT_TIMESTAMP;\\012ALTER TABLE material_types\\012\\011ADD COLUMN modification_timestamp TIME_STAMP DEFAULT CURRENT_TIMESTAMP;\\012ALTER TABLE data_set_types\\012\\011ADD COLUMN modification_timestamp TIME_STAMP DEFAULT CURRENT_TIMESTAMP;\\012ALTER TABLE controlled_vocabularies\\012\\011ADD COLUMN modification_timestamp TIME_STAMP DEFAULT CURRENT_TIMESTAMP;\\012-- -------\\012-- add properties to data sets\\012-- -------\\012CREATE TABLE DATA_SET_PROPERTIES (ID TECH_ID NOT NULL,DS_ID TECH_ID NOT NULL,DSTPT_ID TECH_ID NOT NULL,VALUE GENERIC_VALUE,CVTE_ID TECH_ID, MATE_PROP_ID TECH_ID, PERS_ID_REGISTERER TECH_ID NOT NULL,REGISTRATION_TIMESTAMP TIME_STAMP_DFL NOT NULL DEFAULT CURRENT_TIMESTAMP, MODIFICATION_TIMESTAMP TIME_STAMP DEFAULT CURRENT_TIMESTAMP);\\012CREATE TABLE DATA_SET_TYPE_PROPERTY_TYPES (ID TECH_ID NOT NULL,DSTY_ID TECH_ID NOT NULL,PRTY_ID TECH_ID NOT NULL,IS_MANDATORY BOOLEAN_CHAR NOT NULL DEFAULT 'F',IS_MANAGED_INTERNALLY BOOLEAN_CHAR NOT NULL DEFAULT 'F',PERS_ID_REGISTERER TECH_ID NOT NULL,REGISTRATION_TIMESTAMP TIME_STAMP_DFL NOT NULL DEFAULT CURRENT_TIMESTAMP);\\012\\012CREATE SEQUENCE DATA_SET_PROPERTY_ID_SEQ;\\012CREATE SEQUENCE DSTPT_ID_SEQ;\\012\\012ALTER TABLE DATA_SET_TYPE_PROPERTY_TYPES ADD CONSTRAINT DSTPT_PK PRIMARY KEY(ID);\\012ALTER TABLE DATA_SET_PROPERTIES ADD CONSTRAINT DSPR_PK PRIMARY KEY(ID);\\012\\012ALTER TABLE DATA_SET_TYPE_PROPERTY_TYPES ADD CONSTRAINT DSTPT_BK_UK UNIQUE(DSTY_ID,PRTY_ID);\\012ALTER TABLE DATA_SET_PROPERTIES ADD CONSTRAINT DSPR_BK_UK UNIQUE(DS_ID,DSTPT_ID);\\012\\012\\012ALTER TABLE DATA_SET_TYPE_PROPERTY_TYPES ADD CONSTRAINT DSTPT_DSTY_FK FOREIGN KEY (DSTY_ID) REFERENCES DATA_SET_TYPES(ID);\\012ALTER TABLE DATA_SET_TYPE_PROPERTY_TYPES ADD CONSTRAINT DSTPT_PERS_FK FOREIGN KEY (PERS_ID_REGISTERER) REFERENCES PERSONS(ID);\\012ALTER TABLE DATA_SET_TYPE_PROPERTY_TYPES ADD CONSTRAINT DSTPT_PRTY_FK FOREIGN KEY (PRTY_ID) REFERENCES PROPERTY_TYPES(ID);\\012ALTER TABLE DATA_SET_PROPERTIES ADD CONSTRAINT DSPR_CVTE_FK FOREIGN KEY (CVTE_ID) REFERENCES CONTROLLED_VOCABULARY_TERMS(ID);\\012ALTER TABLE DATA_SET_PROPERTIES ADD CONSTRAINT DSPR_DSTPT_FK FOREIGN KEY (DSTPT_ID) REFERENCES DATA_SET_TYPE_PROPERTY_TYPES(ID) ON DELETE CASCADE;\\012ALTER TABLE DATA_SET_PROPERTIES ADD CONSTRAINT DSPR_DS_FK FOREIGN KEY (DS_ID) REFERENCES DATA(ID);\\012ALTER TABLE DATA_SET_PROPERTIES ADD CONSTRAINT DSPR_PERS_FK FOREIGN KEY (PERS_ID_REGISTERER) REFERENCES PERSONS(ID);\\012ALTER TABLE DATA_SET_PROPERTIES ADD CONSTRAINT DSPR_MAPR_FK FOREIGN KEY (MATE_PROP_ID) REFERENCES MATERIALS(ID);\\012\\012ALTER TABLE DATA_SET_PROPERTIES ADD CONSTRAINT DSPR_CK CHECK \\012\\011((VALUE IS NOT NULL AND CVTE_ID IS NULL AND MATE_PROP_ID IS NULL) OR \\012\\011 (VALUE IS NULL AND CVTE_ID IS NOT NULL AND MATE_PROP_ID IS NULL) OR\\012\\011 (VALUE IS NULL AND CVTE_ID IS NULL AND MATE_PROP_ID IS NOT NULL)\\012\\011);\\012\\012CREATE INDEX DSPR_CVTE_FK_I ON DATA_SET_PROPERTIES (CVTE_ID);\\012CREATE INDEX DSPR_DSTPT_FK_I ON DATA_SET_PROPERTIES (DSTPT_ID);\\012CREATE INDEX DSPR_DS_FK_I ON DATA_SET_PROPERTIES (DS_ID);\\012CREATE INDEX DSPR_PERS_FK_I ON DATA_SET_PROPERTIES (PERS_ID_REGISTERER);\\012CREATE INDEX DSTPT_DSTY_FK_I ON DATA_SET_TYPE_PROPERTY_TYPES (DSTY_ID);\\012CREATE INDEX DSTPT_PERS_FK_I ON DATA_SET_TYPE_PROPERTY_TYPES (PERS_ID_REGISTERER);\\012CREATE INDEX DSTPT_PRTY_FK_I ON DATA_SET_TYPE_PROPERTY_TYPES (PRTY_ID);\\012\\012CREATE OR REPLACE FUNCTION DATA_SET_PROPERTY_WITH_MATERIAL_DATA_TYPE_CHECK() RETURNS trigger AS $$\\012DECLARE\\012   v_type_id  CODE;\\012   v_type_id_prop  CODE;\\012BEGIN\\012   if NEW.mate_prop_id IS NOT NULL then\\012\\011\\011\\011-- find material type id of the property type \\012\\011\\011\\011select pt.maty_prop_id into v_type_id_prop \\012\\011\\011\\011  from data_set_type_property_types dstpt, property_types pt \\012\\011\\011\\011 where NEW.dstpt_id = dstpt.id AND dstpt.prty_id = pt.id;\\012\\011\\011\\012\\011\\011\\011if v_type_id_prop IS NOT NULL then\\012\\011\\011\\011\\011-- find material type id of the material which consists the entity's property value\\012\\011\\011\\011\\011select entity.maty_id into v_type_id \\012\\011\\011\\011\\011  from materials entity\\012\\011\\011\\011\\011 where NEW.mate_prop_id = entity.id;\\012\\011\\011\\011\\011if v_type_id != v_type_id_prop then\\012\\011\\011\\011\\011\\011RAISE EXCEPTION 'Insert/Update of property value referencing material (id: %) failed, as referenced material type is different than expected (id %, expected id: %).', \\012\\011\\011\\011\\011\\011\\011\\011\\011\\011\\011\\011\\011 NEW.mate_prop_id, v_type_id, v_type_id_prop;\\012\\011\\011\\011\\011end if;\\012\\011\\011\\011end if;\\012   end if;\\012   RETURN NEW;\\012END;\\012$$ LANGUAGE 'plpgsql';\\012\\012CREATE TRIGGER DATA_SET_PROPERTY_WITH_MATERIAL_DATA_TYPE_CHECK BEFORE INSERT OR UPDATE ON data_set_properties\\012    FOR EACH ROW EXECUTE PROCEDURE DATA_SET_PROPERTY_WITH_MATERIAL_DATA_TYPE_CHECK();   \\012	\N
+./sourceTest/sql/postgresql/051/.svn/text-base/017=database_version_logs.tsv.svn-base:032	source/sql/postgresql/migration/migration-031-032.sql	SUCCESS	2009-04-09 09:36:36.2	-- -------\\012-- Modify MATERIAL_BATCHES\\012-- -------\\012\\012ALTER TABLE material_batches\\012    DROP COLUMN proc_id;\\012\\012-- -------\\012-- Modify SAMPLES\\012-- -------\\012\\012ALTER TABLE samples\\012    ADD COLUMN expe_id tech_id;\\012\\012ALTER TABLE samples\\012    ADD CONSTRAINT samp_expe_fk FOREIGN KEY (expe_id) REFERENCES experiments(id);\\012\\012CREATE INDEX samp_expe_fk_i ON samples USING btree (expe_id);\\012\\012-- relink samples directly to experiments\\012\\012UPDATE samples\\012SET expe_id = (SELECT e.id FROM experiments e, procedures p, sample_inputs si \\012               WHERE si.samp_id = samples.id AND si.proc_id = p.id AND p.expe_id = e.id AND e.inva_id IS NULL);\\012\\012\\012-- -------\\012-- Modify DATA\\012-- -------\\012\\012ALTER TABLE data\\012    ADD COLUMN expe_id tech_id;\\012\\012ALTER TABLE data\\012    ADD CONSTRAINT data_expe_fk FOREIGN KEY (expe_id) REFERENCES experiments(id);\\012\\012CREATE INDEX data_expe_fk_i ON data USING btree (expe_id);\\012\\012UPDATE data\\012SET expe_id = (SELECT e.id FROM experiments e, procedures p \\012               WHERE data.proc_id_produced_by = p.id AND p.expe_id = e.id);\\012\\012ALTER TABLE data\\012    ALTER COLUMN expe_id SET NOT NULL;\\012\\012ALTER TABLE data\\012    DROP COLUMN proc_id_produced_by;\\012\\012-- -------\\012-- Drop PROCEDURES, PROCEDURE_TYPES, and SAMPLE_INPUTS\\012-- -------\\012\\012DROP TABLE sample_inputs;\\012DROP TABLE procedures;\\012DROP TABLE procedure_types;\\012\\012DROP SEQUENCE procedure_id_seq;\\012DROP SEQUENCE procedure_type_id_seq;\\012\\012-- -------\\012-- Add CODE_SEQ\\012-- -------\\012\\012CREATE SEQUENCE CODE_SEQ;\\012\\012-- -------\\012-- Add new columns to DATA_STORES\\012-- -------\\012\\012ALTER TABLE data_stores\\012    ADD COLUMN remote_url character varying(250),\\012    ADD COLUMN session_token character varying(50),\\012    ADD COLUMN modification_timestamp time_stamp DEFAULT now();\\012\\012UPDATE data_stores\\012SET remote_url = '', session_token='';\\012\\012ALTER TABLE data_stores\\012    ALTER COLUMN remote_url SET NOT NULL,\\012    ALTER COLUMN session_token SET NOT NULL;\\012\\012-- -------\\012-- Drop foreign keys onto DATA_STORES\\012-- -------\\012\\012ALTER TABLE database_instances\\012    DROP COLUMN dast_id;\\012\\012ALTER TABLE groups\\012    DROP COLUMN dast_id;\\012\\012ALTER TABLE projects\\012    DROP COLUMN dast_id;\\012\\012ALTER TABLE experiments\\012    DROP COLUMN dast_id;\\012\\012-- -------\\012-- Add foreign key from DATA onto DATA_STORES\\012-- -------\\012\\012ALTER TABLE data\\012    ADD COLUMN dast_id tech_id;\\012\\012ALTER TABLE data\\012    ADD CONSTRAINT data_dast_fk FOREIGN KEY (dast_id) REFERENCES data_stores(id);\\012\\012UPDATE data\\012SET dast_id = (select id from data_stores where code = 'STANDARD');\\012\\012ALTER TABLE data\\012    ALTER COLUMN dast_id SET NOT NULL;\\012\\012\\012------------------------------------------------------------------------------------\\012--  Purpose:  Replace trigger SAMPLE_CODE_UNIQUENESS_CHECK \\012------------------------------------------------------------------------------------\\012\\012CREATE OR REPLACE FUNCTION SAMPLE_CODE_UNIQUENESS_CHECK() RETURNS trigger AS $$\\012DECLARE\\012   counter  INTEGER;\\012BEGIN\\012    LOCK TABLE samples IN EXCLUSIVE MODE;\\012    IF (NEW.samp_id_part_of is NULL) THEN\\012        IF (NEW.dbin_id is not NULL) THEN\\012            SELECT count(*) into counter FROM samples \\012                where id != NEW.id and code = NEW.code and samp_id_part_of is NULL and dbin_id = NEW.dbin_id;\\012            IF (counter > 0) THEN\\012                RAISE EXCEPTION 'Insert/Update of Sample (Code: %) failed because database instance sample with the same code already exists.', NEW.code;\\012            END IF;\\012        ELSIF (NEW.grou_id is not NULL) THEN\\012            SELECT count(*) into counter FROM samples \\012                where id != NEW.id and code = NEW.code and samp_id_part_of is NULL and grou_id = NEW.grou_id;\\012            IF (counter > 0) THEN\\012                RAISE EXCEPTION 'Insert/Update of Sample (Code: %) failed because group sample with the same code already exists.', NEW.code;\\012            END IF;\\012        END IF;\\012        ELSE\\012        IF (NEW.dbin_id is not NULL) THEN\\012            SELECT count(*) into counter FROM samples \\012                where id != NEW.id and code = NEW.code and samp_id_part_of = NEW.samp_id_part_of and dbin_id = NEW.dbin_id;\\012            IF (counter > 0) THEN\\012                RAISE EXCEPTION 'Insert/Update of Sample (Code: %) failed because database instance sample with the same code and being the part of the same parent already exists.', NEW.code;\\012            END IF;\\012        ELSIF (NEW.grou_id is not NULL) THEN\\012            SELECT count(*) into counter FROM samples \\012                where id != NEW.id and code = NEW.code and samp_id_part_of = NEW.samp_id_part_of and grou_id = NEW.grou_id;\\012            IF (counter > 0) THEN\\012                RAISE EXCEPTION 'Insert/Update of Sample (Code: %) failed because group sample with the same code and being the part of the same parent already exists.', NEW.code;\\012            END IF;\\012        END IF;\\012        END IF;   \\012   RETURN NEW;\\012END;\\012$$ LANGUAGE 'plpgsql';\\012\\012\\012\\012	\N
+./sourceTest/sql/postgresql/051/.svn/text-base/017=database_version_logs.tsv.svn-base:034	source/sql/postgresql/migration/migration-033-034.sql	SUCCESS	2009-05-26 08:32:49.935	------------------------------------------------------------------------------------\\012-- Create sequence for generating permanent identifiers starting with nextval of existing dataset sequence.\\012------------------------------------------------------------------------------------\\012CREATE FUNCTION CREATE_SEQUENCE(EXISTING_SEQUENCE VARCHAR, NEW_SEQUENCE VARCHAR) RETURNS VOID AS $$\\012DECLARE\\012  CURR_SEQ_VAL   INTEGER;\\012BEGIN\\012  SELECT INTO CURR_SEQ_VAL NEXTVAL(EXISTING_SEQUENCE);\\012  EXECUTE 'CREATE SEQUENCE ' || NEW_SEQUENCE || ' START WITH ' || CURR_SEQ_VAL;\\012  RETURN;\\012END;\\012$$ LANGUAGE 'plpgsql';\\012\\012SELECT CREATE_SEQUENCE('DATA_ID_SEQ', 'PERM_ID_SEQ');\\012DROP FUNCTION CREATE_SEQUENCE(VARCHAR, VARCHAR);\\012\\012------------------------------------------------------------------------------------\\012-- Add perm_id columns to samples and experiments.\\012------------------------------------------------------------------------------------\\012ALTER TABLE SAMPLES ADD COLUMN PERM_ID CODE;\\012ALTER TABLE EXPERIMENTS ADD COLUMN PERM_ID CODE;\\012\\012UPDATE SAMPLES SET PERM_ID = to_char(registration_timestamp,'YYYYMMDDHHSSMS') || '-' || NEXTVAL('PERM_ID_SEQ');\\012UPDATE EXPERIMENTS SET PERM_ID = to_char(registration_timestamp,'YYYYMMDDHHSSMS') || '-' || NEXTVAL('PERM_ID_SEQ');\\012ALTER TABLE SAMPLES ALTER COLUMN PERM_ID SET NOT NULL;\\012ALTER TABLE EXPERIMENTS ALTER COLUMN PERM_ID SET NOT NULL;\\012ALTER TABLE SAMPLES ADD CONSTRAINT SAMP_PI_UK UNIQUE(PERM_ID);\\012ALTER TABLE EXPERIMENTS ADD CONSTRAINT EXPE_PI_UK UNIQUE(PERM_ID);\\012\\012\\012------------------------------------------------------------------------------------\\012-- Add column is_chosen_from_list to controlled_vocabularies.\\012------------------------------------------------------------------------------------\\012ALTER TABLE controlled_vocabularies ADD COLUMN is_chosen_from_list BOOLEAN_CHAR NOT NULL DEFAULT TRUE;\\012ALTER TABLE controlled_vocabularies ADD COLUMN source_uri CHARACTER VARYING(250);\\012------------------------------------------------------------------------------------\\012-- Modify Data table - remove arc connection between Sample and Data table, use a flag instead\\012------------------------------------------------------------------------------------\\012\\012-- add new columns\\012\\012ALTER TABLE data\\012    ADD COLUMN is_derived boolean_char;\\012ALTER TABLE data\\012    ADD COLUMN samp_id tech_id;\\012\\012-- update values in new columns\\012\\012UPDATE data\\012    SET is_derived = (samp_id_derived_from IS NOT NULL); \\012UPDATE data\\012    SET samp_id = samp_id_derived_from \\012    WHERE is_derived = 'TRUE';\\012UPDATE data\\012    SET samp_id = samp_id_acquired_from \\012    WHERE is_derived = 'FALSE';\\012\\012-- add constraints and indexes to new columns\\012\\012ALTER TABLE data\\012    ALTER COLUMN is_derived SET NOT NULL;\\012ALTER TABLE data\\012    ALTER COLUMN samp_id SET NOT NULL;   \\012ALTER TABLE data\\012    ADD CONSTRAINT data_samp_fk FOREIGN KEY (samp_id) REFERENCES samples (id);\\012CREATE INDEX data_samp_fk_i ON data USING btree (samp_id);\\012\\012-- remove old columns\\012\\012ALTER TABLE data\\012    DROP COLUMN samp_id_acquired_from;\\012ALTER TABLE data\\012    DROP COLUMN samp_id_derived_from;\\012    \\012------------------------------------------------------------------------------------\\012-- Granting SELECT privilege to group openbis_readonly\\012------------------------------------------------------------------------------------\\012\\012GRANT SELECT ON SEQUENCE attachment_content_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE attachment_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE code_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE controlled_vocabulary_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE cvte_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE data_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE data_set_property_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE data_set_relationship_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE data_set_type_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE data_store_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE data_type_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE database_instance_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE dstpt_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE etpt_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE event_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE experiment_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE experiment_property_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE experiment_type_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE file_format_type_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE group_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE invalidation_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE locator_type_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE material_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE material_property_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE material_type_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE mtpt_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE perm_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE person_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE project_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE property_type_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE role_assignment_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE sample_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE sample_property_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE sample_type_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE stpt_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE attachment_contents TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE attachments TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE controlled_vocabularies TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE controlled_vocabulary_terms TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE data TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE data_set_properties TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE data_set_relationships TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE data_set_type_property_types TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE data_set_types TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE data_stores TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE data_types TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE database_instances TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE database_version_logs TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE events TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE experiment_properties TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE experiment_type_property_types TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE experiment_types TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE experiments TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE external_data TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE file_format_types TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE groups TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE invalidations TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE locator_types TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE material_properties TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE material_type_property_types TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE material_types TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE materials TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE persons TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE projects TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE property_types TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE role_assignments TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE sample_properties TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE sample_type_property_types TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE sample_types TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE samples TO GROUP OPENBIS_READONLY;\\012\\012------------------------------------------------------------------------------------\\012-- Delete MATERIAL_BATCHES table\\012------------------------------------------------------------------------------------\\012\\012-- WARNING: Potential data lost!!!\\012-- WARNING: Potential data lost!!!\\012-- WARNING: Potential data lost!!!\\012\\012DROP TABLE SAMPLE_MATERIAL_BATCHES;\\012DROP TABLE MATERIAL_BATCHES;\\012DROP SEQUENCE MATERIAL_BATCH_ID_SEQ;\\012\\012------------------------------------------------------------------------------------\\012-- Delete MATE_ID_INHIBITOR_OF from table MATERIALS\\012------------------------------------------------------------------------------------\\012\\012-- WARNING: Potential data lost!!!\\012-- WARNING: Potential data lost!!!\\012-- WARNING: Potential data lost!!!\\012\\012ALTER TABLE MATERIALS DROP COLUMN MATE_ID_INHIBITOR_OF;\\012	\N
+./sourceTest/sql/postgresql/051/.svn/text-base/017=database_version_logs.tsv.svn-base:041	source/sql/postgresql/migration/migration-040-041.sql	SUCCESS	2009-09-14 13:48:57.539	-- Create FILTERS table\\012\\012CREATE TABLE FILTERS (ID TECH_ID NOT NULL, DBIN_ID TECH_ID NOT NULL, NAME VARCHAR(200) NOT NULL, DESCRIPTION DESCRIPTION_1000,REGISTRATION_TIMESTAMP TIME_STAMP_DFL NOT NULL DEFAULT CURRENT_TIMESTAMP, PERS_ID_REGISTERER TECH_ID NOT NULL, MODIFICATION_TIMESTAMP TIME_STAMP DEFAULT CURRENT_TIMESTAMP, EXPRESSION VARCHAR(2000) NOT NULL, IS_PUBLIC BOOLEAN NOT NULL, GRID_ID VARCHAR(200) NOT NULL);\\012CREATE SEQUENCE FILTER_ID_SEQ;\\012ALTER TABLE FILTERS ADD CONSTRAINT FILT_PK PRIMARY KEY(ID);\\012ALTER TABLE FILTERS ADD CONSTRAINT FILT_BK_UK UNIQUE(NAME, DBIN_ID, GRID_ID);\\012ALTER TABLE FILTERS ADD CONSTRAINT FILT_PERS_FK FOREIGN KEY (PERS_ID_REGISTERER) REFERENCES PERSONS(ID);\\012ALTER TABLE FILTERS ADD CONSTRAINT FILT_DBIN_FK FOREIGN KEY (DBIN_ID) REFERENCES DATABASE_INSTANCES(ID);\\012CREATE INDEX FILT_PERS_FK_I ON FILTERS (PERS_ID_REGISTERER);\\012CREATE INDEX FILT_DBIN_FK_I ON FILTERS (DBIN_ID);\\012GRANT SELECT ON SEQUENCE filter_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE filters TO GROUP OPENBIS_READONLY;\\012\\012-- Add missing foreign key to role assignments authorization group\\012ALTER TABLE ROLE_ASSIGNMENTS ADD CONSTRAINT ROAS_AG_FK_GRANTEE FOREIGN KEY (AG_ID_GRANTEE) REFERENCES AUTHORIZATION_GROUPS(ID);\\012\\012--------------------------------------------------------------------------------------------------\\012-- Modify dataset connections:\\012-- 1. connection with sample shouldn't be mandatory any more\\012-- 2. introduce an arc condition that dataset cannot be connected with a sample and a parent dataset at the same time\\012--------------------------------------------------------------------------------------------------\\012\\012-- Weaken data-sample connection constraint - allow dataset to have no connection with sample\\012ALTER TABLE data ALTER COLUMN samp_id DROP NOT NULL;\\012\\012-- Remove data-sample connection for datasets that have a parent\\012\\012UPDATE data \\012   SET samp_id = NULL \\012 WHERE id IN (SELECT DISTINCT data_id_child FROM data_set_relationships);\\012\\012-- With PostgreSQL 8.4 one can check that before migration there were no cycles in dataset relationships:\\012--\\012-- WITH RECURSIVE data_set_parents(id, parent_ids, cycle) AS (\\012--         SELECT  r.data_id_child AS id, \\012--                 ARRAY[CAST (r.data_id_parent AS bigint)] AS parent_ids, \\012--                 false AS cycle \\012--         FROM data_set_relationships r\\012--     UNION ALL\\012--         SELECT  r.data_id_child,\\012--                 CAST (r.data_id_parent AS bigint) || p.parent_ids,\\012--                 r.data_id_child = ANY(p.parent_ids)\\012--         FROM data_set_relationships r, data_set_parents p\\012--         WHERE r.data_id_parent = p.id AND NOT cycle\\012-- )\\012-- SELECT count(*) AS cycles FROM data_set_parents WHERE cycle = true;\\012\\012---------------------------------------------------------------------------------------------------\\012--  Purpose:  Create DEFERRED triggers:\\012--            * check_dataset_relationships_on_data_table_modification,\\012--            * check_dataset_relationships_on_relationships_table_modification.\\012--            They check that after all modifications of database (just before commit) \\012--            if 'data'/'data_set_relationships' tables are among modified tables \\012--            dataset is not connected with a sample and a parent dataset at the same time.\\012--            This connections are held in two different tables so simple immediate trigger \\012--            with arc check cannot be used and we need two deferred triggers.\\012----------------------------------------------------------------------------------------------------\\012\\012-- trigger for 'data' table\\012\\012CREATE OR REPLACE FUNCTION check_dataset_relationships_on_data_table_modification() RETURNS trigger AS $$\\012DECLARE\\012\\011counter\\011INTEGER;\\012BEGIN\\012\\011-- if there is a connection with a Sample there should not be any connection with a parent Data Set\\012\\011IF (NEW.samp_id IS NOT NULL) THEN\\012\\011\\011-- count number of parents\\012\\011\\011SELECT count(*) INTO counter \\012\\011\\011\\011FROM data_set_relationships \\012\\011\\011\\011WHERE data_id_child = OLD.id;\\012\\011\\011IF (counter > 0) THEN\\012\\011\\011\\011RAISE EXCEPTION 'Insert/Update of Data Set (Code: %) failed because it cannot be connected with a Sample and a parent Data Set at the same time.', OLD.code;\\012\\011\\011END IF;\\012\\011END IF;\\012  RETURN NEW;\\012END;\\012$$ LANGUAGE 'plpgsql';\\012\\012CREATE CONSTRAINT TRIGGER check_dataset_relationships_on_data_table_modification \\012  AFTER INSERT OR UPDATE ON data\\012\\011DEFERRABLE INITIALLY DEFERRED\\012\\011FOR EACH ROW \\012\\011EXECUTE PROCEDURE check_dataset_relationships_on_data_table_modification();\\012\\012-- trigger for 'data_set_relationships'\\012\\012CREATE OR REPLACE FUNCTION check_dataset_relationships_on_relationships_table_modification() RETURNS trigger AS $$\\012DECLARE\\012\\011counter\\011INTEGER;\\012\\011sample_id\\011TECH_ID;\\012\\011data_code\\011CODE;\\012BEGIN\\012\\011-- child will have a parent added so it should not be connected with any sample\\012\\011SELECT samp_id, code INTO sample_id, data_code \\012\\011\\011FROM data \\012\\011\\011WHERE id = NEW.data_id_child;\\012\\011IF (sample_id IS NOT NULL) THEN\\012\\011\\011RAISE EXCEPTION 'Insert/Update of Data Set (Code: %) failed because it cannot be connected to a Sample and to a parent Data Set at the same time.', data_code;\\012\\011END IF;\\012\\011RETURN NEW;\\012END;\\012$$ LANGUAGE 'plpgsql';\\012  \\012CREATE CONSTRAINT TRIGGER check_dataset_relationships_on_relationships_table_modification \\012  AFTER INSERT OR UPDATE ON data_set_relationships\\012\\011DEFERRABLE INITIALLY DEFERRED\\012\\011FOR EACH ROW \\012\\011EXECUTE PROCEDURE check_dataset_relationships_on_relationships_table_modification();\\012	\N
+./sourceTest/sql/postgresql/051/.svn/text-base/schema-051.sql.svn-base:    LANGUAGE plpgsql
+./sourceTest/sql/postgresql/051/.svn/text-base/schema-051.sql.svn-base:    LANGUAGE plpgsql
+./sourceTest/sql/postgresql/051/.svn/text-base/schema-051.sql.svn-base:    LANGUAGE plpgsql
+./sourceTest/sql/postgresql/051/.svn/text-base/schema-051.sql.svn-base:    LANGUAGE plpgsql
+./sourceTest/sql/postgresql/051/.svn/text-base/schema-051.sql.svn-base:    LANGUAGE plpgsql
+./sourceTest/sql/postgresql/051/.svn/text-base/schema-051.sql.svn-base:    LANGUAGE plpgsql
+./sourceTest/sql/postgresql/051/.svn/text-base/schema-051.sql.svn-base:    LANGUAGE plpgsql
+./sourceTest/sql/postgresql/051/.svn/text-base/schema-051.sql.svn-base:    LANGUAGE plpgsql
+./sourceTest/sql/postgresql/051/.svn/text-base/schema-051.sql.svn-base:    LANGUAGE plpgsql
+./sourceTest/sql/postgresql/051/.svn/text-base/schema-051.sql.svn-base:    LANGUAGE plpgsql
+./sourceTest/sql/postgresql/051/017=database_version_logs.tsv:027	D:\\User\\felmer\\dev-workspace\\openbis/source/sql/postgresql/027/function-027.sql	SUCCESS	2008-11-05 09:18:00.403	-- Creating Functions\\012\\012------------------------------------------------------------------------------------\\012--  Purpose:  Create function RENAME_SEQUENCE() that is required for renaming the sequences belonging to tables\\012------------------------------------------------------------------------------------\\012CREATE FUNCTION RENAME_SEQUENCE(OLD_NAME VARCHAR, NEW_NAME VARCHAR) RETURNS INTEGER AS $$\\012DECLARE\\012  CURR_SEQ_VAL   INTEGER;\\012BEGIN\\012  SELECT INTO CURR_SEQ_VAL NEXTVAL(OLD_NAME);\\012  EXECUTE 'CREATE SEQUENCE ' || NEW_NAME || ' START WITH ' || CURR_SEQ_VAL;\\012  EXECUTE 'DROP SEQUENCE ' || OLD_NAME;\\012  RETURN CURR_SEQ_VAL;\\012END;\\012$$ LANGUAGE 'plpgsql';\\012\\012\\012------------------------------------------------------------------------------------\\012--  Purpose:  Create trigger CONTROLLED_VOCABULARY_CHECK \\012------------------------------------------------------------------------------------\\012\\012CREATE OR REPLACE FUNCTION CONTROLLED_VOCABULARY_CHECK() RETURNS trigger AS $$\\012DECLARE\\012   v_code  CODE;\\012BEGIN\\012\\012   select code into v_code from data_types where id = NEW.daty_id;\\012\\012   -- Check if the data is of type "CONTROLLEDVOCABULARY"\\012   if v_code = 'CONTROLLEDVOCABULARY' then\\012      if NEW.covo_id IS NULL then\\012         RAISE EXCEPTION 'Insert/Update of Property Type (Code: %) failed, as its Data Type is CONTROLLEDVOCABULARY, but it is not linked to a Controlled Vocabulary.', NEW.code;\\012      end if;\\012   end if;\\012\\012   RETURN NEW;\\012\\012END;\\012$$ LANGUAGE 'plpgsql';\\012\\012CREATE TRIGGER CONTROLLED_VOCABULARY_CHECK BEFORE INSERT OR UPDATE ON PROPERTY_TYPES\\012    FOR EACH ROW EXECUTE PROCEDURE CONTROLLED_VOCABULARY_CHECK();\\012\\012\\012------------------------------------------------------------------------------------\\012--  Purpose:  Create trigger EXTERNAL_DATA_STORAGE_FORMAT_CHECK \\012------------------------------------------------------------------------------------\\012\\012CREATE OR REPLACE FUNCTION EXTERNAL_DATA_STORAGE_FORMAT_CHECK() RETURNS trigger AS $$\\012DECLARE\\012   v_covo_code  CODE;\\012   data_code CODE;\\012BEGIN\\012\\012   select code into v_covo_code from controlled_vocabularies\\012      where is_internal_namespace = true and \\012         id = (select covo_id from controlled_vocabulary_terms where id = NEW.cvte_id_stor_fmt);\\012   -- Check if the data storage format is a term of the controlled vocabulary "STORAGE_FORMAT"\\012   if v_covo_code != 'STORAGE_FORMAT' then\\012      select code into data_code from data where id = NEW.data_id; \\012      RAISE EXCEPTION 'Insert/Update of Data (Code: %) failed, as its Storage Format is %, but is required to be STORAGE_FORMAT.', data_code, v_covo_code;\\012   end if;\\012\\012   RETURN NEW;\\012\\012END;\\012$$ LANGUAGE 'plpgsql';\\012\\012CREATE TRIGGER EXTERNAL_DATA_STORAGE_FORMAT_CHECK BEFORE INSERT OR UPDATE ON EXTERNAL_DATA\\012    FOR EACH ROW EXECUTE PROCEDURE EXTERNAL_DATA_STORAGE_FORMAT_CHECK();\\012\\012------------------------------------------------------------------------------------\\012--  Purpose:  Create trigger SAMPLE_CODE_UNIQUENESS_CHECK \\012------------------------------------------------------------------------------------\\012\\012CREATE OR REPLACE FUNCTION SAMPLE_CODE_UNIQUENESS_CHECK() RETURNS trigger AS $$\\012DECLARE\\012   counter  INTEGER;\\012BEGIN\\012\\011IF (NEW.samp_id_part_of is NULL) THEN\\012\\011\\011IF (NEW.dbin_id is not NULL) THEN\\012\\011\\011\\011SELECT count(*) into counter FROM samples \\012\\011\\011\\011\\011where id != NEW.id and code = NEW.code and samp_id_part_of is NULL and dbin_id = NEW.dbin_id;\\012\\011\\011\\011IF (counter > 0) THEN\\012\\011\\011\\011\\011RAISE EXCEPTION 'Insert/Update of Sample (Code: %) failed because database instance sample with the same code already exists.', NEW.code;\\012\\011\\011\\011END IF;\\012\\011\\011ELSIF (NEW.grou_id is not NULL) THEN\\012\\011\\011\\011SELECT count(*) into counter FROM samples \\012\\011\\011\\011\\011where id != NEW.id and code = NEW.code and samp_id_part_of is NULL and grou_id = NEW.grou_id;\\012\\011\\011\\011IF (counter > 0) THEN\\012\\011\\011\\011\\011RAISE EXCEPTION 'Insert/Update of Sample (Code: %) failed because group sample with the same code already exists.', NEW.code;\\012\\011\\011\\011END IF;\\012\\011\\011END IF;\\012        ELSE\\012\\011\\011IF (NEW.dbin_id is not NULL) THEN\\012\\011\\011\\011SELECT count(*) into counter FROM samples \\012\\011\\011\\011\\011where id != NEW.id and code = NEW.code and samp_id_part_of = NEW.samp_id_part_of and dbin_id = NEW.dbin_id;\\012\\011\\011\\011IF (counter > 0) THEN\\012\\011\\011\\011\\011RAISE EXCEPTION 'Insert/Update of Sample (Code: %) failed because database instance sample with the same code and being the part of the same parent already exists.', NEW.code;\\012\\011\\011\\011END IF;\\012\\011\\011ELSIF (NEW.grou_id is not NULL) THEN\\012\\011\\011\\011SELECT count(*) into counter FROM samples \\012\\011\\011\\011\\011where id != NEW.id and code = NEW.code and samp_id_part_of = NEW.samp_id_part_of and grou_id = NEW.grou_id;\\012\\011\\011\\011IF (counter > 0) THEN\\012\\011\\011\\011\\011RAISE EXCEPTION 'Insert/Update of Sample (Code: %) failed because group sample with the same code and being the part of the same parent already exists.', NEW.code;\\012\\011\\011\\011END IF;\\012\\011\\011END IF;\\012        END IF;   \\012   RETURN NEW;\\012END;\\012$$ LANGUAGE 'plpgsql';\\012\\012CREATE TRIGGER SAMPLE_CODE_UNIQUENESS_CHECK BEFORE INSERT OR UPDATE ON SAMPLES\\012    FOR EACH ROW EXECUTE PROCEDURE SAMPLE_CODE_UNIQUENESS_CHECK();\\012	\N
+./sourceTest/sql/postgresql/051/017=database_version_logs.tsv:028	source/sql/postgresql/migration/migration-027-028.sql	SUCCESS	2008-11-18 13:24:17.508	-- Create EXPERIMENT_ATTACHMENT_CONTENTS.\\012CREATE TABLE EXPERIMENT_ATTACHMENT_CONTENTS (ID TECH_ID NOT NULL,VALUE FILE NOT NULL);\\012CREATE SEQUENCE EXPERIMENT_ATTACHMENT_CONTENT_ID_SEQ;\\012ALTER TABLE EXPERIMENT_ATTACHMENT_CONTENTS ADD CONSTRAINT EXAC_PK PRIMARY KEY(ID);\\012\\012-- Alter EXPERIMENT_ATTACHMENTS by adding the new column which has a NULL constraint.\\012-- The NOT NULL constraint is added later on.\\012ALTER TABLE EXPERIMENT_ATTACHMENTS ADD COLUMN EXAC_ID TECH_ID;\\012\\012-- Does the VALUE migration between EXPERIMENT_ATTACHMENTS to EXPERIMENT_ATTACHMENT_CONTENTS.\\012CREATE OR REPLACE FUNCTION move_exp_att_content() RETURNS integer AS $$\\012DECLARE\\012    rec RECORD;\\012    seq BIGINT;\\012BEGIN\\012  FOR rec IN SELECT id, value FROM EXPERIMENT_ATTACHMENTS LOOP\\012  \\011seq := nextval('EXPERIMENT_ATTACHMENT_CONTENT_ID_SEQ');\\012    INSERT INTO EXPERIMENT_ATTACHMENT_CONTENTS (id, value) VALUES (seq, rec.value);\\012    UPDATE EXPERIMENT_ATTACHMENTS SET exac_id = seq WHERE id = rec.id;\\012  END LOOP;\\012  RETURN 1;\\012END;\\012$$ LANGUAGE 'plpgsql';\\012\\012-- Call the function.\\012SELECT move_exp_att_content();\\012DROP FUNCTION move_exp_att_content();\\012\\012\\012-- Finish EXPERIMENT_ATTACHMENTS changes.\\012ALTER TABLE EXPERIMENT_ATTACHMENTS ADD CONSTRAINT EXAT_CONT_FK FOREIGN KEY (EXAC_ID) REFERENCES EXPERIMENT_ATTACHMENT_CONTENTS(ID);\\012ALTER TABLE EXPERIMENT_ATTACHMENTS DROP COLUMN VALUE;\\012ALTER TABLE EXPERIMENT_ATTACHMENTS ALTER COLUMN EXAC_ID SET NOT NULL;\\012	\N
+./sourceTest/sql/postgresql/051/017=database_version_logs.tsv:029	source/sql/postgresql/migration/migration-028-029.sql	SUCCESS	2009-03-18 10:50:20.105	-- -------\\012-- add modification_timestamp field to allow edition with Hibernate\\012-- -------\\012\\012ALTER TABLE samples\\012\\011ADD COLUMN modification_timestamp TIME_STAMP DEFAULT CURRENT_TIMESTAMP;\\012\\012ALTER TABLE experiments\\012\\011ADD COLUMN modification_timestamp TIME_STAMP DEFAULT CURRENT_TIMESTAMP;\\012\\012ALTER TABLE materials\\012\\011ADD COLUMN modification_timestamp TIME_STAMP DEFAULT CURRENT_TIMESTAMP;\\012\\012ALTER TABLE experiment_properties\\012\\011ADD COLUMN modification_timestamp TIME_STAMP DEFAULT CURRENT_TIMESTAMP;\\012\\012ALTER TABLE material_properties\\012\\011ADD COLUMN modification_timestamp TIME_STAMP DEFAULT CURRENT_TIMESTAMP;\\012\\012ALTER TABLE sample_properties\\012\\011ADD COLUMN modification_timestamp TIME_STAMP DEFAULT CURRENT_TIMESTAMP;\\012\\012-- -------\\012-- add property data type which references materials\\012-- -------\\012\\012ALTER TABLE property_types\\012\\011ADD COLUMN maty_prop_id tech_id;\\012\\012ALTER TABLE property_types\\012\\011ADD CONSTRAINT prty_maty_fk FOREIGN KEY (maty_prop_id) REFERENCES material_types(id);\\012\\012ALTER TABLE experiment_properties\\012\\011ADD COLUMN mate_prop_id tech_id;\\012\\012ALTER TABLE material_properties\\012\\011ADD COLUMN mate_prop_id tech_id;\\012\\012ALTER TABLE sample_properties\\012\\011ADD COLUMN mate_prop_id tech_id;\\012\\012ALTER TABLE experiment_properties\\012\\011ADD CONSTRAINT expr_mapr_fk FOREIGN KEY (mate_prop_id) REFERENCES materials(id);\\012\\012ALTER TABLE material_properties\\012\\011ADD CONSTRAINT mapr_mapr_fk FOREIGN KEY (mate_prop_id) REFERENCES materials(id);\\012\\012ALTER TABLE sample_properties\\012\\011ADD CONSTRAINT sapr_mapr_fk FOREIGN KEY (mate_prop_id) REFERENCES materials(id);\\012\\012insert into data_types\\012(id\\012 ,code\\012 ,description)\\012 values \\012 (nextval('DATA_TYPE_ID_SEQ')\\012 ,'MATERIAL'\\012 ,'Reference to a material'\\012);\\012\\012ALTER TABLE MATERIAL_PROPERTIES DROP CONSTRAINT MAPR_CK;\\012ALTER TABLE MATERIAL_PROPERTIES ADD CONSTRAINT MAPR_CK CHECK \\012\\011((VALUE IS NOT NULL AND CVTE_ID IS NULL AND MATE_PROP_ID IS NULL) OR \\012\\011 (VALUE IS NULL AND CVTE_ID IS NOT NULL AND MATE_PROP_ID IS NULL) OR\\012\\011 (VALUE IS NULL AND CVTE_ID IS NULL AND MATE_PROP_ID IS NOT NULL)\\012\\011);\\012\\012ALTER TABLE EXPERIMENT_PROPERTIES DROP CONSTRAINT EXPR_CK;\\012ALTER TABLE EXPERIMENT_PROPERTIES ADD CONSTRAINT EXPR_CK CHECK \\012\\011((VALUE IS NOT NULL AND CVTE_ID IS NULL AND MATE_PROP_ID IS NULL) OR \\012\\011 (VALUE IS NULL AND CVTE_ID IS NOT NULL AND MATE_PROP_ID IS NULL) OR\\012\\011 (VALUE IS NULL AND CVTE_ID IS NULL AND MATE_PROP_ID IS NOT NULL)\\012\\011);\\012\\012ALTER TABLE SAMPLE_PROPERTIES DROP CONSTRAINT SAPR_CK;\\012ALTER TABLE SAMPLE_PROPERTIES ADD CONSTRAINT SAPR_CK CHECK \\012\\011((VALUE IS NOT NULL AND CVTE_ID IS NULL AND MATE_PROP_ID IS NULL) OR \\012\\011 (VALUE IS NULL AND CVTE_ID IS NOT NULL AND MATE_PROP_ID IS NULL) OR\\012\\011 (VALUE IS NULL AND CVTE_ID IS NULL AND MATE_PROP_ID IS NOT NULL)\\012\\011);\\012\\012------------------------------------------------------------------------------------\\012--  Purpose:  Create trigger MATERIAL/SAMPLE/EXPERIMENT _PROPERTY_WITH_MATERIAL_DATA_TYPE_CHECK\\012--            It checks that if material property value is assigned to the entity,\\012--\\011\\011\\011\\011\\011\\011then the material type is equal to the one described by property type.\\012------------------------------------------------------------------------------------\\012\\012CREATE OR REPLACE FUNCTION MATERIAL_PROPERTY_WITH_MATERIAL_DATA_TYPE_CHECK() RETURNS trigger AS $$\\012DECLARE\\012   v_type_id  CODE;\\012   v_type_id_prop  CODE;\\012BEGIN\\012   if NEW.mate_prop_id IS NOT NULL then\\012\\011\\011\\011-- find material type id of the property type \\012\\011\\011\\011select pt.maty_prop_id into v_type_id_prop \\012\\011\\011\\011  from material_type_property_types etpt, property_types pt \\012\\011\\011\\011 where NEW.mtpt_id = etpt.id AND etpt.prty_id = pt.id;\\012\\011\\011\\012\\011\\011\\011if v_type_id_prop IS NOT NULL then\\012\\011\\011\\011\\011-- find material type id of the material which consists the entity's property value\\012\\011\\011\\011\\011select entity.maty_id into v_type_id \\012\\011\\011\\011\\011  from materials entity\\012\\011\\011\\011\\011 where NEW.mate_prop_id = entity.id;\\012\\011\\011\\011\\011if v_type_id != v_type_id_prop then\\012\\011\\011\\011\\011\\011RAISE EXCEPTION 'Insert/Update of property value referencing material (id: %) failed, as referenced material type is different than expected (id %, expected id: %).', \\012\\011\\011\\011\\011\\011\\011\\011 NEW.mate_prop_id, v_type_id, v_type_id_prop;\\012\\011\\011\\011\\011end if;\\012\\011\\011\\011end if;\\012   end if;\\012   RETURN NEW;\\012END;\\012$$ LANGUAGE 'plpgsql';\\012\\012CREATE TRIGGER MATERIAL_PROPERTY_WITH_MATERIAL_DATA_TYPE_CHECK BEFORE INSERT OR UPDATE ON material_properties\\012    FOR EACH ROW EXECUTE PROCEDURE MATERIAL_PROPERTY_WITH_MATERIAL_DATA_TYPE_CHECK();\\012    \\012CREATE OR REPLACE FUNCTION SAMPLE_PROPERTY_WITH_MATERIAL_DATA_TYPE_CHECK() RETURNS trigger AS $$\\012DECLARE\\012   v_type_id  CODE;\\012   v_type_id_prop  CODE;\\012BEGIN\\012   if NEW.mate_prop_id IS NOT NULL then\\012\\011\\011\\011-- find material type id of the property type \\012\\011\\011\\011select pt.maty_prop_id into v_type_id_prop \\012\\011\\011\\011  from sample_type_property_types etpt, property_types pt \\012\\011\\011\\011 where NEW.stpt_id = etpt.id AND etpt.prty_id = pt.id;\\012\\011\\011\\012\\011\\011\\011if v_type_id_prop IS NOT NULL then\\012\\011\\011\\011\\011-- find material type id of the material which consists the entity's property value\\012\\011\\011\\011\\011select entity.maty_id into v_type_id \\012\\011\\011\\011\\011  from materials entity\\012\\011\\011\\011\\011 where NEW.mate_prop_id = entity.id;\\012\\011\\011\\011\\011if v_type_id != v_type_id_prop then\\012\\011\\011\\011\\011\\011RAISE EXCEPTION 'Insert/Update of property value referencing material (id: %) failed, as referenced material type is different than expected (id %, expected id: %).', \\012\\011\\011\\011\\011\\011\\011\\011\\011\\011\\011\\011\\011 NEW.mate_prop_id, v_type_id, v_type_id_prop;\\012\\011\\011\\011\\011end if;\\012\\011\\011\\011end if;\\012   end if;\\012   RETURN NEW;\\012END;\\012$$ LANGUAGE 'plpgsql';\\012\\012CREATE TRIGGER SAMPLE_PROPERTY_WITH_MATERIAL_DATA_TYPE_CHECK BEFORE INSERT OR UPDATE ON sample_properties\\012    FOR EACH ROW EXECUTE PROCEDURE SAMPLE_PROPERTY_WITH_MATERIAL_DATA_TYPE_CHECK();\\012    \\012CREATE OR REPLACE FUNCTION EXPERIMENT_PROPERTY_WITH_MATERIAL_DATA_TYPE_CHECK() RETURNS trigger AS $$\\012DECLARE\\012   v_type_id  CODE;\\012   v_type_id_prop  CODE;\\012BEGIN\\012   if NEW.mate_prop_id IS NOT NULL then\\012\\011\\011\\011-- find material type id of the property type \\012\\011\\011\\011select pt.maty_prop_id into v_type_id_prop \\012\\011\\011\\011  from experiment_type_property_types etpt, property_types pt \\012\\011\\011\\011 where NEW.etpt_id = etpt.id AND etpt.prty_id = pt.id;\\012\\011\\011\\012\\011\\011\\011if v_type_id_prop IS NOT NULL then\\012\\011\\011\\011\\011-- find material type id of the material which consists the entity's property value\\012\\011\\011\\011\\011select entity.maty_id into v_type_id \\012\\011\\011\\011\\011  from materials entity\\012\\011\\011\\011\\011 where NEW.mate_prop_id = entity.id;\\012\\011\\011\\011\\011if v_type_id != v_type_id_prop then\\012\\011\\011\\011\\011\\011RAISE EXCEPTION 'Insert/Update of property value referencing material (id: %) failed, as referenced material type is different than expected (id %, expected id: %).', \\012\\011\\011\\011\\011\\011\\011\\011\\011\\011\\011\\011\\011 NEW.mate_prop_id, v_type_id, v_type_id_prop;\\012\\011\\011\\011\\011end if;\\012\\011\\011\\011end if;\\012   end if;\\012   RETURN NEW;\\012END;\\012$$ LANGUAGE 'plpgsql';\\012\\012CREATE TRIGGER EXPERIMENT_PROPERTY_WITH_MATERIAL_DATA_TYPE_CHECK BEFORE INSERT OR UPDATE ON experiment_properties\\012    FOR EACH ROW EXECUTE PROCEDURE EXPERIMENT_PROPERTY_WITH_MATERIAL_DATA_TYPE_CHECK();\\012       \\012-- -------\\012-- remove the reminescents of the OBSERVABLE_TYPE\\012-- -------\\012\\012ALTER TABLE data\\012\\011DROP CONSTRAINT data_obty_fk;\\012\\012ALTER TABLE data_set_types\\012\\011DROP CONSTRAINT obty_pk;\\012\\012ALTER TABLE data_set_types\\012\\011ADD CONSTRAINT dsty_pk PRIMARY KEY (id);\\012\\012ALTER TABLE data\\012\\011ADD CONSTRAINT data_dsty_fk FOREIGN KEY (dsty_id) REFERENCES data_set_types(id);\\012\\012ALTER TABLE data_set_types\\012\\011DROP CONSTRAINT obty_bk_uk;\\012\\012ALTER TABLE data_set_types\\012\\011DROP CONSTRAINT obty_dbin_fk;\\012\\012ALTER TABLE data_set_types\\012\\011ADD CONSTRAINT dsty_bk_uk UNIQUE (code, dbin_id);\\012\\012ALTER TABLE data_set_types\\012\\011ADD CONSTRAINT dsty_dbin_fk FOREIGN KEY (dbin_id) REFERENCES database_instances(id);\\012\\012DROP INDEX data_obty_fk_i;\\012\\012CREATE INDEX data_dsty_fk_i ON data(dsty_id);\\012	\N
+./sourceTest/sql/postgresql/051/017=database_version_logs.tsv:030	source/sql/postgresql/migration/migration-029-030.sql	SUCCESS	2009-03-23 15:34:44.72	-- -------\\012-- add modification_timestamp field to allow edition with Hibernate\\012-- -------\\012ALTER TABLE data\\012\\011ADD COLUMN modification_timestamp TIME_STAMP DEFAULT CURRENT_TIMESTAMP;\\012ALTER TABLE experiment_types\\012\\011ADD COLUMN modification_timestamp TIME_STAMP DEFAULT CURRENT_TIMESTAMP;\\012ALTER TABLE sample_types\\012\\011ADD COLUMN modification_timestamp TIME_STAMP DEFAULT CURRENT_TIMESTAMP;\\012ALTER TABLE material_types\\012\\011ADD COLUMN modification_timestamp TIME_STAMP DEFAULT CURRENT_TIMESTAMP;\\012ALTER TABLE data_set_types\\012\\011ADD COLUMN modification_timestamp TIME_STAMP DEFAULT CURRENT_TIMESTAMP;\\012ALTER TABLE controlled_vocabularies\\012\\011ADD COLUMN modification_timestamp TIME_STAMP DEFAULT CURRENT_TIMESTAMP;\\012-- -------\\012-- add properties to data sets\\012-- -------\\012CREATE TABLE DATA_SET_PROPERTIES (ID TECH_ID NOT NULL,DS_ID TECH_ID NOT NULL,DSTPT_ID TECH_ID NOT NULL,VALUE GENERIC_VALUE,CVTE_ID TECH_ID, MATE_PROP_ID TECH_ID, PERS_ID_REGISTERER TECH_ID NOT NULL,REGISTRATION_TIMESTAMP TIME_STAMP_DFL NOT NULL DEFAULT CURRENT_TIMESTAMP, MODIFICATION_TIMESTAMP TIME_STAMP DEFAULT CURRENT_TIMESTAMP);\\012CREATE TABLE DATA_SET_TYPE_PROPERTY_TYPES (ID TECH_ID NOT NULL,DSTY_ID TECH_ID NOT NULL,PRTY_ID TECH_ID NOT NULL,IS_MANDATORY BOOLEAN_CHAR NOT NULL DEFAULT 'F',IS_MANAGED_INTERNALLY BOOLEAN_CHAR NOT NULL DEFAULT 'F',PERS_ID_REGISTERER TECH_ID NOT NULL,REGISTRATION_TIMESTAMP TIME_STAMP_DFL NOT NULL DEFAULT CURRENT_TIMESTAMP);\\012\\012CREATE SEQUENCE DATA_SET_PROPERTY_ID_SEQ;\\012CREATE SEQUENCE DSTPT_ID_SEQ;\\012\\012ALTER TABLE DATA_SET_TYPE_PROPERTY_TYPES ADD CONSTRAINT DSTPT_PK PRIMARY KEY(ID);\\012ALTER TABLE DATA_SET_PROPERTIES ADD CONSTRAINT DSPR_PK PRIMARY KEY(ID);\\012\\012ALTER TABLE DATA_SET_TYPE_PROPERTY_TYPES ADD CONSTRAINT DSTPT_BK_UK UNIQUE(DSTY_ID,PRTY_ID);\\012ALTER TABLE DATA_SET_PROPERTIES ADD CONSTRAINT DSPR_BK_UK UNIQUE(DS_ID,DSTPT_ID);\\012\\012\\012ALTER TABLE DATA_SET_TYPE_PROPERTY_TYPES ADD CONSTRAINT DSTPT_DSTY_FK FOREIGN KEY (DSTY_ID) REFERENCES DATA_SET_TYPES(ID);\\012ALTER TABLE DATA_SET_TYPE_PROPERTY_TYPES ADD CONSTRAINT DSTPT_PERS_FK FOREIGN KEY (PERS_ID_REGISTERER) REFERENCES PERSONS(ID);\\012ALTER TABLE DATA_SET_TYPE_PROPERTY_TYPES ADD CONSTRAINT DSTPT_PRTY_FK FOREIGN KEY (PRTY_ID) REFERENCES PROPERTY_TYPES(ID);\\012ALTER TABLE DATA_SET_PROPERTIES ADD CONSTRAINT DSPR_CVTE_FK FOREIGN KEY (CVTE_ID) REFERENCES CONTROLLED_VOCABULARY_TERMS(ID);\\012ALTER TABLE DATA_SET_PROPERTIES ADD CONSTRAINT DSPR_DSTPT_FK FOREIGN KEY (DSTPT_ID) REFERENCES DATA_SET_TYPE_PROPERTY_TYPES(ID) ON DELETE CASCADE;\\012ALTER TABLE DATA_SET_PROPERTIES ADD CONSTRAINT DSPR_DS_FK FOREIGN KEY (DS_ID) REFERENCES DATA(ID);\\012ALTER TABLE DATA_SET_PROPERTIES ADD CONSTRAINT DSPR_PERS_FK FOREIGN KEY (PERS_ID_REGISTERER) REFERENCES PERSONS(ID);\\012ALTER TABLE DATA_SET_PROPERTIES ADD CONSTRAINT DSPR_MAPR_FK FOREIGN KEY (MATE_PROP_ID) REFERENCES MATERIALS(ID);\\012\\012ALTER TABLE DATA_SET_PROPERTIES ADD CONSTRAINT DSPR_CK CHECK \\012\\011((VALUE IS NOT NULL AND CVTE_ID IS NULL AND MATE_PROP_ID IS NULL) OR \\012\\011 (VALUE IS NULL AND CVTE_ID IS NOT NULL AND MATE_PROP_ID IS NULL) OR\\012\\011 (VALUE IS NULL AND CVTE_ID IS NULL AND MATE_PROP_ID IS NOT NULL)\\012\\011);\\012\\012CREATE INDEX DSPR_CVTE_FK_I ON DATA_SET_PROPERTIES (CVTE_ID);\\012CREATE INDEX DSPR_DSTPT_FK_I ON DATA_SET_PROPERTIES (DSTPT_ID);\\012CREATE INDEX DSPR_DS_FK_I ON DATA_SET_PROPERTIES (DS_ID);\\012CREATE INDEX DSPR_PERS_FK_I ON DATA_SET_PROPERTIES (PERS_ID_REGISTERER);\\012CREATE INDEX DSTPT_DSTY_FK_I ON DATA_SET_TYPE_PROPERTY_TYPES (DSTY_ID);\\012CREATE INDEX DSTPT_PERS_FK_I ON DATA_SET_TYPE_PROPERTY_TYPES (PERS_ID_REGISTERER);\\012CREATE INDEX DSTPT_PRTY_FK_I ON DATA_SET_TYPE_PROPERTY_TYPES (PRTY_ID);\\012\\012CREATE OR REPLACE FUNCTION DATA_SET_PROPERTY_WITH_MATERIAL_DATA_TYPE_CHECK() RETURNS trigger AS $$\\012DECLARE\\012   v_type_id  CODE;\\012   v_type_id_prop  CODE;\\012BEGIN\\012   if NEW.mate_prop_id IS NOT NULL then\\012\\011\\011\\011-- find material type id of the property type \\012\\011\\011\\011select pt.maty_prop_id into v_type_id_prop \\012\\011\\011\\011  from data_set_type_property_types dstpt, property_types pt \\012\\011\\011\\011 where NEW.dstpt_id = dstpt.id AND dstpt.prty_id = pt.id;\\012\\011\\011\\012\\011\\011\\011if v_type_id_prop IS NOT NULL then\\012\\011\\011\\011\\011-- find material type id of the material which consists the entity's property value\\012\\011\\011\\011\\011select entity.maty_id into v_type_id \\012\\011\\011\\011\\011  from materials entity\\012\\011\\011\\011\\011 where NEW.mate_prop_id = entity.id;\\012\\011\\011\\011\\011if v_type_id != v_type_id_prop then\\012\\011\\011\\011\\011\\011RAISE EXCEPTION 'Insert/Update of property value referencing material (id: %) failed, as referenced material type is different than expected (id %, expected id: %).', \\012\\011\\011\\011\\011\\011\\011\\011\\011\\011\\011\\011\\011 NEW.mate_prop_id, v_type_id, v_type_id_prop;\\012\\011\\011\\011\\011end if;\\012\\011\\011\\011end if;\\012   end if;\\012   RETURN NEW;\\012END;\\012$$ LANGUAGE 'plpgsql';\\012\\012CREATE TRIGGER DATA_SET_PROPERTY_WITH_MATERIAL_DATA_TYPE_CHECK BEFORE INSERT OR UPDATE ON data_set_properties\\012    FOR EACH ROW EXECUTE PROCEDURE DATA_SET_PROPERTY_WITH_MATERIAL_DATA_TYPE_CHECK();   \\012	\N
+./sourceTest/sql/postgresql/051/017=database_version_logs.tsv:032	source/sql/postgresql/migration/migration-031-032.sql	SUCCESS	2009-04-09 09:36:36.2	-- -------\\012-- Modify MATERIAL_BATCHES\\012-- -------\\012\\012ALTER TABLE material_batches\\012    DROP COLUMN proc_id;\\012\\012-- -------\\012-- Modify SAMPLES\\012-- -------\\012\\012ALTER TABLE samples\\012    ADD COLUMN expe_id tech_id;\\012\\012ALTER TABLE samples\\012    ADD CONSTRAINT samp_expe_fk FOREIGN KEY (expe_id) REFERENCES experiments(id);\\012\\012CREATE INDEX samp_expe_fk_i ON samples USING btree (expe_id);\\012\\012-- relink samples directly to experiments\\012\\012UPDATE samples\\012SET expe_id = (SELECT e.id FROM experiments e, procedures p, sample_inputs si \\012               WHERE si.samp_id = samples.id AND si.proc_id = p.id AND p.expe_id = e.id AND e.inva_id IS NULL);\\012\\012\\012-- -------\\012-- Modify DATA\\012-- -------\\012\\012ALTER TABLE data\\012    ADD COLUMN expe_id tech_id;\\012\\012ALTER TABLE data\\012    ADD CONSTRAINT data_expe_fk FOREIGN KEY (expe_id) REFERENCES experiments(id);\\012\\012CREATE INDEX data_expe_fk_i ON data USING btree (expe_id);\\012\\012UPDATE data\\012SET expe_id = (SELECT e.id FROM experiments e, procedures p \\012               WHERE data.proc_id_produced_by = p.id AND p.expe_id = e.id);\\012\\012ALTER TABLE data\\012    ALTER COLUMN expe_id SET NOT NULL;\\012\\012ALTER TABLE data\\012    DROP COLUMN proc_id_produced_by;\\012\\012-- -------\\012-- Drop PROCEDURES, PROCEDURE_TYPES, and SAMPLE_INPUTS\\012-- -------\\012\\012DROP TABLE sample_inputs;\\012DROP TABLE procedures;\\012DROP TABLE procedure_types;\\012\\012DROP SEQUENCE procedure_id_seq;\\012DROP SEQUENCE procedure_type_id_seq;\\012\\012-- -------\\012-- Add CODE_SEQ\\012-- -------\\012\\012CREATE SEQUENCE CODE_SEQ;\\012\\012-- -------\\012-- Add new columns to DATA_STORES\\012-- -------\\012\\012ALTER TABLE data_stores\\012    ADD COLUMN remote_url character varying(250),\\012    ADD COLUMN session_token character varying(50),\\012    ADD COLUMN modification_timestamp time_stamp DEFAULT now();\\012\\012UPDATE data_stores\\012SET remote_url = '', session_token='';\\012\\012ALTER TABLE data_stores\\012    ALTER COLUMN remote_url SET NOT NULL,\\012    ALTER COLUMN session_token SET NOT NULL;\\012\\012-- -------\\012-- Drop foreign keys onto DATA_STORES\\012-- -------\\012\\012ALTER TABLE database_instances\\012    DROP COLUMN dast_id;\\012\\012ALTER TABLE groups\\012    DROP COLUMN dast_id;\\012\\012ALTER TABLE projects\\012    DROP COLUMN dast_id;\\012\\012ALTER TABLE experiments\\012    DROP COLUMN dast_id;\\012\\012-- -------\\012-- Add foreign key from DATA onto DATA_STORES\\012-- -------\\012\\012ALTER TABLE data\\012    ADD COLUMN dast_id tech_id;\\012\\012ALTER TABLE data\\012    ADD CONSTRAINT data_dast_fk FOREIGN KEY (dast_id) REFERENCES data_stores(id);\\012\\012UPDATE data\\012SET dast_id = (select id from data_stores where code = 'STANDARD');\\012\\012ALTER TABLE data\\012    ALTER COLUMN dast_id SET NOT NULL;\\012\\012\\012------------------------------------------------------------------------------------\\012--  Purpose:  Replace trigger SAMPLE_CODE_UNIQUENESS_CHECK \\012------------------------------------------------------------------------------------\\012\\012CREATE OR REPLACE FUNCTION SAMPLE_CODE_UNIQUENESS_CHECK() RETURNS trigger AS $$\\012DECLARE\\012   counter  INTEGER;\\012BEGIN\\012    LOCK TABLE samples IN EXCLUSIVE MODE;\\012    IF (NEW.samp_id_part_of is NULL) THEN\\012        IF (NEW.dbin_id is not NULL) THEN\\012            SELECT count(*) into counter FROM samples \\012                where id != NEW.id and code = NEW.code and samp_id_part_of is NULL and dbin_id = NEW.dbin_id;\\012            IF (counter > 0) THEN\\012                RAISE EXCEPTION 'Insert/Update of Sample (Code: %) failed because database instance sample with the same code already exists.', NEW.code;\\012            END IF;\\012        ELSIF (NEW.grou_id is not NULL) THEN\\012            SELECT count(*) into counter FROM samples \\012                where id != NEW.id and code = NEW.code and samp_id_part_of is NULL and grou_id = NEW.grou_id;\\012            IF (counter > 0) THEN\\012                RAISE EXCEPTION 'Insert/Update of Sample (Code: %) failed because group sample with the same code already exists.', NEW.code;\\012            END IF;\\012        END IF;\\012        ELSE\\012        IF (NEW.dbin_id is not NULL) THEN\\012            SELECT count(*) into counter FROM samples \\012                where id != NEW.id and code = NEW.code and samp_id_part_of = NEW.samp_id_part_of and dbin_id = NEW.dbin_id;\\012            IF (counter > 0) THEN\\012                RAISE EXCEPTION 'Insert/Update of Sample (Code: %) failed because database instance sample with the same code and being the part of the same parent already exists.', NEW.code;\\012            END IF;\\012        ELSIF (NEW.grou_id is not NULL) THEN\\012            SELECT count(*) into counter FROM samples \\012                where id != NEW.id and code = NEW.code and samp_id_part_of = NEW.samp_id_part_of and grou_id = NEW.grou_id;\\012            IF (counter > 0) THEN\\012                RAISE EXCEPTION 'Insert/Update of Sample (Code: %) failed because group sample with the same code and being the part of the same parent already exists.', NEW.code;\\012            END IF;\\012        END IF;\\012        END IF;   \\012   RETURN NEW;\\012END;\\012$$ LANGUAGE 'plpgsql';\\012\\012\\012\\012	\N
+./sourceTest/sql/postgresql/051/017=database_version_logs.tsv:034	source/sql/postgresql/migration/migration-033-034.sql	SUCCESS	2009-05-26 08:32:49.935	------------------------------------------------------------------------------------\\012-- Create sequence for generating permanent identifiers starting with nextval of existing dataset sequence.\\012------------------------------------------------------------------------------------\\012CREATE FUNCTION CREATE_SEQUENCE(EXISTING_SEQUENCE VARCHAR, NEW_SEQUENCE VARCHAR) RETURNS VOID AS $$\\012DECLARE\\012  CURR_SEQ_VAL   INTEGER;\\012BEGIN\\012  SELECT INTO CURR_SEQ_VAL NEXTVAL(EXISTING_SEQUENCE);\\012  EXECUTE 'CREATE SEQUENCE ' || NEW_SEQUENCE || ' START WITH ' || CURR_SEQ_VAL;\\012  RETURN;\\012END;\\012$$ LANGUAGE 'plpgsql';\\012\\012SELECT CREATE_SEQUENCE('DATA_ID_SEQ', 'PERM_ID_SEQ');\\012DROP FUNCTION CREATE_SEQUENCE(VARCHAR, VARCHAR);\\012\\012------------------------------------------------------------------------------------\\012-- Add perm_id columns to samples and experiments.\\012------------------------------------------------------------------------------------\\012ALTER TABLE SAMPLES ADD COLUMN PERM_ID CODE;\\012ALTER TABLE EXPERIMENTS ADD COLUMN PERM_ID CODE;\\012\\012UPDATE SAMPLES SET PERM_ID = to_char(registration_timestamp,'YYYYMMDDHHSSMS') || '-' || NEXTVAL('PERM_ID_SEQ');\\012UPDATE EXPERIMENTS SET PERM_ID = to_char(registration_timestamp,'YYYYMMDDHHSSMS') || '-' || NEXTVAL('PERM_ID_SEQ');\\012ALTER TABLE SAMPLES ALTER COLUMN PERM_ID SET NOT NULL;\\012ALTER TABLE EXPERIMENTS ALTER COLUMN PERM_ID SET NOT NULL;\\012ALTER TABLE SAMPLES ADD CONSTRAINT SAMP_PI_UK UNIQUE(PERM_ID);\\012ALTER TABLE EXPERIMENTS ADD CONSTRAINT EXPE_PI_UK UNIQUE(PERM_ID);\\012\\012\\012------------------------------------------------------------------------------------\\012-- Add column is_chosen_from_list to controlled_vocabularies.\\012------------------------------------------------------------------------------------\\012ALTER TABLE controlled_vocabularies ADD COLUMN is_chosen_from_list BOOLEAN_CHAR NOT NULL DEFAULT TRUE;\\012ALTER TABLE controlled_vocabularies ADD COLUMN source_uri CHARACTER VARYING(250);\\012------------------------------------------------------------------------------------\\012-- Modify Data table - remove arc connection between Sample and Data table, use a flag instead\\012------------------------------------------------------------------------------------\\012\\012-- add new columns\\012\\012ALTER TABLE data\\012    ADD COLUMN is_derived boolean_char;\\012ALTER TABLE data\\012    ADD COLUMN samp_id tech_id;\\012\\012-- update values in new columns\\012\\012UPDATE data\\012    SET is_derived = (samp_id_derived_from IS NOT NULL); \\012UPDATE data\\012    SET samp_id = samp_id_derived_from \\012    WHERE is_derived = 'TRUE';\\012UPDATE data\\012    SET samp_id = samp_id_acquired_from \\012    WHERE is_derived = 'FALSE';\\012\\012-- add constraints and indexes to new columns\\012\\012ALTER TABLE data\\012    ALTER COLUMN is_derived SET NOT NULL;\\012ALTER TABLE data\\012    ALTER COLUMN samp_id SET NOT NULL;   \\012ALTER TABLE data\\012    ADD CONSTRAINT data_samp_fk FOREIGN KEY (samp_id) REFERENCES samples (id);\\012CREATE INDEX data_samp_fk_i ON data USING btree (samp_id);\\012\\012-- remove old columns\\012\\012ALTER TABLE data\\012    DROP COLUMN samp_id_acquired_from;\\012ALTER TABLE data\\012    DROP COLUMN samp_id_derived_from;\\012    \\012------------------------------------------------------------------------------------\\012-- Granting SELECT privilege to group openbis_readonly\\012------------------------------------------------------------------------------------\\012\\012GRANT SELECT ON SEQUENCE attachment_content_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE attachment_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE code_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE controlled_vocabulary_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE cvte_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE data_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE data_set_property_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE data_set_relationship_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE data_set_type_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE data_store_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE data_type_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE database_instance_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE dstpt_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE etpt_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE event_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE experiment_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE experiment_property_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE experiment_type_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE file_format_type_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE group_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE invalidation_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE locator_type_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE material_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE material_property_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE material_type_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE mtpt_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE perm_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE person_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE project_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE property_type_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE role_assignment_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE sample_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE sample_property_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE sample_type_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE stpt_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE attachment_contents TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE attachments TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE controlled_vocabularies TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE controlled_vocabulary_terms TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE data TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE data_set_properties TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE data_set_relationships TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE data_set_type_property_types TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE data_set_types TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE data_stores TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE data_types TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE database_instances TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE database_version_logs TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE events TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE experiment_properties TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE experiment_type_property_types TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE experiment_types TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE experiments TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE external_data TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE file_format_types TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE groups TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE invalidations TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE locator_types TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE material_properties TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE material_type_property_types TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE material_types TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE materials TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE persons TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE projects TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE property_types TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE role_assignments TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE sample_properties TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE sample_type_property_types TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE sample_types TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE samples TO GROUP OPENBIS_READONLY;\\012\\012------------------------------------------------------------------------------------\\012-- Delete MATERIAL_BATCHES table\\012------------------------------------------------------------------------------------\\012\\012-- WARNING: Potential data lost!!!\\012-- WARNING: Potential data lost!!!\\012-- WARNING: Potential data lost!!!\\012\\012DROP TABLE SAMPLE_MATERIAL_BATCHES;\\012DROP TABLE MATERIAL_BATCHES;\\012DROP SEQUENCE MATERIAL_BATCH_ID_SEQ;\\012\\012------------------------------------------------------------------------------------\\012-- Delete MATE_ID_INHIBITOR_OF from table MATERIALS\\012------------------------------------------------------------------------------------\\012\\012-- WARNING: Potential data lost!!!\\012-- WARNING: Potential data lost!!!\\012-- WARNING: Potential data lost!!!\\012\\012ALTER TABLE MATERIALS DROP COLUMN MATE_ID_INHIBITOR_OF;\\012	\N
+./sourceTest/sql/postgresql/051/017=database_version_logs.tsv:041	source/sql/postgresql/migration/migration-040-041.sql	SUCCESS	2009-09-14 13:48:57.539	-- Create FILTERS table\\012\\012CREATE TABLE FILTERS (ID TECH_ID NOT NULL, DBIN_ID TECH_ID NOT NULL, NAME VARCHAR(200) NOT NULL, DESCRIPTION DESCRIPTION_1000,REGISTRATION_TIMESTAMP TIME_STAMP_DFL NOT NULL DEFAULT CURRENT_TIMESTAMP, PERS_ID_REGISTERER TECH_ID NOT NULL, MODIFICATION_TIMESTAMP TIME_STAMP DEFAULT CURRENT_TIMESTAMP, EXPRESSION VARCHAR(2000) NOT NULL, IS_PUBLIC BOOLEAN NOT NULL, GRID_ID VARCHAR(200) NOT NULL);\\012CREATE SEQUENCE FILTER_ID_SEQ;\\012ALTER TABLE FILTERS ADD CONSTRAINT FILT_PK PRIMARY KEY(ID);\\012ALTER TABLE FILTERS ADD CONSTRAINT FILT_BK_UK UNIQUE(NAME, DBIN_ID, GRID_ID);\\012ALTER TABLE FILTERS ADD CONSTRAINT FILT_PERS_FK FOREIGN KEY (PERS_ID_REGISTERER) REFERENCES PERSONS(ID);\\012ALTER TABLE FILTERS ADD CONSTRAINT FILT_DBIN_FK FOREIGN KEY (DBIN_ID) REFERENCES DATABASE_INSTANCES(ID);\\012CREATE INDEX FILT_PERS_FK_I ON FILTERS (PERS_ID_REGISTERER);\\012CREATE INDEX FILT_DBIN_FK_I ON FILTERS (DBIN_ID);\\012GRANT SELECT ON SEQUENCE filter_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE filters TO GROUP OPENBIS_READONLY;\\012\\012-- Add missing foreign key to role assignments authorization group\\012ALTER TABLE ROLE_ASSIGNMENTS ADD CONSTRAINT ROAS_AG_FK_GRANTEE FOREIGN KEY (AG_ID_GRANTEE) REFERENCES AUTHORIZATION_GROUPS(ID);\\012\\012--------------------------------------------------------------------------------------------------\\012-- Modify dataset connections:\\012-- 1. connection with sample shouldn't be mandatory any more\\012-- 2. introduce an arc condition that dataset cannot be connected with a sample and a parent dataset at the same time\\012--------------------------------------------------------------------------------------------------\\012\\012-- Weaken data-sample connection constraint - allow dataset to have no connection with sample\\012ALTER TABLE data ALTER COLUMN samp_id DROP NOT NULL;\\012\\012-- Remove data-sample connection for datasets that have a parent\\012\\012UPDATE data \\012   SET samp_id = NULL \\012 WHERE id IN (SELECT DISTINCT data_id_child FROM data_set_relationships);\\012\\012-- With PostgreSQL 8.4 one can check that before migration there were no cycles in dataset relationships:\\012--\\012-- WITH RECURSIVE data_set_parents(id, parent_ids, cycle) AS (\\012--         SELECT  r.data_id_child AS id, \\012--                 ARRAY[CAST (r.data_id_parent AS bigint)] AS parent_ids, \\012--                 false AS cycle \\012--         FROM data_set_relationships r\\012--     UNION ALL\\012--         SELECT  r.data_id_child,\\012--                 CAST (r.data_id_parent AS bigint) || p.parent_ids,\\012--                 r.data_id_child = ANY(p.parent_ids)\\012--         FROM data_set_relationships r, data_set_parents p\\012--         WHERE r.data_id_parent = p.id AND NOT cycle\\012-- )\\012-- SELECT count(*) AS cycles FROM data_set_parents WHERE cycle = true;\\012\\012---------------------------------------------------------------------------------------------------\\012--  Purpose:  Create DEFERRED triggers:\\012--            * check_dataset_relationships_on_data_table_modification,\\012--            * check_dataset_relationships_on_relationships_table_modification.\\012--            They check that after all modifications of database (just before commit) \\012--            if 'data'/'data_set_relationships' tables are among modified tables \\012--            dataset is not connected with a sample and a parent dataset at the same time.\\012--            This connections are held in two different tables so simple immediate trigger \\012--            with arc check cannot be used and we need two deferred triggers.\\012----------------------------------------------------------------------------------------------------\\012\\012-- trigger for 'data' table\\012\\012CREATE OR REPLACE FUNCTION check_dataset_relationships_on_data_table_modification() RETURNS trigger AS $$\\012DECLARE\\012\\011counter\\011INTEGER;\\012BEGIN\\012\\011-- if there is a connection with a Sample there should not be any connection with a parent Data Set\\012\\011IF (NEW.samp_id IS NOT NULL) THEN\\012\\011\\011-- count number of parents\\012\\011\\011SELECT count(*) INTO counter \\012\\011\\011\\011FROM data_set_relationships \\012\\011\\011\\011WHERE data_id_child = OLD.id;\\012\\011\\011IF (counter > 0) THEN\\012\\011\\011\\011RAISE EXCEPTION 'Insert/Update of Data Set (Code: %) failed because it cannot be connected with a Sample and a parent Data Set at the same time.', OLD.code;\\012\\011\\011END IF;\\012\\011END IF;\\012  RETURN NEW;\\012END;\\012$$ LANGUAGE 'plpgsql';\\012\\012CREATE CONSTRAINT TRIGGER check_dataset_relationships_on_data_table_modification \\012  AFTER INSERT OR UPDATE ON data\\012\\011DEFERRABLE INITIALLY DEFERRED\\012\\011FOR EACH ROW \\012\\011EXECUTE PROCEDURE check_dataset_relationships_on_data_table_modification();\\012\\012-- trigger for 'data_set_relationships'\\012\\012CREATE OR REPLACE FUNCTION check_dataset_relationships_on_relationships_table_modification() RETURNS trigger AS $$\\012DECLARE\\012\\011counter\\011INTEGER;\\012\\011sample_id\\011TECH_ID;\\012\\011data_code\\011CODE;\\012BEGIN\\012\\011-- child will have a parent added so it should not be connected with any sample\\012\\011SELECT samp_id, code INTO sample_id, data_code \\012\\011\\011FROM data \\012\\011\\011WHERE id = NEW.data_id_child;\\012\\011IF (sample_id IS NOT NULL) THEN\\012\\011\\011RAISE EXCEPTION 'Insert/Update of Data Set (Code: %) failed because it cannot be connected to a Sample and to a parent Data Set at the same time.', data_code;\\012\\011END IF;\\012\\011RETURN NEW;\\012END;\\012$$ LANGUAGE 'plpgsql';\\012  \\012CREATE CONSTRAINT TRIGGER check_dataset_relationships_on_relationships_table_modification \\012  AFTER INSERT OR UPDATE ON data_set_relationships\\012\\011DEFERRABLE INITIALLY DEFERRED\\012\\011FOR EACH ROW \\012\\011EXECUTE PROCEDURE check_dataset_relationships_on_relationships_table_modification();\\012	\N
+./sourceTest/sql/postgresql/051/schema-051.sql:    LANGUAGE plpgsql
+./sourceTest/sql/postgresql/051/schema-051.sql:    LANGUAGE plpgsql
+./sourceTest/sql/postgresql/051/schema-051.sql:    LANGUAGE plpgsql
+./sourceTest/sql/postgresql/051/schema-051.sql:    LANGUAGE plpgsql
+./sourceTest/sql/postgresql/051/schema-051.sql:    LANGUAGE plpgsql
+./sourceTest/sql/postgresql/051/schema-051.sql:    LANGUAGE plpgsql
+./sourceTest/sql/postgresql/051/schema-051.sql:    LANGUAGE plpgsql
+./sourceTest/sql/postgresql/051/schema-051.sql:    LANGUAGE plpgsql
+./sourceTest/sql/postgresql/051/schema-051.sql:    LANGUAGE plpgsql
+./sourceTest/sql/postgresql/051/schema-051.sql:    LANGUAGE plpgsql
+./sourceTest/sql/postgresql/052/.svn/text-base/017=database_version_logs.tsv.svn-base:027	D:\\User\\felmer\\dev-workspace\\openbis/source/sql/postgresql/027/function-027.sql	SUCCESS	2008-11-05 09:18:00.403	-- Creating Functions\\012\\012------------------------------------------------------------------------------------\\012--  Purpose:  Create function RENAME_SEQUENCE() that is required for renaming the sequences belonging to tables\\012------------------------------------------------------------------------------------\\012CREATE FUNCTION RENAME_SEQUENCE(OLD_NAME VARCHAR, NEW_NAME VARCHAR) RETURNS INTEGER AS $$\\012DECLARE\\012  CURR_SEQ_VAL   INTEGER;\\012BEGIN\\012  SELECT INTO CURR_SEQ_VAL NEXTVAL(OLD_NAME);\\012  EXECUTE 'CREATE SEQUENCE ' || NEW_NAME || ' START WITH ' || CURR_SEQ_VAL;\\012  EXECUTE 'DROP SEQUENCE ' || OLD_NAME;\\012  RETURN CURR_SEQ_VAL;\\012END;\\012$$ LANGUAGE 'plpgsql';\\012\\012\\012------------------------------------------------------------------------------------\\012--  Purpose:  Create trigger CONTROLLED_VOCABULARY_CHECK \\012------------------------------------------------------------------------------------\\012\\012CREATE OR REPLACE FUNCTION CONTROLLED_VOCABULARY_CHECK() RETURNS trigger AS $$\\012DECLARE\\012   v_code  CODE;\\012BEGIN\\012\\012   select code into v_code from data_types where id = NEW.daty_id;\\012\\012   -- Check if the data is of type "CONTROLLEDVOCABULARY"\\012   if v_code = 'CONTROLLEDVOCABULARY' then\\012      if NEW.covo_id IS NULL then\\012         RAISE EXCEPTION 'Insert/Update of Property Type (Code: %) failed, as its Data Type is CONTROLLEDVOCABULARY, but it is not linked to a Controlled Vocabulary.', NEW.code;\\012      end if;\\012   end if;\\012\\012   RETURN NEW;\\012\\012END;\\012$$ LANGUAGE 'plpgsql';\\012\\012CREATE TRIGGER CONTROLLED_VOCABULARY_CHECK BEFORE INSERT OR UPDATE ON PROPERTY_TYPES\\012    FOR EACH ROW EXECUTE PROCEDURE CONTROLLED_VOCABULARY_CHECK();\\012\\012\\012------------------------------------------------------------------------------------\\012--  Purpose:  Create trigger EXTERNAL_DATA_STORAGE_FORMAT_CHECK \\012------------------------------------------------------------------------------------\\012\\012CREATE OR REPLACE FUNCTION EXTERNAL_DATA_STORAGE_FORMAT_CHECK() RETURNS trigger AS $$\\012DECLARE\\012   v_covo_code  CODE;\\012   data_code CODE;\\012BEGIN\\012\\012   select code into v_covo_code from controlled_vocabularies\\012      where is_internal_namespace = true and \\012         id = (select covo_id from controlled_vocabulary_terms where id = NEW.cvte_id_stor_fmt);\\012   -- Check if the data storage format is a term of the controlled vocabulary "STORAGE_FORMAT"\\012   if v_covo_code != 'STORAGE_FORMAT' then\\012      select code into data_code from data where id = NEW.data_id; \\012      RAISE EXCEPTION 'Insert/Update of Data (Code: %) failed, as its Storage Format is %, but is required to be STORAGE_FORMAT.', data_code, v_covo_code;\\012   end if;\\012\\012   RETURN NEW;\\012\\012END;\\012$$ LANGUAGE 'plpgsql';\\012\\012CREATE TRIGGER EXTERNAL_DATA_STORAGE_FORMAT_CHECK BEFORE INSERT OR UPDATE ON EXTERNAL_DATA\\012    FOR EACH ROW EXECUTE PROCEDURE EXTERNAL_DATA_STORAGE_FORMAT_CHECK();\\012\\012------------------------------------------------------------------------------------\\012--  Purpose:  Create trigger SAMPLE_CODE_UNIQUENESS_CHECK \\012------------------------------------------------------------------------------------\\012\\012CREATE OR REPLACE FUNCTION SAMPLE_CODE_UNIQUENESS_CHECK() RETURNS trigger AS $$\\012DECLARE\\012   counter  INTEGER;\\012BEGIN\\012\\011IF (NEW.samp_id_part_of is NULL) THEN\\012\\011\\011IF (NEW.dbin_id is not NULL) THEN\\012\\011\\011\\011SELECT count(*) into counter FROM samples \\012\\011\\011\\011\\011where id != NEW.id and code = NEW.code and samp_id_part_of is NULL and dbin_id = NEW.dbin_id;\\012\\011\\011\\011IF (counter > 0) THEN\\012\\011\\011\\011\\011RAISE EXCEPTION 'Insert/Update of Sample (Code: %) failed because database instance sample with the same code already exists.', NEW.code;\\012\\011\\011\\011END IF;\\012\\011\\011ELSIF (NEW.grou_id is not NULL) THEN\\012\\011\\011\\011SELECT count(*) into counter FROM samples \\012\\011\\011\\011\\011where id != NEW.id and code = NEW.code and samp_id_part_of is NULL and grou_id = NEW.grou_id;\\012\\011\\011\\011IF (counter > 0) THEN\\012\\011\\011\\011\\011RAISE EXCEPTION 'Insert/Update of Sample (Code: %) failed because group sample with the same code already exists.', NEW.code;\\012\\011\\011\\011END IF;\\012\\011\\011END IF;\\012        ELSE\\012\\011\\011IF (NEW.dbin_id is not NULL) THEN\\012\\011\\011\\011SELECT count(*) into counter FROM samples \\012\\011\\011\\011\\011where id != NEW.id and code = NEW.code and samp_id_part_of = NEW.samp_id_part_of and dbin_id = NEW.dbin_id;\\012\\011\\011\\011IF (counter > 0) THEN\\012\\011\\011\\011\\011RAISE EXCEPTION 'Insert/Update of Sample (Code: %) failed because database instance sample with the same code and being the part of the same parent already exists.', NEW.code;\\012\\011\\011\\011END IF;\\012\\011\\011ELSIF (NEW.grou_id is not NULL) THEN\\012\\011\\011\\011SELECT count(*) into counter FROM samples \\012\\011\\011\\011\\011where id != NEW.id and code = NEW.code and samp_id_part_of = NEW.samp_id_part_of and grou_id = NEW.grou_id;\\012\\011\\011\\011IF (counter > 0) THEN\\012\\011\\011\\011\\011RAISE EXCEPTION 'Insert/Update of Sample (Code: %) failed because group sample with the same code and being the part of the same parent already exists.', NEW.code;\\012\\011\\011\\011END IF;\\012\\011\\011END IF;\\012        END IF;   \\012   RETURN NEW;\\012END;\\012$$ LANGUAGE 'plpgsql';\\012\\012CREATE TRIGGER SAMPLE_CODE_UNIQUENESS_CHECK BEFORE INSERT OR UPDATE ON SAMPLES\\012    FOR EACH ROW EXECUTE PROCEDURE SAMPLE_CODE_UNIQUENESS_CHECK();\\012	\N
+./sourceTest/sql/postgresql/052/.svn/text-base/017=database_version_logs.tsv.svn-base:028	source/sql/postgresql/migration/migration-027-028.sql	SUCCESS	2008-11-18 13:24:17.508	-- Create EXPERIMENT_ATTACHMENT_CONTENTS.\\012CREATE TABLE EXPERIMENT_ATTACHMENT_CONTENTS (ID TECH_ID NOT NULL,VALUE FILE NOT NULL);\\012CREATE SEQUENCE EXPERIMENT_ATTACHMENT_CONTENT_ID_SEQ;\\012ALTER TABLE EXPERIMENT_ATTACHMENT_CONTENTS ADD CONSTRAINT EXAC_PK PRIMARY KEY(ID);\\012\\012-- Alter EXPERIMENT_ATTACHMENTS by adding the new column which has a NULL constraint.\\012-- The NOT NULL constraint is added later on.\\012ALTER TABLE EXPERIMENT_ATTACHMENTS ADD COLUMN EXAC_ID TECH_ID;\\012\\012-- Does the VALUE migration between EXPERIMENT_ATTACHMENTS to EXPERIMENT_ATTACHMENT_CONTENTS.\\012CREATE OR REPLACE FUNCTION move_exp_att_content() RETURNS integer AS $$\\012DECLARE\\012    rec RECORD;\\012    seq BIGINT;\\012BEGIN\\012  FOR rec IN SELECT id, value FROM EXPERIMENT_ATTACHMENTS LOOP\\012  \\011seq := nextval('EXPERIMENT_ATTACHMENT_CONTENT_ID_SEQ');\\012    INSERT INTO EXPERIMENT_ATTACHMENT_CONTENTS (id, value) VALUES (seq, rec.value);\\012    UPDATE EXPERIMENT_ATTACHMENTS SET exac_id = seq WHERE id = rec.id;\\012  END LOOP;\\012  RETURN 1;\\012END;\\012$$ LANGUAGE 'plpgsql';\\012\\012-- Call the function.\\012SELECT move_exp_att_content();\\012DROP FUNCTION move_exp_att_content();\\012\\012\\012-- Finish EXPERIMENT_ATTACHMENTS changes.\\012ALTER TABLE EXPERIMENT_ATTACHMENTS ADD CONSTRAINT EXAT_CONT_FK FOREIGN KEY (EXAC_ID) REFERENCES EXPERIMENT_ATTACHMENT_CONTENTS(ID);\\012ALTER TABLE EXPERIMENT_ATTACHMENTS DROP COLUMN VALUE;\\012ALTER TABLE EXPERIMENT_ATTACHMENTS ALTER COLUMN EXAC_ID SET NOT NULL;\\012	\N
+./sourceTest/sql/postgresql/052/.svn/text-base/017=database_version_logs.tsv.svn-base:029	source/sql/postgresql/migration/migration-028-029.sql	SUCCESS	2009-03-18 10:50:20.105	-- -------\\012-- add modification_timestamp field to allow edition with Hibernate\\012-- -------\\012\\012ALTER TABLE samples\\012\\011ADD COLUMN modification_timestamp TIME_STAMP DEFAULT CURRENT_TIMESTAMP;\\012\\012ALTER TABLE experiments\\012\\011ADD COLUMN modification_timestamp TIME_STAMP DEFAULT CURRENT_TIMESTAMP;\\012\\012ALTER TABLE materials\\012\\011ADD COLUMN modification_timestamp TIME_STAMP DEFAULT CURRENT_TIMESTAMP;\\012\\012ALTER TABLE experiment_properties\\012\\011ADD COLUMN modification_timestamp TIME_STAMP DEFAULT CURRENT_TIMESTAMP;\\012\\012ALTER TABLE material_properties\\012\\011ADD COLUMN modification_timestamp TIME_STAMP DEFAULT CURRENT_TIMESTAMP;\\012\\012ALTER TABLE sample_properties\\012\\011ADD COLUMN modification_timestamp TIME_STAMP DEFAULT CURRENT_TIMESTAMP;\\012\\012-- -------\\012-- add property data type which references materials\\012-- -------\\012\\012ALTER TABLE property_types\\012\\011ADD COLUMN maty_prop_id tech_id;\\012\\012ALTER TABLE property_types\\012\\011ADD CONSTRAINT prty_maty_fk FOREIGN KEY (maty_prop_id) REFERENCES material_types(id);\\012\\012ALTER TABLE experiment_properties\\012\\011ADD COLUMN mate_prop_id tech_id;\\012\\012ALTER TABLE material_properties\\012\\011ADD COLUMN mate_prop_id tech_id;\\012\\012ALTER TABLE sample_properties\\012\\011ADD COLUMN mate_prop_id tech_id;\\012\\012ALTER TABLE experiment_properties\\012\\011ADD CONSTRAINT expr_mapr_fk FOREIGN KEY (mate_prop_id) REFERENCES materials(id);\\012\\012ALTER TABLE material_properties\\012\\011ADD CONSTRAINT mapr_mapr_fk FOREIGN KEY (mate_prop_id) REFERENCES materials(id);\\012\\012ALTER TABLE sample_properties\\012\\011ADD CONSTRAINT sapr_mapr_fk FOREIGN KEY (mate_prop_id) REFERENCES materials(id);\\012\\012insert into data_types\\012(id\\012 ,code\\012 ,description)\\012 values \\012 (nextval('DATA_TYPE_ID_SEQ')\\012 ,'MATERIAL'\\012 ,'Reference to a material'\\012);\\012\\012ALTER TABLE MATERIAL_PROPERTIES DROP CONSTRAINT MAPR_CK;\\012ALTER TABLE MATERIAL_PROPERTIES ADD CONSTRAINT MAPR_CK CHECK \\012\\011((VALUE IS NOT NULL AND CVTE_ID IS NULL AND MATE_PROP_ID IS NULL) OR \\012\\011 (VALUE IS NULL AND CVTE_ID IS NOT NULL AND MATE_PROP_ID IS NULL) OR\\012\\011 (VALUE IS NULL AND CVTE_ID IS NULL AND MATE_PROP_ID IS NOT NULL)\\012\\011);\\012\\012ALTER TABLE EXPERIMENT_PROPERTIES DROP CONSTRAINT EXPR_CK;\\012ALTER TABLE EXPERIMENT_PROPERTIES ADD CONSTRAINT EXPR_CK CHECK \\012\\011((VALUE IS NOT NULL AND CVTE_ID IS NULL AND MATE_PROP_ID IS NULL) OR \\012\\011 (VALUE IS NULL AND CVTE_ID IS NOT NULL AND MATE_PROP_ID IS NULL) OR\\012\\011 (VALUE IS NULL AND CVTE_ID IS NULL AND MATE_PROP_ID IS NOT NULL)\\012\\011);\\012\\012ALTER TABLE SAMPLE_PROPERTIES DROP CONSTRAINT SAPR_CK;\\012ALTER TABLE SAMPLE_PROPERTIES ADD CONSTRAINT SAPR_CK CHECK \\012\\011((VALUE IS NOT NULL AND CVTE_ID IS NULL AND MATE_PROP_ID IS NULL) OR \\012\\011 (VALUE IS NULL AND CVTE_ID IS NOT NULL AND MATE_PROP_ID IS NULL) OR\\012\\011 (VALUE IS NULL AND CVTE_ID IS NULL AND MATE_PROP_ID IS NOT NULL)\\012\\011);\\012\\012------------------------------------------------------------------------------------\\012--  Purpose:  Create trigger MATERIAL/SAMPLE/EXPERIMENT _PROPERTY_WITH_MATERIAL_DATA_TYPE_CHECK\\012--            It checks that if material property value is assigned to the entity,\\012--\\011\\011\\011\\011\\011\\011then the material type is equal to the one described by property type.\\012------------------------------------------------------------------------------------\\012\\012CREATE OR REPLACE FUNCTION MATERIAL_PROPERTY_WITH_MATERIAL_DATA_TYPE_CHECK() RETURNS trigger AS $$\\012DECLARE\\012   v_type_id  CODE;\\012   v_type_id_prop  CODE;\\012BEGIN\\012   if NEW.mate_prop_id IS NOT NULL then\\012\\011\\011\\011-- find material type id of the property type \\012\\011\\011\\011select pt.maty_prop_id into v_type_id_prop \\012\\011\\011\\011  from material_type_property_types etpt, property_types pt \\012\\011\\011\\011 where NEW.mtpt_id = etpt.id AND etpt.prty_id = pt.id;\\012\\011\\011\\012\\011\\011\\011if v_type_id_prop IS NOT NULL then\\012\\011\\011\\011\\011-- find material type id of the material which consists the entity's property value\\012\\011\\011\\011\\011select entity.maty_id into v_type_id \\012\\011\\011\\011\\011  from materials entity\\012\\011\\011\\011\\011 where NEW.mate_prop_id = entity.id;\\012\\011\\011\\011\\011if v_type_id != v_type_id_prop then\\012\\011\\011\\011\\011\\011RAISE EXCEPTION 'Insert/Update of property value referencing material (id: %) failed, as referenced material type is different than expected (id %, expected id: %).', \\012\\011\\011\\011\\011\\011\\011\\011 NEW.mate_prop_id, v_type_id, v_type_id_prop;\\012\\011\\011\\011\\011end if;\\012\\011\\011\\011end if;\\012   end if;\\012   RETURN NEW;\\012END;\\012$$ LANGUAGE 'plpgsql';\\012\\012CREATE TRIGGER MATERIAL_PROPERTY_WITH_MATERIAL_DATA_TYPE_CHECK BEFORE INSERT OR UPDATE ON material_properties\\012    FOR EACH ROW EXECUTE PROCEDURE MATERIAL_PROPERTY_WITH_MATERIAL_DATA_TYPE_CHECK();\\012    \\012CREATE OR REPLACE FUNCTION SAMPLE_PROPERTY_WITH_MATERIAL_DATA_TYPE_CHECK() RETURNS trigger AS $$\\012DECLARE\\012   v_type_id  CODE;\\012   v_type_id_prop  CODE;\\012BEGIN\\012   if NEW.mate_prop_id IS NOT NULL then\\012\\011\\011\\011-- find material type id of the property type \\012\\011\\011\\011select pt.maty_prop_id into v_type_id_prop \\012\\011\\011\\011  from sample_type_property_types etpt, property_types pt \\012\\011\\011\\011 where NEW.stpt_id = etpt.id AND etpt.prty_id = pt.id;\\012\\011\\011\\012\\011\\011\\011if v_type_id_prop IS NOT NULL then\\012\\011\\011\\011\\011-- find material type id of the material which consists the entity's property value\\012\\011\\011\\011\\011select entity.maty_id into v_type_id \\012\\011\\011\\011\\011  from materials entity\\012\\011\\011\\011\\011 where NEW.mate_prop_id = entity.id;\\012\\011\\011\\011\\011if v_type_id != v_type_id_prop then\\012\\011\\011\\011\\011\\011RAISE EXCEPTION 'Insert/Update of property value referencing material (id: %) failed, as referenced material type is different than expected (id %, expected id: %).', \\012\\011\\011\\011\\011\\011\\011\\011\\011\\011\\011\\011\\011 NEW.mate_prop_id, v_type_id, v_type_id_prop;\\012\\011\\011\\011\\011end if;\\012\\011\\011\\011end if;\\012   end if;\\012   RETURN NEW;\\012END;\\012$$ LANGUAGE 'plpgsql';\\012\\012CREATE TRIGGER SAMPLE_PROPERTY_WITH_MATERIAL_DATA_TYPE_CHECK BEFORE INSERT OR UPDATE ON sample_properties\\012    FOR EACH ROW EXECUTE PROCEDURE SAMPLE_PROPERTY_WITH_MATERIAL_DATA_TYPE_CHECK();\\012    \\012CREATE OR REPLACE FUNCTION EXPERIMENT_PROPERTY_WITH_MATERIAL_DATA_TYPE_CHECK() RETURNS trigger AS $$\\012DECLARE\\012   v_type_id  CODE;\\012   v_type_id_prop  CODE;\\012BEGIN\\012   if NEW.mate_prop_id IS NOT NULL then\\012\\011\\011\\011-- find material type id of the property type \\012\\011\\011\\011select pt.maty_prop_id into v_type_id_prop \\012\\011\\011\\011  from experiment_type_property_types etpt, property_types pt \\012\\011\\011\\011 where NEW.etpt_id = etpt.id AND etpt.prty_id = pt.id;\\012\\011\\011\\012\\011\\011\\011if v_type_id_prop IS NOT NULL then\\012\\011\\011\\011\\011-- find material type id of the material which consists the entity's property value\\012\\011\\011\\011\\011select entity.maty_id into v_type_id \\012\\011\\011\\011\\011  from materials entity\\012\\011\\011\\011\\011 where NEW.mate_prop_id = entity.id;\\012\\011\\011\\011\\011if v_type_id != v_type_id_prop then\\012\\011\\011\\011\\011\\011RAISE EXCEPTION 'Insert/Update of property value referencing material (id: %) failed, as referenced material type is different than expected (id %, expected id: %).', \\012\\011\\011\\011\\011\\011\\011\\011\\011\\011\\011\\011\\011 NEW.mate_prop_id, v_type_id, v_type_id_prop;\\012\\011\\011\\011\\011end if;\\012\\011\\011\\011end if;\\012   end if;\\012   RETURN NEW;\\012END;\\012$$ LANGUAGE 'plpgsql';\\012\\012CREATE TRIGGER EXPERIMENT_PROPERTY_WITH_MATERIAL_DATA_TYPE_CHECK BEFORE INSERT OR UPDATE ON experiment_properties\\012    FOR EACH ROW EXECUTE PROCEDURE EXPERIMENT_PROPERTY_WITH_MATERIAL_DATA_TYPE_CHECK();\\012       \\012-- -------\\012-- remove the reminescents of the OBSERVABLE_TYPE\\012-- -------\\012\\012ALTER TABLE data\\012\\011DROP CONSTRAINT data_obty_fk;\\012\\012ALTER TABLE data_set_types\\012\\011DROP CONSTRAINT obty_pk;\\012\\012ALTER TABLE data_set_types\\012\\011ADD CONSTRAINT dsty_pk PRIMARY KEY (id);\\012\\012ALTER TABLE data\\012\\011ADD CONSTRAINT data_dsty_fk FOREIGN KEY (dsty_id) REFERENCES data_set_types(id);\\012\\012ALTER TABLE data_set_types\\012\\011DROP CONSTRAINT obty_bk_uk;\\012\\012ALTER TABLE data_set_types\\012\\011DROP CONSTRAINT obty_dbin_fk;\\012\\012ALTER TABLE data_set_types\\012\\011ADD CONSTRAINT dsty_bk_uk UNIQUE (code, dbin_id);\\012\\012ALTER TABLE data_set_types\\012\\011ADD CONSTRAINT dsty_dbin_fk FOREIGN KEY (dbin_id) REFERENCES database_instances(id);\\012\\012DROP INDEX data_obty_fk_i;\\012\\012CREATE INDEX data_dsty_fk_i ON data(dsty_id);\\012	\N
+./sourceTest/sql/postgresql/052/.svn/text-base/017=database_version_logs.tsv.svn-base:030	source/sql/postgresql/migration/migration-029-030.sql	SUCCESS	2009-03-23 15:34:44.72	-- -------\\012-- add modification_timestamp field to allow edition with Hibernate\\012-- -------\\012ALTER TABLE data\\012\\011ADD COLUMN modification_timestamp TIME_STAMP DEFAULT CURRENT_TIMESTAMP;\\012ALTER TABLE experiment_types\\012\\011ADD COLUMN modification_timestamp TIME_STAMP DEFAULT CURRENT_TIMESTAMP;\\012ALTER TABLE sample_types\\012\\011ADD COLUMN modification_timestamp TIME_STAMP DEFAULT CURRENT_TIMESTAMP;\\012ALTER TABLE material_types\\012\\011ADD COLUMN modification_timestamp TIME_STAMP DEFAULT CURRENT_TIMESTAMP;\\012ALTER TABLE data_set_types\\012\\011ADD COLUMN modification_timestamp TIME_STAMP DEFAULT CURRENT_TIMESTAMP;\\012ALTER TABLE controlled_vocabularies\\012\\011ADD COLUMN modification_timestamp TIME_STAMP DEFAULT CURRENT_TIMESTAMP;\\012-- -------\\012-- add properties to data sets\\012-- -------\\012CREATE TABLE DATA_SET_PROPERTIES (ID TECH_ID NOT NULL,DS_ID TECH_ID NOT NULL,DSTPT_ID TECH_ID NOT NULL,VALUE GENERIC_VALUE,CVTE_ID TECH_ID, MATE_PROP_ID TECH_ID, PERS_ID_REGISTERER TECH_ID NOT NULL,REGISTRATION_TIMESTAMP TIME_STAMP_DFL NOT NULL DEFAULT CURRENT_TIMESTAMP, MODIFICATION_TIMESTAMP TIME_STAMP DEFAULT CURRENT_TIMESTAMP);\\012CREATE TABLE DATA_SET_TYPE_PROPERTY_TYPES (ID TECH_ID NOT NULL,DSTY_ID TECH_ID NOT NULL,PRTY_ID TECH_ID NOT NULL,IS_MANDATORY BOOLEAN_CHAR NOT NULL DEFAULT 'F',IS_MANAGED_INTERNALLY BOOLEAN_CHAR NOT NULL DEFAULT 'F',PERS_ID_REGISTERER TECH_ID NOT NULL,REGISTRATION_TIMESTAMP TIME_STAMP_DFL NOT NULL DEFAULT CURRENT_TIMESTAMP);\\012\\012CREATE SEQUENCE DATA_SET_PROPERTY_ID_SEQ;\\012CREATE SEQUENCE DSTPT_ID_SEQ;\\012\\012ALTER TABLE DATA_SET_TYPE_PROPERTY_TYPES ADD CONSTRAINT DSTPT_PK PRIMARY KEY(ID);\\012ALTER TABLE DATA_SET_PROPERTIES ADD CONSTRAINT DSPR_PK PRIMARY KEY(ID);\\012\\012ALTER TABLE DATA_SET_TYPE_PROPERTY_TYPES ADD CONSTRAINT DSTPT_BK_UK UNIQUE(DSTY_ID,PRTY_ID);\\012ALTER TABLE DATA_SET_PROPERTIES ADD CONSTRAINT DSPR_BK_UK UNIQUE(DS_ID,DSTPT_ID);\\012\\012\\012ALTER TABLE DATA_SET_TYPE_PROPERTY_TYPES ADD CONSTRAINT DSTPT_DSTY_FK FOREIGN KEY (DSTY_ID) REFERENCES DATA_SET_TYPES(ID);\\012ALTER TABLE DATA_SET_TYPE_PROPERTY_TYPES ADD CONSTRAINT DSTPT_PERS_FK FOREIGN KEY (PERS_ID_REGISTERER) REFERENCES PERSONS(ID);\\012ALTER TABLE DATA_SET_TYPE_PROPERTY_TYPES ADD CONSTRAINT DSTPT_PRTY_FK FOREIGN KEY (PRTY_ID) REFERENCES PROPERTY_TYPES(ID);\\012ALTER TABLE DATA_SET_PROPERTIES ADD CONSTRAINT DSPR_CVTE_FK FOREIGN KEY (CVTE_ID) REFERENCES CONTROLLED_VOCABULARY_TERMS(ID);\\012ALTER TABLE DATA_SET_PROPERTIES ADD CONSTRAINT DSPR_DSTPT_FK FOREIGN KEY (DSTPT_ID) REFERENCES DATA_SET_TYPE_PROPERTY_TYPES(ID) ON DELETE CASCADE;\\012ALTER TABLE DATA_SET_PROPERTIES ADD CONSTRAINT DSPR_DS_FK FOREIGN KEY (DS_ID) REFERENCES DATA(ID);\\012ALTER TABLE DATA_SET_PROPERTIES ADD CONSTRAINT DSPR_PERS_FK FOREIGN KEY (PERS_ID_REGISTERER) REFERENCES PERSONS(ID);\\012ALTER TABLE DATA_SET_PROPERTIES ADD CONSTRAINT DSPR_MAPR_FK FOREIGN KEY (MATE_PROP_ID) REFERENCES MATERIALS(ID);\\012\\012ALTER TABLE DATA_SET_PROPERTIES ADD CONSTRAINT DSPR_CK CHECK \\012\\011((VALUE IS NOT NULL AND CVTE_ID IS NULL AND MATE_PROP_ID IS NULL) OR \\012\\011 (VALUE IS NULL AND CVTE_ID IS NOT NULL AND MATE_PROP_ID IS NULL) OR\\012\\011 (VALUE IS NULL AND CVTE_ID IS NULL AND MATE_PROP_ID IS NOT NULL)\\012\\011);\\012\\012CREATE INDEX DSPR_CVTE_FK_I ON DATA_SET_PROPERTIES (CVTE_ID);\\012CREATE INDEX DSPR_DSTPT_FK_I ON DATA_SET_PROPERTIES (DSTPT_ID);\\012CREATE INDEX DSPR_DS_FK_I ON DATA_SET_PROPERTIES (DS_ID);\\012CREATE INDEX DSPR_PERS_FK_I ON DATA_SET_PROPERTIES (PERS_ID_REGISTERER);\\012CREATE INDEX DSTPT_DSTY_FK_I ON DATA_SET_TYPE_PROPERTY_TYPES (DSTY_ID);\\012CREATE INDEX DSTPT_PERS_FK_I ON DATA_SET_TYPE_PROPERTY_TYPES (PERS_ID_REGISTERER);\\012CREATE INDEX DSTPT_PRTY_FK_I ON DATA_SET_TYPE_PROPERTY_TYPES (PRTY_ID);\\012\\012CREATE OR REPLACE FUNCTION DATA_SET_PROPERTY_WITH_MATERIAL_DATA_TYPE_CHECK() RETURNS trigger AS $$\\012DECLARE\\012   v_type_id  CODE;\\012   v_type_id_prop  CODE;\\012BEGIN\\012   if NEW.mate_prop_id IS NOT NULL then\\012\\011\\011\\011-- find material type id of the property type \\012\\011\\011\\011select pt.maty_prop_id into v_type_id_prop \\012\\011\\011\\011  from data_set_type_property_types dstpt, property_types pt \\012\\011\\011\\011 where NEW.dstpt_id = dstpt.id AND dstpt.prty_id = pt.id;\\012\\011\\011\\012\\011\\011\\011if v_type_id_prop IS NOT NULL then\\012\\011\\011\\011\\011-- find material type id of the material which consists the entity's property value\\012\\011\\011\\011\\011select entity.maty_id into v_type_id \\012\\011\\011\\011\\011  from materials entity\\012\\011\\011\\011\\011 where NEW.mate_prop_id = entity.id;\\012\\011\\011\\011\\011if v_type_id != v_type_id_prop then\\012\\011\\011\\011\\011\\011RAISE EXCEPTION 'Insert/Update of property value referencing material (id: %) failed, as referenced material type is different than expected (id %, expected id: %).', \\012\\011\\011\\011\\011\\011\\011\\011\\011\\011\\011\\011\\011 NEW.mate_prop_id, v_type_id, v_type_id_prop;\\012\\011\\011\\011\\011end if;\\012\\011\\011\\011end if;\\012   end if;\\012   RETURN NEW;\\012END;\\012$$ LANGUAGE 'plpgsql';\\012\\012CREATE TRIGGER DATA_SET_PROPERTY_WITH_MATERIAL_DATA_TYPE_CHECK BEFORE INSERT OR UPDATE ON data_set_properties\\012    FOR EACH ROW EXECUTE PROCEDURE DATA_SET_PROPERTY_WITH_MATERIAL_DATA_TYPE_CHECK();   \\012	\N
+./sourceTest/sql/postgresql/052/.svn/text-base/017=database_version_logs.tsv.svn-base:032	source/sql/postgresql/migration/migration-031-032.sql	SUCCESS	2009-04-09 09:36:36.2	-- -------\\012-- Modify MATERIAL_BATCHES\\012-- -------\\012\\012ALTER TABLE material_batches\\012    DROP COLUMN proc_id;\\012\\012-- -------\\012-- Modify SAMPLES\\012-- -------\\012\\012ALTER TABLE samples\\012    ADD COLUMN expe_id tech_id;\\012\\012ALTER TABLE samples\\012    ADD CONSTRAINT samp_expe_fk FOREIGN KEY (expe_id) REFERENCES experiments(id);\\012\\012CREATE INDEX samp_expe_fk_i ON samples USING btree (expe_id);\\012\\012-- relink samples directly to experiments\\012\\012UPDATE samples\\012SET expe_id = (SELECT e.id FROM experiments e, procedures p, sample_inputs si \\012               WHERE si.samp_id = samples.id AND si.proc_id = p.id AND p.expe_id = e.id AND e.inva_id IS NULL);\\012\\012\\012-- -------\\012-- Modify DATA\\012-- -------\\012\\012ALTER TABLE data\\012    ADD COLUMN expe_id tech_id;\\012\\012ALTER TABLE data\\012    ADD CONSTRAINT data_expe_fk FOREIGN KEY (expe_id) REFERENCES experiments(id);\\012\\012CREATE INDEX data_expe_fk_i ON data USING btree (expe_id);\\012\\012UPDATE data\\012SET expe_id = (SELECT e.id FROM experiments e, procedures p \\012               WHERE data.proc_id_produced_by = p.id AND p.expe_id = e.id);\\012\\012ALTER TABLE data\\012    ALTER COLUMN expe_id SET NOT NULL;\\012\\012ALTER TABLE data\\012    DROP COLUMN proc_id_produced_by;\\012\\012-- -------\\012-- Drop PROCEDURES, PROCEDURE_TYPES, and SAMPLE_INPUTS\\012-- -------\\012\\012DROP TABLE sample_inputs;\\012DROP TABLE procedures;\\012DROP TABLE procedure_types;\\012\\012DROP SEQUENCE procedure_id_seq;\\012DROP SEQUENCE procedure_type_id_seq;\\012\\012-- -------\\012-- Add CODE_SEQ\\012-- -------\\012\\012CREATE SEQUENCE CODE_SEQ;\\012\\012-- -------\\012-- Add new columns to DATA_STORES\\012-- -------\\012\\012ALTER TABLE data_stores\\012    ADD COLUMN remote_url character varying(250),\\012    ADD COLUMN session_token character varying(50),\\012    ADD COLUMN modification_timestamp time_stamp DEFAULT now();\\012\\012UPDATE data_stores\\012SET remote_url = '', session_token='';\\012\\012ALTER TABLE data_stores\\012    ALTER COLUMN remote_url SET NOT NULL,\\012    ALTER COLUMN session_token SET NOT NULL;\\012\\012-- -------\\012-- Drop foreign keys onto DATA_STORES\\012-- -------\\012\\012ALTER TABLE database_instances\\012    DROP COLUMN dast_id;\\012\\012ALTER TABLE groups\\012    DROP COLUMN dast_id;\\012\\012ALTER TABLE projects\\012    DROP COLUMN dast_id;\\012\\012ALTER TABLE experiments\\012    DROP COLUMN dast_id;\\012\\012-- -------\\012-- Add foreign key from DATA onto DATA_STORES\\012-- -------\\012\\012ALTER TABLE data\\012    ADD COLUMN dast_id tech_id;\\012\\012ALTER TABLE data\\012    ADD CONSTRAINT data_dast_fk FOREIGN KEY (dast_id) REFERENCES data_stores(id);\\012\\012UPDATE data\\012SET dast_id = (select id from data_stores where code = 'STANDARD');\\012\\012ALTER TABLE data\\012    ALTER COLUMN dast_id SET NOT NULL;\\012\\012\\012------------------------------------------------------------------------------------\\012--  Purpose:  Replace trigger SAMPLE_CODE_UNIQUENESS_CHECK \\012------------------------------------------------------------------------------------\\012\\012CREATE OR REPLACE FUNCTION SAMPLE_CODE_UNIQUENESS_CHECK() RETURNS trigger AS $$\\012DECLARE\\012   counter  INTEGER;\\012BEGIN\\012    LOCK TABLE samples IN EXCLUSIVE MODE;\\012    IF (NEW.samp_id_part_of is NULL) THEN\\012        IF (NEW.dbin_id is not NULL) THEN\\012            SELECT count(*) into counter FROM samples \\012                where id != NEW.id and code = NEW.code and samp_id_part_of is NULL and dbin_id = NEW.dbin_id;\\012            IF (counter > 0) THEN\\012                RAISE EXCEPTION 'Insert/Update of Sample (Code: %) failed because database instance sample with the same code already exists.', NEW.code;\\012            END IF;\\012        ELSIF (NEW.grou_id is not NULL) THEN\\012            SELECT count(*) into counter FROM samples \\012                where id != NEW.id and code = NEW.code and samp_id_part_of is NULL and grou_id = NEW.grou_id;\\012            IF (counter > 0) THEN\\012                RAISE EXCEPTION 'Insert/Update of Sample (Code: %) failed because group sample with the same code already exists.', NEW.code;\\012            END IF;\\012        END IF;\\012        ELSE\\012        IF (NEW.dbin_id is not NULL) THEN\\012            SELECT count(*) into counter FROM samples \\012                where id != NEW.id and code = NEW.code and samp_id_part_of = NEW.samp_id_part_of and dbin_id = NEW.dbin_id;\\012            IF (counter > 0) THEN\\012                RAISE EXCEPTION 'Insert/Update of Sample (Code: %) failed because database instance sample with the same code and being the part of the same parent already exists.', NEW.code;\\012            END IF;\\012        ELSIF (NEW.grou_id is not NULL) THEN\\012            SELECT count(*) into counter FROM samples \\012                where id != NEW.id and code = NEW.code and samp_id_part_of = NEW.samp_id_part_of and grou_id = NEW.grou_id;\\012            IF (counter > 0) THEN\\012                RAISE EXCEPTION 'Insert/Update of Sample (Code: %) failed because group sample with the same code and being the part of the same parent already exists.', NEW.code;\\012            END IF;\\012        END IF;\\012        END IF;   \\012   RETURN NEW;\\012END;\\012$$ LANGUAGE 'plpgsql';\\012\\012\\012\\012	\N
+./sourceTest/sql/postgresql/052/.svn/text-base/017=database_version_logs.tsv.svn-base:034	source/sql/postgresql/migration/migration-033-034.sql	SUCCESS	2009-05-26 08:32:49.935	------------------------------------------------------------------------------------\\012-- Create sequence for generating permanent identifiers starting with nextval of existing dataset sequence.\\012------------------------------------------------------------------------------------\\012CREATE FUNCTION CREATE_SEQUENCE(EXISTING_SEQUENCE VARCHAR, NEW_SEQUENCE VARCHAR) RETURNS VOID AS $$\\012DECLARE\\012  CURR_SEQ_VAL   INTEGER;\\012BEGIN\\012  SELECT INTO CURR_SEQ_VAL NEXTVAL(EXISTING_SEQUENCE);\\012  EXECUTE 'CREATE SEQUENCE ' || NEW_SEQUENCE || ' START WITH ' || CURR_SEQ_VAL;\\012  RETURN;\\012END;\\012$$ LANGUAGE 'plpgsql';\\012\\012SELECT CREATE_SEQUENCE('DATA_ID_SEQ', 'PERM_ID_SEQ');\\012DROP FUNCTION CREATE_SEQUENCE(VARCHAR, VARCHAR);\\012\\012------------------------------------------------------------------------------------\\012-- Add perm_id columns to samples and experiments.\\012------------------------------------------------------------------------------------\\012ALTER TABLE SAMPLES ADD COLUMN PERM_ID CODE;\\012ALTER TABLE EXPERIMENTS ADD COLUMN PERM_ID CODE;\\012\\012UPDATE SAMPLES SET PERM_ID = to_char(registration_timestamp,'YYYYMMDDHHSSMS') || '-' || NEXTVAL('PERM_ID_SEQ');\\012UPDATE EXPERIMENTS SET PERM_ID = to_char(registration_timestamp,'YYYYMMDDHHSSMS') || '-' || NEXTVAL('PERM_ID_SEQ');\\012ALTER TABLE SAMPLES ALTER COLUMN PERM_ID SET NOT NULL;\\012ALTER TABLE EXPERIMENTS ALTER COLUMN PERM_ID SET NOT NULL;\\012ALTER TABLE SAMPLES ADD CONSTRAINT SAMP_PI_UK UNIQUE(PERM_ID);\\012ALTER TABLE EXPERIMENTS ADD CONSTRAINT EXPE_PI_UK UNIQUE(PERM_ID);\\012\\012\\012------------------------------------------------------------------------------------\\012-- Add column is_chosen_from_list to controlled_vocabularies.\\012------------------------------------------------------------------------------------\\012ALTER TABLE controlled_vocabularies ADD COLUMN is_chosen_from_list BOOLEAN_CHAR NOT NULL DEFAULT TRUE;\\012ALTER TABLE controlled_vocabularies ADD COLUMN source_uri CHARACTER VARYING(250);\\012------------------------------------------------------------------------------------\\012-- Modify Data table - remove arc connection between Sample and Data table, use a flag instead\\012------------------------------------------------------------------------------------\\012\\012-- add new columns\\012\\012ALTER TABLE data\\012    ADD COLUMN is_derived boolean_char;\\012ALTER TABLE data\\012    ADD COLUMN samp_id tech_id;\\012\\012-- update values in new columns\\012\\012UPDATE data\\012    SET is_derived = (samp_id_derived_from IS NOT NULL); \\012UPDATE data\\012    SET samp_id = samp_id_derived_from \\012    WHERE is_derived = 'TRUE';\\012UPDATE data\\012    SET samp_id = samp_id_acquired_from \\012    WHERE is_derived = 'FALSE';\\012\\012-- add constraints and indexes to new columns\\012\\012ALTER TABLE data\\012    ALTER COLUMN is_derived SET NOT NULL;\\012ALTER TABLE data\\012    ALTER COLUMN samp_id SET NOT NULL;   \\012ALTER TABLE data\\012    ADD CONSTRAINT data_samp_fk FOREIGN KEY (samp_id) REFERENCES samples (id);\\012CREATE INDEX data_samp_fk_i ON data USING btree (samp_id);\\012\\012-- remove old columns\\012\\012ALTER TABLE data\\012    DROP COLUMN samp_id_acquired_from;\\012ALTER TABLE data\\012    DROP COLUMN samp_id_derived_from;\\012    \\012------------------------------------------------------------------------------------\\012-- Granting SELECT privilege to group openbis_readonly\\012------------------------------------------------------------------------------------\\012\\012GRANT SELECT ON SEQUENCE attachment_content_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE attachment_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE code_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE controlled_vocabulary_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE cvte_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE data_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE data_set_property_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE data_set_relationship_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE data_set_type_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE data_store_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE data_type_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE database_instance_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE dstpt_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE etpt_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE event_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE experiment_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE experiment_property_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE experiment_type_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE file_format_type_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE group_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE invalidation_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE locator_type_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE material_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE material_property_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE material_type_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE mtpt_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE perm_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE person_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE project_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE property_type_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE role_assignment_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE sample_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE sample_property_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE sample_type_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE stpt_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE attachment_contents TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE attachments TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE controlled_vocabularies TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE controlled_vocabulary_terms TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE data TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE data_set_properties TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE data_set_relationships TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE data_set_type_property_types TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE data_set_types TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE data_stores TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE data_types TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE database_instances TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE database_version_logs TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE events TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE experiment_properties TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE experiment_type_property_types TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE experiment_types TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE experiments TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE external_data TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE file_format_types TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE groups TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE invalidations TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE locator_types TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE material_properties TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE material_type_property_types TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE material_types TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE materials TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE persons TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE projects TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE property_types TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE role_assignments TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE sample_properties TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE sample_type_property_types TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE sample_types TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE samples TO GROUP OPENBIS_READONLY;\\012\\012------------------------------------------------------------------------------------\\012-- Delete MATERIAL_BATCHES table\\012------------------------------------------------------------------------------------\\012\\012-- WARNING: Potential data lost!!!\\012-- WARNING: Potential data lost!!!\\012-- WARNING: Potential data lost!!!\\012\\012DROP TABLE SAMPLE_MATERIAL_BATCHES;\\012DROP TABLE MATERIAL_BATCHES;\\012DROP SEQUENCE MATERIAL_BATCH_ID_SEQ;\\012\\012------------------------------------------------------------------------------------\\012-- Delete MATE_ID_INHIBITOR_OF from table MATERIALS\\012------------------------------------------------------------------------------------\\012\\012-- WARNING: Potential data lost!!!\\012-- WARNING: Potential data lost!!!\\012-- WARNING: Potential data lost!!!\\012\\012ALTER TABLE MATERIALS DROP COLUMN MATE_ID_INHIBITOR_OF;\\012	\N
+./sourceTest/sql/postgresql/052/.svn/text-base/017=database_version_logs.tsv.svn-base:041	source/sql/postgresql/migration/migration-040-041.sql	SUCCESS	2009-09-14 13:48:57.539	-- Create FILTERS table\\012\\012CREATE TABLE FILTERS (ID TECH_ID NOT NULL, DBIN_ID TECH_ID NOT NULL, NAME VARCHAR(200) NOT NULL, DESCRIPTION DESCRIPTION_1000,REGISTRATION_TIMESTAMP TIME_STAMP_DFL NOT NULL DEFAULT CURRENT_TIMESTAMP, PERS_ID_REGISTERER TECH_ID NOT NULL, MODIFICATION_TIMESTAMP TIME_STAMP DEFAULT CURRENT_TIMESTAMP, EXPRESSION VARCHAR(2000) NOT NULL, IS_PUBLIC BOOLEAN NOT NULL, GRID_ID VARCHAR(200) NOT NULL);\\012CREATE SEQUENCE FILTER_ID_SEQ;\\012ALTER TABLE FILTERS ADD CONSTRAINT FILT_PK PRIMARY KEY(ID);\\012ALTER TABLE FILTERS ADD CONSTRAINT FILT_BK_UK UNIQUE(NAME, DBIN_ID, GRID_ID);\\012ALTER TABLE FILTERS ADD CONSTRAINT FILT_PERS_FK FOREIGN KEY (PERS_ID_REGISTERER) REFERENCES PERSONS(ID);\\012ALTER TABLE FILTERS ADD CONSTRAINT FILT_DBIN_FK FOREIGN KEY (DBIN_ID) REFERENCES DATABASE_INSTANCES(ID);\\012CREATE INDEX FILT_PERS_FK_I ON FILTERS (PERS_ID_REGISTERER);\\012CREATE INDEX FILT_DBIN_FK_I ON FILTERS (DBIN_ID);\\012GRANT SELECT ON SEQUENCE filter_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE filters TO GROUP OPENBIS_READONLY;\\012\\012-- Add missing foreign key to role assignments authorization group\\012ALTER TABLE ROLE_ASSIGNMENTS ADD CONSTRAINT ROAS_AG_FK_GRANTEE FOREIGN KEY (AG_ID_GRANTEE) REFERENCES AUTHORIZATION_GROUPS(ID);\\012\\012--------------------------------------------------------------------------------------------------\\012-- Modify dataset connections:\\012-- 1. connection with sample shouldn't be mandatory any more\\012-- 2. introduce an arc condition that dataset cannot be connected with a sample and a parent dataset at the same time\\012--------------------------------------------------------------------------------------------------\\012\\012-- Weaken data-sample connection constraint - allow dataset to have no connection with sample\\012ALTER TABLE data ALTER COLUMN samp_id DROP NOT NULL;\\012\\012-- Remove data-sample connection for datasets that have a parent\\012\\012UPDATE data \\012   SET samp_id = NULL \\012 WHERE id IN (SELECT DISTINCT data_id_child FROM data_set_relationships);\\012\\012-- With PostgreSQL 8.4 one can check that before migration there were no cycles in dataset relationships:\\012--\\012-- WITH RECURSIVE data_set_parents(id, parent_ids, cycle) AS (\\012--         SELECT  r.data_id_child AS id, \\012--                 ARRAY[CAST (r.data_id_parent AS bigint)] AS parent_ids, \\012--                 false AS cycle \\012--         FROM data_set_relationships r\\012--     UNION ALL\\012--         SELECT  r.data_id_child,\\012--                 CAST (r.data_id_parent AS bigint) || p.parent_ids,\\012--                 r.data_id_child = ANY(p.parent_ids)\\012--         FROM data_set_relationships r, data_set_parents p\\012--         WHERE r.data_id_parent = p.id AND NOT cycle\\012-- )\\012-- SELECT count(*) AS cycles FROM data_set_parents WHERE cycle = true;\\012\\012---------------------------------------------------------------------------------------------------\\012--  Purpose:  Create DEFERRED triggers:\\012--            * check_dataset_relationships_on_data_table_modification,\\012--            * check_dataset_relationships_on_relationships_table_modification.\\012--            They check that after all modifications of database (just before commit) \\012--            if 'data'/'data_set_relationships' tables are among modified tables \\012--            dataset is not connected with a sample and a parent dataset at the same time.\\012--            This connections are held in two different tables so simple immediate trigger \\012--            with arc check cannot be used and we need two deferred triggers.\\012----------------------------------------------------------------------------------------------------\\012\\012-- trigger for 'data' table\\012\\012CREATE OR REPLACE FUNCTION check_dataset_relationships_on_data_table_modification() RETURNS trigger AS $$\\012DECLARE\\012\\011counter\\011INTEGER;\\012BEGIN\\012\\011-- if there is a connection with a Sample there should not be any connection with a parent Data Set\\012\\011IF (NEW.samp_id IS NOT NULL) THEN\\012\\011\\011-- count number of parents\\012\\011\\011SELECT count(*) INTO counter \\012\\011\\011\\011FROM data_set_relationships \\012\\011\\011\\011WHERE data_id_child = OLD.id;\\012\\011\\011IF (counter > 0) THEN\\012\\011\\011\\011RAISE EXCEPTION 'Insert/Update of Data Set (Code: %) failed because it cannot be connected with a Sample and a parent Data Set at the same time.', OLD.code;\\012\\011\\011END IF;\\012\\011END IF;\\012  RETURN NEW;\\012END;\\012$$ LANGUAGE 'plpgsql';\\012\\012CREATE CONSTRAINT TRIGGER check_dataset_relationships_on_data_table_modification \\012  AFTER INSERT OR UPDATE ON data\\012\\011DEFERRABLE INITIALLY DEFERRED\\012\\011FOR EACH ROW \\012\\011EXECUTE PROCEDURE check_dataset_relationships_on_data_table_modification();\\012\\012-- trigger for 'data_set_relationships'\\012\\012CREATE OR REPLACE FUNCTION check_dataset_relationships_on_relationships_table_modification() RETURNS trigger AS $$\\012DECLARE\\012\\011counter\\011INTEGER;\\012\\011sample_id\\011TECH_ID;\\012\\011data_code\\011CODE;\\012BEGIN\\012\\011-- child will have a parent added so it should not be connected with any sample\\012\\011SELECT samp_id, code INTO sample_id, data_code \\012\\011\\011FROM data \\012\\011\\011WHERE id = NEW.data_id_child;\\012\\011IF (sample_id IS NOT NULL) THEN\\012\\011\\011RAISE EXCEPTION 'Insert/Update of Data Set (Code: %) failed because it cannot be connected to a Sample and to a parent Data Set at the same time.', data_code;\\012\\011END IF;\\012\\011RETURN NEW;\\012END;\\012$$ LANGUAGE 'plpgsql';\\012  \\012CREATE CONSTRAINT TRIGGER check_dataset_relationships_on_relationships_table_modification \\012  AFTER INSERT OR UPDATE ON data_set_relationships\\012\\011DEFERRABLE INITIALLY DEFERRED\\012\\011FOR EACH ROW \\012\\011EXECUTE PROCEDURE check_dataset_relationships_on_relationships_table_modification();\\012	\N
+./sourceTest/sql/postgresql/052/.svn/text-base/schema-052.sql.svn-base:    LANGUAGE plpgsql
+./sourceTest/sql/postgresql/052/.svn/text-base/schema-052.sql.svn-base:    LANGUAGE plpgsql
+./sourceTest/sql/postgresql/052/.svn/text-base/schema-052.sql.svn-base:    LANGUAGE plpgsql
+./sourceTest/sql/postgresql/052/.svn/text-base/schema-052.sql.svn-base:    LANGUAGE plpgsql
+./sourceTest/sql/postgresql/052/.svn/text-base/schema-052.sql.svn-base:    LANGUAGE plpgsql
+./sourceTest/sql/postgresql/052/.svn/text-base/schema-052.sql.svn-base:    LANGUAGE plpgsql
+./sourceTest/sql/postgresql/052/.svn/text-base/schema-052.sql.svn-base:    LANGUAGE plpgsql
+./sourceTest/sql/postgresql/052/.svn/text-base/schema-052.sql.svn-base:    LANGUAGE plpgsql
+./sourceTest/sql/postgresql/052/.svn/text-base/schema-052.sql.svn-base:    LANGUAGE plpgsql
+./sourceTest/sql/postgresql/052/.svn/text-base/schema-052.sql.svn-base:    LANGUAGE plpgsql
+./sourceTest/sql/postgresql/052/017=database_version_logs.tsv:027	D:\\User\\felmer\\dev-workspace\\openbis/source/sql/postgresql/027/function-027.sql	SUCCESS	2008-11-05 09:18:00.403	-- Creating Functions\\012\\012------------------------------------------------------------------------------------\\012--  Purpose:  Create function RENAME_SEQUENCE() that is required for renaming the sequences belonging to tables\\012------------------------------------------------------------------------------------\\012CREATE FUNCTION RENAME_SEQUENCE(OLD_NAME VARCHAR, NEW_NAME VARCHAR) RETURNS INTEGER AS $$\\012DECLARE\\012  CURR_SEQ_VAL   INTEGER;\\012BEGIN\\012  SELECT INTO CURR_SEQ_VAL NEXTVAL(OLD_NAME);\\012  EXECUTE 'CREATE SEQUENCE ' || NEW_NAME || ' START WITH ' || CURR_SEQ_VAL;\\012  EXECUTE 'DROP SEQUENCE ' || OLD_NAME;\\012  RETURN CURR_SEQ_VAL;\\012END;\\012$$ LANGUAGE 'plpgsql';\\012\\012\\012------------------------------------------------------------------------------------\\012--  Purpose:  Create trigger CONTROLLED_VOCABULARY_CHECK \\012------------------------------------------------------------------------------------\\012\\012CREATE OR REPLACE FUNCTION CONTROLLED_VOCABULARY_CHECK() RETURNS trigger AS $$\\012DECLARE\\012   v_code  CODE;\\012BEGIN\\012\\012   select code into v_code from data_types where id = NEW.daty_id;\\012\\012   -- Check if the data is of type "CONTROLLEDVOCABULARY"\\012   if v_code = 'CONTROLLEDVOCABULARY' then\\012      if NEW.covo_id IS NULL then\\012         RAISE EXCEPTION 'Insert/Update of Property Type (Code: %) failed, as its Data Type is CONTROLLEDVOCABULARY, but it is not linked to a Controlled Vocabulary.', NEW.code;\\012      end if;\\012   end if;\\012\\012   RETURN NEW;\\012\\012END;\\012$$ LANGUAGE 'plpgsql';\\012\\012CREATE TRIGGER CONTROLLED_VOCABULARY_CHECK BEFORE INSERT OR UPDATE ON PROPERTY_TYPES\\012    FOR EACH ROW EXECUTE PROCEDURE CONTROLLED_VOCABULARY_CHECK();\\012\\012\\012------------------------------------------------------------------------------------\\012--  Purpose:  Create trigger EXTERNAL_DATA_STORAGE_FORMAT_CHECK \\012------------------------------------------------------------------------------------\\012\\012CREATE OR REPLACE FUNCTION EXTERNAL_DATA_STORAGE_FORMAT_CHECK() RETURNS trigger AS $$\\012DECLARE\\012   v_covo_code  CODE;\\012   data_code CODE;\\012BEGIN\\012\\012   select code into v_covo_code from controlled_vocabularies\\012      where is_internal_namespace = true and \\012         id = (select covo_id from controlled_vocabulary_terms where id = NEW.cvte_id_stor_fmt);\\012   -- Check if the data storage format is a term of the controlled vocabulary "STORAGE_FORMAT"\\012   if v_covo_code != 'STORAGE_FORMAT' then\\012      select code into data_code from data where id = NEW.data_id; \\012      RAISE EXCEPTION 'Insert/Update of Data (Code: %) failed, as its Storage Format is %, but is required to be STORAGE_FORMAT.', data_code, v_covo_code;\\012   end if;\\012\\012   RETURN NEW;\\012\\012END;\\012$$ LANGUAGE 'plpgsql';\\012\\012CREATE TRIGGER EXTERNAL_DATA_STORAGE_FORMAT_CHECK BEFORE INSERT OR UPDATE ON EXTERNAL_DATA\\012    FOR EACH ROW EXECUTE PROCEDURE EXTERNAL_DATA_STORAGE_FORMAT_CHECK();\\012\\012------------------------------------------------------------------------------------\\012--  Purpose:  Create trigger SAMPLE_CODE_UNIQUENESS_CHECK \\012------------------------------------------------------------------------------------\\012\\012CREATE OR REPLACE FUNCTION SAMPLE_CODE_UNIQUENESS_CHECK() RETURNS trigger AS $$\\012DECLARE\\012   counter  INTEGER;\\012BEGIN\\012\\011IF (NEW.samp_id_part_of is NULL) THEN\\012\\011\\011IF (NEW.dbin_id is not NULL) THEN\\012\\011\\011\\011SELECT count(*) into counter FROM samples \\012\\011\\011\\011\\011where id != NEW.id and code = NEW.code and samp_id_part_of is NULL and dbin_id = NEW.dbin_id;\\012\\011\\011\\011IF (counter > 0) THEN\\012\\011\\011\\011\\011RAISE EXCEPTION 'Insert/Update of Sample (Code: %) failed because database instance sample with the same code already exists.', NEW.code;\\012\\011\\011\\011END IF;\\012\\011\\011ELSIF (NEW.grou_id is not NULL) THEN\\012\\011\\011\\011SELECT count(*) into counter FROM samples \\012\\011\\011\\011\\011where id != NEW.id and code = NEW.code and samp_id_part_of is NULL and grou_id = NEW.grou_id;\\012\\011\\011\\011IF (counter > 0) THEN\\012\\011\\011\\011\\011RAISE EXCEPTION 'Insert/Update of Sample (Code: %) failed because group sample with the same code already exists.', NEW.code;\\012\\011\\011\\011END IF;\\012\\011\\011END IF;\\012        ELSE\\012\\011\\011IF (NEW.dbin_id is not NULL) THEN\\012\\011\\011\\011SELECT count(*) into counter FROM samples \\012\\011\\011\\011\\011where id != NEW.id and code = NEW.code and samp_id_part_of = NEW.samp_id_part_of and dbin_id = NEW.dbin_id;\\012\\011\\011\\011IF (counter > 0) THEN\\012\\011\\011\\011\\011RAISE EXCEPTION 'Insert/Update of Sample (Code: %) failed because database instance sample with the same code and being the part of the same parent already exists.', NEW.code;\\012\\011\\011\\011END IF;\\012\\011\\011ELSIF (NEW.grou_id is not NULL) THEN\\012\\011\\011\\011SELECT count(*) into counter FROM samples \\012\\011\\011\\011\\011where id != NEW.id and code = NEW.code and samp_id_part_of = NEW.samp_id_part_of and grou_id = NEW.grou_id;\\012\\011\\011\\011IF (counter > 0) THEN\\012\\011\\011\\011\\011RAISE EXCEPTION 'Insert/Update of Sample (Code: %) failed because group sample with the same code and being the part of the same parent already exists.', NEW.code;\\012\\011\\011\\011END IF;\\012\\011\\011END IF;\\012        END IF;   \\012   RETURN NEW;\\012END;\\012$$ LANGUAGE 'plpgsql';\\012\\012CREATE TRIGGER SAMPLE_CODE_UNIQUENESS_CHECK BEFORE INSERT OR UPDATE ON SAMPLES\\012    FOR EACH ROW EXECUTE PROCEDURE SAMPLE_CODE_UNIQUENESS_CHECK();\\012	\N
+./sourceTest/sql/postgresql/052/017=database_version_logs.tsv:028	source/sql/postgresql/migration/migration-027-028.sql	SUCCESS	2008-11-18 13:24:17.508	-- Create EXPERIMENT_ATTACHMENT_CONTENTS.\\012CREATE TABLE EXPERIMENT_ATTACHMENT_CONTENTS (ID TECH_ID NOT NULL,VALUE FILE NOT NULL);\\012CREATE SEQUENCE EXPERIMENT_ATTACHMENT_CONTENT_ID_SEQ;\\012ALTER TABLE EXPERIMENT_ATTACHMENT_CONTENTS ADD CONSTRAINT EXAC_PK PRIMARY KEY(ID);\\012\\012-- Alter EXPERIMENT_ATTACHMENTS by adding the new column which has a NULL constraint.\\012-- The NOT NULL constraint is added later on.\\012ALTER TABLE EXPERIMENT_ATTACHMENTS ADD COLUMN EXAC_ID TECH_ID;\\012\\012-- Does the VALUE migration between EXPERIMENT_ATTACHMENTS to EXPERIMENT_ATTACHMENT_CONTENTS.\\012CREATE OR REPLACE FUNCTION move_exp_att_content() RETURNS integer AS $$\\012DECLARE\\012    rec RECORD;\\012    seq BIGINT;\\012BEGIN\\012  FOR rec IN SELECT id, value FROM EXPERIMENT_ATTACHMENTS LOOP\\012  \\011seq := nextval('EXPERIMENT_ATTACHMENT_CONTENT_ID_SEQ');\\012    INSERT INTO EXPERIMENT_ATTACHMENT_CONTENTS (id, value) VALUES (seq, rec.value);\\012    UPDATE EXPERIMENT_ATTACHMENTS SET exac_id = seq WHERE id = rec.id;\\012  END LOOP;\\012  RETURN 1;\\012END;\\012$$ LANGUAGE 'plpgsql';\\012\\012-- Call the function.\\012SELECT move_exp_att_content();\\012DROP FUNCTION move_exp_att_content();\\012\\012\\012-- Finish EXPERIMENT_ATTACHMENTS changes.\\012ALTER TABLE EXPERIMENT_ATTACHMENTS ADD CONSTRAINT EXAT_CONT_FK FOREIGN KEY (EXAC_ID) REFERENCES EXPERIMENT_ATTACHMENT_CONTENTS(ID);\\012ALTER TABLE EXPERIMENT_ATTACHMENTS DROP COLUMN VALUE;\\012ALTER TABLE EXPERIMENT_ATTACHMENTS ALTER COLUMN EXAC_ID SET NOT NULL;\\012	\N
+./sourceTest/sql/postgresql/052/017=database_version_logs.tsv:029	source/sql/postgresql/migration/migration-028-029.sql	SUCCESS	2009-03-18 10:50:20.105	-- -------\\012-- add modification_timestamp field to allow edition with Hibernate\\012-- -------\\012\\012ALTER TABLE samples\\012\\011ADD COLUMN modification_timestamp TIME_STAMP DEFAULT CURRENT_TIMESTAMP;\\012\\012ALTER TABLE experiments\\012\\011ADD COLUMN modification_timestamp TIME_STAMP DEFAULT CURRENT_TIMESTAMP;\\012\\012ALTER TABLE materials\\012\\011ADD COLUMN modification_timestamp TIME_STAMP DEFAULT CURRENT_TIMESTAMP;\\012\\012ALTER TABLE experiment_properties\\012\\011ADD COLUMN modification_timestamp TIME_STAMP DEFAULT CURRENT_TIMESTAMP;\\012\\012ALTER TABLE material_properties\\012\\011ADD COLUMN modification_timestamp TIME_STAMP DEFAULT CURRENT_TIMESTAMP;\\012\\012ALTER TABLE sample_properties\\012\\011ADD COLUMN modification_timestamp TIME_STAMP DEFAULT CURRENT_TIMESTAMP;\\012\\012-- -------\\012-- add property data type which references materials\\012-- -------\\012\\012ALTER TABLE property_types\\012\\011ADD COLUMN maty_prop_id tech_id;\\012\\012ALTER TABLE property_types\\012\\011ADD CONSTRAINT prty_maty_fk FOREIGN KEY (maty_prop_id) REFERENCES material_types(id);\\012\\012ALTER TABLE experiment_properties\\012\\011ADD COLUMN mate_prop_id tech_id;\\012\\012ALTER TABLE material_properties\\012\\011ADD COLUMN mate_prop_id tech_id;\\012\\012ALTER TABLE sample_properties\\012\\011ADD COLUMN mate_prop_id tech_id;\\012\\012ALTER TABLE experiment_properties\\012\\011ADD CONSTRAINT expr_mapr_fk FOREIGN KEY (mate_prop_id) REFERENCES materials(id);\\012\\012ALTER TABLE material_properties\\012\\011ADD CONSTRAINT mapr_mapr_fk FOREIGN KEY (mate_prop_id) REFERENCES materials(id);\\012\\012ALTER TABLE sample_properties\\012\\011ADD CONSTRAINT sapr_mapr_fk FOREIGN KEY (mate_prop_id) REFERENCES materials(id);\\012\\012insert into data_types\\012(id\\012 ,code\\012 ,description)\\012 values \\012 (nextval('DATA_TYPE_ID_SEQ')\\012 ,'MATERIAL'\\012 ,'Reference to a material'\\012);\\012\\012ALTER TABLE MATERIAL_PROPERTIES DROP CONSTRAINT MAPR_CK;\\012ALTER TABLE MATERIAL_PROPERTIES ADD CONSTRAINT MAPR_CK CHECK \\012\\011((VALUE IS NOT NULL AND CVTE_ID IS NULL AND MATE_PROP_ID IS NULL) OR \\012\\011 (VALUE IS NULL AND CVTE_ID IS NOT NULL AND MATE_PROP_ID IS NULL) OR\\012\\011 (VALUE IS NULL AND CVTE_ID IS NULL AND MATE_PROP_ID IS NOT NULL)\\012\\011);\\012\\012ALTER TABLE EXPERIMENT_PROPERTIES DROP CONSTRAINT EXPR_CK;\\012ALTER TABLE EXPERIMENT_PROPERTIES ADD CONSTRAINT EXPR_CK CHECK \\012\\011((VALUE IS NOT NULL AND CVTE_ID IS NULL AND MATE_PROP_ID IS NULL) OR \\012\\011 (VALUE IS NULL AND CVTE_ID IS NOT NULL AND MATE_PROP_ID IS NULL) OR\\012\\011 (VALUE IS NULL AND CVTE_ID IS NULL AND MATE_PROP_ID IS NOT NULL)\\012\\011);\\012\\012ALTER TABLE SAMPLE_PROPERTIES DROP CONSTRAINT SAPR_CK;\\012ALTER TABLE SAMPLE_PROPERTIES ADD CONSTRAINT SAPR_CK CHECK \\012\\011((VALUE IS NOT NULL AND CVTE_ID IS NULL AND MATE_PROP_ID IS NULL) OR \\012\\011 (VALUE IS NULL AND CVTE_ID IS NOT NULL AND MATE_PROP_ID IS NULL) OR\\012\\011 (VALUE IS NULL AND CVTE_ID IS NULL AND MATE_PROP_ID IS NOT NULL)\\012\\011);\\012\\012------------------------------------------------------------------------------------\\012--  Purpose:  Create trigger MATERIAL/SAMPLE/EXPERIMENT _PROPERTY_WITH_MATERIAL_DATA_TYPE_CHECK\\012--            It checks that if material property value is assigned to the entity,\\012--\\011\\011\\011\\011\\011\\011then the material type is equal to the one described by property type.\\012------------------------------------------------------------------------------------\\012\\012CREATE OR REPLACE FUNCTION MATERIAL_PROPERTY_WITH_MATERIAL_DATA_TYPE_CHECK() RETURNS trigger AS $$\\012DECLARE\\012   v_type_id  CODE;\\012   v_type_id_prop  CODE;\\012BEGIN\\012   if NEW.mate_prop_id IS NOT NULL then\\012\\011\\011\\011-- find material type id of the property type \\012\\011\\011\\011select pt.maty_prop_id into v_type_id_prop \\012\\011\\011\\011  from material_type_property_types etpt, property_types pt \\012\\011\\011\\011 where NEW.mtpt_id = etpt.id AND etpt.prty_id = pt.id;\\012\\011\\011\\012\\011\\011\\011if v_type_id_prop IS NOT NULL then\\012\\011\\011\\011\\011-- find material type id of the material which consists the entity's property value\\012\\011\\011\\011\\011select entity.maty_id into v_type_id \\012\\011\\011\\011\\011  from materials entity\\012\\011\\011\\011\\011 where NEW.mate_prop_id = entity.id;\\012\\011\\011\\011\\011if v_type_id != v_type_id_prop then\\012\\011\\011\\011\\011\\011RAISE EXCEPTION 'Insert/Update of property value referencing material (id: %) failed, as referenced material type is different than expected (id %, expected id: %).', \\012\\011\\011\\011\\011\\011\\011\\011 NEW.mate_prop_id, v_type_id, v_type_id_prop;\\012\\011\\011\\011\\011end if;\\012\\011\\011\\011end if;\\012   end if;\\012   RETURN NEW;\\012END;\\012$$ LANGUAGE 'plpgsql';\\012\\012CREATE TRIGGER MATERIAL_PROPERTY_WITH_MATERIAL_DATA_TYPE_CHECK BEFORE INSERT OR UPDATE ON material_properties\\012    FOR EACH ROW EXECUTE PROCEDURE MATERIAL_PROPERTY_WITH_MATERIAL_DATA_TYPE_CHECK();\\012    \\012CREATE OR REPLACE FUNCTION SAMPLE_PROPERTY_WITH_MATERIAL_DATA_TYPE_CHECK() RETURNS trigger AS $$\\012DECLARE\\012   v_type_id  CODE;\\012   v_type_id_prop  CODE;\\012BEGIN\\012   if NEW.mate_prop_id IS NOT NULL then\\012\\011\\011\\011-- find material type id of the property type \\012\\011\\011\\011select pt.maty_prop_id into v_type_id_prop \\012\\011\\011\\011  from sample_type_property_types etpt, property_types pt \\012\\011\\011\\011 where NEW.stpt_id = etpt.id AND etpt.prty_id = pt.id;\\012\\011\\011\\012\\011\\011\\011if v_type_id_prop IS NOT NULL then\\012\\011\\011\\011\\011-- find material type id of the material which consists the entity's property value\\012\\011\\011\\011\\011select entity.maty_id into v_type_id \\012\\011\\011\\011\\011  from materials entity\\012\\011\\011\\011\\011 where NEW.mate_prop_id = entity.id;\\012\\011\\011\\011\\011if v_type_id != v_type_id_prop then\\012\\011\\011\\011\\011\\011RAISE EXCEPTION 'Insert/Update of property value referencing material (id: %) failed, as referenced material type is different than expected (id %, expected id: %).', \\012\\011\\011\\011\\011\\011\\011\\011\\011\\011\\011\\011\\011 NEW.mate_prop_id, v_type_id, v_type_id_prop;\\012\\011\\011\\011\\011end if;\\012\\011\\011\\011end if;\\012   end if;\\012   RETURN NEW;\\012END;\\012$$ LANGUAGE 'plpgsql';\\012\\012CREATE TRIGGER SAMPLE_PROPERTY_WITH_MATERIAL_DATA_TYPE_CHECK BEFORE INSERT OR UPDATE ON sample_properties\\012    FOR EACH ROW EXECUTE PROCEDURE SAMPLE_PROPERTY_WITH_MATERIAL_DATA_TYPE_CHECK();\\012    \\012CREATE OR REPLACE FUNCTION EXPERIMENT_PROPERTY_WITH_MATERIAL_DATA_TYPE_CHECK() RETURNS trigger AS $$\\012DECLARE\\012   v_type_id  CODE;\\012   v_type_id_prop  CODE;\\012BEGIN\\012   if NEW.mate_prop_id IS NOT NULL then\\012\\011\\011\\011-- find material type id of the property type \\012\\011\\011\\011select pt.maty_prop_id into v_type_id_prop \\012\\011\\011\\011  from experiment_type_property_types etpt, property_types pt \\012\\011\\011\\011 where NEW.etpt_id = etpt.id AND etpt.prty_id = pt.id;\\012\\011\\011\\012\\011\\011\\011if v_type_id_prop IS NOT NULL then\\012\\011\\011\\011\\011-- find material type id of the material which consists the entity's property value\\012\\011\\011\\011\\011select entity.maty_id into v_type_id \\012\\011\\011\\011\\011  from materials entity\\012\\011\\011\\011\\011 where NEW.mate_prop_id = entity.id;\\012\\011\\011\\011\\011if v_type_id != v_type_id_prop then\\012\\011\\011\\011\\011\\011RAISE EXCEPTION 'Insert/Update of property value referencing material (id: %) failed, as referenced material type is different than expected (id %, expected id: %).', \\012\\011\\011\\011\\011\\011\\011\\011\\011\\011\\011\\011\\011 NEW.mate_prop_id, v_type_id, v_type_id_prop;\\012\\011\\011\\011\\011end if;\\012\\011\\011\\011end if;\\012   end if;\\012   RETURN NEW;\\012END;\\012$$ LANGUAGE 'plpgsql';\\012\\012CREATE TRIGGER EXPERIMENT_PROPERTY_WITH_MATERIAL_DATA_TYPE_CHECK BEFORE INSERT OR UPDATE ON experiment_properties\\012    FOR EACH ROW EXECUTE PROCEDURE EXPERIMENT_PROPERTY_WITH_MATERIAL_DATA_TYPE_CHECK();\\012       \\012-- -------\\012-- remove the reminescents of the OBSERVABLE_TYPE\\012-- -------\\012\\012ALTER TABLE data\\012\\011DROP CONSTRAINT data_obty_fk;\\012\\012ALTER TABLE data_set_types\\012\\011DROP CONSTRAINT obty_pk;\\012\\012ALTER TABLE data_set_types\\012\\011ADD CONSTRAINT dsty_pk PRIMARY KEY (id);\\012\\012ALTER TABLE data\\012\\011ADD CONSTRAINT data_dsty_fk FOREIGN KEY (dsty_id) REFERENCES data_set_types(id);\\012\\012ALTER TABLE data_set_types\\012\\011DROP CONSTRAINT obty_bk_uk;\\012\\012ALTER TABLE data_set_types\\012\\011DROP CONSTRAINT obty_dbin_fk;\\012\\012ALTER TABLE data_set_types\\012\\011ADD CONSTRAINT dsty_bk_uk UNIQUE (code, dbin_id);\\012\\012ALTER TABLE data_set_types\\012\\011ADD CONSTRAINT dsty_dbin_fk FOREIGN KEY (dbin_id) REFERENCES database_instances(id);\\012\\012DROP INDEX data_obty_fk_i;\\012\\012CREATE INDEX data_dsty_fk_i ON data(dsty_id);\\012	\N
+./sourceTest/sql/postgresql/052/017=database_version_logs.tsv:030	source/sql/postgresql/migration/migration-029-030.sql	SUCCESS	2009-03-23 15:34:44.72	-- -------\\012-- add modification_timestamp field to allow edition with Hibernate\\012-- -------\\012ALTER TABLE data\\012\\011ADD COLUMN modification_timestamp TIME_STAMP DEFAULT CURRENT_TIMESTAMP;\\012ALTER TABLE experiment_types\\012\\011ADD COLUMN modification_timestamp TIME_STAMP DEFAULT CURRENT_TIMESTAMP;\\012ALTER TABLE sample_types\\012\\011ADD COLUMN modification_timestamp TIME_STAMP DEFAULT CURRENT_TIMESTAMP;\\012ALTER TABLE material_types\\012\\011ADD COLUMN modification_timestamp TIME_STAMP DEFAULT CURRENT_TIMESTAMP;\\012ALTER TABLE data_set_types\\012\\011ADD COLUMN modification_timestamp TIME_STAMP DEFAULT CURRENT_TIMESTAMP;\\012ALTER TABLE controlled_vocabularies\\012\\011ADD COLUMN modification_timestamp TIME_STAMP DEFAULT CURRENT_TIMESTAMP;\\012-- -------\\012-- add properties to data sets\\012-- -------\\012CREATE TABLE DATA_SET_PROPERTIES (ID TECH_ID NOT NULL,DS_ID TECH_ID NOT NULL,DSTPT_ID TECH_ID NOT NULL,VALUE GENERIC_VALUE,CVTE_ID TECH_ID, MATE_PROP_ID TECH_ID, PERS_ID_REGISTERER TECH_ID NOT NULL,REGISTRATION_TIMESTAMP TIME_STAMP_DFL NOT NULL DEFAULT CURRENT_TIMESTAMP, MODIFICATION_TIMESTAMP TIME_STAMP DEFAULT CURRENT_TIMESTAMP);\\012CREATE TABLE DATA_SET_TYPE_PROPERTY_TYPES (ID TECH_ID NOT NULL,DSTY_ID TECH_ID NOT NULL,PRTY_ID TECH_ID NOT NULL,IS_MANDATORY BOOLEAN_CHAR NOT NULL DEFAULT 'F',IS_MANAGED_INTERNALLY BOOLEAN_CHAR NOT NULL DEFAULT 'F',PERS_ID_REGISTERER TECH_ID NOT NULL,REGISTRATION_TIMESTAMP TIME_STAMP_DFL NOT NULL DEFAULT CURRENT_TIMESTAMP);\\012\\012CREATE SEQUENCE DATA_SET_PROPERTY_ID_SEQ;\\012CREATE SEQUENCE DSTPT_ID_SEQ;\\012\\012ALTER TABLE DATA_SET_TYPE_PROPERTY_TYPES ADD CONSTRAINT DSTPT_PK PRIMARY KEY(ID);\\012ALTER TABLE DATA_SET_PROPERTIES ADD CONSTRAINT DSPR_PK PRIMARY KEY(ID);\\012\\012ALTER TABLE DATA_SET_TYPE_PROPERTY_TYPES ADD CONSTRAINT DSTPT_BK_UK UNIQUE(DSTY_ID,PRTY_ID);\\012ALTER TABLE DATA_SET_PROPERTIES ADD CONSTRAINT DSPR_BK_UK UNIQUE(DS_ID,DSTPT_ID);\\012\\012\\012ALTER TABLE DATA_SET_TYPE_PROPERTY_TYPES ADD CONSTRAINT DSTPT_DSTY_FK FOREIGN KEY (DSTY_ID) REFERENCES DATA_SET_TYPES(ID);\\012ALTER TABLE DATA_SET_TYPE_PROPERTY_TYPES ADD CONSTRAINT DSTPT_PERS_FK FOREIGN KEY (PERS_ID_REGISTERER) REFERENCES PERSONS(ID);\\012ALTER TABLE DATA_SET_TYPE_PROPERTY_TYPES ADD CONSTRAINT DSTPT_PRTY_FK FOREIGN KEY (PRTY_ID) REFERENCES PROPERTY_TYPES(ID);\\012ALTER TABLE DATA_SET_PROPERTIES ADD CONSTRAINT DSPR_CVTE_FK FOREIGN KEY (CVTE_ID) REFERENCES CONTROLLED_VOCABULARY_TERMS(ID);\\012ALTER TABLE DATA_SET_PROPERTIES ADD CONSTRAINT DSPR_DSTPT_FK FOREIGN KEY (DSTPT_ID) REFERENCES DATA_SET_TYPE_PROPERTY_TYPES(ID) ON DELETE CASCADE;\\012ALTER TABLE DATA_SET_PROPERTIES ADD CONSTRAINT DSPR_DS_FK FOREIGN KEY (DS_ID) REFERENCES DATA(ID);\\012ALTER TABLE DATA_SET_PROPERTIES ADD CONSTRAINT DSPR_PERS_FK FOREIGN KEY (PERS_ID_REGISTERER) REFERENCES PERSONS(ID);\\012ALTER TABLE DATA_SET_PROPERTIES ADD CONSTRAINT DSPR_MAPR_FK FOREIGN KEY (MATE_PROP_ID) REFERENCES MATERIALS(ID);\\012\\012ALTER TABLE DATA_SET_PROPERTIES ADD CONSTRAINT DSPR_CK CHECK \\012\\011((VALUE IS NOT NULL AND CVTE_ID IS NULL AND MATE_PROP_ID IS NULL) OR \\012\\011 (VALUE IS NULL AND CVTE_ID IS NOT NULL AND MATE_PROP_ID IS NULL) OR\\012\\011 (VALUE IS NULL AND CVTE_ID IS NULL AND MATE_PROP_ID IS NOT NULL)\\012\\011);\\012\\012CREATE INDEX DSPR_CVTE_FK_I ON DATA_SET_PROPERTIES (CVTE_ID);\\012CREATE INDEX DSPR_DSTPT_FK_I ON DATA_SET_PROPERTIES (DSTPT_ID);\\012CREATE INDEX DSPR_DS_FK_I ON DATA_SET_PROPERTIES (DS_ID);\\012CREATE INDEX DSPR_PERS_FK_I ON DATA_SET_PROPERTIES (PERS_ID_REGISTERER);\\012CREATE INDEX DSTPT_DSTY_FK_I ON DATA_SET_TYPE_PROPERTY_TYPES (DSTY_ID);\\012CREATE INDEX DSTPT_PERS_FK_I ON DATA_SET_TYPE_PROPERTY_TYPES (PERS_ID_REGISTERER);\\012CREATE INDEX DSTPT_PRTY_FK_I ON DATA_SET_TYPE_PROPERTY_TYPES (PRTY_ID);\\012\\012CREATE OR REPLACE FUNCTION DATA_SET_PROPERTY_WITH_MATERIAL_DATA_TYPE_CHECK() RETURNS trigger AS $$\\012DECLARE\\012   v_type_id  CODE;\\012   v_type_id_prop  CODE;\\012BEGIN\\012   if NEW.mate_prop_id IS NOT NULL then\\012\\011\\011\\011-- find material type id of the property type \\012\\011\\011\\011select pt.maty_prop_id into v_type_id_prop \\012\\011\\011\\011  from data_set_type_property_types dstpt, property_types pt \\012\\011\\011\\011 where NEW.dstpt_id = dstpt.id AND dstpt.prty_id = pt.id;\\012\\011\\011\\012\\011\\011\\011if v_type_id_prop IS NOT NULL then\\012\\011\\011\\011\\011-- find material type id of the material which consists the entity's property value\\012\\011\\011\\011\\011select entity.maty_id into v_type_id \\012\\011\\011\\011\\011  from materials entity\\012\\011\\011\\011\\011 where NEW.mate_prop_id = entity.id;\\012\\011\\011\\011\\011if v_type_id != v_type_id_prop then\\012\\011\\011\\011\\011\\011RAISE EXCEPTION 'Insert/Update of property value referencing material (id: %) failed, as referenced material type is different than expected (id %, expected id: %).', \\012\\011\\011\\011\\011\\011\\011\\011\\011\\011\\011\\011\\011 NEW.mate_prop_id, v_type_id, v_type_id_prop;\\012\\011\\011\\011\\011end if;\\012\\011\\011\\011end if;\\012   end if;\\012   RETURN NEW;\\012END;\\012$$ LANGUAGE 'plpgsql';\\012\\012CREATE TRIGGER DATA_SET_PROPERTY_WITH_MATERIAL_DATA_TYPE_CHECK BEFORE INSERT OR UPDATE ON data_set_properties\\012    FOR EACH ROW EXECUTE PROCEDURE DATA_SET_PROPERTY_WITH_MATERIAL_DATA_TYPE_CHECK();   \\012	\N
+./sourceTest/sql/postgresql/052/017=database_version_logs.tsv:032	source/sql/postgresql/migration/migration-031-032.sql	SUCCESS	2009-04-09 09:36:36.2	-- -------\\012-- Modify MATERIAL_BATCHES\\012-- -------\\012\\012ALTER TABLE material_batches\\012    DROP COLUMN proc_id;\\012\\012-- -------\\012-- Modify SAMPLES\\012-- -------\\012\\012ALTER TABLE samples\\012    ADD COLUMN expe_id tech_id;\\012\\012ALTER TABLE samples\\012    ADD CONSTRAINT samp_expe_fk FOREIGN KEY (expe_id) REFERENCES experiments(id);\\012\\012CREATE INDEX samp_expe_fk_i ON samples USING btree (expe_id);\\012\\012-- relink samples directly to experiments\\012\\012UPDATE samples\\012SET expe_id = (SELECT e.id FROM experiments e, procedures p, sample_inputs si \\012               WHERE si.samp_id = samples.id AND si.proc_id = p.id AND p.expe_id = e.id AND e.inva_id IS NULL);\\012\\012\\012-- -------\\012-- Modify DATA\\012-- -------\\012\\012ALTER TABLE data\\012    ADD COLUMN expe_id tech_id;\\012\\012ALTER TABLE data\\012    ADD CONSTRAINT data_expe_fk FOREIGN KEY (expe_id) REFERENCES experiments(id);\\012\\012CREATE INDEX data_expe_fk_i ON data USING btree (expe_id);\\012\\012UPDATE data\\012SET expe_id = (SELECT e.id FROM experiments e, procedures p \\012               WHERE data.proc_id_produced_by = p.id AND p.expe_id = e.id);\\012\\012ALTER TABLE data\\012    ALTER COLUMN expe_id SET NOT NULL;\\012\\012ALTER TABLE data\\012    DROP COLUMN proc_id_produced_by;\\012\\012-- -------\\012-- Drop PROCEDURES, PROCEDURE_TYPES, and SAMPLE_INPUTS\\012-- -------\\012\\012DROP TABLE sample_inputs;\\012DROP TABLE procedures;\\012DROP TABLE procedure_types;\\012\\012DROP SEQUENCE procedure_id_seq;\\012DROP SEQUENCE procedure_type_id_seq;\\012\\012-- -------\\012-- Add CODE_SEQ\\012-- -------\\012\\012CREATE SEQUENCE CODE_SEQ;\\012\\012-- -------\\012-- Add new columns to DATA_STORES\\012-- -------\\012\\012ALTER TABLE data_stores\\012    ADD COLUMN remote_url character varying(250),\\012    ADD COLUMN session_token character varying(50),\\012    ADD COLUMN modification_timestamp time_stamp DEFAULT now();\\012\\012UPDATE data_stores\\012SET remote_url = '', session_token='';\\012\\012ALTER TABLE data_stores\\012    ALTER COLUMN remote_url SET NOT NULL,\\012    ALTER COLUMN session_token SET NOT NULL;\\012\\012-- -------\\012-- Drop foreign keys onto DATA_STORES\\012-- -------\\012\\012ALTER TABLE database_instances\\012    DROP COLUMN dast_id;\\012\\012ALTER TABLE groups\\012    DROP COLUMN dast_id;\\012\\012ALTER TABLE projects\\012    DROP COLUMN dast_id;\\012\\012ALTER TABLE experiments\\012    DROP COLUMN dast_id;\\012\\012-- -------\\012-- Add foreign key from DATA onto DATA_STORES\\012-- -------\\012\\012ALTER TABLE data\\012    ADD COLUMN dast_id tech_id;\\012\\012ALTER TABLE data\\012    ADD CONSTRAINT data_dast_fk FOREIGN KEY (dast_id) REFERENCES data_stores(id);\\012\\012UPDATE data\\012SET dast_id = (select id from data_stores where code = 'STANDARD');\\012\\012ALTER TABLE data\\012    ALTER COLUMN dast_id SET NOT NULL;\\012\\012\\012------------------------------------------------------------------------------------\\012--  Purpose:  Replace trigger SAMPLE_CODE_UNIQUENESS_CHECK \\012------------------------------------------------------------------------------------\\012\\012CREATE OR REPLACE FUNCTION SAMPLE_CODE_UNIQUENESS_CHECK() RETURNS trigger AS $$\\012DECLARE\\012   counter  INTEGER;\\012BEGIN\\012    LOCK TABLE samples IN EXCLUSIVE MODE;\\012    IF (NEW.samp_id_part_of is NULL) THEN\\012        IF (NEW.dbin_id is not NULL) THEN\\012            SELECT count(*) into counter FROM samples \\012                where id != NEW.id and code = NEW.code and samp_id_part_of is NULL and dbin_id = NEW.dbin_id;\\012            IF (counter > 0) THEN\\012                RAISE EXCEPTION 'Insert/Update of Sample (Code: %) failed because database instance sample with the same code already exists.', NEW.code;\\012            END IF;\\012        ELSIF (NEW.grou_id is not NULL) THEN\\012            SELECT count(*) into counter FROM samples \\012                where id != NEW.id and code = NEW.code and samp_id_part_of is NULL and grou_id = NEW.grou_id;\\012            IF (counter > 0) THEN\\012                RAISE EXCEPTION 'Insert/Update of Sample (Code: %) failed because group sample with the same code already exists.', NEW.code;\\012            END IF;\\012        END IF;\\012        ELSE\\012        IF (NEW.dbin_id is not NULL) THEN\\012            SELECT count(*) into counter FROM samples \\012                where id != NEW.id and code = NEW.code and samp_id_part_of = NEW.samp_id_part_of and dbin_id = NEW.dbin_id;\\012            IF (counter > 0) THEN\\012                RAISE EXCEPTION 'Insert/Update of Sample (Code: %) failed because database instance sample with the same code and being the part of the same parent already exists.', NEW.code;\\012            END IF;\\012        ELSIF (NEW.grou_id is not NULL) THEN\\012            SELECT count(*) into counter FROM samples \\012                where id != NEW.id and code = NEW.code and samp_id_part_of = NEW.samp_id_part_of and grou_id = NEW.grou_id;\\012            IF (counter > 0) THEN\\012                RAISE EXCEPTION 'Insert/Update of Sample (Code: %) failed because group sample with the same code and being the part of the same parent already exists.', NEW.code;\\012            END IF;\\012        END IF;\\012        END IF;   \\012   RETURN NEW;\\012END;\\012$$ LANGUAGE 'plpgsql';\\012\\012\\012\\012	\N
+./sourceTest/sql/postgresql/052/017=database_version_logs.tsv:034	source/sql/postgresql/migration/migration-033-034.sql	SUCCESS	2009-05-26 08:32:49.935	------------------------------------------------------------------------------------\\012-- Create sequence for generating permanent identifiers starting with nextval of existing dataset sequence.\\012------------------------------------------------------------------------------------\\012CREATE FUNCTION CREATE_SEQUENCE(EXISTING_SEQUENCE VARCHAR, NEW_SEQUENCE VARCHAR) RETURNS VOID AS $$\\012DECLARE\\012  CURR_SEQ_VAL   INTEGER;\\012BEGIN\\012  SELECT INTO CURR_SEQ_VAL NEXTVAL(EXISTING_SEQUENCE);\\012  EXECUTE 'CREATE SEQUENCE ' || NEW_SEQUENCE || ' START WITH ' || CURR_SEQ_VAL;\\012  RETURN;\\012END;\\012$$ LANGUAGE 'plpgsql';\\012\\012SELECT CREATE_SEQUENCE('DATA_ID_SEQ', 'PERM_ID_SEQ');\\012DROP FUNCTION CREATE_SEQUENCE(VARCHAR, VARCHAR);\\012\\012------------------------------------------------------------------------------------\\012-- Add perm_id columns to samples and experiments.\\012------------------------------------------------------------------------------------\\012ALTER TABLE SAMPLES ADD COLUMN PERM_ID CODE;\\012ALTER TABLE EXPERIMENTS ADD COLUMN PERM_ID CODE;\\012\\012UPDATE SAMPLES SET PERM_ID = to_char(registration_timestamp,'YYYYMMDDHHSSMS') || '-' || NEXTVAL('PERM_ID_SEQ');\\012UPDATE EXPERIMENTS SET PERM_ID = to_char(registration_timestamp,'YYYYMMDDHHSSMS') || '-' || NEXTVAL('PERM_ID_SEQ');\\012ALTER TABLE SAMPLES ALTER COLUMN PERM_ID SET NOT NULL;\\012ALTER TABLE EXPERIMENTS ALTER COLUMN PERM_ID SET NOT NULL;\\012ALTER TABLE SAMPLES ADD CONSTRAINT SAMP_PI_UK UNIQUE(PERM_ID);\\012ALTER TABLE EXPERIMENTS ADD CONSTRAINT EXPE_PI_UK UNIQUE(PERM_ID);\\012\\012\\012------------------------------------------------------------------------------------\\012-- Add column is_chosen_from_list to controlled_vocabularies.\\012------------------------------------------------------------------------------------\\012ALTER TABLE controlled_vocabularies ADD COLUMN is_chosen_from_list BOOLEAN_CHAR NOT NULL DEFAULT TRUE;\\012ALTER TABLE controlled_vocabularies ADD COLUMN source_uri CHARACTER VARYING(250);\\012------------------------------------------------------------------------------------\\012-- Modify Data table - remove arc connection between Sample and Data table, use a flag instead\\012------------------------------------------------------------------------------------\\012\\012-- add new columns\\012\\012ALTER TABLE data\\012    ADD COLUMN is_derived boolean_char;\\012ALTER TABLE data\\012    ADD COLUMN samp_id tech_id;\\012\\012-- update values in new columns\\012\\012UPDATE data\\012    SET is_derived = (samp_id_derived_from IS NOT NULL); \\012UPDATE data\\012    SET samp_id = samp_id_derived_from \\012    WHERE is_derived = 'TRUE';\\012UPDATE data\\012    SET samp_id = samp_id_acquired_from \\012    WHERE is_derived = 'FALSE';\\012\\012-- add constraints and indexes to new columns\\012\\012ALTER TABLE data\\012    ALTER COLUMN is_derived SET NOT NULL;\\012ALTER TABLE data\\012    ALTER COLUMN samp_id SET NOT NULL;   \\012ALTER TABLE data\\012    ADD CONSTRAINT data_samp_fk FOREIGN KEY (samp_id) REFERENCES samples (id);\\012CREATE INDEX data_samp_fk_i ON data USING btree (samp_id);\\012\\012-- remove old columns\\012\\012ALTER TABLE data\\012    DROP COLUMN samp_id_acquired_from;\\012ALTER TABLE data\\012    DROP COLUMN samp_id_derived_from;\\012    \\012------------------------------------------------------------------------------------\\012-- Granting SELECT privilege to group openbis_readonly\\012------------------------------------------------------------------------------------\\012\\012GRANT SELECT ON SEQUENCE attachment_content_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE attachment_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE code_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE controlled_vocabulary_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE cvte_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE data_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE data_set_property_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE data_set_relationship_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE data_set_type_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE data_store_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE data_type_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE database_instance_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE dstpt_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE etpt_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE event_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE experiment_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE experiment_property_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE experiment_type_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE file_format_type_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE group_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE invalidation_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE locator_type_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE material_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE material_property_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE material_type_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE mtpt_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE perm_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE person_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE project_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE property_type_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE role_assignment_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE sample_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE sample_property_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE sample_type_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE stpt_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE attachment_contents TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE attachments TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE controlled_vocabularies TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE controlled_vocabulary_terms TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE data TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE data_set_properties TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE data_set_relationships TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE data_set_type_property_types TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE data_set_types TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE data_stores TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE data_types TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE database_instances TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE database_version_logs TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE events TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE experiment_properties TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE experiment_type_property_types TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE experiment_types TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE experiments TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE external_data TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE file_format_types TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE groups TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE invalidations TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE locator_types TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE material_properties TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE material_type_property_types TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE material_types TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE materials TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE persons TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE projects TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE property_types TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE role_assignments TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE sample_properties TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE sample_type_property_types TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE sample_types TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE samples TO GROUP OPENBIS_READONLY;\\012\\012------------------------------------------------------------------------------------\\012-- Delete MATERIAL_BATCHES table\\012------------------------------------------------------------------------------------\\012\\012-- WARNING: Potential data lost!!!\\012-- WARNING: Potential data lost!!!\\012-- WARNING: Potential data lost!!!\\012\\012DROP TABLE SAMPLE_MATERIAL_BATCHES;\\012DROP TABLE MATERIAL_BATCHES;\\012DROP SEQUENCE MATERIAL_BATCH_ID_SEQ;\\012\\012------------------------------------------------------------------------------------\\012-- Delete MATE_ID_INHIBITOR_OF from table MATERIALS\\012------------------------------------------------------------------------------------\\012\\012-- WARNING: Potential data lost!!!\\012-- WARNING: Potential data lost!!!\\012-- WARNING: Potential data lost!!!\\012\\012ALTER TABLE MATERIALS DROP COLUMN MATE_ID_INHIBITOR_OF;\\012	\N
+./sourceTest/sql/postgresql/052/017=database_version_logs.tsv:041	source/sql/postgresql/migration/migration-040-041.sql	SUCCESS	2009-09-14 13:48:57.539	-- Create FILTERS table\\012\\012CREATE TABLE FILTERS (ID TECH_ID NOT NULL, DBIN_ID TECH_ID NOT NULL, NAME VARCHAR(200) NOT NULL, DESCRIPTION DESCRIPTION_1000,REGISTRATION_TIMESTAMP TIME_STAMP_DFL NOT NULL DEFAULT CURRENT_TIMESTAMP, PERS_ID_REGISTERER TECH_ID NOT NULL, MODIFICATION_TIMESTAMP TIME_STAMP DEFAULT CURRENT_TIMESTAMP, EXPRESSION VARCHAR(2000) NOT NULL, IS_PUBLIC BOOLEAN NOT NULL, GRID_ID VARCHAR(200) NOT NULL);\\012CREATE SEQUENCE FILTER_ID_SEQ;\\012ALTER TABLE FILTERS ADD CONSTRAINT FILT_PK PRIMARY KEY(ID);\\012ALTER TABLE FILTERS ADD CONSTRAINT FILT_BK_UK UNIQUE(NAME, DBIN_ID, GRID_ID);\\012ALTER TABLE FILTERS ADD CONSTRAINT FILT_PERS_FK FOREIGN KEY (PERS_ID_REGISTERER) REFERENCES PERSONS(ID);\\012ALTER TABLE FILTERS ADD CONSTRAINT FILT_DBIN_FK FOREIGN KEY (DBIN_ID) REFERENCES DATABASE_INSTANCES(ID);\\012CREATE INDEX FILT_PERS_FK_I ON FILTERS (PERS_ID_REGISTERER);\\012CREATE INDEX FILT_DBIN_FK_I ON FILTERS (DBIN_ID);\\012GRANT SELECT ON SEQUENCE filter_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE filters TO GROUP OPENBIS_READONLY;\\012\\012-- Add missing foreign key to role assignments authorization group\\012ALTER TABLE ROLE_ASSIGNMENTS ADD CONSTRAINT ROAS_AG_FK_GRANTEE FOREIGN KEY (AG_ID_GRANTEE) REFERENCES AUTHORIZATION_GROUPS(ID);\\012\\012--------------------------------------------------------------------------------------------------\\012-- Modify dataset connections:\\012-- 1. connection with sample shouldn't be mandatory any more\\012-- 2. introduce an arc condition that dataset cannot be connected with a sample and a parent dataset at the same time\\012--------------------------------------------------------------------------------------------------\\012\\012-- Weaken data-sample connection constraint - allow dataset to have no connection with sample\\012ALTER TABLE data ALTER COLUMN samp_id DROP NOT NULL;\\012\\012-- Remove data-sample connection for datasets that have a parent\\012\\012UPDATE data \\012   SET samp_id = NULL \\012 WHERE id IN (SELECT DISTINCT data_id_child FROM data_set_relationships);\\012\\012-- With PostgreSQL 8.4 one can check that before migration there were no cycles in dataset relationships:\\012--\\012-- WITH RECURSIVE data_set_parents(id, parent_ids, cycle) AS (\\012--         SELECT  r.data_id_child AS id, \\012--                 ARRAY[CAST (r.data_id_parent AS bigint)] AS parent_ids, \\012--                 false AS cycle \\012--         FROM data_set_relationships r\\012--     UNION ALL\\012--         SELECT  r.data_id_child,\\012--                 CAST (r.data_id_parent AS bigint) || p.parent_ids,\\012--                 r.data_id_child = ANY(p.parent_ids)\\012--         FROM data_set_relationships r, data_set_parents p\\012--         WHERE r.data_id_parent = p.id AND NOT cycle\\012-- )\\012-- SELECT count(*) AS cycles FROM data_set_parents WHERE cycle = true;\\012\\012---------------------------------------------------------------------------------------------------\\012--  Purpose:  Create DEFERRED triggers:\\012--            * check_dataset_relationships_on_data_table_modification,\\012--            * check_dataset_relationships_on_relationships_table_modification.\\012--            They check that after all modifications of database (just before commit) \\012--            if 'data'/'data_set_relationships' tables are among modified tables \\012--            dataset is not connected with a sample and a parent dataset at the same time.\\012--            This connections are held in two different tables so simple immediate trigger \\012--            with arc check cannot be used and we need two deferred triggers.\\012----------------------------------------------------------------------------------------------------\\012\\012-- trigger for 'data' table\\012\\012CREATE OR REPLACE FUNCTION check_dataset_relationships_on_data_table_modification() RETURNS trigger AS $$\\012DECLARE\\012\\011counter\\011INTEGER;\\012BEGIN\\012\\011-- if there is a connection with a Sample there should not be any connection with a parent Data Set\\012\\011IF (NEW.samp_id IS NOT NULL) THEN\\012\\011\\011-- count number of parents\\012\\011\\011SELECT count(*) INTO counter \\012\\011\\011\\011FROM data_set_relationships \\012\\011\\011\\011WHERE data_id_child = OLD.id;\\012\\011\\011IF (counter > 0) THEN\\012\\011\\011\\011RAISE EXCEPTION 'Insert/Update of Data Set (Code: %) failed because it cannot be connected with a Sample and a parent Data Set at the same time.', OLD.code;\\012\\011\\011END IF;\\012\\011END IF;\\012  RETURN NEW;\\012END;\\012$$ LANGUAGE 'plpgsql';\\012\\012CREATE CONSTRAINT TRIGGER check_dataset_relationships_on_data_table_modification \\012  AFTER INSERT OR UPDATE ON data\\012\\011DEFERRABLE INITIALLY DEFERRED\\012\\011FOR EACH ROW \\012\\011EXECUTE PROCEDURE check_dataset_relationships_on_data_table_modification();\\012\\012-- trigger for 'data_set_relationships'\\012\\012CREATE OR REPLACE FUNCTION check_dataset_relationships_on_relationships_table_modification() RETURNS trigger AS $$\\012DECLARE\\012\\011counter\\011INTEGER;\\012\\011sample_id\\011TECH_ID;\\012\\011data_code\\011CODE;\\012BEGIN\\012\\011-- child will have a parent added so it should not be connected with any sample\\012\\011SELECT samp_id, code INTO sample_id, data_code \\012\\011\\011FROM data \\012\\011\\011WHERE id = NEW.data_id_child;\\012\\011IF (sample_id IS NOT NULL) THEN\\012\\011\\011RAISE EXCEPTION 'Insert/Update of Data Set (Code: %) failed because it cannot be connected to a Sample and to a parent Data Set at the same time.', data_code;\\012\\011END IF;\\012\\011RETURN NEW;\\012END;\\012$$ LANGUAGE 'plpgsql';\\012  \\012CREATE CONSTRAINT TRIGGER check_dataset_relationships_on_relationships_table_modification \\012  AFTER INSERT OR UPDATE ON data_set_relationships\\012\\011DEFERRABLE INITIALLY DEFERRED\\012\\011FOR EACH ROW \\012\\011EXECUTE PROCEDURE check_dataset_relationships_on_relationships_table_modification();\\012	\N
+./sourceTest/sql/postgresql/052/schema-052.sql:    LANGUAGE plpgsql
+./sourceTest/sql/postgresql/052/schema-052.sql:    LANGUAGE plpgsql
+./sourceTest/sql/postgresql/052/schema-052.sql:    LANGUAGE plpgsql
+./sourceTest/sql/postgresql/052/schema-052.sql:    LANGUAGE plpgsql
+./sourceTest/sql/postgresql/052/schema-052.sql:    LANGUAGE plpgsql
+./sourceTest/sql/postgresql/052/schema-052.sql:    LANGUAGE plpgsql
+./sourceTest/sql/postgresql/052/schema-052.sql:    LANGUAGE plpgsql
+./sourceTest/sql/postgresql/052/schema-052.sql:    LANGUAGE plpgsql
+./sourceTest/sql/postgresql/052/schema-052.sql:    LANGUAGE plpgsql
+./sourceTest/sql/postgresql/052/schema-052.sql:    LANGUAGE plpgsql
+./sourceTest/sql/postgresql/053/.svn/text-base/017=database_version_logs.tsv.svn-base:027	D:\\User\\felmer\\dev-workspace\\openbis/source/sql/postgresql/027/function-027.sql	SUCCESS	2008-11-05 09:18:00.403	-- Creating Functions\\012\\012------------------------------------------------------------------------------------\\012--  Purpose:  Create function RENAME_SEQUENCE() that is required for renaming the sequences belonging to tables\\012------------------------------------------------------------------------------------\\012CREATE FUNCTION RENAME_SEQUENCE(OLD_NAME VARCHAR, NEW_NAME VARCHAR) RETURNS INTEGER AS $$\\012DECLARE\\012  CURR_SEQ_VAL   INTEGER;\\012BEGIN\\012  SELECT INTO CURR_SEQ_VAL NEXTVAL(OLD_NAME);\\012  EXECUTE 'CREATE SEQUENCE ' || NEW_NAME || ' START WITH ' || CURR_SEQ_VAL;\\012  EXECUTE 'DROP SEQUENCE ' || OLD_NAME;\\012  RETURN CURR_SEQ_VAL;\\012END;\\012$$ LANGUAGE 'plpgsql';\\012\\012\\012------------------------------------------------------------------------------------\\012--  Purpose:  Create trigger CONTROLLED_VOCABULARY_CHECK \\012------------------------------------------------------------------------------------\\012\\012CREATE OR REPLACE FUNCTION CONTROLLED_VOCABULARY_CHECK() RETURNS trigger AS $$\\012DECLARE\\012   v_code  CODE;\\012BEGIN\\012\\012   select code into v_code from data_types where id = NEW.daty_id;\\012\\012   -- Check if the data is of type "CONTROLLEDVOCABULARY"\\012   if v_code = 'CONTROLLEDVOCABULARY' then\\012      if NEW.covo_id IS NULL then\\012         RAISE EXCEPTION 'Insert/Update of Property Type (Code: %) failed, as its Data Type is CONTROLLEDVOCABULARY, but it is not linked to a Controlled Vocabulary.', NEW.code;\\012      end if;\\012   end if;\\012\\012   RETURN NEW;\\012\\012END;\\012$$ LANGUAGE 'plpgsql';\\012\\012CREATE TRIGGER CONTROLLED_VOCABULARY_CHECK BEFORE INSERT OR UPDATE ON PROPERTY_TYPES\\012    FOR EACH ROW EXECUTE PROCEDURE CONTROLLED_VOCABULARY_CHECK();\\012\\012\\012------------------------------------------------------------------------------------\\012--  Purpose:  Create trigger EXTERNAL_DATA_STORAGE_FORMAT_CHECK \\012------------------------------------------------------------------------------------\\012\\012CREATE OR REPLACE FUNCTION EXTERNAL_DATA_STORAGE_FORMAT_CHECK() RETURNS trigger AS $$\\012DECLARE\\012   v_covo_code  CODE;\\012   data_code CODE;\\012BEGIN\\012\\012   select code into v_covo_code from controlled_vocabularies\\012      where is_internal_namespace = true and \\012         id = (select covo_id from controlled_vocabulary_terms where id = NEW.cvte_id_stor_fmt);\\012   -- Check if the data storage format is a term of the controlled vocabulary "STORAGE_FORMAT"\\012   if v_covo_code != 'STORAGE_FORMAT' then\\012      select code into data_code from data where id = NEW.data_id; \\012      RAISE EXCEPTION 'Insert/Update of Data (Code: %) failed, as its Storage Format is %, but is required to be STORAGE_FORMAT.', data_code, v_covo_code;\\012   end if;\\012\\012   RETURN NEW;\\012\\012END;\\012$$ LANGUAGE 'plpgsql';\\012\\012CREATE TRIGGER EXTERNAL_DATA_STORAGE_FORMAT_CHECK BEFORE INSERT OR UPDATE ON EXTERNAL_DATA\\012    FOR EACH ROW EXECUTE PROCEDURE EXTERNAL_DATA_STORAGE_FORMAT_CHECK();\\012\\012------------------------------------------------------------------------------------\\012--  Purpose:  Create trigger SAMPLE_CODE_UNIQUENESS_CHECK \\012------------------------------------------------------------------------------------\\012\\012CREATE OR REPLACE FUNCTION SAMPLE_CODE_UNIQUENESS_CHECK() RETURNS trigger AS $$\\012DECLARE\\012   counter  INTEGER;\\012BEGIN\\012\\011IF (NEW.samp_id_part_of is NULL) THEN\\012\\011\\011IF (NEW.dbin_id is not NULL) THEN\\012\\011\\011\\011SELECT count(*) into counter FROM samples \\012\\011\\011\\011\\011where id != NEW.id and code = NEW.code and samp_id_part_of is NULL and dbin_id = NEW.dbin_id;\\012\\011\\011\\011IF (counter > 0) THEN\\012\\011\\011\\011\\011RAISE EXCEPTION 'Insert/Update of Sample (Code: %) failed because database instance sample with the same code already exists.', NEW.code;\\012\\011\\011\\011END IF;\\012\\011\\011ELSIF (NEW.grou_id is not NULL) THEN\\012\\011\\011\\011SELECT count(*) into counter FROM samples \\012\\011\\011\\011\\011where id != NEW.id and code = NEW.code and samp_id_part_of is NULL and grou_id = NEW.grou_id;\\012\\011\\011\\011IF (counter > 0) THEN\\012\\011\\011\\011\\011RAISE EXCEPTION 'Insert/Update of Sample (Code: %) failed because group sample with the same code already exists.', NEW.code;\\012\\011\\011\\011END IF;\\012\\011\\011END IF;\\012        ELSE\\012\\011\\011IF (NEW.dbin_id is not NULL) THEN\\012\\011\\011\\011SELECT count(*) into counter FROM samples \\012\\011\\011\\011\\011where id != NEW.id and code = NEW.code and samp_id_part_of = NEW.samp_id_part_of and dbin_id = NEW.dbin_id;\\012\\011\\011\\011IF (counter > 0) THEN\\012\\011\\011\\011\\011RAISE EXCEPTION 'Insert/Update of Sample (Code: %) failed because database instance sample with the same code and being the part of the same parent already exists.', NEW.code;\\012\\011\\011\\011END IF;\\012\\011\\011ELSIF (NEW.grou_id is not NULL) THEN\\012\\011\\011\\011SELECT count(*) into counter FROM samples \\012\\011\\011\\011\\011where id != NEW.id and code = NEW.code and samp_id_part_of = NEW.samp_id_part_of and grou_id = NEW.grou_id;\\012\\011\\011\\011IF (counter > 0) THEN\\012\\011\\011\\011\\011RAISE EXCEPTION 'Insert/Update of Sample (Code: %) failed because group sample with the same code and being the part of the same parent already exists.', NEW.code;\\012\\011\\011\\011END IF;\\012\\011\\011END IF;\\012        END IF;   \\012   RETURN NEW;\\012END;\\012$$ LANGUAGE 'plpgsql';\\012\\012CREATE TRIGGER SAMPLE_CODE_UNIQUENESS_CHECK BEFORE INSERT OR UPDATE ON SAMPLES\\012    FOR EACH ROW EXECUTE PROCEDURE SAMPLE_CODE_UNIQUENESS_CHECK();\\012	\N
+./sourceTest/sql/postgresql/053/.svn/text-base/017=database_version_logs.tsv.svn-base:028	source/sql/postgresql/migration/migration-027-028.sql	SUCCESS	2008-11-18 13:24:17.508	-- Create EXPERIMENT_ATTACHMENT_CONTENTS.\\012CREATE TABLE EXPERIMENT_ATTACHMENT_CONTENTS (ID TECH_ID NOT NULL,VALUE FILE NOT NULL);\\012CREATE SEQUENCE EXPERIMENT_ATTACHMENT_CONTENT_ID_SEQ;\\012ALTER TABLE EXPERIMENT_ATTACHMENT_CONTENTS ADD CONSTRAINT EXAC_PK PRIMARY KEY(ID);\\012\\012-- Alter EXPERIMENT_ATTACHMENTS by adding the new column which has a NULL constraint.\\012-- The NOT NULL constraint is added later on.\\012ALTER TABLE EXPERIMENT_ATTACHMENTS ADD COLUMN EXAC_ID TECH_ID;\\012\\012-- Does the VALUE migration between EXPERIMENT_ATTACHMENTS to EXPERIMENT_ATTACHMENT_CONTENTS.\\012CREATE OR REPLACE FUNCTION move_exp_att_content() RETURNS integer AS $$\\012DECLARE\\012    rec RECORD;\\012    seq BIGINT;\\012BEGIN\\012  FOR rec IN SELECT id, value FROM EXPERIMENT_ATTACHMENTS LOOP\\012  \\011seq := nextval('EXPERIMENT_ATTACHMENT_CONTENT_ID_SEQ');\\012    INSERT INTO EXPERIMENT_ATTACHMENT_CONTENTS (id, value) VALUES (seq, rec.value);\\012    UPDATE EXPERIMENT_ATTACHMENTS SET exac_id = seq WHERE id = rec.id;\\012  END LOOP;\\012  RETURN 1;\\012END;\\012$$ LANGUAGE 'plpgsql';\\012\\012-- Call the function.\\012SELECT move_exp_att_content();\\012DROP FUNCTION move_exp_att_content();\\012\\012\\012-- Finish EXPERIMENT_ATTACHMENTS changes.\\012ALTER TABLE EXPERIMENT_ATTACHMENTS ADD CONSTRAINT EXAT_CONT_FK FOREIGN KEY (EXAC_ID) REFERENCES EXPERIMENT_ATTACHMENT_CONTENTS(ID);\\012ALTER TABLE EXPERIMENT_ATTACHMENTS DROP COLUMN VALUE;\\012ALTER TABLE EXPERIMENT_ATTACHMENTS ALTER COLUMN EXAC_ID SET NOT NULL;\\012	\N
+./sourceTest/sql/postgresql/053/.svn/text-base/017=database_version_logs.tsv.svn-base:029	source/sql/postgresql/migration/migration-028-029.sql	SUCCESS	2009-03-18 10:50:20.105	-- -------\\012-- add modification_timestamp field to allow edition with Hibernate\\012-- -------\\012\\012ALTER TABLE samples\\012\\011ADD COLUMN modification_timestamp TIME_STAMP DEFAULT CURRENT_TIMESTAMP;\\012\\012ALTER TABLE experiments\\012\\011ADD COLUMN modification_timestamp TIME_STAMP DEFAULT CURRENT_TIMESTAMP;\\012\\012ALTER TABLE materials\\012\\011ADD COLUMN modification_timestamp TIME_STAMP DEFAULT CURRENT_TIMESTAMP;\\012\\012ALTER TABLE experiment_properties\\012\\011ADD COLUMN modification_timestamp TIME_STAMP DEFAULT CURRENT_TIMESTAMP;\\012\\012ALTER TABLE material_properties\\012\\011ADD COLUMN modification_timestamp TIME_STAMP DEFAULT CURRENT_TIMESTAMP;\\012\\012ALTER TABLE sample_properties\\012\\011ADD COLUMN modification_timestamp TIME_STAMP DEFAULT CURRENT_TIMESTAMP;\\012\\012-- -------\\012-- add property data type which references materials\\012-- -------\\012\\012ALTER TABLE property_types\\012\\011ADD COLUMN maty_prop_id tech_id;\\012\\012ALTER TABLE property_types\\012\\011ADD CONSTRAINT prty_maty_fk FOREIGN KEY (maty_prop_id) REFERENCES material_types(id);\\012\\012ALTER TABLE experiment_properties\\012\\011ADD COLUMN mate_prop_id tech_id;\\012\\012ALTER TABLE material_properties\\012\\011ADD COLUMN mate_prop_id tech_id;\\012\\012ALTER TABLE sample_properties\\012\\011ADD COLUMN mate_prop_id tech_id;\\012\\012ALTER TABLE experiment_properties\\012\\011ADD CONSTRAINT expr_mapr_fk FOREIGN KEY (mate_prop_id) REFERENCES materials(id);\\012\\012ALTER TABLE material_properties\\012\\011ADD CONSTRAINT mapr_mapr_fk FOREIGN KEY (mate_prop_id) REFERENCES materials(id);\\012\\012ALTER TABLE sample_properties\\012\\011ADD CONSTRAINT sapr_mapr_fk FOREIGN KEY (mate_prop_id) REFERENCES materials(id);\\012\\012insert into data_types\\012(id\\012 ,code\\012 ,description)\\012 values \\012 (nextval('DATA_TYPE_ID_SEQ')\\012 ,'MATERIAL'\\012 ,'Reference to a material'\\012);\\012\\012ALTER TABLE MATERIAL_PROPERTIES DROP CONSTRAINT MAPR_CK;\\012ALTER TABLE MATERIAL_PROPERTIES ADD CONSTRAINT MAPR_CK CHECK \\012\\011((VALUE IS NOT NULL AND CVTE_ID IS NULL AND MATE_PROP_ID IS NULL) OR \\012\\011 (VALUE IS NULL AND CVTE_ID IS NOT NULL AND MATE_PROP_ID IS NULL) OR\\012\\011 (VALUE IS NULL AND CVTE_ID IS NULL AND MATE_PROP_ID IS NOT NULL)\\012\\011);\\012\\012ALTER TABLE EXPERIMENT_PROPERTIES DROP CONSTRAINT EXPR_CK;\\012ALTER TABLE EXPERIMENT_PROPERTIES ADD CONSTRAINT EXPR_CK CHECK \\012\\011((VALUE IS NOT NULL AND CVTE_ID IS NULL AND MATE_PROP_ID IS NULL) OR \\012\\011 (VALUE IS NULL AND CVTE_ID IS NOT NULL AND MATE_PROP_ID IS NULL) OR\\012\\011 (VALUE IS NULL AND CVTE_ID IS NULL AND MATE_PROP_ID IS NOT NULL)\\012\\011);\\012\\012ALTER TABLE SAMPLE_PROPERTIES DROP CONSTRAINT SAPR_CK;\\012ALTER TABLE SAMPLE_PROPERTIES ADD CONSTRAINT SAPR_CK CHECK \\012\\011((VALUE IS NOT NULL AND CVTE_ID IS NULL AND MATE_PROP_ID IS NULL) OR \\012\\011 (VALUE IS NULL AND CVTE_ID IS NOT NULL AND MATE_PROP_ID IS NULL) OR\\012\\011 (VALUE IS NULL AND CVTE_ID IS NULL AND MATE_PROP_ID IS NOT NULL)\\012\\011);\\012\\012------------------------------------------------------------------------------------\\012--  Purpose:  Create trigger MATERIAL/SAMPLE/EXPERIMENT _PROPERTY_WITH_MATERIAL_DATA_TYPE_CHECK\\012--            It checks that if material property value is assigned to the entity,\\012--\\011\\011\\011\\011\\011\\011then the material type is equal to the one described by property type.\\012------------------------------------------------------------------------------------\\012\\012CREATE OR REPLACE FUNCTION MATERIAL_PROPERTY_WITH_MATERIAL_DATA_TYPE_CHECK() RETURNS trigger AS $$\\012DECLARE\\012   v_type_id  CODE;\\012   v_type_id_prop  CODE;\\012BEGIN\\012   if NEW.mate_prop_id IS NOT NULL then\\012\\011\\011\\011-- find material type id of the property type \\012\\011\\011\\011select pt.maty_prop_id into v_type_id_prop \\012\\011\\011\\011  from material_type_property_types etpt, property_types pt \\012\\011\\011\\011 where NEW.mtpt_id = etpt.id AND etpt.prty_id = pt.id;\\012\\011\\011\\012\\011\\011\\011if v_type_id_prop IS NOT NULL then\\012\\011\\011\\011\\011-- find material type id of the material which consists the entity's property value\\012\\011\\011\\011\\011select entity.maty_id into v_type_id \\012\\011\\011\\011\\011  from materials entity\\012\\011\\011\\011\\011 where NEW.mate_prop_id = entity.id;\\012\\011\\011\\011\\011if v_type_id != v_type_id_prop then\\012\\011\\011\\011\\011\\011RAISE EXCEPTION 'Insert/Update of property value referencing material (id: %) failed, as referenced material type is different than expected (id %, expected id: %).', \\012\\011\\011\\011\\011\\011\\011\\011 NEW.mate_prop_id, v_type_id, v_type_id_prop;\\012\\011\\011\\011\\011end if;\\012\\011\\011\\011end if;\\012   end if;\\012   RETURN NEW;\\012END;\\012$$ LANGUAGE 'plpgsql';\\012\\012CREATE TRIGGER MATERIAL_PROPERTY_WITH_MATERIAL_DATA_TYPE_CHECK BEFORE INSERT OR UPDATE ON material_properties\\012    FOR EACH ROW EXECUTE PROCEDURE MATERIAL_PROPERTY_WITH_MATERIAL_DATA_TYPE_CHECK();\\012    \\012CREATE OR REPLACE FUNCTION SAMPLE_PROPERTY_WITH_MATERIAL_DATA_TYPE_CHECK() RETURNS trigger AS $$\\012DECLARE\\012   v_type_id  CODE;\\012   v_type_id_prop  CODE;\\012BEGIN\\012   if NEW.mate_prop_id IS NOT NULL then\\012\\011\\011\\011-- find material type id of the property type \\012\\011\\011\\011select pt.maty_prop_id into v_type_id_prop \\012\\011\\011\\011  from sample_type_property_types etpt, property_types pt \\012\\011\\011\\011 where NEW.stpt_id = etpt.id AND etpt.prty_id = pt.id;\\012\\011\\011\\012\\011\\011\\011if v_type_id_prop IS NOT NULL then\\012\\011\\011\\011\\011-- find material type id of the material which consists the entity's property value\\012\\011\\011\\011\\011select entity.maty_id into v_type_id \\012\\011\\011\\011\\011  from materials entity\\012\\011\\011\\011\\011 where NEW.mate_prop_id = entity.id;\\012\\011\\011\\011\\011if v_type_id != v_type_id_prop then\\012\\011\\011\\011\\011\\011RAISE EXCEPTION 'Insert/Update of property value referencing material (id: %) failed, as referenced material type is different than expected (id %, expected id: %).', \\012\\011\\011\\011\\011\\011\\011\\011\\011\\011\\011\\011\\011 NEW.mate_prop_id, v_type_id, v_type_id_prop;\\012\\011\\011\\011\\011end if;\\012\\011\\011\\011end if;\\012   end if;\\012   RETURN NEW;\\012END;\\012$$ LANGUAGE 'plpgsql';\\012\\012CREATE TRIGGER SAMPLE_PROPERTY_WITH_MATERIAL_DATA_TYPE_CHECK BEFORE INSERT OR UPDATE ON sample_properties\\012    FOR EACH ROW EXECUTE PROCEDURE SAMPLE_PROPERTY_WITH_MATERIAL_DATA_TYPE_CHECK();\\012    \\012CREATE OR REPLACE FUNCTION EXPERIMENT_PROPERTY_WITH_MATERIAL_DATA_TYPE_CHECK() RETURNS trigger AS $$\\012DECLARE\\012   v_type_id  CODE;\\012   v_type_id_prop  CODE;\\012BEGIN\\012   if NEW.mate_prop_id IS NOT NULL then\\012\\011\\011\\011-- find material type id of the property type \\012\\011\\011\\011select pt.maty_prop_id into v_type_id_prop \\012\\011\\011\\011  from experiment_type_property_types etpt, property_types pt \\012\\011\\011\\011 where NEW.etpt_id = etpt.id AND etpt.prty_id = pt.id;\\012\\011\\011\\012\\011\\011\\011if v_type_id_prop IS NOT NULL then\\012\\011\\011\\011\\011-- find material type id of the material which consists the entity's property value\\012\\011\\011\\011\\011select entity.maty_id into v_type_id \\012\\011\\011\\011\\011  from materials entity\\012\\011\\011\\011\\011 where NEW.mate_prop_id = entity.id;\\012\\011\\011\\011\\011if v_type_id != v_type_id_prop then\\012\\011\\011\\011\\011\\011RAISE EXCEPTION 'Insert/Update of property value referencing material (id: %) failed, as referenced material type is different than expected (id %, expected id: %).', \\012\\011\\011\\011\\011\\011\\011\\011\\011\\011\\011\\011\\011 NEW.mate_prop_id, v_type_id, v_type_id_prop;\\012\\011\\011\\011\\011end if;\\012\\011\\011\\011end if;\\012   end if;\\012   RETURN NEW;\\012END;\\012$$ LANGUAGE 'plpgsql';\\012\\012CREATE TRIGGER EXPERIMENT_PROPERTY_WITH_MATERIAL_DATA_TYPE_CHECK BEFORE INSERT OR UPDATE ON experiment_properties\\012    FOR EACH ROW EXECUTE PROCEDURE EXPERIMENT_PROPERTY_WITH_MATERIAL_DATA_TYPE_CHECK();\\012       \\012-- -------\\012-- remove the reminescents of the OBSERVABLE_TYPE\\012-- -------\\012\\012ALTER TABLE data\\012\\011DROP CONSTRAINT data_obty_fk;\\012\\012ALTER TABLE data_set_types\\012\\011DROP CONSTRAINT obty_pk;\\012\\012ALTER TABLE data_set_types\\012\\011ADD CONSTRAINT dsty_pk PRIMARY KEY (id);\\012\\012ALTER TABLE data\\012\\011ADD CONSTRAINT data_dsty_fk FOREIGN KEY (dsty_id) REFERENCES data_set_types(id);\\012\\012ALTER TABLE data_set_types\\012\\011DROP CONSTRAINT obty_bk_uk;\\012\\012ALTER TABLE data_set_types\\012\\011DROP CONSTRAINT obty_dbin_fk;\\012\\012ALTER TABLE data_set_types\\012\\011ADD CONSTRAINT dsty_bk_uk UNIQUE (code, dbin_id);\\012\\012ALTER TABLE data_set_types\\012\\011ADD CONSTRAINT dsty_dbin_fk FOREIGN KEY (dbin_id) REFERENCES database_instances(id);\\012\\012DROP INDEX data_obty_fk_i;\\012\\012CREATE INDEX data_dsty_fk_i ON data(dsty_id);\\012	\N
+./sourceTest/sql/postgresql/053/.svn/text-base/017=database_version_logs.tsv.svn-base:030	source/sql/postgresql/migration/migration-029-030.sql	SUCCESS	2009-03-23 15:34:44.72	-- -------\\012-- add modification_timestamp field to allow edition with Hibernate\\012-- -------\\012ALTER TABLE data\\012\\011ADD COLUMN modification_timestamp TIME_STAMP DEFAULT CURRENT_TIMESTAMP;\\012ALTER TABLE experiment_types\\012\\011ADD COLUMN modification_timestamp TIME_STAMP DEFAULT CURRENT_TIMESTAMP;\\012ALTER TABLE sample_types\\012\\011ADD COLUMN modification_timestamp TIME_STAMP DEFAULT CURRENT_TIMESTAMP;\\012ALTER TABLE material_types\\012\\011ADD COLUMN modification_timestamp TIME_STAMP DEFAULT CURRENT_TIMESTAMP;\\012ALTER TABLE data_set_types\\012\\011ADD COLUMN modification_timestamp TIME_STAMP DEFAULT CURRENT_TIMESTAMP;\\012ALTER TABLE controlled_vocabularies\\012\\011ADD COLUMN modification_timestamp TIME_STAMP DEFAULT CURRENT_TIMESTAMP;\\012-- -------\\012-- add properties to data sets\\012-- -------\\012CREATE TABLE DATA_SET_PROPERTIES (ID TECH_ID NOT NULL,DS_ID TECH_ID NOT NULL,DSTPT_ID TECH_ID NOT NULL,VALUE GENERIC_VALUE,CVTE_ID TECH_ID, MATE_PROP_ID TECH_ID, PERS_ID_REGISTERER TECH_ID NOT NULL,REGISTRATION_TIMESTAMP TIME_STAMP_DFL NOT NULL DEFAULT CURRENT_TIMESTAMP, MODIFICATION_TIMESTAMP TIME_STAMP DEFAULT CURRENT_TIMESTAMP);\\012CREATE TABLE DATA_SET_TYPE_PROPERTY_TYPES (ID TECH_ID NOT NULL,DSTY_ID TECH_ID NOT NULL,PRTY_ID TECH_ID NOT NULL,IS_MANDATORY BOOLEAN_CHAR NOT NULL DEFAULT 'F',IS_MANAGED_INTERNALLY BOOLEAN_CHAR NOT NULL DEFAULT 'F',PERS_ID_REGISTERER TECH_ID NOT NULL,REGISTRATION_TIMESTAMP TIME_STAMP_DFL NOT NULL DEFAULT CURRENT_TIMESTAMP);\\012\\012CREATE SEQUENCE DATA_SET_PROPERTY_ID_SEQ;\\012CREATE SEQUENCE DSTPT_ID_SEQ;\\012\\012ALTER TABLE DATA_SET_TYPE_PROPERTY_TYPES ADD CONSTRAINT DSTPT_PK PRIMARY KEY(ID);\\012ALTER TABLE DATA_SET_PROPERTIES ADD CONSTRAINT DSPR_PK PRIMARY KEY(ID);\\012\\012ALTER TABLE DATA_SET_TYPE_PROPERTY_TYPES ADD CONSTRAINT DSTPT_BK_UK UNIQUE(DSTY_ID,PRTY_ID);\\012ALTER TABLE DATA_SET_PROPERTIES ADD CONSTRAINT DSPR_BK_UK UNIQUE(DS_ID,DSTPT_ID);\\012\\012\\012ALTER TABLE DATA_SET_TYPE_PROPERTY_TYPES ADD CONSTRAINT DSTPT_DSTY_FK FOREIGN KEY (DSTY_ID) REFERENCES DATA_SET_TYPES(ID);\\012ALTER TABLE DATA_SET_TYPE_PROPERTY_TYPES ADD CONSTRAINT DSTPT_PERS_FK FOREIGN KEY (PERS_ID_REGISTERER) REFERENCES PERSONS(ID);\\012ALTER TABLE DATA_SET_TYPE_PROPERTY_TYPES ADD CONSTRAINT DSTPT_PRTY_FK FOREIGN KEY (PRTY_ID) REFERENCES PROPERTY_TYPES(ID);\\012ALTER TABLE DATA_SET_PROPERTIES ADD CONSTRAINT DSPR_CVTE_FK FOREIGN KEY (CVTE_ID) REFERENCES CONTROLLED_VOCABULARY_TERMS(ID);\\012ALTER TABLE DATA_SET_PROPERTIES ADD CONSTRAINT DSPR_DSTPT_FK FOREIGN KEY (DSTPT_ID) REFERENCES DATA_SET_TYPE_PROPERTY_TYPES(ID) ON DELETE CASCADE;\\012ALTER TABLE DATA_SET_PROPERTIES ADD CONSTRAINT DSPR_DS_FK FOREIGN KEY (DS_ID) REFERENCES DATA(ID);\\012ALTER TABLE DATA_SET_PROPERTIES ADD CONSTRAINT DSPR_PERS_FK FOREIGN KEY (PERS_ID_REGISTERER) REFERENCES PERSONS(ID);\\012ALTER TABLE DATA_SET_PROPERTIES ADD CONSTRAINT DSPR_MAPR_FK FOREIGN KEY (MATE_PROP_ID) REFERENCES MATERIALS(ID);\\012\\012ALTER TABLE DATA_SET_PROPERTIES ADD CONSTRAINT DSPR_CK CHECK \\012\\011((VALUE IS NOT NULL AND CVTE_ID IS NULL AND MATE_PROP_ID IS NULL) OR \\012\\011 (VALUE IS NULL AND CVTE_ID IS NOT NULL AND MATE_PROP_ID IS NULL) OR\\012\\011 (VALUE IS NULL AND CVTE_ID IS NULL AND MATE_PROP_ID IS NOT NULL)\\012\\011);\\012\\012CREATE INDEX DSPR_CVTE_FK_I ON DATA_SET_PROPERTIES (CVTE_ID);\\012CREATE INDEX DSPR_DSTPT_FK_I ON DATA_SET_PROPERTIES (DSTPT_ID);\\012CREATE INDEX DSPR_DS_FK_I ON DATA_SET_PROPERTIES (DS_ID);\\012CREATE INDEX DSPR_PERS_FK_I ON DATA_SET_PROPERTIES (PERS_ID_REGISTERER);\\012CREATE INDEX DSTPT_DSTY_FK_I ON DATA_SET_TYPE_PROPERTY_TYPES (DSTY_ID);\\012CREATE INDEX DSTPT_PERS_FK_I ON DATA_SET_TYPE_PROPERTY_TYPES (PERS_ID_REGISTERER);\\012CREATE INDEX DSTPT_PRTY_FK_I ON DATA_SET_TYPE_PROPERTY_TYPES (PRTY_ID);\\012\\012CREATE OR REPLACE FUNCTION DATA_SET_PROPERTY_WITH_MATERIAL_DATA_TYPE_CHECK() RETURNS trigger AS $$\\012DECLARE\\012   v_type_id  CODE;\\012   v_type_id_prop  CODE;\\012BEGIN\\012   if NEW.mate_prop_id IS NOT NULL then\\012\\011\\011\\011-- find material type id of the property type \\012\\011\\011\\011select pt.maty_prop_id into v_type_id_prop \\012\\011\\011\\011  from data_set_type_property_types dstpt, property_types pt \\012\\011\\011\\011 where NEW.dstpt_id = dstpt.id AND dstpt.prty_id = pt.id;\\012\\011\\011\\012\\011\\011\\011if v_type_id_prop IS NOT NULL then\\012\\011\\011\\011\\011-- find material type id of the material which consists the entity's property value\\012\\011\\011\\011\\011select entity.maty_id into v_type_id \\012\\011\\011\\011\\011  from materials entity\\012\\011\\011\\011\\011 where NEW.mate_prop_id = entity.id;\\012\\011\\011\\011\\011if v_type_id != v_type_id_prop then\\012\\011\\011\\011\\011\\011RAISE EXCEPTION 'Insert/Update of property value referencing material (id: %) failed, as referenced material type is different than expected (id %, expected id: %).', \\012\\011\\011\\011\\011\\011\\011\\011\\011\\011\\011\\011\\011 NEW.mate_prop_id, v_type_id, v_type_id_prop;\\012\\011\\011\\011\\011end if;\\012\\011\\011\\011end if;\\012   end if;\\012   RETURN NEW;\\012END;\\012$$ LANGUAGE 'plpgsql';\\012\\012CREATE TRIGGER DATA_SET_PROPERTY_WITH_MATERIAL_DATA_TYPE_CHECK BEFORE INSERT OR UPDATE ON data_set_properties\\012    FOR EACH ROW EXECUTE PROCEDURE DATA_SET_PROPERTY_WITH_MATERIAL_DATA_TYPE_CHECK();   \\012	\N
+./sourceTest/sql/postgresql/053/.svn/text-base/017=database_version_logs.tsv.svn-base:032	source/sql/postgresql/migration/migration-031-032.sql	SUCCESS	2009-04-09 09:36:36.2	-- -------\\012-- Modify MATERIAL_BATCHES\\012-- -------\\012\\012ALTER TABLE material_batches\\012    DROP COLUMN proc_id;\\012\\012-- -------\\012-- Modify SAMPLES\\012-- -------\\012\\012ALTER TABLE samples\\012    ADD COLUMN expe_id tech_id;\\012\\012ALTER TABLE samples\\012    ADD CONSTRAINT samp_expe_fk FOREIGN KEY (expe_id) REFERENCES experiments(id);\\012\\012CREATE INDEX samp_expe_fk_i ON samples USING btree (expe_id);\\012\\012-- relink samples directly to experiments\\012\\012UPDATE samples\\012SET expe_id = (SELECT e.id FROM experiments e, procedures p, sample_inputs si \\012               WHERE si.samp_id = samples.id AND si.proc_id = p.id AND p.expe_id = e.id AND e.inva_id IS NULL);\\012\\012\\012-- -------\\012-- Modify DATA\\012-- -------\\012\\012ALTER TABLE data\\012    ADD COLUMN expe_id tech_id;\\012\\012ALTER TABLE data\\012    ADD CONSTRAINT data_expe_fk FOREIGN KEY (expe_id) REFERENCES experiments(id);\\012\\012CREATE INDEX data_expe_fk_i ON data USING btree (expe_id);\\012\\012UPDATE data\\012SET expe_id = (SELECT e.id FROM experiments e, procedures p \\012               WHERE data.proc_id_produced_by = p.id AND p.expe_id = e.id);\\012\\012ALTER TABLE data\\012    ALTER COLUMN expe_id SET NOT NULL;\\012\\012ALTER TABLE data\\012    DROP COLUMN proc_id_produced_by;\\012\\012-- -------\\012-- Drop PROCEDURES, PROCEDURE_TYPES, and SAMPLE_INPUTS\\012-- -------\\012\\012DROP TABLE sample_inputs;\\012DROP TABLE procedures;\\012DROP TABLE procedure_types;\\012\\012DROP SEQUENCE procedure_id_seq;\\012DROP SEQUENCE procedure_type_id_seq;\\012\\012-- -------\\012-- Add CODE_SEQ\\012-- -------\\012\\012CREATE SEQUENCE CODE_SEQ;\\012\\012-- -------\\012-- Add new columns to DATA_STORES\\012-- -------\\012\\012ALTER TABLE data_stores\\012    ADD COLUMN remote_url character varying(250),\\012    ADD COLUMN session_token character varying(50),\\012    ADD COLUMN modification_timestamp time_stamp DEFAULT now();\\012\\012UPDATE data_stores\\012SET remote_url = '', session_token='';\\012\\012ALTER TABLE data_stores\\012    ALTER COLUMN remote_url SET NOT NULL,\\012    ALTER COLUMN session_token SET NOT NULL;\\012\\012-- -------\\012-- Drop foreign keys onto DATA_STORES\\012-- -------\\012\\012ALTER TABLE database_instances\\012    DROP COLUMN dast_id;\\012\\012ALTER TABLE groups\\012    DROP COLUMN dast_id;\\012\\012ALTER TABLE projects\\012    DROP COLUMN dast_id;\\012\\012ALTER TABLE experiments\\012    DROP COLUMN dast_id;\\012\\012-- -------\\012-- Add foreign key from DATA onto DATA_STORES\\012-- -------\\012\\012ALTER TABLE data\\012    ADD COLUMN dast_id tech_id;\\012\\012ALTER TABLE data\\012    ADD CONSTRAINT data_dast_fk FOREIGN KEY (dast_id) REFERENCES data_stores(id);\\012\\012UPDATE data\\012SET dast_id = (select id from data_stores where code = 'STANDARD');\\012\\012ALTER TABLE data\\012    ALTER COLUMN dast_id SET NOT NULL;\\012\\012\\012------------------------------------------------------------------------------------\\012--  Purpose:  Replace trigger SAMPLE_CODE_UNIQUENESS_CHECK \\012------------------------------------------------------------------------------------\\012\\012CREATE OR REPLACE FUNCTION SAMPLE_CODE_UNIQUENESS_CHECK() RETURNS trigger AS $$\\012DECLARE\\012   counter  INTEGER;\\012BEGIN\\012    LOCK TABLE samples IN EXCLUSIVE MODE;\\012    IF (NEW.samp_id_part_of is NULL) THEN\\012        IF (NEW.dbin_id is not NULL) THEN\\012            SELECT count(*) into counter FROM samples \\012                where id != NEW.id and code = NEW.code and samp_id_part_of is NULL and dbin_id = NEW.dbin_id;\\012            IF (counter > 0) THEN\\012                RAISE EXCEPTION 'Insert/Update of Sample (Code: %) failed because database instance sample with the same code already exists.', NEW.code;\\012            END IF;\\012        ELSIF (NEW.grou_id is not NULL) THEN\\012            SELECT count(*) into counter FROM samples \\012                where id != NEW.id and code = NEW.code and samp_id_part_of is NULL and grou_id = NEW.grou_id;\\012            IF (counter > 0) THEN\\012                RAISE EXCEPTION 'Insert/Update of Sample (Code: %) failed because group sample with the same code already exists.', NEW.code;\\012            END IF;\\012        END IF;\\012        ELSE\\012        IF (NEW.dbin_id is not NULL) THEN\\012            SELECT count(*) into counter FROM samples \\012                where id != NEW.id and code = NEW.code and samp_id_part_of = NEW.samp_id_part_of and dbin_id = NEW.dbin_id;\\012            IF (counter > 0) THEN\\012                RAISE EXCEPTION 'Insert/Update of Sample (Code: %) failed because database instance sample with the same code and being the part of the same parent already exists.', NEW.code;\\012            END IF;\\012        ELSIF (NEW.grou_id is not NULL) THEN\\012            SELECT count(*) into counter FROM samples \\012                where id != NEW.id and code = NEW.code and samp_id_part_of = NEW.samp_id_part_of and grou_id = NEW.grou_id;\\012            IF (counter > 0) THEN\\012                RAISE EXCEPTION 'Insert/Update of Sample (Code: %) failed because group sample with the same code and being the part of the same parent already exists.', NEW.code;\\012            END IF;\\012        END IF;\\012        END IF;   \\012   RETURN NEW;\\012END;\\012$$ LANGUAGE 'plpgsql';\\012\\012\\012\\012	\N
+./sourceTest/sql/postgresql/053/.svn/text-base/017=database_version_logs.tsv.svn-base:034	source/sql/postgresql/migration/migration-033-034.sql	SUCCESS	2009-05-26 08:32:49.935	------------------------------------------------------------------------------------\\012-- Create sequence for generating permanent identifiers starting with nextval of existing dataset sequence.\\012------------------------------------------------------------------------------------\\012CREATE FUNCTION CREATE_SEQUENCE(EXISTING_SEQUENCE VARCHAR, NEW_SEQUENCE VARCHAR) RETURNS VOID AS $$\\012DECLARE\\012  CURR_SEQ_VAL   INTEGER;\\012BEGIN\\012  SELECT INTO CURR_SEQ_VAL NEXTVAL(EXISTING_SEQUENCE);\\012  EXECUTE 'CREATE SEQUENCE ' || NEW_SEQUENCE || ' START WITH ' || CURR_SEQ_VAL;\\012  RETURN;\\012END;\\012$$ LANGUAGE 'plpgsql';\\012\\012SELECT CREATE_SEQUENCE('DATA_ID_SEQ', 'PERM_ID_SEQ');\\012DROP FUNCTION CREATE_SEQUENCE(VARCHAR, VARCHAR);\\012\\012------------------------------------------------------------------------------------\\012-- Add perm_id columns to samples and experiments.\\012------------------------------------------------------------------------------------\\012ALTER TABLE SAMPLES ADD COLUMN PERM_ID CODE;\\012ALTER TABLE EXPERIMENTS ADD COLUMN PERM_ID CODE;\\012\\012UPDATE SAMPLES SET PERM_ID = to_char(registration_timestamp,'YYYYMMDDHHSSMS') || '-' || NEXTVAL('PERM_ID_SEQ');\\012UPDATE EXPERIMENTS SET PERM_ID = to_char(registration_timestamp,'YYYYMMDDHHSSMS') || '-' || NEXTVAL('PERM_ID_SEQ');\\012ALTER TABLE SAMPLES ALTER COLUMN PERM_ID SET NOT NULL;\\012ALTER TABLE EXPERIMENTS ALTER COLUMN PERM_ID SET NOT NULL;\\012ALTER TABLE SAMPLES ADD CONSTRAINT SAMP_PI_UK UNIQUE(PERM_ID);\\012ALTER TABLE EXPERIMENTS ADD CONSTRAINT EXPE_PI_UK UNIQUE(PERM_ID);\\012\\012\\012------------------------------------------------------------------------------------\\012-- Add column is_chosen_from_list to controlled_vocabularies.\\012------------------------------------------------------------------------------------\\012ALTER TABLE controlled_vocabularies ADD COLUMN is_chosen_from_list BOOLEAN_CHAR NOT NULL DEFAULT TRUE;\\012ALTER TABLE controlled_vocabularies ADD COLUMN source_uri CHARACTER VARYING(250);\\012------------------------------------------------------------------------------------\\012-- Modify Data table - remove arc connection between Sample and Data table, use a flag instead\\012------------------------------------------------------------------------------------\\012\\012-- add new columns\\012\\012ALTER TABLE data\\012    ADD COLUMN is_derived boolean_char;\\012ALTER TABLE data\\012    ADD COLUMN samp_id tech_id;\\012\\012-- update values in new columns\\012\\012UPDATE data\\012    SET is_derived = (samp_id_derived_from IS NOT NULL); \\012UPDATE data\\012    SET samp_id = samp_id_derived_from \\012    WHERE is_derived = 'TRUE';\\012UPDATE data\\012    SET samp_id = samp_id_acquired_from \\012    WHERE is_derived = 'FALSE';\\012\\012-- add constraints and indexes to new columns\\012\\012ALTER TABLE data\\012    ALTER COLUMN is_derived SET NOT NULL;\\012ALTER TABLE data\\012    ALTER COLUMN samp_id SET NOT NULL;   \\012ALTER TABLE data\\012    ADD CONSTRAINT data_samp_fk FOREIGN KEY (samp_id) REFERENCES samples (id);\\012CREATE INDEX data_samp_fk_i ON data USING btree (samp_id);\\012\\012-- remove old columns\\012\\012ALTER TABLE data\\012    DROP COLUMN samp_id_acquired_from;\\012ALTER TABLE data\\012    DROP COLUMN samp_id_derived_from;\\012    \\012------------------------------------------------------------------------------------\\012-- Granting SELECT privilege to group openbis_readonly\\012------------------------------------------------------------------------------------\\012\\012GRANT SELECT ON SEQUENCE attachment_content_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE attachment_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE code_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE controlled_vocabulary_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE cvte_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE data_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE data_set_property_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE data_set_relationship_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE data_set_type_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE data_store_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE data_type_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE database_instance_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE dstpt_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE etpt_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE event_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE experiment_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE experiment_property_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE experiment_type_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE file_format_type_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE group_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE invalidation_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE locator_type_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE material_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE material_property_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE material_type_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE mtpt_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE perm_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE person_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE project_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE property_type_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE role_assignment_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE sample_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE sample_property_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE sample_type_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE stpt_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE attachment_contents TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE attachments TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE controlled_vocabularies TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE controlled_vocabulary_terms TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE data TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE data_set_properties TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE data_set_relationships TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE data_set_type_property_types TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE data_set_types TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE data_stores TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE data_types TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE database_instances TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE database_version_logs TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE events TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE experiment_properties TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE experiment_type_property_types TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE experiment_types TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE experiments TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE external_data TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE file_format_types TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE groups TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE invalidations TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE locator_types TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE material_properties TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE material_type_property_types TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE material_types TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE materials TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE persons TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE projects TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE property_types TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE role_assignments TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE sample_properties TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE sample_type_property_types TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE sample_types TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE samples TO GROUP OPENBIS_READONLY;\\012\\012------------------------------------------------------------------------------------\\012-- Delete MATERIAL_BATCHES table\\012------------------------------------------------------------------------------------\\012\\012-- WARNING: Potential data lost!!!\\012-- WARNING: Potential data lost!!!\\012-- WARNING: Potential data lost!!!\\012\\012DROP TABLE SAMPLE_MATERIAL_BATCHES;\\012DROP TABLE MATERIAL_BATCHES;\\012DROP SEQUENCE MATERIAL_BATCH_ID_SEQ;\\012\\012------------------------------------------------------------------------------------\\012-- Delete MATE_ID_INHIBITOR_OF from table MATERIALS\\012------------------------------------------------------------------------------------\\012\\012-- WARNING: Potential data lost!!!\\012-- WARNING: Potential data lost!!!\\012-- WARNING: Potential data lost!!!\\012\\012ALTER TABLE MATERIALS DROP COLUMN MATE_ID_INHIBITOR_OF;\\012	\N
+./sourceTest/sql/postgresql/053/.svn/text-base/017=database_version_logs.tsv.svn-base:041	source/sql/postgresql/migration/migration-040-041.sql	SUCCESS	2009-09-14 13:48:57.539	-- Create FILTERS table\\012\\012CREATE TABLE FILTERS (ID TECH_ID NOT NULL, DBIN_ID TECH_ID NOT NULL, NAME VARCHAR(200) NOT NULL, DESCRIPTION DESCRIPTION_1000,REGISTRATION_TIMESTAMP TIME_STAMP_DFL NOT NULL DEFAULT CURRENT_TIMESTAMP, PERS_ID_REGISTERER TECH_ID NOT NULL, MODIFICATION_TIMESTAMP TIME_STAMP DEFAULT CURRENT_TIMESTAMP, EXPRESSION VARCHAR(2000) NOT NULL, IS_PUBLIC BOOLEAN NOT NULL, GRID_ID VARCHAR(200) NOT NULL);\\012CREATE SEQUENCE FILTER_ID_SEQ;\\012ALTER TABLE FILTERS ADD CONSTRAINT FILT_PK PRIMARY KEY(ID);\\012ALTER TABLE FILTERS ADD CONSTRAINT FILT_BK_UK UNIQUE(NAME, DBIN_ID, GRID_ID);\\012ALTER TABLE FILTERS ADD CONSTRAINT FILT_PERS_FK FOREIGN KEY (PERS_ID_REGISTERER) REFERENCES PERSONS(ID);\\012ALTER TABLE FILTERS ADD CONSTRAINT FILT_DBIN_FK FOREIGN KEY (DBIN_ID) REFERENCES DATABASE_INSTANCES(ID);\\012CREATE INDEX FILT_PERS_FK_I ON FILTERS (PERS_ID_REGISTERER);\\012CREATE INDEX FILT_DBIN_FK_I ON FILTERS (DBIN_ID);\\012GRANT SELECT ON SEQUENCE filter_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE filters TO GROUP OPENBIS_READONLY;\\012\\012-- Add missing foreign key to role assignments authorization group\\012ALTER TABLE ROLE_ASSIGNMENTS ADD CONSTRAINT ROAS_AG_FK_GRANTEE FOREIGN KEY (AG_ID_GRANTEE) REFERENCES AUTHORIZATION_GROUPS(ID);\\012\\012--------------------------------------------------------------------------------------------------\\012-- Modify dataset connections:\\012-- 1. connection with sample shouldn't be mandatory any more\\012-- 2. introduce an arc condition that dataset cannot be connected with a sample and a parent dataset at the same time\\012--------------------------------------------------------------------------------------------------\\012\\012-- Weaken data-sample connection constraint - allow dataset to have no connection with sample\\012ALTER TABLE data ALTER COLUMN samp_id DROP NOT NULL;\\012\\012-- Remove data-sample connection for datasets that have a parent\\012\\012UPDATE data \\012   SET samp_id = NULL \\012 WHERE id IN (SELECT DISTINCT data_id_child FROM data_set_relationships);\\012\\012-- With PostgreSQL 8.4 one can check that before migration there were no cycles in dataset relationships:\\012--\\012-- WITH RECURSIVE data_set_parents(id, parent_ids, cycle) AS (\\012--         SELECT  r.data_id_child AS id, \\012--                 ARRAY[CAST (r.data_id_parent AS bigint)] AS parent_ids, \\012--                 false AS cycle \\012--         FROM data_set_relationships r\\012--     UNION ALL\\012--         SELECT  r.data_id_child,\\012--                 CAST (r.data_id_parent AS bigint) || p.parent_ids,\\012--                 r.data_id_child = ANY(p.parent_ids)\\012--         FROM data_set_relationships r, data_set_parents p\\012--         WHERE r.data_id_parent = p.id AND NOT cycle\\012-- )\\012-- SELECT count(*) AS cycles FROM data_set_parents WHERE cycle = true;\\012\\012---------------------------------------------------------------------------------------------------\\012--  Purpose:  Create DEFERRED triggers:\\012--            * check_dataset_relationships_on_data_table_modification,\\012--            * check_dataset_relationships_on_relationships_table_modification.\\012--            They check that after all modifications of database (just before commit) \\012--            if 'data'/'data_set_relationships' tables are among modified tables \\012--            dataset is not connected with a sample and a parent dataset at the same time.\\012--            This connections are held in two different tables so simple immediate trigger \\012--            with arc check cannot be used and we need two deferred triggers.\\012----------------------------------------------------------------------------------------------------\\012\\012-- trigger for 'data' table\\012\\012CREATE OR REPLACE FUNCTION check_dataset_relationships_on_data_table_modification() RETURNS trigger AS $$\\012DECLARE\\012\\011counter\\011INTEGER;\\012BEGIN\\012\\011-- if there is a connection with a Sample there should not be any connection with a parent Data Set\\012\\011IF (NEW.samp_id IS NOT NULL) THEN\\012\\011\\011-- count number of parents\\012\\011\\011SELECT count(*) INTO counter \\012\\011\\011\\011FROM data_set_relationships \\012\\011\\011\\011WHERE data_id_child = OLD.id;\\012\\011\\011IF (counter > 0) THEN\\012\\011\\011\\011RAISE EXCEPTION 'Insert/Update of Data Set (Code: %) failed because it cannot be connected with a Sample and a parent Data Set at the same time.', OLD.code;\\012\\011\\011END IF;\\012\\011END IF;\\012  RETURN NEW;\\012END;\\012$$ LANGUAGE 'plpgsql';\\012\\012CREATE CONSTRAINT TRIGGER check_dataset_relationships_on_data_table_modification \\012  AFTER INSERT OR UPDATE ON data\\012\\011DEFERRABLE INITIALLY DEFERRED\\012\\011FOR EACH ROW \\012\\011EXECUTE PROCEDURE check_dataset_relationships_on_data_table_modification();\\012\\012-- trigger for 'data_set_relationships'\\012\\012CREATE OR REPLACE FUNCTION check_dataset_relationships_on_relationships_table_modification() RETURNS trigger AS $$\\012DECLARE\\012\\011counter\\011INTEGER;\\012\\011sample_id\\011TECH_ID;\\012\\011data_code\\011CODE;\\012BEGIN\\012\\011-- child will have a parent added so it should not be connected with any sample\\012\\011SELECT samp_id, code INTO sample_id, data_code \\012\\011\\011FROM data \\012\\011\\011WHERE id = NEW.data_id_child;\\012\\011IF (sample_id IS NOT NULL) THEN\\012\\011\\011RAISE EXCEPTION 'Insert/Update of Data Set (Code: %) failed because it cannot be connected to a Sample and to a parent Data Set at the same time.', data_code;\\012\\011END IF;\\012\\011RETURN NEW;\\012END;\\012$$ LANGUAGE 'plpgsql';\\012  \\012CREATE CONSTRAINT TRIGGER check_dataset_relationships_on_relationships_table_modification \\012  AFTER INSERT OR UPDATE ON data_set_relationships\\012\\011DEFERRABLE INITIALLY DEFERRED\\012\\011FOR EACH ROW \\012\\011EXECUTE PROCEDURE check_dataset_relationships_on_relationships_table_modification();\\012	\N
+./sourceTest/sql/postgresql/053/.svn/text-base/017=database_version_logs.tsv.svn-base:053	source/sql/postgresql/migration/migration-052-053.sql	SUCCESS	2010-06-08 15:27:55.032	-- Migration from 052 to 053\\012\\012-- Change code uniqueness check for samples of specific type.\\012-- If sample_types.is_subcode_unique flag is set to 'true', additional check is performed \\012-- on codes of samples of the type. Subcodes will have to be unique as well.\\012\\012ALTER TABLE sample_types ADD COLUMN is_subcode_unique boolean_char NOT NULL DEFAULT false;\\012\\012CREATE OR REPLACE FUNCTION SAMPLE_SUBCODE_UNIQUENESS_CHECK() RETURNS trigger AS $$\\012DECLARE\\012   counter  INTEGER;\\012   unique_subcode  BOOLEAN_CHAR;\\012BEGIN\\012  LOCK TABLE samples IN EXCLUSIVE MODE;\\012  \\012  SELECT is_subcode_unique into unique_subcode FROM sample_types WHERE id = NEW.saty_id;\\012  \\012  IF (unique_subcode) THEN\\012    IF (NEW.dbin_id is not NULL) THEN\\012\\011\\011\\011SELECT count(*) into counter FROM samples \\012\\011\\011\\011\\011where id != NEW.id and code = NEW.code and saty_id = NEW.saty_id and dbin_id = NEW.dbin_id;\\012\\011\\011\\011IF (counter > 0) THEN\\012\\011\\011\\011\\011RAISE EXCEPTION 'Insert/Update of Sample (Code: %) failed because database instance sample of the same type with the same subcode already exists.', NEW.code;\\012\\011\\011\\011END IF;\\012\\011\\011ELSIF (NEW.grou_id is not NULL) THEN\\012\\011\\011\\011SELECT count(*) into counter FROM samples \\012\\011\\011\\011\\011where id != NEW.id and code = NEW.code and saty_id = NEW.saty_id and grou_id = NEW.grou_id;\\012\\011\\011\\011IF (counter > 0) THEN\\012\\011\\011\\011\\011RAISE EXCEPTION 'Insert/Update of Sample (Code: %) failed because space sample of the same type with the same subcode already exists.', NEW.code;\\012\\011\\011\\011END IF;\\012\\011\\011END IF;\\012  END IF;\\012  \\012  RETURN NEW;\\012END;\\012$$ LANGUAGE 'plpgsql';\\012\\012CREATE TRIGGER SAMPLE_SUBCODE_UNIQUENESS_CHECK BEFORE INSERT OR UPDATE ON SAMPLES\\012    FOR EACH ROW EXECUTE PROCEDURE SAMPLE_SUBCODE_UNIQUENESS_CHECK();\\012    \\012-- Fixing error messages in old trigger\\012\\012CREATE OR REPLACE FUNCTION SAMPLE_CODE_UNIQUENESS_CHECK() RETURNS trigger AS $$\\012DECLARE\\012   counter  INTEGER;\\012BEGIN\\012  LOCK TABLE samples IN EXCLUSIVE MODE;\\012  \\012\\011  IF (NEW.samp_id_part_of is NULL) THEN\\012\\011\\011  IF (NEW.dbin_id is not NULL) THEN\\012\\011\\011\\011  SELECT count(*) into counter FROM samples \\012\\011\\011      where id != NEW.id and code = NEW.code and samp_id_part_of is NULL and dbin_id = NEW.dbin_id;\\012        IF (counter > 0) THEN\\012\\011\\011\\011\\011  RAISE EXCEPTION 'Insert/Update of Sample (Code: %) failed because database instance sample with the same code already exists.', NEW.code;\\012        END IF;\\012\\011\\011  ELSIF (NEW.grou_id is not NULL) THEN\\012\\011\\011\\011  SELECT count(*) into counter FROM samples \\012\\011\\011\\011\\011  where id != NEW.id and code = NEW.code and samp_id_part_of is NULL and grou_id = NEW.grou_id;\\012\\011\\011\\011  IF (counter > 0) THEN\\012\\011\\011\\011\\011  RAISE EXCEPTION 'Insert/Update of Sample (Code: %) failed because space sample with the same code already exists.', NEW.code;\\012\\011\\011\\011  END IF;\\012      END IF;\\012    ELSE\\012\\011\\011  IF (NEW.dbin_id is not NULL) THEN\\012\\011\\011\\011  SELECT count(*) into counter FROM samples \\012\\011\\011\\011\\011  where id != NEW.id and code = NEW.code and samp_id_part_of = NEW.samp_id_part_of and dbin_id = NEW.dbin_id;\\012\\011\\011\\011  IF (counter > 0) THEN\\012\\011\\011\\011\\011  RAISE EXCEPTION 'Insert/Update of Sample (Code: %) failed because database instance sample with the same code and being the part of the same container already exists.', NEW.code;\\012\\011\\011\\011  END IF;\\012\\011\\011  ELSIF (NEW.grou_id is not NULL) THEN\\012\\011\\011\\011  SELECT count(*) into counter FROM samples \\012\\011\\011\\011\\011  where id != NEW.id and code = NEW.code and samp_id_part_of = NEW.samp_id_part_of and grou_id = NEW.grou_id;\\012\\011\\011\\011  IF (counter > 0) THEN\\012\\011\\011\\011\\011  RAISE EXCEPTION 'Insert/Update of Sample (Code: %) failed because space sample with the same code and being the part of the same container already exists.', NEW.code;\\012\\011\\011\\011  END IF;\\012\\011\\011  END IF;\\012     END IF;   \\012  \\012  RETURN NEW;\\012END;\\012$$ LANGUAGE 'plpgsql';\\012	\N
+./sourceTest/sql/postgresql/053/.svn/text-base/schema-053.sql.svn-base:    LANGUAGE plpgsql
+./sourceTest/sql/postgresql/053/.svn/text-base/schema-053.sql.svn-base:    LANGUAGE plpgsql
+./sourceTest/sql/postgresql/053/.svn/text-base/schema-053.sql.svn-base:    LANGUAGE plpgsql
+./sourceTest/sql/postgresql/053/.svn/text-base/schema-053.sql.svn-base:    LANGUAGE plpgsql
+./sourceTest/sql/postgresql/053/.svn/text-base/schema-053.sql.svn-base:    LANGUAGE plpgsql
+./sourceTest/sql/postgresql/053/.svn/text-base/schema-053.sql.svn-base:    LANGUAGE plpgsql
+./sourceTest/sql/postgresql/053/.svn/text-base/schema-053.sql.svn-base:    LANGUAGE plpgsql
+./sourceTest/sql/postgresql/053/.svn/text-base/schema-053.sql.svn-base:    LANGUAGE plpgsql
+./sourceTest/sql/postgresql/053/.svn/text-base/schema-053.sql.svn-base:    LANGUAGE plpgsql
+./sourceTest/sql/postgresql/053/.svn/text-base/schema-053.sql.svn-base:    LANGUAGE plpgsql
+./sourceTest/sql/postgresql/053/.svn/text-base/schema-053.sql.svn-base:    LANGUAGE plpgsql
+./sourceTest/sql/postgresql/053/017=database_version_logs.tsv:027	D:\\User\\felmer\\dev-workspace\\openbis/source/sql/postgresql/027/function-027.sql	SUCCESS	2008-11-05 09:18:00.403	-- Creating Functions\\012\\012------------------------------------------------------------------------------------\\012--  Purpose:  Create function RENAME_SEQUENCE() that is required for renaming the sequences belonging to tables\\012------------------------------------------------------------------------------------\\012CREATE FUNCTION RENAME_SEQUENCE(OLD_NAME VARCHAR, NEW_NAME VARCHAR) RETURNS INTEGER AS $$\\012DECLARE\\012  CURR_SEQ_VAL   INTEGER;\\012BEGIN\\012  SELECT INTO CURR_SEQ_VAL NEXTVAL(OLD_NAME);\\012  EXECUTE 'CREATE SEQUENCE ' || NEW_NAME || ' START WITH ' || CURR_SEQ_VAL;\\012  EXECUTE 'DROP SEQUENCE ' || OLD_NAME;\\012  RETURN CURR_SEQ_VAL;\\012END;\\012$$ LANGUAGE 'plpgsql';\\012\\012\\012------------------------------------------------------------------------------------\\012--  Purpose:  Create trigger CONTROLLED_VOCABULARY_CHECK \\012------------------------------------------------------------------------------------\\012\\012CREATE OR REPLACE FUNCTION CONTROLLED_VOCABULARY_CHECK() RETURNS trigger AS $$\\012DECLARE\\012   v_code  CODE;\\012BEGIN\\012\\012   select code into v_code from data_types where id = NEW.daty_id;\\012\\012   -- Check if the data is of type "CONTROLLEDVOCABULARY"\\012   if v_code = 'CONTROLLEDVOCABULARY' then\\012      if NEW.covo_id IS NULL then\\012         RAISE EXCEPTION 'Insert/Update of Property Type (Code: %) failed, as its Data Type is CONTROLLEDVOCABULARY, but it is not linked to a Controlled Vocabulary.', NEW.code;\\012      end if;\\012   end if;\\012\\012   RETURN NEW;\\012\\012END;\\012$$ LANGUAGE 'plpgsql';\\012\\012CREATE TRIGGER CONTROLLED_VOCABULARY_CHECK BEFORE INSERT OR UPDATE ON PROPERTY_TYPES\\012    FOR EACH ROW EXECUTE PROCEDURE CONTROLLED_VOCABULARY_CHECK();\\012\\012\\012------------------------------------------------------------------------------------\\012--  Purpose:  Create trigger EXTERNAL_DATA_STORAGE_FORMAT_CHECK \\012------------------------------------------------------------------------------------\\012\\012CREATE OR REPLACE FUNCTION EXTERNAL_DATA_STORAGE_FORMAT_CHECK() RETURNS trigger AS $$\\012DECLARE\\012   v_covo_code  CODE;\\012   data_code CODE;\\012BEGIN\\012\\012   select code into v_covo_code from controlled_vocabularies\\012      where is_internal_namespace = true and \\012         id = (select covo_id from controlled_vocabulary_terms where id = NEW.cvte_id_stor_fmt);\\012   -- Check if the data storage format is a term of the controlled vocabulary "STORAGE_FORMAT"\\012   if v_covo_code != 'STORAGE_FORMAT' then\\012      select code into data_code from data where id = NEW.data_id; \\012      RAISE EXCEPTION 'Insert/Update of Data (Code: %) failed, as its Storage Format is %, but is required to be STORAGE_FORMAT.', data_code, v_covo_code;\\012   end if;\\012\\012   RETURN NEW;\\012\\012END;\\012$$ LANGUAGE 'plpgsql';\\012\\012CREATE TRIGGER EXTERNAL_DATA_STORAGE_FORMAT_CHECK BEFORE INSERT OR UPDATE ON EXTERNAL_DATA\\012    FOR EACH ROW EXECUTE PROCEDURE EXTERNAL_DATA_STORAGE_FORMAT_CHECK();\\012\\012------------------------------------------------------------------------------------\\012--  Purpose:  Create trigger SAMPLE_CODE_UNIQUENESS_CHECK \\012------------------------------------------------------------------------------------\\012\\012CREATE OR REPLACE FUNCTION SAMPLE_CODE_UNIQUENESS_CHECK() RETURNS trigger AS $$\\012DECLARE\\012   counter  INTEGER;\\012BEGIN\\012\\011IF (NEW.samp_id_part_of is NULL) THEN\\012\\011\\011IF (NEW.dbin_id is not NULL) THEN\\012\\011\\011\\011SELECT count(*) into counter FROM samples \\012\\011\\011\\011\\011where id != NEW.id and code = NEW.code and samp_id_part_of is NULL and dbin_id = NEW.dbin_id;\\012\\011\\011\\011IF (counter > 0) THEN\\012\\011\\011\\011\\011RAISE EXCEPTION 'Insert/Update of Sample (Code: %) failed because database instance sample with the same code already exists.', NEW.code;\\012\\011\\011\\011END IF;\\012\\011\\011ELSIF (NEW.grou_id is not NULL) THEN\\012\\011\\011\\011SELECT count(*) into counter FROM samples \\012\\011\\011\\011\\011where id != NEW.id and code = NEW.code and samp_id_part_of is NULL and grou_id = NEW.grou_id;\\012\\011\\011\\011IF (counter > 0) THEN\\012\\011\\011\\011\\011RAISE EXCEPTION 'Insert/Update of Sample (Code: %) failed because group sample with the same code already exists.', NEW.code;\\012\\011\\011\\011END IF;\\012\\011\\011END IF;\\012        ELSE\\012\\011\\011IF (NEW.dbin_id is not NULL) THEN\\012\\011\\011\\011SELECT count(*) into counter FROM samples \\012\\011\\011\\011\\011where id != NEW.id and code = NEW.code and samp_id_part_of = NEW.samp_id_part_of and dbin_id = NEW.dbin_id;\\012\\011\\011\\011IF (counter > 0) THEN\\012\\011\\011\\011\\011RAISE EXCEPTION 'Insert/Update of Sample (Code: %) failed because database instance sample with the same code and being the part of the same parent already exists.', NEW.code;\\012\\011\\011\\011END IF;\\012\\011\\011ELSIF (NEW.grou_id is not NULL) THEN\\012\\011\\011\\011SELECT count(*) into counter FROM samples \\012\\011\\011\\011\\011where id != NEW.id and code = NEW.code and samp_id_part_of = NEW.samp_id_part_of and grou_id = NEW.grou_id;\\012\\011\\011\\011IF (counter > 0) THEN\\012\\011\\011\\011\\011RAISE EXCEPTION 'Insert/Update of Sample (Code: %) failed because group sample with the same code and being the part of the same parent already exists.', NEW.code;\\012\\011\\011\\011END IF;\\012\\011\\011END IF;\\012        END IF;   \\012   RETURN NEW;\\012END;\\012$$ LANGUAGE 'plpgsql';\\012\\012CREATE TRIGGER SAMPLE_CODE_UNIQUENESS_CHECK BEFORE INSERT OR UPDATE ON SAMPLES\\012    FOR EACH ROW EXECUTE PROCEDURE SAMPLE_CODE_UNIQUENESS_CHECK();\\012	\N
+./sourceTest/sql/postgresql/053/017=database_version_logs.tsv:028	source/sql/postgresql/migration/migration-027-028.sql	SUCCESS	2008-11-18 13:24:17.508	-- Create EXPERIMENT_ATTACHMENT_CONTENTS.\\012CREATE TABLE EXPERIMENT_ATTACHMENT_CONTENTS (ID TECH_ID NOT NULL,VALUE FILE NOT NULL);\\012CREATE SEQUENCE EXPERIMENT_ATTACHMENT_CONTENT_ID_SEQ;\\012ALTER TABLE EXPERIMENT_ATTACHMENT_CONTENTS ADD CONSTRAINT EXAC_PK PRIMARY KEY(ID);\\012\\012-- Alter EXPERIMENT_ATTACHMENTS by adding the new column which has a NULL constraint.\\012-- The NOT NULL constraint is added later on.\\012ALTER TABLE EXPERIMENT_ATTACHMENTS ADD COLUMN EXAC_ID TECH_ID;\\012\\012-- Does the VALUE migration between EXPERIMENT_ATTACHMENTS to EXPERIMENT_ATTACHMENT_CONTENTS.\\012CREATE OR REPLACE FUNCTION move_exp_att_content() RETURNS integer AS $$\\012DECLARE\\012    rec RECORD;\\012    seq BIGINT;\\012BEGIN\\012  FOR rec IN SELECT id, value FROM EXPERIMENT_ATTACHMENTS LOOP\\012  \\011seq := nextval('EXPERIMENT_ATTACHMENT_CONTENT_ID_SEQ');\\012    INSERT INTO EXPERIMENT_ATTACHMENT_CONTENTS (id, value) VALUES (seq, rec.value);\\012    UPDATE EXPERIMENT_ATTACHMENTS SET exac_id = seq WHERE id = rec.id;\\012  END LOOP;\\012  RETURN 1;\\012END;\\012$$ LANGUAGE 'plpgsql';\\012\\012-- Call the function.\\012SELECT move_exp_att_content();\\012DROP FUNCTION move_exp_att_content();\\012\\012\\012-- Finish EXPERIMENT_ATTACHMENTS changes.\\012ALTER TABLE EXPERIMENT_ATTACHMENTS ADD CONSTRAINT EXAT_CONT_FK FOREIGN KEY (EXAC_ID) REFERENCES EXPERIMENT_ATTACHMENT_CONTENTS(ID);\\012ALTER TABLE EXPERIMENT_ATTACHMENTS DROP COLUMN VALUE;\\012ALTER TABLE EXPERIMENT_ATTACHMENTS ALTER COLUMN EXAC_ID SET NOT NULL;\\012	\N
+./sourceTest/sql/postgresql/053/017=database_version_logs.tsv:029	source/sql/postgresql/migration/migration-028-029.sql	SUCCESS	2009-03-18 10:50:20.105	-- -------\\012-- add modification_timestamp field to allow edition with Hibernate\\012-- -------\\012\\012ALTER TABLE samples\\012\\011ADD COLUMN modification_timestamp TIME_STAMP DEFAULT CURRENT_TIMESTAMP;\\012\\012ALTER TABLE experiments\\012\\011ADD COLUMN modification_timestamp TIME_STAMP DEFAULT CURRENT_TIMESTAMP;\\012\\012ALTER TABLE materials\\012\\011ADD COLUMN modification_timestamp TIME_STAMP DEFAULT CURRENT_TIMESTAMP;\\012\\012ALTER TABLE experiment_properties\\012\\011ADD COLUMN modification_timestamp TIME_STAMP DEFAULT CURRENT_TIMESTAMP;\\012\\012ALTER TABLE material_properties\\012\\011ADD COLUMN modification_timestamp TIME_STAMP DEFAULT CURRENT_TIMESTAMP;\\012\\012ALTER TABLE sample_properties\\012\\011ADD COLUMN modification_timestamp TIME_STAMP DEFAULT CURRENT_TIMESTAMP;\\012\\012-- -------\\012-- add property data type which references materials\\012-- -------\\012\\012ALTER TABLE property_types\\012\\011ADD COLUMN maty_prop_id tech_id;\\012\\012ALTER TABLE property_types\\012\\011ADD CONSTRAINT prty_maty_fk FOREIGN KEY (maty_prop_id) REFERENCES material_types(id);\\012\\012ALTER TABLE experiment_properties\\012\\011ADD COLUMN mate_prop_id tech_id;\\012\\012ALTER TABLE material_properties\\012\\011ADD COLUMN mate_prop_id tech_id;\\012\\012ALTER TABLE sample_properties\\012\\011ADD COLUMN mate_prop_id tech_id;\\012\\012ALTER TABLE experiment_properties\\012\\011ADD CONSTRAINT expr_mapr_fk FOREIGN KEY (mate_prop_id) REFERENCES materials(id);\\012\\012ALTER TABLE material_properties\\012\\011ADD CONSTRAINT mapr_mapr_fk FOREIGN KEY (mate_prop_id) REFERENCES materials(id);\\012\\012ALTER TABLE sample_properties\\012\\011ADD CONSTRAINT sapr_mapr_fk FOREIGN KEY (mate_prop_id) REFERENCES materials(id);\\012\\012insert into data_types\\012(id\\012 ,code\\012 ,description)\\012 values \\012 (nextval('DATA_TYPE_ID_SEQ')\\012 ,'MATERIAL'\\012 ,'Reference to a material'\\012);\\012\\012ALTER TABLE MATERIAL_PROPERTIES DROP CONSTRAINT MAPR_CK;\\012ALTER TABLE MATERIAL_PROPERTIES ADD CONSTRAINT MAPR_CK CHECK \\012\\011((VALUE IS NOT NULL AND CVTE_ID IS NULL AND MATE_PROP_ID IS NULL) OR \\012\\011 (VALUE IS NULL AND CVTE_ID IS NOT NULL AND MATE_PROP_ID IS NULL) OR\\012\\011 (VALUE IS NULL AND CVTE_ID IS NULL AND MATE_PROP_ID IS NOT NULL)\\012\\011);\\012\\012ALTER TABLE EXPERIMENT_PROPERTIES DROP CONSTRAINT EXPR_CK;\\012ALTER TABLE EXPERIMENT_PROPERTIES ADD CONSTRAINT EXPR_CK CHECK \\012\\011((VALUE IS NOT NULL AND CVTE_ID IS NULL AND MATE_PROP_ID IS NULL) OR \\012\\011 (VALUE IS NULL AND CVTE_ID IS NOT NULL AND MATE_PROP_ID IS NULL) OR\\012\\011 (VALUE IS NULL AND CVTE_ID IS NULL AND MATE_PROP_ID IS NOT NULL)\\012\\011);\\012\\012ALTER TABLE SAMPLE_PROPERTIES DROP CONSTRAINT SAPR_CK;\\012ALTER TABLE SAMPLE_PROPERTIES ADD CONSTRAINT SAPR_CK CHECK \\012\\011((VALUE IS NOT NULL AND CVTE_ID IS NULL AND MATE_PROP_ID IS NULL) OR \\012\\011 (VALUE IS NULL AND CVTE_ID IS NOT NULL AND MATE_PROP_ID IS NULL) OR\\012\\011 (VALUE IS NULL AND CVTE_ID IS NULL AND MATE_PROP_ID IS NOT NULL)\\012\\011);\\012\\012------------------------------------------------------------------------------------\\012--  Purpose:  Create trigger MATERIAL/SAMPLE/EXPERIMENT _PROPERTY_WITH_MATERIAL_DATA_TYPE_CHECK\\012--            It checks that if material property value is assigned to the entity,\\012--\\011\\011\\011\\011\\011\\011then the material type is equal to the one described by property type.\\012------------------------------------------------------------------------------------\\012\\012CREATE OR REPLACE FUNCTION MATERIAL_PROPERTY_WITH_MATERIAL_DATA_TYPE_CHECK() RETURNS trigger AS $$\\012DECLARE\\012   v_type_id  CODE;\\012   v_type_id_prop  CODE;\\012BEGIN\\012   if NEW.mate_prop_id IS NOT NULL then\\012\\011\\011\\011-- find material type id of the property type \\012\\011\\011\\011select pt.maty_prop_id into v_type_id_prop \\012\\011\\011\\011  from material_type_property_types etpt, property_types pt \\012\\011\\011\\011 where NEW.mtpt_id = etpt.id AND etpt.prty_id = pt.id;\\012\\011\\011\\012\\011\\011\\011if v_type_id_prop IS NOT NULL then\\012\\011\\011\\011\\011-- find material type id of the material which consists the entity's property value\\012\\011\\011\\011\\011select entity.maty_id into v_type_id \\012\\011\\011\\011\\011  from materials entity\\012\\011\\011\\011\\011 where NEW.mate_prop_id = entity.id;\\012\\011\\011\\011\\011if v_type_id != v_type_id_prop then\\012\\011\\011\\011\\011\\011RAISE EXCEPTION 'Insert/Update of property value referencing material (id: %) failed, as referenced material type is different than expected (id %, expected id: %).', \\012\\011\\011\\011\\011\\011\\011\\011 NEW.mate_prop_id, v_type_id, v_type_id_prop;\\012\\011\\011\\011\\011end if;\\012\\011\\011\\011end if;\\012   end if;\\012   RETURN NEW;\\012END;\\012$$ LANGUAGE 'plpgsql';\\012\\012CREATE TRIGGER MATERIAL_PROPERTY_WITH_MATERIAL_DATA_TYPE_CHECK BEFORE INSERT OR UPDATE ON material_properties\\012    FOR EACH ROW EXECUTE PROCEDURE MATERIAL_PROPERTY_WITH_MATERIAL_DATA_TYPE_CHECK();\\012    \\012CREATE OR REPLACE FUNCTION SAMPLE_PROPERTY_WITH_MATERIAL_DATA_TYPE_CHECK() RETURNS trigger AS $$\\012DECLARE\\012   v_type_id  CODE;\\012   v_type_id_prop  CODE;\\012BEGIN\\012   if NEW.mate_prop_id IS NOT NULL then\\012\\011\\011\\011-- find material type id of the property type \\012\\011\\011\\011select pt.maty_prop_id into v_type_id_prop \\012\\011\\011\\011  from sample_type_property_types etpt, property_types pt \\012\\011\\011\\011 where NEW.stpt_id = etpt.id AND etpt.prty_id = pt.id;\\012\\011\\011\\012\\011\\011\\011if v_type_id_prop IS NOT NULL then\\012\\011\\011\\011\\011-- find material type id of the material which consists the entity's property value\\012\\011\\011\\011\\011select entity.maty_id into v_type_id \\012\\011\\011\\011\\011  from materials entity\\012\\011\\011\\011\\011 where NEW.mate_prop_id = entity.id;\\012\\011\\011\\011\\011if v_type_id != v_type_id_prop then\\012\\011\\011\\011\\011\\011RAISE EXCEPTION 'Insert/Update of property value referencing material (id: %) failed, as referenced material type is different than expected (id %, expected id: %).', \\012\\011\\011\\011\\011\\011\\011\\011\\011\\011\\011\\011\\011 NEW.mate_prop_id, v_type_id, v_type_id_prop;\\012\\011\\011\\011\\011end if;\\012\\011\\011\\011end if;\\012   end if;\\012   RETURN NEW;\\012END;\\012$$ LANGUAGE 'plpgsql';\\012\\012CREATE TRIGGER SAMPLE_PROPERTY_WITH_MATERIAL_DATA_TYPE_CHECK BEFORE INSERT OR UPDATE ON sample_properties\\012    FOR EACH ROW EXECUTE PROCEDURE SAMPLE_PROPERTY_WITH_MATERIAL_DATA_TYPE_CHECK();\\012    \\012CREATE OR REPLACE FUNCTION EXPERIMENT_PROPERTY_WITH_MATERIAL_DATA_TYPE_CHECK() RETURNS trigger AS $$\\012DECLARE\\012   v_type_id  CODE;\\012   v_type_id_prop  CODE;\\012BEGIN\\012   if NEW.mate_prop_id IS NOT NULL then\\012\\011\\011\\011-- find material type id of the property type \\012\\011\\011\\011select pt.maty_prop_id into v_type_id_prop \\012\\011\\011\\011  from experiment_type_property_types etpt, property_types pt \\012\\011\\011\\011 where NEW.etpt_id = etpt.id AND etpt.prty_id = pt.id;\\012\\011\\011\\012\\011\\011\\011if v_type_id_prop IS NOT NULL then\\012\\011\\011\\011\\011-- find material type id of the material which consists the entity's property value\\012\\011\\011\\011\\011select entity.maty_id into v_type_id \\012\\011\\011\\011\\011  from materials entity\\012\\011\\011\\011\\011 where NEW.mate_prop_id = entity.id;\\012\\011\\011\\011\\011if v_type_id != v_type_id_prop then\\012\\011\\011\\011\\011\\011RAISE EXCEPTION 'Insert/Update of property value referencing material (id: %) failed, as referenced material type is different than expected (id %, expected id: %).', \\012\\011\\011\\011\\011\\011\\011\\011\\011\\011\\011\\011\\011 NEW.mate_prop_id, v_type_id, v_type_id_prop;\\012\\011\\011\\011\\011end if;\\012\\011\\011\\011end if;\\012   end if;\\012   RETURN NEW;\\012END;\\012$$ LANGUAGE 'plpgsql';\\012\\012CREATE TRIGGER EXPERIMENT_PROPERTY_WITH_MATERIAL_DATA_TYPE_CHECK BEFORE INSERT OR UPDATE ON experiment_properties\\012    FOR EACH ROW EXECUTE PROCEDURE EXPERIMENT_PROPERTY_WITH_MATERIAL_DATA_TYPE_CHECK();\\012       \\012-- -------\\012-- remove the reminescents of the OBSERVABLE_TYPE\\012-- -------\\012\\012ALTER TABLE data\\012\\011DROP CONSTRAINT data_obty_fk;\\012\\012ALTER TABLE data_set_types\\012\\011DROP CONSTRAINT obty_pk;\\012\\012ALTER TABLE data_set_types\\012\\011ADD CONSTRAINT dsty_pk PRIMARY KEY (id);\\012\\012ALTER TABLE data\\012\\011ADD CONSTRAINT data_dsty_fk FOREIGN KEY (dsty_id) REFERENCES data_set_types(id);\\012\\012ALTER TABLE data_set_types\\012\\011DROP CONSTRAINT obty_bk_uk;\\012\\012ALTER TABLE data_set_types\\012\\011DROP CONSTRAINT obty_dbin_fk;\\012\\012ALTER TABLE data_set_types\\012\\011ADD CONSTRAINT dsty_bk_uk UNIQUE (code, dbin_id);\\012\\012ALTER TABLE data_set_types\\012\\011ADD CONSTRAINT dsty_dbin_fk FOREIGN KEY (dbin_id) REFERENCES database_instances(id);\\012\\012DROP INDEX data_obty_fk_i;\\012\\012CREATE INDEX data_dsty_fk_i ON data(dsty_id);\\012	\N
+./sourceTest/sql/postgresql/053/017=database_version_logs.tsv:030	source/sql/postgresql/migration/migration-029-030.sql	SUCCESS	2009-03-23 15:34:44.72	-- -------\\012-- add modification_timestamp field to allow edition with Hibernate\\012-- -------\\012ALTER TABLE data\\012\\011ADD COLUMN modification_timestamp TIME_STAMP DEFAULT CURRENT_TIMESTAMP;\\012ALTER TABLE experiment_types\\012\\011ADD COLUMN modification_timestamp TIME_STAMP DEFAULT CURRENT_TIMESTAMP;\\012ALTER TABLE sample_types\\012\\011ADD COLUMN modification_timestamp TIME_STAMP DEFAULT CURRENT_TIMESTAMP;\\012ALTER TABLE material_types\\012\\011ADD COLUMN modification_timestamp TIME_STAMP DEFAULT CURRENT_TIMESTAMP;\\012ALTER TABLE data_set_types\\012\\011ADD COLUMN modification_timestamp TIME_STAMP DEFAULT CURRENT_TIMESTAMP;\\012ALTER TABLE controlled_vocabularies\\012\\011ADD COLUMN modification_timestamp TIME_STAMP DEFAULT CURRENT_TIMESTAMP;\\012-- -------\\012-- add properties to data sets\\012-- -------\\012CREATE TABLE DATA_SET_PROPERTIES (ID TECH_ID NOT NULL,DS_ID TECH_ID NOT NULL,DSTPT_ID TECH_ID NOT NULL,VALUE GENERIC_VALUE,CVTE_ID TECH_ID, MATE_PROP_ID TECH_ID, PERS_ID_REGISTERER TECH_ID NOT NULL,REGISTRATION_TIMESTAMP TIME_STAMP_DFL NOT NULL DEFAULT CURRENT_TIMESTAMP, MODIFICATION_TIMESTAMP TIME_STAMP DEFAULT CURRENT_TIMESTAMP);\\012CREATE TABLE DATA_SET_TYPE_PROPERTY_TYPES (ID TECH_ID NOT NULL,DSTY_ID TECH_ID NOT NULL,PRTY_ID TECH_ID NOT NULL,IS_MANDATORY BOOLEAN_CHAR NOT NULL DEFAULT 'F',IS_MANAGED_INTERNALLY BOOLEAN_CHAR NOT NULL DEFAULT 'F',PERS_ID_REGISTERER TECH_ID NOT NULL,REGISTRATION_TIMESTAMP TIME_STAMP_DFL NOT NULL DEFAULT CURRENT_TIMESTAMP);\\012\\012CREATE SEQUENCE DATA_SET_PROPERTY_ID_SEQ;\\012CREATE SEQUENCE DSTPT_ID_SEQ;\\012\\012ALTER TABLE DATA_SET_TYPE_PROPERTY_TYPES ADD CONSTRAINT DSTPT_PK PRIMARY KEY(ID);\\012ALTER TABLE DATA_SET_PROPERTIES ADD CONSTRAINT DSPR_PK PRIMARY KEY(ID);\\012\\012ALTER TABLE DATA_SET_TYPE_PROPERTY_TYPES ADD CONSTRAINT DSTPT_BK_UK UNIQUE(DSTY_ID,PRTY_ID);\\012ALTER TABLE DATA_SET_PROPERTIES ADD CONSTRAINT DSPR_BK_UK UNIQUE(DS_ID,DSTPT_ID);\\012\\012\\012ALTER TABLE DATA_SET_TYPE_PROPERTY_TYPES ADD CONSTRAINT DSTPT_DSTY_FK FOREIGN KEY (DSTY_ID) REFERENCES DATA_SET_TYPES(ID);\\012ALTER TABLE DATA_SET_TYPE_PROPERTY_TYPES ADD CONSTRAINT DSTPT_PERS_FK FOREIGN KEY (PERS_ID_REGISTERER) REFERENCES PERSONS(ID);\\012ALTER TABLE DATA_SET_TYPE_PROPERTY_TYPES ADD CONSTRAINT DSTPT_PRTY_FK FOREIGN KEY (PRTY_ID) REFERENCES PROPERTY_TYPES(ID);\\012ALTER TABLE DATA_SET_PROPERTIES ADD CONSTRAINT DSPR_CVTE_FK FOREIGN KEY (CVTE_ID) REFERENCES CONTROLLED_VOCABULARY_TERMS(ID);\\012ALTER TABLE DATA_SET_PROPERTIES ADD CONSTRAINT DSPR_DSTPT_FK FOREIGN KEY (DSTPT_ID) REFERENCES DATA_SET_TYPE_PROPERTY_TYPES(ID) ON DELETE CASCADE;\\012ALTER TABLE DATA_SET_PROPERTIES ADD CONSTRAINT DSPR_DS_FK FOREIGN KEY (DS_ID) REFERENCES DATA(ID);\\012ALTER TABLE DATA_SET_PROPERTIES ADD CONSTRAINT DSPR_PERS_FK FOREIGN KEY (PERS_ID_REGISTERER) REFERENCES PERSONS(ID);\\012ALTER TABLE DATA_SET_PROPERTIES ADD CONSTRAINT DSPR_MAPR_FK FOREIGN KEY (MATE_PROP_ID) REFERENCES MATERIALS(ID);\\012\\012ALTER TABLE DATA_SET_PROPERTIES ADD CONSTRAINT DSPR_CK CHECK \\012\\011((VALUE IS NOT NULL AND CVTE_ID IS NULL AND MATE_PROP_ID IS NULL) OR \\012\\011 (VALUE IS NULL AND CVTE_ID IS NOT NULL AND MATE_PROP_ID IS NULL) OR\\012\\011 (VALUE IS NULL AND CVTE_ID IS NULL AND MATE_PROP_ID IS NOT NULL)\\012\\011);\\012\\012CREATE INDEX DSPR_CVTE_FK_I ON DATA_SET_PROPERTIES (CVTE_ID);\\012CREATE INDEX DSPR_DSTPT_FK_I ON DATA_SET_PROPERTIES (DSTPT_ID);\\012CREATE INDEX DSPR_DS_FK_I ON DATA_SET_PROPERTIES (DS_ID);\\012CREATE INDEX DSPR_PERS_FK_I ON DATA_SET_PROPERTIES (PERS_ID_REGISTERER);\\012CREATE INDEX DSTPT_DSTY_FK_I ON DATA_SET_TYPE_PROPERTY_TYPES (DSTY_ID);\\012CREATE INDEX DSTPT_PERS_FK_I ON DATA_SET_TYPE_PROPERTY_TYPES (PERS_ID_REGISTERER);\\012CREATE INDEX DSTPT_PRTY_FK_I ON DATA_SET_TYPE_PROPERTY_TYPES (PRTY_ID);\\012\\012CREATE OR REPLACE FUNCTION DATA_SET_PROPERTY_WITH_MATERIAL_DATA_TYPE_CHECK() RETURNS trigger AS $$\\012DECLARE\\012   v_type_id  CODE;\\012   v_type_id_prop  CODE;\\012BEGIN\\012   if NEW.mate_prop_id IS NOT NULL then\\012\\011\\011\\011-- find material type id of the property type \\012\\011\\011\\011select pt.maty_prop_id into v_type_id_prop \\012\\011\\011\\011  from data_set_type_property_types dstpt, property_types pt \\012\\011\\011\\011 where NEW.dstpt_id = dstpt.id AND dstpt.prty_id = pt.id;\\012\\011\\011\\012\\011\\011\\011if v_type_id_prop IS NOT NULL then\\012\\011\\011\\011\\011-- find material type id of the material which consists the entity's property value\\012\\011\\011\\011\\011select entity.maty_id into v_type_id \\012\\011\\011\\011\\011  from materials entity\\012\\011\\011\\011\\011 where NEW.mate_prop_id = entity.id;\\012\\011\\011\\011\\011if v_type_id != v_type_id_prop then\\012\\011\\011\\011\\011\\011RAISE EXCEPTION 'Insert/Update of property value referencing material (id: %) failed, as referenced material type is different than expected (id %, expected id: %).', \\012\\011\\011\\011\\011\\011\\011\\011\\011\\011\\011\\011\\011 NEW.mate_prop_id, v_type_id, v_type_id_prop;\\012\\011\\011\\011\\011end if;\\012\\011\\011\\011end if;\\012   end if;\\012   RETURN NEW;\\012END;\\012$$ LANGUAGE 'plpgsql';\\012\\012CREATE TRIGGER DATA_SET_PROPERTY_WITH_MATERIAL_DATA_TYPE_CHECK BEFORE INSERT OR UPDATE ON data_set_properties\\012    FOR EACH ROW EXECUTE PROCEDURE DATA_SET_PROPERTY_WITH_MATERIAL_DATA_TYPE_CHECK();   \\012	\N
+./sourceTest/sql/postgresql/053/017=database_version_logs.tsv:032	source/sql/postgresql/migration/migration-031-032.sql	SUCCESS	2009-04-09 09:36:36.2	-- -------\\012-- Modify MATERIAL_BATCHES\\012-- -------\\012\\012ALTER TABLE material_batches\\012    DROP COLUMN proc_id;\\012\\012-- -------\\012-- Modify SAMPLES\\012-- -------\\012\\012ALTER TABLE samples\\012    ADD COLUMN expe_id tech_id;\\012\\012ALTER TABLE samples\\012    ADD CONSTRAINT samp_expe_fk FOREIGN KEY (expe_id) REFERENCES experiments(id);\\012\\012CREATE INDEX samp_expe_fk_i ON samples USING btree (expe_id);\\012\\012-- relink samples directly to experiments\\012\\012UPDATE samples\\012SET expe_id = (SELECT e.id FROM experiments e, procedures p, sample_inputs si \\012               WHERE si.samp_id = samples.id AND si.proc_id = p.id AND p.expe_id = e.id AND e.inva_id IS NULL);\\012\\012\\012-- -------\\012-- Modify DATA\\012-- -------\\012\\012ALTER TABLE data\\012    ADD COLUMN expe_id tech_id;\\012\\012ALTER TABLE data\\012    ADD CONSTRAINT data_expe_fk FOREIGN KEY (expe_id) REFERENCES experiments(id);\\012\\012CREATE INDEX data_expe_fk_i ON data USING btree (expe_id);\\012\\012UPDATE data\\012SET expe_id = (SELECT e.id FROM experiments e, procedures p \\012               WHERE data.proc_id_produced_by = p.id AND p.expe_id = e.id);\\012\\012ALTER TABLE data\\012    ALTER COLUMN expe_id SET NOT NULL;\\012\\012ALTER TABLE data\\012    DROP COLUMN proc_id_produced_by;\\012\\012-- -------\\012-- Drop PROCEDURES, PROCEDURE_TYPES, and SAMPLE_INPUTS\\012-- -------\\012\\012DROP TABLE sample_inputs;\\012DROP TABLE procedures;\\012DROP TABLE procedure_types;\\012\\012DROP SEQUENCE procedure_id_seq;\\012DROP SEQUENCE procedure_type_id_seq;\\012\\012-- -------\\012-- Add CODE_SEQ\\012-- -------\\012\\012CREATE SEQUENCE CODE_SEQ;\\012\\012-- -------\\012-- Add new columns to DATA_STORES\\012-- -------\\012\\012ALTER TABLE data_stores\\012    ADD COLUMN remote_url character varying(250),\\012    ADD COLUMN session_token character varying(50),\\012    ADD COLUMN modification_timestamp time_stamp DEFAULT now();\\012\\012UPDATE data_stores\\012SET remote_url = '', session_token='';\\012\\012ALTER TABLE data_stores\\012    ALTER COLUMN remote_url SET NOT NULL,\\012    ALTER COLUMN session_token SET NOT NULL;\\012\\012-- -------\\012-- Drop foreign keys onto DATA_STORES\\012-- -------\\012\\012ALTER TABLE database_instances\\012    DROP COLUMN dast_id;\\012\\012ALTER TABLE groups\\012    DROP COLUMN dast_id;\\012\\012ALTER TABLE projects\\012    DROP COLUMN dast_id;\\012\\012ALTER TABLE experiments\\012    DROP COLUMN dast_id;\\012\\012-- -------\\012-- Add foreign key from DATA onto DATA_STORES\\012-- -------\\012\\012ALTER TABLE data\\012    ADD COLUMN dast_id tech_id;\\012\\012ALTER TABLE data\\012    ADD CONSTRAINT data_dast_fk FOREIGN KEY (dast_id) REFERENCES data_stores(id);\\012\\012UPDATE data\\012SET dast_id = (select id from data_stores where code = 'STANDARD');\\012\\012ALTER TABLE data\\012    ALTER COLUMN dast_id SET NOT NULL;\\012\\012\\012------------------------------------------------------------------------------------\\012--  Purpose:  Replace trigger SAMPLE_CODE_UNIQUENESS_CHECK \\012------------------------------------------------------------------------------------\\012\\012CREATE OR REPLACE FUNCTION SAMPLE_CODE_UNIQUENESS_CHECK() RETURNS trigger AS $$\\012DECLARE\\012   counter  INTEGER;\\012BEGIN\\012    LOCK TABLE samples IN EXCLUSIVE MODE;\\012    IF (NEW.samp_id_part_of is NULL) THEN\\012        IF (NEW.dbin_id is not NULL) THEN\\012            SELECT count(*) into counter FROM samples \\012                where id != NEW.id and code = NEW.code and samp_id_part_of is NULL and dbin_id = NEW.dbin_id;\\012            IF (counter > 0) THEN\\012                RAISE EXCEPTION 'Insert/Update of Sample (Code: %) failed because database instance sample with the same code already exists.', NEW.code;\\012            END IF;\\012        ELSIF (NEW.grou_id is not NULL) THEN\\012            SELECT count(*) into counter FROM samples \\012                where id != NEW.id and code = NEW.code and samp_id_part_of is NULL and grou_id = NEW.grou_id;\\012            IF (counter > 0) THEN\\012                RAISE EXCEPTION 'Insert/Update of Sample (Code: %) failed because group sample with the same code already exists.', NEW.code;\\012            END IF;\\012        END IF;\\012        ELSE\\012        IF (NEW.dbin_id is not NULL) THEN\\012            SELECT count(*) into counter FROM samples \\012                where id != NEW.id and code = NEW.code and samp_id_part_of = NEW.samp_id_part_of and dbin_id = NEW.dbin_id;\\012            IF (counter > 0) THEN\\012                RAISE EXCEPTION 'Insert/Update of Sample (Code: %) failed because database instance sample with the same code and being the part of the same parent already exists.', NEW.code;\\012            END IF;\\012        ELSIF (NEW.grou_id is not NULL) THEN\\012            SELECT count(*) into counter FROM samples \\012                where id != NEW.id and code = NEW.code and samp_id_part_of = NEW.samp_id_part_of and grou_id = NEW.grou_id;\\012            IF (counter > 0) THEN\\012                RAISE EXCEPTION 'Insert/Update of Sample (Code: %) failed because group sample with the same code and being the part of the same parent already exists.', NEW.code;\\012            END IF;\\012        END IF;\\012        END IF;   \\012   RETURN NEW;\\012END;\\012$$ LANGUAGE 'plpgsql';\\012\\012\\012\\012	\N
+./sourceTest/sql/postgresql/053/017=database_version_logs.tsv:034	source/sql/postgresql/migration/migration-033-034.sql	SUCCESS	2009-05-26 08:32:49.935	------------------------------------------------------------------------------------\\012-- Create sequence for generating permanent identifiers starting with nextval of existing dataset sequence.\\012------------------------------------------------------------------------------------\\012CREATE FUNCTION CREATE_SEQUENCE(EXISTING_SEQUENCE VARCHAR, NEW_SEQUENCE VARCHAR) RETURNS VOID AS $$\\012DECLARE\\012  CURR_SEQ_VAL   INTEGER;\\012BEGIN\\012  SELECT INTO CURR_SEQ_VAL NEXTVAL(EXISTING_SEQUENCE);\\012  EXECUTE 'CREATE SEQUENCE ' || NEW_SEQUENCE || ' START WITH ' || CURR_SEQ_VAL;\\012  RETURN;\\012END;\\012$$ LANGUAGE 'plpgsql';\\012\\012SELECT CREATE_SEQUENCE('DATA_ID_SEQ', 'PERM_ID_SEQ');\\012DROP FUNCTION CREATE_SEQUENCE(VARCHAR, VARCHAR);\\012\\012------------------------------------------------------------------------------------\\012-- Add perm_id columns to samples and experiments.\\012------------------------------------------------------------------------------------\\012ALTER TABLE SAMPLES ADD COLUMN PERM_ID CODE;\\012ALTER TABLE EXPERIMENTS ADD COLUMN PERM_ID CODE;\\012\\012UPDATE SAMPLES SET PERM_ID = to_char(registration_timestamp,'YYYYMMDDHHSSMS') || '-' || NEXTVAL('PERM_ID_SEQ');\\012UPDATE EXPERIMENTS SET PERM_ID = to_char(registration_timestamp,'YYYYMMDDHHSSMS') || '-' || NEXTVAL('PERM_ID_SEQ');\\012ALTER TABLE SAMPLES ALTER COLUMN PERM_ID SET NOT NULL;\\012ALTER TABLE EXPERIMENTS ALTER COLUMN PERM_ID SET NOT NULL;\\012ALTER TABLE SAMPLES ADD CONSTRAINT SAMP_PI_UK UNIQUE(PERM_ID);\\012ALTER TABLE EXPERIMENTS ADD CONSTRAINT EXPE_PI_UK UNIQUE(PERM_ID);\\012\\012\\012------------------------------------------------------------------------------------\\012-- Add column is_chosen_from_list to controlled_vocabularies.\\012------------------------------------------------------------------------------------\\012ALTER TABLE controlled_vocabularies ADD COLUMN is_chosen_from_list BOOLEAN_CHAR NOT NULL DEFAULT TRUE;\\012ALTER TABLE controlled_vocabularies ADD COLUMN source_uri CHARACTER VARYING(250);\\012------------------------------------------------------------------------------------\\012-- Modify Data table - remove arc connection between Sample and Data table, use a flag instead\\012------------------------------------------------------------------------------------\\012\\012-- add new columns\\012\\012ALTER TABLE data\\012    ADD COLUMN is_derived boolean_char;\\012ALTER TABLE data\\012    ADD COLUMN samp_id tech_id;\\012\\012-- update values in new columns\\012\\012UPDATE data\\012    SET is_derived = (samp_id_derived_from IS NOT NULL); \\012UPDATE data\\012    SET samp_id = samp_id_derived_from \\012    WHERE is_derived = 'TRUE';\\012UPDATE data\\012    SET samp_id = samp_id_acquired_from \\012    WHERE is_derived = 'FALSE';\\012\\012-- add constraints and indexes to new columns\\012\\012ALTER TABLE data\\012    ALTER COLUMN is_derived SET NOT NULL;\\012ALTER TABLE data\\012    ALTER COLUMN samp_id SET NOT NULL;   \\012ALTER TABLE data\\012    ADD CONSTRAINT data_samp_fk FOREIGN KEY (samp_id) REFERENCES samples (id);\\012CREATE INDEX data_samp_fk_i ON data USING btree (samp_id);\\012\\012-- remove old columns\\012\\012ALTER TABLE data\\012    DROP COLUMN samp_id_acquired_from;\\012ALTER TABLE data\\012    DROP COLUMN samp_id_derived_from;\\012    \\012------------------------------------------------------------------------------------\\012-- Granting SELECT privilege to group openbis_readonly\\012------------------------------------------------------------------------------------\\012\\012GRANT SELECT ON SEQUENCE attachment_content_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE attachment_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE code_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE controlled_vocabulary_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE cvte_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE data_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE data_set_property_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE data_set_relationship_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE data_set_type_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE data_store_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE data_type_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE database_instance_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE dstpt_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE etpt_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE event_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE experiment_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE experiment_property_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE experiment_type_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE file_format_type_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE group_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE invalidation_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE locator_type_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE material_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE material_property_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE material_type_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE mtpt_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE perm_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE person_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE project_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE property_type_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE role_assignment_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE sample_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE sample_property_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE sample_type_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE stpt_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE attachment_contents TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE attachments TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE controlled_vocabularies TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE controlled_vocabulary_terms TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE data TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE data_set_properties TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE data_set_relationships TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE data_set_type_property_types TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE data_set_types TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE data_stores TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE data_types TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE database_instances TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE database_version_logs TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE events TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE experiment_properties TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE experiment_type_property_types TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE experiment_types TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE experiments TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE external_data TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE file_format_types TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE groups TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE invalidations TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE locator_types TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE material_properties TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE material_type_property_types TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE material_types TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE materials TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE persons TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE projects TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE property_types TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE role_assignments TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE sample_properties TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE sample_type_property_types TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE sample_types TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE samples TO GROUP OPENBIS_READONLY;\\012\\012------------------------------------------------------------------------------------\\012-- Delete MATERIAL_BATCHES table\\012------------------------------------------------------------------------------------\\012\\012-- WARNING: Potential data lost!!!\\012-- WARNING: Potential data lost!!!\\012-- WARNING: Potential data lost!!!\\012\\012DROP TABLE SAMPLE_MATERIAL_BATCHES;\\012DROP TABLE MATERIAL_BATCHES;\\012DROP SEQUENCE MATERIAL_BATCH_ID_SEQ;\\012\\012------------------------------------------------------------------------------------\\012-- Delete MATE_ID_INHIBITOR_OF from table MATERIALS\\012------------------------------------------------------------------------------------\\012\\012-- WARNING: Potential data lost!!!\\012-- WARNING: Potential data lost!!!\\012-- WARNING: Potential data lost!!!\\012\\012ALTER TABLE MATERIALS DROP COLUMN MATE_ID_INHIBITOR_OF;\\012	\N
+./sourceTest/sql/postgresql/053/017=database_version_logs.tsv:041	source/sql/postgresql/migration/migration-040-041.sql	SUCCESS	2009-09-14 13:48:57.539	-- Create FILTERS table\\012\\012CREATE TABLE FILTERS (ID TECH_ID NOT NULL, DBIN_ID TECH_ID NOT NULL, NAME VARCHAR(200) NOT NULL, DESCRIPTION DESCRIPTION_1000,REGISTRATION_TIMESTAMP TIME_STAMP_DFL NOT NULL DEFAULT CURRENT_TIMESTAMP, PERS_ID_REGISTERER TECH_ID NOT NULL, MODIFICATION_TIMESTAMP TIME_STAMP DEFAULT CURRENT_TIMESTAMP, EXPRESSION VARCHAR(2000) NOT NULL, IS_PUBLIC BOOLEAN NOT NULL, GRID_ID VARCHAR(200) NOT NULL);\\012CREATE SEQUENCE FILTER_ID_SEQ;\\012ALTER TABLE FILTERS ADD CONSTRAINT FILT_PK PRIMARY KEY(ID);\\012ALTER TABLE FILTERS ADD CONSTRAINT FILT_BK_UK UNIQUE(NAME, DBIN_ID, GRID_ID);\\012ALTER TABLE FILTERS ADD CONSTRAINT FILT_PERS_FK FOREIGN KEY (PERS_ID_REGISTERER) REFERENCES PERSONS(ID);\\012ALTER TABLE FILTERS ADD CONSTRAINT FILT_DBIN_FK FOREIGN KEY (DBIN_ID) REFERENCES DATABASE_INSTANCES(ID);\\012CREATE INDEX FILT_PERS_FK_I ON FILTERS (PERS_ID_REGISTERER);\\012CREATE INDEX FILT_DBIN_FK_I ON FILTERS (DBIN_ID);\\012GRANT SELECT ON SEQUENCE filter_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE filters TO GROUP OPENBIS_READONLY;\\012\\012-- Add missing foreign key to role assignments authorization group\\012ALTER TABLE ROLE_ASSIGNMENTS ADD CONSTRAINT ROAS_AG_FK_GRANTEE FOREIGN KEY (AG_ID_GRANTEE) REFERENCES AUTHORIZATION_GROUPS(ID);\\012\\012--------------------------------------------------------------------------------------------------\\012-- Modify dataset connections:\\012-- 1. connection with sample shouldn't be mandatory any more\\012-- 2. introduce an arc condition that dataset cannot be connected with a sample and a parent dataset at the same time\\012--------------------------------------------------------------------------------------------------\\012\\012-- Weaken data-sample connection constraint - allow dataset to have no connection with sample\\012ALTER TABLE data ALTER COLUMN samp_id DROP NOT NULL;\\012\\012-- Remove data-sample connection for datasets that have a parent\\012\\012UPDATE data \\012   SET samp_id = NULL \\012 WHERE id IN (SELECT DISTINCT data_id_child FROM data_set_relationships);\\012\\012-- With PostgreSQL 8.4 one can check that before migration there were no cycles in dataset relationships:\\012--\\012-- WITH RECURSIVE data_set_parents(id, parent_ids, cycle) AS (\\012--         SELECT  r.data_id_child AS id, \\012--                 ARRAY[CAST (r.data_id_parent AS bigint)] AS parent_ids, \\012--                 false AS cycle \\012--         FROM data_set_relationships r\\012--     UNION ALL\\012--         SELECT  r.data_id_child,\\012--                 CAST (r.data_id_parent AS bigint) || p.parent_ids,\\012--                 r.data_id_child = ANY(p.parent_ids)\\012--         FROM data_set_relationships r, data_set_parents p\\012--         WHERE r.data_id_parent = p.id AND NOT cycle\\012-- )\\012-- SELECT count(*) AS cycles FROM data_set_parents WHERE cycle = true;\\012\\012---------------------------------------------------------------------------------------------------\\012--  Purpose:  Create DEFERRED triggers:\\012--            * check_dataset_relationships_on_data_table_modification,\\012--            * check_dataset_relationships_on_relationships_table_modification.\\012--            They check that after all modifications of database (just before commit) \\012--            if 'data'/'data_set_relationships' tables are among modified tables \\012--            dataset is not connected with a sample and a parent dataset at the same time.\\012--            This connections are held in two different tables so simple immediate trigger \\012--            with arc check cannot be used and we need two deferred triggers.\\012----------------------------------------------------------------------------------------------------\\012\\012-- trigger for 'data' table\\012\\012CREATE OR REPLACE FUNCTION check_dataset_relationships_on_data_table_modification() RETURNS trigger AS $$\\012DECLARE\\012\\011counter\\011INTEGER;\\012BEGIN\\012\\011-- if there is a connection with a Sample there should not be any connection with a parent Data Set\\012\\011IF (NEW.samp_id IS NOT NULL) THEN\\012\\011\\011-- count number of parents\\012\\011\\011SELECT count(*) INTO counter \\012\\011\\011\\011FROM data_set_relationships \\012\\011\\011\\011WHERE data_id_child = OLD.id;\\012\\011\\011IF (counter > 0) THEN\\012\\011\\011\\011RAISE EXCEPTION 'Insert/Update of Data Set (Code: %) failed because it cannot be connected with a Sample and a parent Data Set at the same time.', OLD.code;\\012\\011\\011END IF;\\012\\011END IF;\\012  RETURN NEW;\\012END;\\012$$ LANGUAGE 'plpgsql';\\012\\012CREATE CONSTRAINT TRIGGER check_dataset_relationships_on_data_table_modification \\012  AFTER INSERT OR UPDATE ON data\\012\\011DEFERRABLE INITIALLY DEFERRED\\012\\011FOR EACH ROW \\012\\011EXECUTE PROCEDURE check_dataset_relationships_on_data_table_modification();\\012\\012-- trigger for 'data_set_relationships'\\012\\012CREATE OR REPLACE FUNCTION check_dataset_relationships_on_relationships_table_modification() RETURNS trigger AS $$\\012DECLARE\\012\\011counter\\011INTEGER;\\012\\011sample_id\\011TECH_ID;\\012\\011data_code\\011CODE;\\012BEGIN\\012\\011-- child will have a parent added so it should not be connected with any sample\\012\\011SELECT samp_id, code INTO sample_id, data_code \\012\\011\\011FROM data \\012\\011\\011WHERE id = NEW.data_id_child;\\012\\011IF (sample_id IS NOT NULL) THEN\\012\\011\\011RAISE EXCEPTION 'Insert/Update of Data Set (Code: %) failed because it cannot be connected to a Sample and to a parent Data Set at the same time.', data_code;\\012\\011END IF;\\012\\011RETURN NEW;\\012END;\\012$$ LANGUAGE 'plpgsql';\\012  \\012CREATE CONSTRAINT TRIGGER check_dataset_relationships_on_relationships_table_modification \\012  AFTER INSERT OR UPDATE ON data_set_relationships\\012\\011DEFERRABLE INITIALLY DEFERRED\\012\\011FOR EACH ROW \\012\\011EXECUTE PROCEDURE check_dataset_relationships_on_relationships_table_modification();\\012	\N
+./sourceTest/sql/postgresql/053/017=database_version_logs.tsv:053	source/sql/postgresql/migration/migration-052-053.sql	SUCCESS	2010-06-08 15:27:55.032	-- Migration from 052 to 053\\012\\012-- Change code uniqueness check for samples of specific type.\\012-- If sample_types.is_subcode_unique flag is set to 'true', additional check is performed \\012-- on codes of samples of the type. Subcodes will have to be unique as well.\\012\\012ALTER TABLE sample_types ADD COLUMN is_subcode_unique boolean_char NOT NULL DEFAULT false;\\012\\012CREATE OR REPLACE FUNCTION SAMPLE_SUBCODE_UNIQUENESS_CHECK() RETURNS trigger AS $$\\012DECLARE\\012   counter  INTEGER;\\012   unique_subcode  BOOLEAN_CHAR;\\012BEGIN\\012  LOCK TABLE samples IN EXCLUSIVE MODE;\\012  \\012  SELECT is_subcode_unique into unique_subcode FROM sample_types WHERE id = NEW.saty_id;\\012  \\012  IF (unique_subcode) THEN\\012    IF (NEW.dbin_id is not NULL) THEN\\012\\011\\011\\011SELECT count(*) into counter FROM samples \\012\\011\\011\\011\\011where id != NEW.id and code = NEW.code and saty_id = NEW.saty_id and dbin_id = NEW.dbin_id;\\012\\011\\011\\011IF (counter > 0) THEN\\012\\011\\011\\011\\011RAISE EXCEPTION 'Insert/Update of Sample (Code: %) failed because database instance sample of the same type with the same subcode already exists.', NEW.code;\\012\\011\\011\\011END IF;\\012\\011\\011ELSIF (NEW.grou_id is not NULL) THEN\\012\\011\\011\\011SELECT count(*) into counter FROM samples \\012\\011\\011\\011\\011where id != NEW.id and code = NEW.code and saty_id = NEW.saty_id and grou_id = NEW.grou_id;\\012\\011\\011\\011IF (counter > 0) THEN\\012\\011\\011\\011\\011RAISE EXCEPTION 'Insert/Update of Sample (Code: %) failed because space sample of the same type with the same subcode already exists.', NEW.code;\\012\\011\\011\\011END IF;\\012\\011\\011END IF;\\012  END IF;\\012  \\012  RETURN NEW;\\012END;\\012$$ LANGUAGE 'plpgsql';\\012\\012CREATE TRIGGER SAMPLE_SUBCODE_UNIQUENESS_CHECK BEFORE INSERT OR UPDATE ON SAMPLES\\012    FOR EACH ROW EXECUTE PROCEDURE SAMPLE_SUBCODE_UNIQUENESS_CHECK();\\012    \\012-- Fixing error messages in old trigger\\012\\012CREATE OR REPLACE FUNCTION SAMPLE_CODE_UNIQUENESS_CHECK() RETURNS trigger AS $$\\012DECLARE\\012   counter  INTEGER;\\012BEGIN\\012  LOCK TABLE samples IN EXCLUSIVE MODE;\\012  \\012\\011  IF (NEW.samp_id_part_of is NULL) THEN\\012\\011\\011  IF (NEW.dbin_id is not NULL) THEN\\012\\011\\011\\011  SELECT count(*) into counter FROM samples \\012\\011\\011      where id != NEW.id and code = NEW.code and samp_id_part_of is NULL and dbin_id = NEW.dbin_id;\\012        IF (counter > 0) THEN\\012\\011\\011\\011\\011  RAISE EXCEPTION 'Insert/Update of Sample (Code: %) failed because database instance sample with the same code already exists.', NEW.code;\\012        END IF;\\012\\011\\011  ELSIF (NEW.grou_id is not NULL) THEN\\012\\011\\011\\011  SELECT count(*) into counter FROM samples \\012\\011\\011\\011\\011  where id != NEW.id and code = NEW.code and samp_id_part_of is NULL and grou_id = NEW.grou_id;\\012\\011\\011\\011  IF (counter > 0) THEN\\012\\011\\011\\011\\011  RAISE EXCEPTION 'Insert/Update of Sample (Code: %) failed because space sample with the same code already exists.', NEW.code;\\012\\011\\011\\011  END IF;\\012      END IF;\\012    ELSE\\012\\011\\011  IF (NEW.dbin_id is not NULL) THEN\\012\\011\\011\\011  SELECT count(*) into counter FROM samples \\012\\011\\011\\011\\011  where id != NEW.id and code = NEW.code and samp_id_part_of = NEW.samp_id_part_of and dbin_id = NEW.dbin_id;\\012\\011\\011\\011  IF (counter > 0) THEN\\012\\011\\011\\011\\011  RAISE EXCEPTION 'Insert/Update of Sample (Code: %) failed because database instance sample with the same code and being the part of the same container already exists.', NEW.code;\\012\\011\\011\\011  END IF;\\012\\011\\011  ELSIF (NEW.grou_id is not NULL) THEN\\012\\011\\011\\011  SELECT count(*) into counter FROM samples \\012\\011\\011\\011\\011  where id != NEW.id and code = NEW.code and samp_id_part_of = NEW.samp_id_part_of and grou_id = NEW.grou_id;\\012\\011\\011\\011  IF (counter > 0) THEN\\012\\011\\011\\011\\011  RAISE EXCEPTION 'Insert/Update of Sample (Code: %) failed because space sample with the same code and being the part of the same container already exists.', NEW.code;\\012\\011\\011\\011  END IF;\\012\\011\\011  END IF;\\012     END IF;   \\012  \\012  RETURN NEW;\\012END;\\012$$ LANGUAGE 'plpgsql';\\012	\N
+./sourceTest/sql/postgresql/053/schema-053.sql:    LANGUAGE plpgsql
+./sourceTest/sql/postgresql/053/schema-053.sql:    LANGUAGE plpgsql
+./sourceTest/sql/postgresql/053/schema-053.sql:    LANGUAGE plpgsql
+./sourceTest/sql/postgresql/053/schema-053.sql:    LANGUAGE plpgsql
+./sourceTest/sql/postgresql/053/schema-053.sql:    LANGUAGE plpgsql
+./sourceTest/sql/postgresql/053/schema-053.sql:    LANGUAGE plpgsql
+./sourceTest/sql/postgresql/053/schema-053.sql:    LANGUAGE plpgsql
+./sourceTest/sql/postgresql/053/schema-053.sql:    LANGUAGE plpgsql
+./sourceTest/sql/postgresql/053/schema-053.sql:    LANGUAGE plpgsql
+./sourceTest/sql/postgresql/053/schema-053.sql:    LANGUAGE plpgsql
+./sourceTest/sql/postgresql/053/schema-053.sql:    LANGUAGE plpgsql
+./sourceTest/sql/postgresql/054/.svn/text-base/017=database_version_logs.tsv.svn-base:027	D:\\User\\felmer\\dev-workspace\\openbis/source/sql/postgresql/027/function-027.sql	SUCCESS	2008-11-05 09:18:00.403	-- Creating Functions\\012\\012------------------------------------------------------------------------------------\\012--  Purpose:  Create function RENAME_SEQUENCE() that is required for renaming the sequences belonging to tables\\012------------------------------------------------------------------------------------\\012CREATE FUNCTION RENAME_SEQUENCE(OLD_NAME VARCHAR, NEW_NAME VARCHAR) RETURNS INTEGER AS $$\\012DECLARE\\012  CURR_SEQ_VAL   INTEGER;\\012BEGIN\\012  SELECT INTO CURR_SEQ_VAL NEXTVAL(OLD_NAME);\\012  EXECUTE 'CREATE SEQUENCE ' || NEW_NAME || ' START WITH ' || CURR_SEQ_VAL;\\012  EXECUTE 'DROP SEQUENCE ' || OLD_NAME;\\012  RETURN CURR_SEQ_VAL;\\012END;\\012$$ LANGUAGE 'plpgsql';\\012\\012\\012------------------------------------------------------------------------------------\\012--  Purpose:  Create trigger CONTROLLED_VOCABULARY_CHECK \\012------------------------------------------------------------------------------------\\012\\012CREATE OR REPLACE FUNCTION CONTROLLED_VOCABULARY_CHECK() RETURNS trigger AS $$\\012DECLARE\\012   v_code  CODE;\\012BEGIN\\012\\012   select code into v_code from data_types where id = NEW.daty_id;\\012\\012   -- Check if the data is of type "CONTROLLEDVOCABULARY"\\012   if v_code = 'CONTROLLEDVOCABULARY' then\\012      if NEW.covo_id IS NULL then\\012         RAISE EXCEPTION 'Insert/Update of Property Type (Code: %) failed, as its Data Type is CONTROLLEDVOCABULARY, but it is not linked to a Controlled Vocabulary.', NEW.code;\\012      end if;\\012   end if;\\012\\012   RETURN NEW;\\012\\012END;\\012$$ LANGUAGE 'plpgsql';\\012\\012CREATE TRIGGER CONTROLLED_VOCABULARY_CHECK BEFORE INSERT OR UPDATE ON PROPERTY_TYPES\\012    FOR EACH ROW EXECUTE PROCEDURE CONTROLLED_VOCABULARY_CHECK();\\012\\012\\012------------------------------------------------------------------------------------\\012--  Purpose:  Create trigger EXTERNAL_DATA_STORAGE_FORMAT_CHECK \\012------------------------------------------------------------------------------------\\012\\012CREATE OR REPLACE FUNCTION EXTERNAL_DATA_STORAGE_FORMAT_CHECK() RETURNS trigger AS $$\\012DECLARE\\012   v_covo_code  CODE;\\012   data_code CODE;\\012BEGIN\\012\\012   select code into v_covo_code from controlled_vocabularies\\012      where is_internal_namespace = true and \\012         id = (select covo_id from controlled_vocabulary_terms where id = NEW.cvte_id_stor_fmt);\\012   -- Check if the data storage format is a term of the controlled vocabulary "STORAGE_FORMAT"\\012   if v_covo_code != 'STORAGE_FORMAT' then\\012      select code into data_code from data where id = NEW.data_id; \\012      RAISE EXCEPTION 'Insert/Update of Data (Code: %) failed, as its Storage Format is %, but is required to be STORAGE_FORMAT.', data_code, v_covo_code;\\012   end if;\\012\\012   RETURN NEW;\\012\\012END;\\012$$ LANGUAGE 'plpgsql';\\012\\012CREATE TRIGGER EXTERNAL_DATA_STORAGE_FORMAT_CHECK BEFORE INSERT OR UPDATE ON EXTERNAL_DATA\\012    FOR EACH ROW EXECUTE PROCEDURE EXTERNAL_DATA_STORAGE_FORMAT_CHECK();\\012\\012------------------------------------------------------------------------------------\\012--  Purpose:  Create trigger SAMPLE_CODE_UNIQUENESS_CHECK \\012------------------------------------------------------------------------------------\\012\\012CREATE OR REPLACE FUNCTION SAMPLE_CODE_UNIQUENESS_CHECK() RETURNS trigger AS $$\\012DECLARE\\012   counter  INTEGER;\\012BEGIN\\012\\011IF (NEW.samp_id_part_of is NULL) THEN\\012\\011\\011IF (NEW.dbin_id is not NULL) THEN\\012\\011\\011\\011SELECT count(*) into counter FROM samples \\012\\011\\011\\011\\011where id != NEW.id and code = NEW.code and samp_id_part_of is NULL and dbin_id = NEW.dbin_id;\\012\\011\\011\\011IF (counter > 0) THEN\\012\\011\\011\\011\\011RAISE EXCEPTION 'Insert/Update of Sample (Code: %) failed because database instance sample with the same code already exists.', NEW.code;\\012\\011\\011\\011END IF;\\012\\011\\011ELSIF (NEW.grou_id is not NULL) THEN\\012\\011\\011\\011SELECT count(*) into counter FROM samples \\012\\011\\011\\011\\011where id != NEW.id and code = NEW.code and samp_id_part_of is NULL and grou_id = NEW.grou_id;\\012\\011\\011\\011IF (counter > 0) THEN\\012\\011\\011\\011\\011RAISE EXCEPTION 'Insert/Update of Sample (Code: %) failed because group sample with the same code already exists.', NEW.code;\\012\\011\\011\\011END IF;\\012\\011\\011END IF;\\012        ELSE\\012\\011\\011IF (NEW.dbin_id is not NULL) THEN\\012\\011\\011\\011SELECT count(*) into counter FROM samples \\012\\011\\011\\011\\011where id != NEW.id and code = NEW.code and samp_id_part_of = NEW.samp_id_part_of and dbin_id = NEW.dbin_id;\\012\\011\\011\\011IF (counter > 0) THEN\\012\\011\\011\\011\\011RAISE EXCEPTION 'Insert/Update of Sample (Code: %) failed because database instance sample with the same code and being the part of the same parent already exists.', NEW.code;\\012\\011\\011\\011END IF;\\012\\011\\011ELSIF (NEW.grou_id is not NULL) THEN\\012\\011\\011\\011SELECT count(*) into counter FROM samples \\012\\011\\011\\011\\011where id != NEW.id and code = NEW.code and samp_id_part_of = NEW.samp_id_part_of and grou_id = NEW.grou_id;\\012\\011\\011\\011IF (counter > 0) THEN\\012\\011\\011\\011\\011RAISE EXCEPTION 'Insert/Update of Sample (Code: %) failed because group sample with the same code and being the part of the same parent already exists.', NEW.code;\\012\\011\\011\\011END IF;\\012\\011\\011END IF;\\012        END IF;   \\012   RETURN NEW;\\012END;\\012$$ LANGUAGE 'plpgsql';\\012\\012CREATE TRIGGER SAMPLE_CODE_UNIQUENESS_CHECK BEFORE INSERT OR UPDATE ON SAMPLES\\012    FOR EACH ROW EXECUTE PROCEDURE SAMPLE_CODE_UNIQUENESS_CHECK();\\012	\N
+./sourceTest/sql/postgresql/054/.svn/text-base/017=database_version_logs.tsv.svn-base:028	source/sql/postgresql/migration/migration-027-028.sql	SUCCESS	2008-11-18 13:24:17.508	-- Create EXPERIMENT_ATTACHMENT_CONTENTS.\\012CREATE TABLE EXPERIMENT_ATTACHMENT_CONTENTS (ID TECH_ID NOT NULL,VALUE FILE NOT NULL);\\012CREATE SEQUENCE EXPERIMENT_ATTACHMENT_CONTENT_ID_SEQ;\\012ALTER TABLE EXPERIMENT_ATTACHMENT_CONTENTS ADD CONSTRAINT EXAC_PK PRIMARY KEY(ID);\\012\\012-- Alter EXPERIMENT_ATTACHMENTS by adding the new column which has a NULL constraint.\\012-- The NOT NULL constraint is added later on.\\012ALTER TABLE EXPERIMENT_ATTACHMENTS ADD COLUMN EXAC_ID TECH_ID;\\012\\012-- Does the VALUE migration between EXPERIMENT_ATTACHMENTS to EXPERIMENT_ATTACHMENT_CONTENTS.\\012CREATE OR REPLACE FUNCTION move_exp_att_content() RETURNS integer AS $$\\012DECLARE\\012    rec RECORD;\\012    seq BIGINT;\\012BEGIN\\012  FOR rec IN SELECT id, value FROM EXPERIMENT_ATTACHMENTS LOOP\\012  \\011seq := nextval('EXPERIMENT_ATTACHMENT_CONTENT_ID_SEQ');\\012    INSERT INTO EXPERIMENT_ATTACHMENT_CONTENTS (id, value) VALUES (seq, rec.value);\\012    UPDATE EXPERIMENT_ATTACHMENTS SET exac_id = seq WHERE id = rec.id;\\012  END LOOP;\\012  RETURN 1;\\012END;\\012$$ LANGUAGE 'plpgsql';\\012\\012-- Call the function.\\012SELECT move_exp_att_content();\\012DROP FUNCTION move_exp_att_content();\\012\\012\\012-- Finish EXPERIMENT_ATTACHMENTS changes.\\012ALTER TABLE EXPERIMENT_ATTACHMENTS ADD CONSTRAINT EXAT_CONT_FK FOREIGN KEY (EXAC_ID) REFERENCES EXPERIMENT_ATTACHMENT_CONTENTS(ID);\\012ALTER TABLE EXPERIMENT_ATTACHMENTS DROP COLUMN VALUE;\\012ALTER TABLE EXPERIMENT_ATTACHMENTS ALTER COLUMN EXAC_ID SET NOT NULL;\\012	\N
+./sourceTest/sql/postgresql/054/.svn/text-base/017=database_version_logs.tsv.svn-base:029	source/sql/postgresql/migration/migration-028-029.sql	SUCCESS	2009-03-18 10:50:20.105	-- -------\\012-- add modification_timestamp field to allow edition with Hibernate\\012-- -------\\012\\012ALTER TABLE samples\\012\\011ADD COLUMN modification_timestamp TIME_STAMP DEFAULT CURRENT_TIMESTAMP;\\012\\012ALTER TABLE experiments\\012\\011ADD COLUMN modification_timestamp TIME_STAMP DEFAULT CURRENT_TIMESTAMP;\\012\\012ALTER TABLE materials\\012\\011ADD COLUMN modification_timestamp TIME_STAMP DEFAULT CURRENT_TIMESTAMP;\\012\\012ALTER TABLE experiment_properties\\012\\011ADD COLUMN modification_timestamp TIME_STAMP DEFAULT CURRENT_TIMESTAMP;\\012\\012ALTER TABLE material_properties\\012\\011ADD COLUMN modification_timestamp TIME_STAMP DEFAULT CURRENT_TIMESTAMP;\\012\\012ALTER TABLE sample_properties\\012\\011ADD COLUMN modification_timestamp TIME_STAMP DEFAULT CURRENT_TIMESTAMP;\\012\\012-- -------\\012-- add property data type which references materials\\012-- -------\\012\\012ALTER TABLE property_types\\012\\011ADD COLUMN maty_prop_id tech_id;\\012\\012ALTER TABLE property_types\\012\\011ADD CONSTRAINT prty_maty_fk FOREIGN KEY (maty_prop_id) REFERENCES material_types(id);\\012\\012ALTER TABLE experiment_properties\\012\\011ADD COLUMN mate_prop_id tech_id;\\012\\012ALTER TABLE material_properties\\012\\011ADD COLUMN mate_prop_id tech_id;\\012\\012ALTER TABLE sample_properties\\012\\011ADD COLUMN mate_prop_id tech_id;\\012\\012ALTER TABLE experiment_properties\\012\\011ADD CONSTRAINT expr_mapr_fk FOREIGN KEY (mate_prop_id) REFERENCES materials(id);\\012\\012ALTER TABLE material_properties\\012\\011ADD CONSTRAINT mapr_mapr_fk FOREIGN KEY (mate_prop_id) REFERENCES materials(id);\\012\\012ALTER TABLE sample_properties\\012\\011ADD CONSTRAINT sapr_mapr_fk FOREIGN KEY (mate_prop_id) REFERENCES materials(id);\\012\\012insert into data_types\\012(id\\012 ,code\\012 ,description)\\012 values \\012 (nextval('DATA_TYPE_ID_SEQ')\\012 ,'MATERIAL'\\012 ,'Reference to a material'\\012);\\012\\012ALTER TABLE MATERIAL_PROPERTIES DROP CONSTRAINT MAPR_CK;\\012ALTER TABLE MATERIAL_PROPERTIES ADD CONSTRAINT MAPR_CK CHECK \\012\\011((VALUE IS NOT NULL AND CVTE_ID IS NULL AND MATE_PROP_ID IS NULL) OR \\012\\011 (VALUE IS NULL AND CVTE_ID IS NOT NULL AND MATE_PROP_ID IS NULL) OR\\012\\011 (VALUE IS NULL AND CVTE_ID IS NULL AND MATE_PROP_ID IS NOT NULL)\\012\\011);\\012\\012ALTER TABLE EXPERIMENT_PROPERTIES DROP CONSTRAINT EXPR_CK;\\012ALTER TABLE EXPERIMENT_PROPERTIES ADD CONSTRAINT EXPR_CK CHECK \\012\\011((VALUE IS NOT NULL AND CVTE_ID IS NULL AND MATE_PROP_ID IS NULL) OR \\012\\011 (VALUE IS NULL AND CVTE_ID IS NOT NULL AND MATE_PROP_ID IS NULL) OR\\012\\011 (VALUE IS NULL AND CVTE_ID IS NULL AND MATE_PROP_ID IS NOT NULL)\\012\\011);\\012\\012ALTER TABLE SAMPLE_PROPERTIES DROP CONSTRAINT SAPR_CK;\\012ALTER TABLE SAMPLE_PROPERTIES ADD CONSTRAINT SAPR_CK CHECK \\012\\011((VALUE IS NOT NULL AND CVTE_ID IS NULL AND MATE_PROP_ID IS NULL) OR \\012\\011 (VALUE IS NULL AND CVTE_ID IS NOT NULL AND MATE_PROP_ID IS NULL) OR\\012\\011 (VALUE IS NULL AND CVTE_ID IS NULL AND MATE_PROP_ID IS NOT NULL)\\012\\011);\\012\\012------------------------------------------------------------------------------------\\012--  Purpose:  Create trigger MATERIAL/SAMPLE/EXPERIMENT _PROPERTY_WITH_MATERIAL_DATA_TYPE_CHECK\\012--            It checks that if material property value is assigned to the entity,\\012--\\011\\011\\011\\011\\011\\011then the material type is equal to the one described by property type.\\012------------------------------------------------------------------------------------\\012\\012CREATE OR REPLACE FUNCTION MATERIAL_PROPERTY_WITH_MATERIAL_DATA_TYPE_CHECK() RETURNS trigger AS $$\\012DECLARE\\012   v_type_id  CODE;\\012   v_type_id_prop  CODE;\\012BEGIN\\012   if NEW.mate_prop_id IS NOT NULL then\\012\\011\\011\\011-- find material type id of the property type \\012\\011\\011\\011select pt.maty_prop_id into v_type_id_prop \\012\\011\\011\\011  from material_type_property_types etpt, property_types pt \\012\\011\\011\\011 where NEW.mtpt_id = etpt.id AND etpt.prty_id = pt.id;\\012\\011\\011\\012\\011\\011\\011if v_type_id_prop IS NOT NULL then\\012\\011\\011\\011\\011-- find material type id of the material which consists the entity's property value\\012\\011\\011\\011\\011select entity.maty_id into v_type_id \\012\\011\\011\\011\\011  from materials entity\\012\\011\\011\\011\\011 where NEW.mate_prop_id = entity.id;\\012\\011\\011\\011\\011if v_type_id != v_type_id_prop then\\012\\011\\011\\011\\011\\011RAISE EXCEPTION 'Insert/Update of property value referencing material (id: %) failed, as referenced material type is different than expected (id %, expected id: %).', \\012\\011\\011\\011\\011\\011\\011\\011 NEW.mate_prop_id, v_type_id, v_type_id_prop;\\012\\011\\011\\011\\011end if;\\012\\011\\011\\011end if;\\012   end if;\\012   RETURN NEW;\\012END;\\012$$ LANGUAGE 'plpgsql';\\012\\012CREATE TRIGGER MATERIAL_PROPERTY_WITH_MATERIAL_DATA_TYPE_CHECK BEFORE INSERT OR UPDATE ON material_properties\\012    FOR EACH ROW EXECUTE PROCEDURE MATERIAL_PROPERTY_WITH_MATERIAL_DATA_TYPE_CHECK();\\012    \\012CREATE OR REPLACE FUNCTION SAMPLE_PROPERTY_WITH_MATERIAL_DATA_TYPE_CHECK() RETURNS trigger AS $$\\012DECLARE\\012   v_type_id  CODE;\\012   v_type_id_prop  CODE;\\012BEGIN\\012   if NEW.mate_prop_id IS NOT NULL then\\012\\011\\011\\011-- find material type id of the property type \\012\\011\\011\\011select pt.maty_prop_id into v_type_id_prop \\012\\011\\011\\011  from sample_type_property_types etpt, property_types pt \\012\\011\\011\\011 where NEW.stpt_id = etpt.id AND etpt.prty_id = pt.id;\\012\\011\\011\\012\\011\\011\\011if v_type_id_prop IS NOT NULL then\\012\\011\\011\\011\\011-- find material type id of the material which consists the entity's property value\\012\\011\\011\\011\\011select entity.maty_id into v_type_id \\012\\011\\011\\011\\011  from materials entity\\012\\011\\011\\011\\011 where NEW.mate_prop_id = entity.id;\\012\\011\\011\\011\\011if v_type_id != v_type_id_prop then\\012\\011\\011\\011\\011\\011RAISE EXCEPTION 'Insert/Update of property value referencing material (id: %) failed, as referenced material type is different than expected (id %, expected id: %).', \\012\\011\\011\\011\\011\\011\\011\\011\\011\\011\\011\\011\\011 NEW.mate_prop_id, v_type_id, v_type_id_prop;\\012\\011\\011\\011\\011end if;\\012\\011\\011\\011end if;\\012   end if;\\012   RETURN NEW;\\012END;\\012$$ LANGUAGE 'plpgsql';\\012\\012CREATE TRIGGER SAMPLE_PROPERTY_WITH_MATERIAL_DATA_TYPE_CHECK BEFORE INSERT OR UPDATE ON sample_properties\\012    FOR EACH ROW EXECUTE PROCEDURE SAMPLE_PROPERTY_WITH_MATERIAL_DATA_TYPE_CHECK();\\012    \\012CREATE OR REPLACE FUNCTION EXPERIMENT_PROPERTY_WITH_MATERIAL_DATA_TYPE_CHECK() RETURNS trigger AS $$\\012DECLARE\\012   v_type_id  CODE;\\012   v_type_id_prop  CODE;\\012BEGIN\\012   if NEW.mate_prop_id IS NOT NULL then\\012\\011\\011\\011-- find material type id of the property type \\012\\011\\011\\011select pt.maty_prop_id into v_type_id_prop \\012\\011\\011\\011  from experiment_type_property_types etpt, property_types pt \\012\\011\\011\\011 where NEW.etpt_id = etpt.id AND etpt.prty_id = pt.id;\\012\\011\\011\\012\\011\\011\\011if v_type_id_prop IS NOT NULL then\\012\\011\\011\\011\\011-- find material type id of the material which consists the entity's property value\\012\\011\\011\\011\\011select entity.maty_id into v_type_id \\012\\011\\011\\011\\011  from materials entity\\012\\011\\011\\011\\011 where NEW.mate_prop_id = entity.id;\\012\\011\\011\\011\\011if v_type_id != v_type_id_prop then\\012\\011\\011\\011\\011\\011RAISE EXCEPTION 'Insert/Update of property value referencing material (id: %) failed, as referenced material type is different than expected (id %, expected id: %).', \\012\\011\\011\\011\\011\\011\\011\\011\\011\\011\\011\\011\\011 NEW.mate_prop_id, v_type_id, v_type_id_prop;\\012\\011\\011\\011\\011end if;\\012\\011\\011\\011end if;\\012   end if;\\012   RETURN NEW;\\012END;\\012$$ LANGUAGE 'plpgsql';\\012\\012CREATE TRIGGER EXPERIMENT_PROPERTY_WITH_MATERIAL_DATA_TYPE_CHECK BEFORE INSERT OR UPDATE ON experiment_properties\\012    FOR EACH ROW EXECUTE PROCEDURE EXPERIMENT_PROPERTY_WITH_MATERIAL_DATA_TYPE_CHECK();\\012       \\012-- -------\\012-- remove the reminescents of the OBSERVABLE_TYPE\\012-- -------\\012\\012ALTER TABLE data\\012\\011DROP CONSTRAINT data_obty_fk;\\012\\012ALTER TABLE data_set_types\\012\\011DROP CONSTRAINT obty_pk;\\012\\012ALTER TABLE data_set_types\\012\\011ADD CONSTRAINT dsty_pk PRIMARY KEY (id);\\012\\012ALTER TABLE data\\012\\011ADD CONSTRAINT data_dsty_fk FOREIGN KEY (dsty_id) REFERENCES data_set_types(id);\\012\\012ALTER TABLE data_set_types\\012\\011DROP CONSTRAINT obty_bk_uk;\\012\\012ALTER TABLE data_set_types\\012\\011DROP CONSTRAINT obty_dbin_fk;\\012\\012ALTER TABLE data_set_types\\012\\011ADD CONSTRAINT dsty_bk_uk UNIQUE (code, dbin_id);\\012\\012ALTER TABLE data_set_types\\012\\011ADD CONSTRAINT dsty_dbin_fk FOREIGN KEY (dbin_id) REFERENCES database_instances(id);\\012\\012DROP INDEX data_obty_fk_i;\\012\\012CREATE INDEX data_dsty_fk_i ON data(dsty_id);\\012	\N
+./sourceTest/sql/postgresql/054/.svn/text-base/017=database_version_logs.tsv.svn-base:030	source/sql/postgresql/migration/migration-029-030.sql	SUCCESS	2009-03-23 15:34:44.72	-- -------\\012-- add modification_timestamp field to allow edition with Hibernate\\012-- -------\\012ALTER TABLE data\\012\\011ADD COLUMN modification_timestamp TIME_STAMP DEFAULT CURRENT_TIMESTAMP;\\012ALTER TABLE experiment_types\\012\\011ADD COLUMN modification_timestamp TIME_STAMP DEFAULT CURRENT_TIMESTAMP;\\012ALTER TABLE sample_types\\012\\011ADD COLUMN modification_timestamp TIME_STAMP DEFAULT CURRENT_TIMESTAMP;\\012ALTER TABLE material_types\\012\\011ADD COLUMN modification_timestamp TIME_STAMP DEFAULT CURRENT_TIMESTAMP;\\012ALTER TABLE data_set_types\\012\\011ADD COLUMN modification_timestamp TIME_STAMP DEFAULT CURRENT_TIMESTAMP;\\012ALTER TABLE controlled_vocabularies\\012\\011ADD COLUMN modification_timestamp TIME_STAMP DEFAULT CURRENT_TIMESTAMP;\\012-- -------\\012-- add properties to data sets\\012-- -------\\012CREATE TABLE DATA_SET_PROPERTIES (ID TECH_ID NOT NULL,DS_ID TECH_ID NOT NULL,DSTPT_ID TECH_ID NOT NULL,VALUE GENERIC_VALUE,CVTE_ID TECH_ID, MATE_PROP_ID TECH_ID, PERS_ID_REGISTERER TECH_ID NOT NULL,REGISTRATION_TIMESTAMP TIME_STAMP_DFL NOT NULL DEFAULT CURRENT_TIMESTAMP, MODIFICATION_TIMESTAMP TIME_STAMP DEFAULT CURRENT_TIMESTAMP);\\012CREATE TABLE DATA_SET_TYPE_PROPERTY_TYPES (ID TECH_ID NOT NULL,DSTY_ID TECH_ID NOT NULL,PRTY_ID TECH_ID NOT NULL,IS_MANDATORY BOOLEAN_CHAR NOT NULL DEFAULT 'F',IS_MANAGED_INTERNALLY BOOLEAN_CHAR NOT NULL DEFAULT 'F',PERS_ID_REGISTERER TECH_ID NOT NULL,REGISTRATION_TIMESTAMP TIME_STAMP_DFL NOT NULL DEFAULT CURRENT_TIMESTAMP);\\012\\012CREATE SEQUENCE DATA_SET_PROPERTY_ID_SEQ;\\012CREATE SEQUENCE DSTPT_ID_SEQ;\\012\\012ALTER TABLE DATA_SET_TYPE_PROPERTY_TYPES ADD CONSTRAINT DSTPT_PK PRIMARY KEY(ID);\\012ALTER TABLE DATA_SET_PROPERTIES ADD CONSTRAINT DSPR_PK PRIMARY KEY(ID);\\012\\012ALTER TABLE DATA_SET_TYPE_PROPERTY_TYPES ADD CONSTRAINT DSTPT_BK_UK UNIQUE(DSTY_ID,PRTY_ID);\\012ALTER TABLE DATA_SET_PROPERTIES ADD CONSTRAINT DSPR_BK_UK UNIQUE(DS_ID,DSTPT_ID);\\012\\012\\012ALTER TABLE DATA_SET_TYPE_PROPERTY_TYPES ADD CONSTRAINT DSTPT_DSTY_FK FOREIGN KEY (DSTY_ID) REFERENCES DATA_SET_TYPES(ID);\\012ALTER TABLE DATA_SET_TYPE_PROPERTY_TYPES ADD CONSTRAINT DSTPT_PERS_FK FOREIGN KEY (PERS_ID_REGISTERER) REFERENCES PERSONS(ID);\\012ALTER TABLE DATA_SET_TYPE_PROPERTY_TYPES ADD CONSTRAINT DSTPT_PRTY_FK FOREIGN KEY (PRTY_ID) REFERENCES PROPERTY_TYPES(ID);\\012ALTER TABLE DATA_SET_PROPERTIES ADD CONSTRAINT DSPR_CVTE_FK FOREIGN KEY (CVTE_ID) REFERENCES CONTROLLED_VOCABULARY_TERMS(ID);\\012ALTER TABLE DATA_SET_PROPERTIES ADD CONSTRAINT DSPR_DSTPT_FK FOREIGN KEY (DSTPT_ID) REFERENCES DATA_SET_TYPE_PROPERTY_TYPES(ID) ON DELETE CASCADE;\\012ALTER TABLE DATA_SET_PROPERTIES ADD CONSTRAINT DSPR_DS_FK FOREIGN KEY (DS_ID) REFERENCES DATA(ID);\\012ALTER TABLE DATA_SET_PROPERTIES ADD CONSTRAINT DSPR_PERS_FK FOREIGN KEY (PERS_ID_REGISTERER) REFERENCES PERSONS(ID);\\012ALTER TABLE DATA_SET_PROPERTIES ADD CONSTRAINT DSPR_MAPR_FK FOREIGN KEY (MATE_PROP_ID) REFERENCES MATERIALS(ID);\\012\\012ALTER TABLE DATA_SET_PROPERTIES ADD CONSTRAINT DSPR_CK CHECK \\012\\011((VALUE IS NOT NULL AND CVTE_ID IS NULL AND MATE_PROP_ID IS NULL) OR \\012\\011 (VALUE IS NULL AND CVTE_ID IS NOT NULL AND MATE_PROP_ID IS NULL) OR\\012\\011 (VALUE IS NULL AND CVTE_ID IS NULL AND MATE_PROP_ID IS NOT NULL)\\012\\011);\\012\\012CREATE INDEX DSPR_CVTE_FK_I ON DATA_SET_PROPERTIES (CVTE_ID);\\012CREATE INDEX DSPR_DSTPT_FK_I ON DATA_SET_PROPERTIES (DSTPT_ID);\\012CREATE INDEX DSPR_DS_FK_I ON DATA_SET_PROPERTIES (DS_ID);\\012CREATE INDEX DSPR_PERS_FK_I ON DATA_SET_PROPERTIES (PERS_ID_REGISTERER);\\012CREATE INDEX DSTPT_DSTY_FK_I ON DATA_SET_TYPE_PROPERTY_TYPES (DSTY_ID);\\012CREATE INDEX DSTPT_PERS_FK_I ON DATA_SET_TYPE_PROPERTY_TYPES (PERS_ID_REGISTERER);\\012CREATE INDEX DSTPT_PRTY_FK_I ON DATA_SET_TYPE_PROPERTY_TYPES (PRTY_ID);\\012\\012CREATE OR REPLACE FUNCTION DATA_SET_PROPERTY_WITH_MATERIAL_DATA_TYPE_CHECK() RETURNS trigger AS $$\\012DECLARE\\012   v_type_id  CODE;\\012   v_type_id_prop  CODE;\\012BEGIN\\012   if NEW.mate_prop_id IS NOT NULL then\\012\\011\\011\\011-- find material type id of the property type \\012\\011\\011\\011select pt.maty_prop_id into v_type_id_prop \\012\\011\\011\\011  from data_set_type_property_types dstpt, property_types pt \\012\\011\\011\\011 where NEW.dstpt_id = dstpt.id AND dstpt.prty_id = pt.id;\\012\\011\\011\\012\\011\\011\\011if v_type_id_prop IS NOT NULL then\\012\\011\\011\\011\\011-- find material type id of the material which consists the entity's property value\\012\\011\\011\\011\\011select entity.maty_id into v_type_id \\012\\011\\011\\011\\011  from materials entity\\012\\011\\011\\011\\011 where NEW.mate_prop_id = entity.id;\\012\\011\\011\\011\\011if v_type_id != v_type_id_prop then\\012\\011\\011\\011\\011\\011RAISE EXCEPTION 'Insert/Update of property value referencing material (id: %) failed, as referenced material type is different than expected (id %, expected id: %).', \\012\\011\\011\\011\\011\\011\\011\\011\\011\\011\\011\\011\\011 NEW.mate_prop_id, v_type_id, v_type_id_prop;\\012\\011\\011\\011\\011end if;\\012\\011\\011\\011end if;\\012   end if;\\012   RETURN NEW;\\012END;\\012$$ LANGUAGE 'plpgsql';\\012\\012CREATE TRIGGER DATA_SET_PROPERTY_WITH_MATERIAL_DATA_TYPE_CHECK BEFORE INSERT OR UPDATE ON data_set_properties\\012    FOR EACH ROW EXECUTE PROCEDURE DATA_SET_PROPERTY_WITH_MATERIAL_DATA_TYPE_CHECK();   \\012	\N
+./sourceTest/sql/postgresql/054/.svn/text-base/017=database_version_logs.tsv.svn-base:032	source/sql/postgresql/migration/migration-031-032.sql	SUCCESS	2009-04-09 09:36:36.2	-- -------\\012-- Modify MATERIAL_BATCHES\\012-- -------\\012\\012ALTER TABLE material_batches\\012    DROP COLUMN proc_id;\\012\\012-- -------\\012-- Modify SAMPLES\\012-- -------\\012\\012ALTER TABLE samples\\012    ADD COLUMN expe_id tech_id;\\012\\012ALTER TABLE samples\\012    ADD CONSTRAINT samp_expe_fk FOREIGN KEY (expe_id) REFERENCES experiments(id);\\012\\012CREATE INDEX samp_expe_fk_i ON samples USING btree (expe_id);\\012\\012-- relink samples directly to experiments\\012\\012UPDATE samples\\012SET expe_id = (SELECT e.id FROM experiments e, procedures p, sample_inputs si \\012               WHERE si.samp_id = samples.id AND si.proc_id = p.id AND p.expe_id = e.id AND e.inva_id IS NULL);\\012\\012\\012-- -------\\012-- Modify DATA\\012-- -------\\012\\012ALTER TABLE data\\012    ADD COLUMN expe_id tech_id;\\012\\012ALTER TABLE data\\012    ADD CONSTRAINT data_expe_fk FOREIGN KEY (expe_id) REFERENCES experiments(id);\\012\\012CREATE INDEX data_expe_fk_i ON data USING btree (expe_id);\\012\\012UPDATE data\\012SET expe_id = (SELECT e.id FROM experiments e, procedures p \\012               WHERE data.proc_id_produced_by = p.id AND p.expe_id = e.id);\\012\\012ALTER TABLE data\\012    ALTER COLUMN expe_id SET NOT NULL;\\012\\012ALTER TABLE data\\012    DROP COLUMN proc_id_produced_by;\\012\\012-- -------\\012-- Drop PROCEDURES, PROCEDURE_TYPES, and SAMPLE_INPUTS\\012-- -------\\012\\012DROP TABLE sample_inputs;\\012DROP TABLE procedures;\\012DROP TABLE procedure_types;\\012\\012DROP SEQUENCE procedure_id_seq;\\012DROP SEQUENCE procedure_type_id_seq;\\012\\012-- -------\\012-- Add CODE_SEQ\\012-- -------\\012\\012CREATE SEQUENCE CODE_SEQ;\\012\\012-- -------\\012-- Add new columns to DATA_STORES\\012-- -------\\012\\012ALTER TABLE data_stores\\012    ADD COLUMN remote_url character varying(250),\\012    ADD COLUMN session_token character varying(50),\\012    ADD COLUMN modification_timestamp time_stamp DEFAULT now();\\012\\012UPDATE data_stores\\012SET remote_url = '', session_token='';\\012\\012ALTER TABLE data_stores\\012    ALTER COLUMN remote_url SET NOT NULL,\\012    ALTER COLUMN session_token SET NOT NULL;\\012\\012-- -------\\012-- Drop foreign keys onto DATA_STORES\\012-- -------\\012\\012ALTER TABLE database_instances\\012    DROP COLUMN dast_id;\\012\\012ALTER TABLE groups\\012    DROP COLUMN dast_id;\\012\\012ALTER TABLE projects\\012    DROP COLUMN dast_id;\\012\\012ALTER TABLE experiments\\012    DROP COLUMN dast_id;\\012\\012-- -------\\012-- Add foreign key from DATA onto DATA_STORES\\012-- -------\\012\\012ALTER TABLE data\\012    ADD COLUMN dast_id tech_id;\\012\\012ALTER TABLE data\\012    ADD CONSTRAINT data_dast_fk FOREIGN KEY (dast_id) REFERENCES data_stores(id);\\012\\012UPDATE data\\012SET dast_id = (select id from data_stores where code = 'STANDARD');\\012\\012ALTER TABLE data\\012    ALTER COLUMN dast_id SET NOT NULL;\\012\\012\\012------------------------------------------------------------------------------------\\012--  Purpose:  Replace trigger SAMPLE_CODE_UNIQUENESS_CHECK \\012------------------------------------------------------------------------------------\\012\\012CREATE OR REPLACE FUNCTION SAMPLE_CODE_UNIQUENESS_CHECK() RETURNS trigger AS $$\\012DECLARE\\012   counter  INTEGER;\\012BEGIN\\012    LOCK TABLE samples IN EXCLUSIVE MODE;\\012    IF (NEW.samp_id_part_of is NULL) THEN\\012        IF (NEW.dbin_id is not NULL) THEN\\012            SELECT count(*) into counter FROM samples \\012                where id != NEW.id and code = NEW.code and samp_id_part_of is NULL and dbin_id = NEW.dbin_id;\\012            IF (counter > 0) THEN\\012                RAISE EXCEPTION 'Insert/Update of Sample (Code: %) failed because database instance sample with the same code already exists.', NEW.code;\\012            END IF;\\012        ELSIF (NEW.grou_id is not NULL) THEN\\012            SELECT count(*) into counter FROM samples \\012                where id != NEW.id and code = NEW.code and samp_id_part_of is NULL and grou_id = NEW.grou_id;\\012            IF (counter > 0) THEN\\012                RAISE EXCEPTION 'Insert/Update of Sample (Code: %) failed because group sample with the same code already exists.', NEW.code;\\012            END IF;\\012        END IF;\\012        ELSE\\012        IF (NEW.dbin_id is not NULL) THEN\\012            SELECT count(*) into counter FROM samples \\012                where id != NEW.id and code = NEW.code and samp_id_part_of = NEW.samp_id_part_of and dbin_id = NEW.dbin_id;\\012            IF (counter > 0) THEN\\012                RAISE EXCEPTION 'Insert/Update of Sample (Code: %) failed because database instance sample with the same code and being the part of the same parent already exists.', NEW.code;\\012            END IF;\\012        ELSIF (NEW.grou_id is not NULL) THEN\\012            SELECT count(*) into counter FROM samples \\012                where id != NEW.id and code = NEW.code and samp_id_part_of = NEW.samp_id_part_of and grou_id = NEW.grou_id;\\012            IF (counter > 0) THEN\\012                RAISE EXCEPTION 'Insert/Update of Sample (Code: %) failed because group sample with the same code and being the part of the same parent already exists.', NEW.code;\\012            END IF;\\012        END IF;\\012        END IF;   \\012   RETURN NEW;\\012END;\\012$$ LANGUAGE 'plpgsql';\\012\\012\\012\\012	\N
+./sourceTest/sql/postgresql/054/.svn/text-base/017=database_version_logs.tsv.svn-base:034	source/sql/postgresql/migration/migration-033-034.sql	SUCCESS	2009-05-26 08:32:49.935	------------------------------------------------------------------------------------\\012-- Create sequence for generating permanent identifiers starting with nextval of existing dataset sequence.\\012------------------------------------------------------------------------------------\\012CREATE FUNCTION CREATE_SEQUENCE(EXISTING_SEQUENCE VARCHAR, NEW_SEQUENCE VARCHAR) RETURNS VOID AS $$\\012DECLARE\\012  CURR_SEQ_VAL   INTEGER;\\012BEGIN\\012  SELECT INTO CURR_SEQ_VAL NEXTVAL(EXISTING_SEQUENCE);\\012  EXECUTE 'CREATE SEQUENCE ' || NEW_SEQUENCE || ' START WITH ' || CURR_SEQ_VAL;\\012  RETURN;\\012END;\\012$$ LANGUAGE 'plpgsql';\\012\\012SELECT CREATE_SEQUENCE('DATA_ID_SEQ', 'PERM_ID_SEQ');\\012DROP FUNCTION CREATE_SEQUENCE(VARCHAR, VARCHAR);\\012\\012------------------------------------------------------------------------------------\\012-- Add perm_id columns to samples and experiments.\\012------------------------------------------------------------------------------------\\012ALTER TABLE SAMPLES ADD COLUMN PERM_ID CODE;\\012ALTER TABLE EXPERIMENTS ADD COLUMN PERM_ID CODE;\\012\\012UPDATE SAMPLES SET PERM_ID = to_char(registration_timestamp,'YYYYMMDDHHSSMS') || '-' || NEXTVAL('PERM_ID_SEQ');\\012UPDATE EXPERIMENTS SET PERM_ID = to_char(registration_timestamp,'YYYYMMDDHHSSMS') || '-' || NEXTVAL('PERM_ID_SEQ');\\012ALTER TABLE SAMPLES ALTER COLUMN PERM_ID SET NOT NULL;\\012ALTER TABLE EXPERIMENTS ALTER COLUMN PERM_ID SET NOT NULL;\\012ALTER TABLE SAMPLES ADD CONSTRAINT SAMP_PI_UK UNIQUE(PERM_ID);\\012ALTER TABLE EXPERIMENTS ADD CONSTRAINT EXPE_PI_UK UNIQUE(PERM_ID);\\012\\012\\012------------------------------------------------------------------------------------\\012-- Add column is_chosen_from_list to controlled_vocabularies.\\012------------------------------------------------------------------------------------\\012ALTER TABLE controlled_vocabularies ADD COLUMN is_chosen_from_list BOOLEAN_CHAR NOT NULL DEFAULT TRUE;\\012ALTER TABLE controlled_vocabularies ADD COLUMN source_uri CHARACTER VARYING(250);\\012------------------------------------------------------------------------------------\\012-- Modify Data table - remove arc connection between Sample and Data table, use a flag instead\\012------------------------------------------------------------------------------------\\012\\012-- add new columns\\012\\012ALTER TABLE data\\012    ADD COLUMN is_derived boolean_char;\\012ALTER TABLE data\\012    ADD COLUMN samp_id tech_id;\\012\\012-- update values in new columns\\012\\012UPDATE data\\012    SET is_derived = (samp_id_derived_from IS NOT NULL); \\012UPDATE data\\012    SET samp_id = samp_id_derived_from \\012    WHERE is_derived = 'TRUE';\\012UPDATE data\\012    SET samp_id = samp_id_acquired_from \\012    WHERE is_derived = 'FALSE';\\012\\012-- add constraints and indexes to new columns\\012\\012ALTER TABLE data\\012    ALTER COLUMN is_derived SET NOT NULL;\\012ALTER TABLE data\\012    ALTER COLUMN samp_id SET NOT NULL;   \\012ALTER TABLE data\\012    ADD CONSTRAINT data_samp_fk FOREIGN KEY (samp_id) REFERENCES samples (id);\\012CREATE INDEX data_samp_fk_i ON data USING btree (samp_id);\\012\\012-- remove old columns\\012\\012ALTER TABLE data\\012    DROP COLUMN samp_id_acquired_from;\\012ALTER TABLE data\\012    DROP COLUMN samp_id_derived_from;\\012    \\012------------------------------------------------------------------------------------\\012-- Granting SELECT privilege to group openbis_readonly\\012------------------------------------------------------------------------------------\\012\\012GRANT SELECT ON SEQUENCE attachment_content_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE attachment_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE code_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE controlled_vocabulary_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE cvte_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE data_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE data_set_property_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE data_set_relationship_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE data_set_type_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE data_store_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE data_type_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE database_instance_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE dstpt_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE etpt_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE event_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE experiment_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE experiment_property_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE experiment_type_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE file_format_type_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE group_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE invalidation_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE locator_type_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE material_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE material_property_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE material_type_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE mtpt_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE perm_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE person_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE project_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE property_type_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE role_assignment_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE sample_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE sample_property_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE sample_type_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE stpt_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE attachment_contents TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE attachments TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE controlled_vocabularies TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE controlled_vocabulary_terms TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE data TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE data_set_properties TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE data_set_relationships TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE data_set_type_property_types TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE data_set_types TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE data_stores TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE data_types TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE database_instances TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE database_version_logs TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE events TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE experiment_properties TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE experiment_type_property_types TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE experiment_types TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE experiments TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE external_data TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE file_format_types TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE groups TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE invalidations TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE locator_types TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE material_properties TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE material_type_property_types TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE material_types TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE materials TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE persons TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE projects TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE property_types TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE role_assignments TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE sample_properties TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE sample_type_property_types TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE sample_types TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE samples TO GROUP OPENBIS_READONLY;\\012\\012------------------------------------------------------------------------------------\\012-- Delete MATERIAL_BATCHES table\\012------------------------------------------------------------------------------------\\012\\012-- WARNING: Potential data lost!!!\\012-- WARNING: Potential data lost!!!\\012-- WARNING: Potential data lost!!!\\012\\012DROP TABLE SAMPLE_MATERIAL_BATCHES;\\012DROP TABLE MATERIAL_BATCHES;\\012DROP SEQUENCE MATERIAL_BATCH_ID_SEQ;\\012\\012------------------------------------------------------------------------------------\\012-- Delete MATE_ID_INHIBITOR_OF from table MATERIALS\\012------------------------------------------------------------------------------------\\012\\012-- WARNING: Potential data lost!!!\\012-- WARNING: Potential data lost!!!\\012-- WARNING: Potential data lost!!!\\012\\012ALTER TABLE MATERIALS DROP COLUMN MATE_ID_INHIBITOR_OF;\\012	\N
+./sourceTest/sql/postgresql/054/.svn/text-base/017=database_version_logs.tsv.svn-base:041	source/sql/postgresql/migration/migration-040-041.sql	SUCCESS	2009-09-14 13:48:57.539	-- Create FILTERS table\\012\\012CREATE TABLE FILTERS (ID TECH_ID NOT NULL, DBIN_ID TECH_ID NOT NULL, NAME VARCHAR(200) NOT NULL, DESCRIPTION DESCRIPTION_1000,REGISTRATION_TIMESTAMP TIME_STAMP_DFL NOT NULL DEFAULT CURRENT_TIMESTAMP, PERS_ID_REGISTERER TECH_ID NOT NULL, MODIFICATION_TIMESTAMP TIME_STAMP DEFAULT CURRENT_TIMESTAMP, EXPRESSION VARCHAR(2000) NOT NULL, IS_PUBLIC BOOLEAN NOT NULL, GRID_ID VARCHAR(200) NOT NULL);\\012CREATE SEQUENCE FILTER_ID_SEQ;\\012ALTER TABLE FILTERS ADD CONSTRAINT FILT_PK PRIMARY KEY(ID);\\012ALTER TABLE FILTERS ADD CONSTRAINT FILT_BK_UK UNIQUE(NAME, DBIN_ID, GRID_ID);\\012ALTER TABLE FILTERS ADD CONSTRAINT FILT_PERS_FK FOREIGN KEY (PERS_ID_REGISTERER) REFERENCES PERSONS(ID);\\012ALTER TABLE FILTERS ADD CONSTRAINT FILT_DBIN_FK FOREIGN KEY (DBIN_ID) REFERENCES DATABASE_INSTANCES(ID);\\012CREATE INDEX FILT_PERS_FK_I ON FILTERS (PERS_ID_REGISTERER);\\012CREATE INDEX FILT_DBIN_FK_I ON FILTERS (DBIN_ID);\\012GRANT SELECT ON SEQUENCE filter_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE filters TO GROUP OPENBIS_READONLY;\\012\\012-- Add missing foreign key to role assignments authorization group\\012ALTER TABLE ROLE_ASSIGNMENTS ADD CONSTRAINT ROAS_AG_FK_GRANTEE FOREIGN KEY (AG_ID_GRANTEE) REFERENCES AUTHORIZATION_GROUPS(ID);\\012\\012--------------------------------------------------------------------------------------------------\\012-- Modify dataset connections:\\012-- 1. connection with sample shouldn't be mandatory any more\\012-- 2. introduce an arc condition that dataset cannot be connected with a sample and a parent dataset at the same time\\012--------------------------------------------------------------------------------------------------\\012\\012-- Weaken data-sample connection constraint - allow dataset to have no connection with sample\\012ALTER TABLE data ALTER COLUMN samp_id DROP NOT NULL;\\012\\012-- Remove data-sample connection for datasets that have a parent\\012\\012UPDATE data \\012   SET samp_id = NULL \\012 WHERE id IN (SELECT DISTINCT data_id_child FROM data_set_relationships);\\012\\012-- With PostgreSQL 8.4 one can check that before migration there were no cycles in dataset relationships:\\012--\\012-- WITH RECURSIVE data_set_parents(id, parent_ids, cycle) AS (\\012--         SELECT  r.data_id_child AS id, \\012--                 ARRAY[CAST (r.data_id_parent AS bigint)] AS parent_ids, \\012--                 false AS cycle \\012--         FROM data_set_relationships r\\012--     UNION ALL\\012--         SELECT  r.data_id_child,\\012--                 CAST (r.data_id_parent AS bigint) || p.parent_ids,\\012--                 r.data_id_child = ANY(p.parent_ids)\\012--         FROM data_set_relationships r, data_set_parents p\\012--         WHERE r.data_id_parent = p.id AND NOT cycle\\012-- )\\012-- SELECT count(*) AS cycles FROM data_set_parents WHERE cycle = true;\\012\\012---------------------------------------------------------------------------------------------------\\012--  Purpose:  Create DEFERRED triggers:\\012--            * check_dataset_relationships_on_data_table_modification,\\012--            * check_dataset_relationships_on_relationships_table_modification.\\012--            They check that after all modifications of database (just before commit) \\012--            if 'data'/'data_set_relationships' tables are among modified tables \\012--            dataset is not connected with a sample and a parent dataset at the same time.\\012--            This connections are held in two different tables so simple immediate trigger \\012--            with arc check cannot be used and we need two deferred triggers.\\012----------------------------------------------------------------------------------------------------\\012\\012-- trigger for 'data' table\\012\\012CREATE OR REPLACE FUNCTION check_dataset_relationships_on_data_table_modification() RETURNS trigger AS $$\\012DECLARE\\012\\011counter\\011INTEGER;\\012BEGIN\\012\\011-- if there is a connection with a Sample there should not be any connection with a parent Data Set\\012\\011IF (NEW.samp_id IS NOT NULL) THEN\\012\\011\\011-- count number of parents\\012\\011\\011SELECT count(*) INTO counter \\012\\011\\011\\011FROM data_set_relationships \\012\\011\\011\\011WHERE data_id_child = OLD.id;\\012\\011\\011IF (counter > 0) THEN\\012\\011\\011\\011RAISE EXCEPTION 'Insert/Update of Data Set (Code: %) failed because it cannot be connected with a Sample and a parent Data Set at the same time.', OLD.code;\\012\\011\\011END IF;\\012\\011END IF;\\012  RETURN NEW;\\012END;\\012$$ LANGUAGE 'plpgsql';\\012\\012CREATE CONSTRAINT TRIGGER check_dataset_relationships_on_data_table_modification \\012  AFTER INSERT OR UPDATE ON data\\012\\011DEFERRABLE INITIALLY DEFERRED\\012\\011FOR EACH ROW \\012\\011EXECUTE PROCEDURE check_dataset_relationships_on_data_table_modification();\\012\\012-- trigger for 'data_set_relationships'\\012\\012CREATE OR REPLACE FUNCTION check_dataset_relationships_on_relationships_table_modification() RETURNS trigger AS $$\\012DECLARE\\012\\011counter\\011INTEGER;\\012\\011sample_id\\011TECH_ID;\\012\\011data_code\\011CODE;\\012BEGIN\\012\\011-- child will have a parent added so it should not be connected with any sample\\012\\011SELECT samp_id, code INTO sample_id, data_code \\012\\011\\011FROM data \\012\\011\\011WHERE id = NEW.data_id_child;\\012\\011IF (sample_id IS NOT NULL) THEN\\012\\011\\011RAISE EXCEPTION 'Insert/Update of Data Set (Code: %) failed because it cannot be connected to a Sample and to a parent Data Set at the same time.', data_code;\\012\\011END IF;\\012\\011RETURN NEW;\\012END;\\012$$ LANGUAGE 'plpgsql';\\012  \\012CREATE CONSTRAINT TRIGGER check_dataset_relationships_on_relationships_table_modification \\012  AFTER INSERT OR UPDATE ON data_set_relationships\\012\\011DEFERRABLE INITIALLY DEFERRED\\012\\011FOR EACH ROW \\012\\011EXECUTE PROCEDURE check_dataset_relationships_on_relationships_table_modification();\\012	\N
+./sourceTest/sql/postgresql/054/.svn/text-base/017=database_version_logs.tsv.svn-base:053	source/sql/postgresql/migration/migration-052-053.sql	SUCCESS	2010-06-08 15:27:55.032	-- Migration from 052 to 053\\012\\012-- Change code uniqueness check for samples of specific type.\\012-- If sample_types.is_subcode_unique flag is set to 'true', additional check is performed \\012-- on codes of samples of the type. Subcodes will have to be unique as well.\\012\\012ALTER TABLE sample_types ADD COLUMN is_subcode_unique boolean_char NOT NULL DEFAULT false;\\012\\012CREATE OR REPLACE FUNCTION SAMPLE_SUBCODE_UNIQUENESS_CHECK() RETURNS trigger AS $$\\012DECLARE\\012   counter  INTEGER;\\012   unique_subcode  BOOLEAN_CHAR;\\012BEGIN\\012  LOCK TABLE samples IN EXCLUSIVE MODE;\\012  \\012  SELECT is_subcode_unique into unique_subcode FROM sample_types WHERE id = NEW.saty_id;\\012  \\012  IF (unique_subcode) THEN\\012    IF (NEW.dbin_id is not NULL) THEN\\012\\011\\011\\011SELECT count(*) into counter FROM samples \\012\\011\\011\\011\\011where id != NEW.id and code = NEW.code and saty_id = NEW.saty_id and dbin_id = NEW.dbin_id;\\012\\011\\011\\011IF (counter > 0) THEN\\012\\011\\011\\011\\011RAISE EXCEPTION 'Insert/Update of Sample (Code: %) failed because database instance sample of the same type with the same subcode already exists.', NEW.code;\\012\\011\\011\\011END IF;\\012\\011\\011ELSIF (NEW.grou_id is not NULL) THEN\\012\\011\\011\\011SELECT count(*) into counter FROM samples \\012\\011\\011\\011\\011where id != NEW.id and code = NEW.code and saty_id = NEW.saty_id and grou_id = NEW.grou_id;\\012\\011\\011\\011IF (counter > 0) THEN\\012\\011\\011\\011\\011RAISE EXCEPTION 'Insert/Update of Sample (Code: %) failed because space sample of the same type with the same subcode already exists.', NEW.code;\\012\\011\\011\\011END IF;\\012\\011\\011END IF;\\012  END IF;\\012  \\012  RETURN NEW;\\012END;\\012$$ LANGUAGE 'plpgsql';\\012\\012CREATE TRIGGER SAMPLE_SUBCODE_UNIQUENESS_CHECK BEFORE INSERT OR UPDATE ON SAMPLES\\012    FOR EACH ROW EXECUTE PROCEDURE SAMPLE_SUBCODE_UNIQUENESS_CHECK();\\012    \\012-- Fixing error messages in old trigger\\012\\012CREATE OR REPLACE FUNCTION SAMPLE_CODE_UNIQUENESS_CHECK() RETURNS trigger AS $$\\012DECLARE\\012   counter  INTEGER;\\012BEGIN\\012  LOCK TABLE samples IN EXCLUSIVE MODE;\\012  \\012\\011  IF (NEW.samp_id_part_of is NULL) THEN\\012\\011\\011  IF (NEW.dbin_id is not NULL) THEN\\012\\011\\011\\011  SELECT count(*) into counter FROM samples \\012\\011\\011      where id != NEW.id and code = NEW.code and samp_id_part_of is NULL and dbin_id = NEW.dbin_id;\\012        IF (counter > 0) THEN\\012\\011\\011\\011\\011  RAISE EXCEPTION 'Insert/Update of Sample (Code: %) failed because database instance sample with the same code already exists.', NEW.code;\\012        END IF;\\012\\011\\011  ELSIF (NEW.grou_id is not NULL) THEN\\012\\011\\011\\011  SELECT count(*) into counter FROM samples \\012\\011\\011\\011\\011  where id != NEW.id and code = NEW.code and samp_id_part_of is NULL and grou_id = NEW.grou_id;\\012\\011\\011\\011  IF (counter > 0) THEN\\012\\011\\011\\011\\011  RAISE EXCEPTION 'Insert/Update of Sample (Code: %) failed because space sample with the same code already exists.', NEW.code;\\012\\011\\011\\011  END IF;\\012      END IF;\\012    ELSE\\012\\011\\011  IF (NEW.dbin_id is not NULL) THEN\\012\\011\\011\\011  SELECT count(*) into counter FROM samples \\012\\011\\011\\011\\011  where id != NEW.id and code = NEW.code and samp_id_part_of = NEW.samp_id_part_of and dbin_id = NEW.dbin_id;\\012\\011\\011\\011  IF (counter > 0) THEN\\012\\011\\011\\011\\011  RAISE EXCEPTION 'Insert/Update of Sample (Code: %) failed because database instance sample with the same code and being the part of the same container already exists.', NEW.code;\\012\\011\\011\\011  END IF;\\012\\011\\011  ELSIF (NEW.grou_id is not NULL) THEN\\012\\011\\011\\011  SELECT count(*) into counter FROM samples \\012\\011\\011\\011\\011  where id != NEW.id and code = NEW.code and samp_id_part_of = NEW.samp_id_part_of and grou_id = NEW.grou_id;\\012\\011\\011\\011  IF (counter > 0) THEN\\012\\011\\011\\011\\011  RAISE EXCEPTION 'Insert/Update of Sample (Code: %) failed because space sample with the same code and being the part of the same container already exists.', NEW.code;\\012\\011\\011\\011  END IF;\\012\\011\\011  END IF;\\012     END IF;   \\012  \\012  RETURN NEW;\\012END;\\012$$ LANGUAGE 'plpgsql';\\012	\N
+./sourceTest/sql/postgresql/054/.svn/text-base/017=database_version_logs.tsv.svn-base:054	source/sql/postgresql/migration/migration-053-054.sql	SUCCESS	2010-07-27 11:30:46.766	-- Migration from 053 to 054\\012\\012\\012-- Add RELATIONSHIP_TYPES table\\012CREATE TABLE relationship_types (id TECH_ID NOT NULL, code CODE NOT NULL, label COLUMN_LABEL, parent_label COLUMN_LABEL, child_label COLUMN_LABEL, description DESCRIPTION_2000, registration_timestamp TIME_STAMP_DFL NOT NULL DEFAULT CURRENT_TIMESTAMP, pers_id_registerer TECH_ID NOT NULL, is_managed_internally BOOLEAN_CHAR NOT NULL DEFAULT 'F', is_internal_namespace BOOLEAN_CHAR NOT NULL DEFAULT 'F', dbin_id TECH_ID NOT NULL);\\012\\012-- Add SAMPLE_RELATIONSHIPS table\\012CREATE TABLE sample_relationships (id TECH_ID NOT NULL, sample_id_parent TECH_ID NOT NULL, relationship_id TECH_ID NOT NULL, sample_id_child TECH_ID NOT NULL);\\012\\012-- Add/update constraints\\012ALTER TABLE relationship_types ADD CONSTRAINT rety_pk PRIMARY KEY (id);\\012ALTER TABLE relationship_types ADD CONSTRAINT rety_uk UNIQUE(code,dbin_id);\\012ALTER TABLE sample_relationships ADD CONSTRAINT sare_pk PRIMARY KEY (id);\\012ALTER TABLE sample_relationships ADD CONSTRAINT sare_bk_uk UNIQUE(sample_id_child,sample_id_parent,relationship_id);\\012ALTER TABLE sample_relationships ADD CONSTRAINT sare_data_fk_child FOREIGN KEY (sample_id_child) REFERENCES samples(id) ON DELETE CASCADE;\\012ALTER TABLE sample_relationships ADD CONSTRAINT sare_data_fk_parent FOREIGN KEY (sample_id_parent) REFERENCES samples(id) ON DELETE CASCADE;\\012ALTER TABLE sample_relationships ADD CONSTRAINT sare_data_fk_relationship FOREIGN KEY (relationship_id) REFERENCES relationship_types(id);\\012\\012-- Create index\\012CREATE INDEX sare_data_fk_i_child ON sample_relationships (sample_id_child);\\012CREATE INDEX sare_data_fk_i_parent ON sample_relationships (sample_id_parent);\\012CREATE INDEX sare_data_fk_i_relationship ON sample_relationships (relationship_id);\\012\\012-- Create sequence for RELATIONSHIP_TYPES\\012CREATE SEQUENCE RELATIONSHIP_TYPE_ID_SEQ;\\012CREATE SEQUENCE SAMPLE_RELATIONSHIP_ID_SEQ;\\012\\012-- Create initial relationships\\012insert into relationship_types\\012(id, \\012code, \\012label, \\012parent_label, \\012child_label, \\012description, \\012pers_id_registerer, \\012is_managed_internally, \\012is_internal_namespace, \\012dbin_id) \\012values\\012(\\012nextval('RELATIONSHIP_TYPE_ID_SEQ'),\\012'PARENT_CHILD',\\012'Parent - Child', \\012'Parent', \\012'Child', \\012'Parent - Child relationship', \\012(select id from persons where user_id ='system'), \\012'T', \\012'T', \\012(select id from database_instances where is_original_source = 'T')\\012);\\012\\012insert into relationship_types\\012(id, \\012code, \\012label, \\012parent_label, \\012child_label, \\012description, \\012pers_id_registerer, \\012is_managed_internally, \\012is_internal_namespace, \\012dbin_id) \\012values\\012(\\012nextval('RELATIONSHIP_TYPE_ID_SEQ'),\\012'PLATE_CONTROL_LAYOUT',\\012'Plate - Control Layout', \\012'Plate', \\012'Control Layout', \\012'Plate - Control Layout relationship', \\012(select id from persons where user_id ='system'), \\012'T', \\012'T', \\012(select id from database_instances where is_original_source = 'T')\\012); \\012\\012\\012-- Migrate sample relationships to new schema\\012INSERT INTO sample_relationships (id, sample_id_parent,sample_id_child,relationship_id) (select distinct nextval('SAMPLE_RELATIONSHIP_ID_SEQ') as id, s.SAMP_ID_GENERATED_FROM as parent_id, s.ID as child_id, rt.id as relationship_id from samples s, relationship_types rt  WHERE rt.code = 'PARENT_CHILD' and s.SAMP_ID_GENERATED_FROM is not null); \\012INSERT INTO sample_relationships (id, sample_id_parent,sample_id_child,relationship_id) (select distinct nextval('SAMPLE_RELATIONSHIP_ID_SEQ') as id, s.SAMP_ID_CONTROL_LAYOUT as parent_id, s.ID as child_id, rt.id as relationship_id from samples s, relationship_types rt  WHERE rt.code = 'PLATE_CONTROL_LAYOUT' and s.SAMP_ID_CONTROL_LAYOUT is not null);\\012\\012-- Drop old sample relations\\012ALTER TABLE SAMPLES DROP COLUMN SAMP_ID_TOP;\\012ALTER TABLE SAMPLES DROP COLUMN SAMP_ID_GENERATED_FROM;\\012ALTER TABLE SAMPLES DROP COLUMN SAMP_ID_CONTROL_LAYOUT;\\012\\012--------------------------------------------------------------------------------------\\012--------------------------------------------------------------------------------------\\012-- This is a screening specific migration. Nothing will be performed on openBIS databases \\012-- which are not screening specific.\\012-- \\012-- This migration for each existing connection between oligo well, oligo material and gene material\\012-- creates a direct connection between the well and the gene. \\012--------------------------------------------------------------------------------------\\012--------------------------------------------------------------------------------------\\012 \\012\\011\\012CREATE OR REPLACE FUNCTION CONNECT_WELLS_WITH_GENES() RETURNS void AS $$\\012DECLARE\\012\\011counter  int;\\012\\011oligo_well_exists bool;\\012BEGIN\\012\\011--------------------------------------------------\\012\\011-- create a gene property and assign it to oligo well\\012\\011--------------------------------------------------\\012\\011\\012\\011select true \\012\\011into oligo_well_exists\\012\\011from sample_types \\012\\011where code = 'OLIGO_WELL';\\012\\011\\012\\011if oligo_well_exists IS NULL then \\012\\011\\011-- skip migration if there are no oligo wells\\012\\011\\011return;\\012\\011end if;   \\012\\011\\012\\011insert into property_types(\\012\\011\\011id, \\012\\011\\011code, description, label, \\012\\011\\011daty_id,\\012\\011\\011pers_id_registerer,\\012\\011\\011dbin_id,\\012\\011\\011maty_prop_id) \\012\\011values(\\012\\011\\011\\011nextval('PROPERTY_TYPE_ID_SEQ'), \\012\\011\\011\\011'GENE','Inhibited gene','Gene',\\012\\011\\011\\011(select id from data_types where code = 'MATERIAL'), \\012\\011\\011\\011(select id from persons where user_id ='system'), \\012\\011\\011\\011(select id from database_instances where is_original_source = 'T'), \\012\\011\\011\\011(select id from material_types where code = 'GENE')\\012\\011\\011);\\012\\011\\011\\012\\011insert into sample_type_property_types( \\012\\011  id,\\012\\011  saty_id,\\012\\011  prty_id,\\012\\011  is_mandatory,\\012\\011  pers_id_registerer,\\012\\011  ordinal\\012\\011) values(\\012\\011\\011\\011nextval('stpt_id_seq'), \\012\\011\\011\\011(select id from sample_types where code = 'OLIGO_WELL'),\\012\\011\\011\\011(select id from property_types where code = 'GENE'),\\012\\011\\011\\011false,\\012\\011\\011\\011(select id from persons where user_id ='system'),\\012\\011\\011\\011(select max(ordinal)+1 from sample_type_property_types \\012\\011\\011\\011\\011where saty_id = (select id from sample_types where code = 'OLIGO_WELL'))\\012\\011\\011);\\012\\012\\011--------------------------------------------------\\012\\011-- create a gene material property for each oligo well\\012\\011--------------------------------------------------\\012\\011\\011\\012\\011select \\011count(*)\\012\\011into counter\\012\\011from\\012\\011\\011samples well, sample_types well_type, sample_properties well_props, \\012\\011\\011materials well_material, material_properties well_material_props,\\012\\011\\011materials nested_well_material\\012\\011where\\012\\011\\011well_type.code = 'OLIGO_WELL' and\\012\\011\\011-- find 'well_material' assigned to the well\\012\\011\\011well_props.samp_id = well.id and well_material.id = well_props.mate_prop_id and \\012\\011\\011-- additional joins to entity type tables\\012\\011\\011well_type.id = well.saty_id and\\012\\011\\011-- well content material property\\012\\011\\011well_material_props.mate_id = well_material.id and \\012\\011\\011-- material connected to the material in the well (e.g. gene)\\012\\011\\011well_material_props.mate_prop_id = nested_well_material.id and\\012\\011\\011nested_well_material.maty_id = (select id from material_types where code = 'GENE');\\012\\011\\012\\011if counter = 0 then \\012\\011\\011-- skip migration if there are no genes indirectly connected to oligo wells\\012\\011\\011return;\\012\\011end if;   \\012\\012\\011insert into sample_properties(id, samp_id, stpt_id, mate_prop_id, pers_id_registerer) (\\012\\011\\011select \\011nextval('sample_property_id_seq') id, \\012\\011\\011\\011well.id samp_id, \\012\\011\\011\\011(select stpt.id from sample_type_property_types stpt, property_types props where stpt.prty_id = props.id and props.code='GENE') stpt_id,\\012\\011\\011\\011nested_well_material.id mate_prop_id,\\012\\011\\011\\011(select id from persons where user_id ='system') pers_id_registerer \\012\\011\\011from\\012\\011\\011\\011samples well, sample_types well_type, sample_properties well_props, \\012\\011\\011\\011materials well_material, material_properties well_material_props,\\012\\011\\011\\011materials nested_well_material\\012\\011\\011where\\012\\011\\011\\011well_type.code = 'OLIGO_WELL' and\\012\\011\\011\\011-- find 'well_material' assigned to the well\\012\\011\\011\\011well_props.samp_id = well.id and well_material.id = well_props.mate_prop_id and \\012\\011\\011\\011-- additional joins to entity type tables\\012\\011\\011\\011well_type.id = well.saty_id and\\012\\011\\011\\011-- well content material property\\012\\011\\011\\011well_material_props.mate_id = well_material.id and \\012\\011\\011\\011-- material connected to the material in the well (e.g. gene)\\012\\011\\011\\011well_material_props.mate_prop_id = nested_well_material.id and\\012\\011\\011\\011nested_well_material.maty_id = (select id from material_types where code = 'GENE')\\012\\011);\\012\\012END;\\012$$ LANGUAGE 'plpgsql';\\012\\012select CONNECT_WELLS_WITH_GENES();\\012drop function CONNECT_WELLS_WITH_GENES();\\012\\012--------------------------------------------------------------------------------------\\012--------------------------------------------------------------------------------------\\012\\012-- drop dataset triggers\\012\\012DROP TRIGGER check_dataset_relationships_on_data_table_modification ON data;\\012DROP FUNCTION check_dataset_relationships_on_data_table_modification();\\012DROP TRIGGER check_dataset_relationships_on_relationships_table_modification ON data_set_relationships;\\012DROP FUNCTION check_dataset_relationships_on_relationships_table_modification();\\012 \\012\\012\\012\\012\\012\\012\\012\\012	\N
+./sourceTest/sql/postgresql/054/.svn/text-base/schema-054.sql.svn-base:    LANGUAGE plpgsql
+./sourceTest/sql/postgresql/054/.svn/text-base/schema-054.sql.svn-base:    LANGUAGE plpgsql
+./sourceTest/sql/postgresql/054/.svn/text-base/schema-054.sql.svn-base:    LANGUAGE plpgsql
+./sourceTest/sql/postgresql/054/.svn/text-base/schema-054.sql.svn-base:    LANGUAGE plpgsql
+./sourceTest/sql/postgresql/054/.svn/text-base/schema-054.sql.svn-base:    LANGUAGE plpgsql
+./sourceTest/sql/postgresql/054/.svn/text-base/schema-054.sql.svn-base:    LANGUAGE plpgsql
+./sourceTest/sql/postgresql/054/.svn/text-base/schema-054.sql.svn-base:    LANGUAGE plpgsql
+./sourceTest/sql/postgresql/054/.svn/text-base/schema-054.sql.svn-base:    LANGUAGE plpgsql
+./sourceTest/sql/postgresql/054/.svn/text-base/schema-054.sql.svn-base:    LANGUAGE plpgsql
+./sourceTest/sql/postgresql/054/017=database_version_logs.tsv:027	D:\\User\\felmer\\dev-workspace\\openbis/source/sql/postgresql/027/function-027.sql	SUCCESS	2008-11-05 09:18:00.403	-- Creating Functions\\012\\012------------------------------------------------------------------------------------\\012--  Purpose:  Create function RENAME_SEQUENCE() that is required for renaming the sequences belonging to tables\\012------------------------------------------------------------------------------------\\012CREATE FUNCTION RENAME_SEQUENCE(OLD_NAME VARCHAR, NEW_NAME VARCHAR) RETURNS INTEGER AS $$\\012DECLARE\\012  CURR_SEQ_VAL   INTEGER;\\012BEGIN\\012  SELECT INTO CURR_SEQ_VAL NEXTVAL(OLD_NAME);\\012  EXECUTE 'CREATE SEQUENCE ' || NEW_NAME || ' START WITH ' || CURR_SEQ_VAL;\\012  EXECUTE 'DROP SEQUENCE ' || OLD_NAME;\\012  RETURN CURR_SEQ_VAL;\\012END;\\012$$ LANGUAGE 'plpgsql';\\012\\012\\012------------------------------------------------------------------------------------\\012--  Purpose:  Create trigger CONTROLLED_VOCABULARY_CHECK \\012------------------------------------------------------------------------------------\\012\\012CREATE OR REPLACE FUNCTION CONTROLLED_VOCABULARY_CHECK() RETURNS trigger AS $$\\012DECLARE\\012   v_code  CODE;\\012BEGIN\\012\\012   select code into v_code from data_types where id = NEW.daty_id;\\012\\012   -- Check if the data is of type "CONTROLLEDVOCABULARY"\\012   if v_code = 'CONTROLLEDVOCABULARY' then\\012      if NEW.covo_id IS NULL then\\012         RAISE EXCEPTION 'Insert/Update of Property Type (Code: %) failed, as its Data Type is CONTROLLEDVOCABULARY, but it is not linked to a Controlled Vocabulary.', NEW.code;\\012      end if;\\012   end if;\\012\\012   RETURN NEW;\\012\\012END;\\012$$ LANGUAGE 'plpgsql';\\012\\012CREATE TRIGGER CONTROLLED_VOCABULARY_CHECK BEFORE INSERT OR UPDATE ON PROPERTY_TYPES\\012    FOR EACH ROW EXECUTE PROCEDURE CONTROLLED_VOCABULARY_CHECK();\\012\\012\\012------------------------------------------------------------------------------------\\012--  Purpose:  Create trigger EXTERNAL_DATA_STORAGE_FORMAT_CHECK \\012------------------------------------------------------------------------------------\\012\\012CREATE OR REPLACE FUNCTION EXTERNAL_DATA_STORAGE_FORMAT_CHECK() RETURNS trigger AS $$\\012DECLARE\\012   v_covo_code  CODE;\\012   data_code CODE;\\012BEGIN\\012\\012   select code into v_covo_code from controlled_vocabularies\\012      where is_internal_namespace = true and \\012         id = (select covo_id from controlled_vocabulary_terms where id = NEW.cvte_id_stor_fmt);\\012   -- Check if the data storage format is a term of the controlled vocabulary "STORAGE_FORMAT"\\012   if v_covo_code != 'STORAGE_FORMAT' then\\012      select code into data_code from data where id = NEW.data_id; \\012      RAISE EXCEPTION 'Insert/Update of Data (Code: %) failed, as its Storage Format is %, but is required to be STORAGE_FORMAT.', data_code, v_covo_code;\\012   end if;\\012\\012   RETURN NEW;\\012\\012END;\\012$$ LANGUAGE 'plpgsql';\\012\\012CREATE TRIGGER EXTERNAL_DATA_STORAGE_FORMAT_CHECK BEFORE INSERT OR UPDATE ON EXTERNAL_DATA\\012    FOR EACH ROW EXECUTE PROCEDURE EXTERNAL_DATA_STORAGE_FORMAT_CHECK();\\012\\012------------------------------------------------------------------------------------\\012--  Purpose:  Create trigger SAMPLE_CODE_UNIQUENESS_CHECK \\012------------------------------------------------------------------------------------\\012\\012CREATE OR REPLACE FUNCTION SAMPLE_CODE_UNIQUENESS_CHECK() RETURNS trigger AS $$\\012DECLARE\\012   counter  INTEGER;\\012BEGIN\\012\\011IF (NEW.samp_id_part_of is NULL) THEN\\012\\011\\011IF (NEW.dbin_id is not NULL) THEN\\012\\011\\011\\011SELECT count(*) into counter FROM samples \\012\\011\\011\\011\\011where id != NEW.id and code = NEW.code and samp_id_part_of is NULL and dbin_id = NEW.dbin_id;\\012\\011\\011\\011IF (counter > 0) THEN\\012\\011\\011\\011\\011RAISE EXCEPTION 'Insert/Update of Sample (Code: %) failed because database instance sample with the same code already exists.', NEW.code;\\012\\011\\011\\011END IF;\\012\\011\\011ELSIF (NEW.grou_id is not NULL) THEN\\012\\011\\011\\011SELECT count(*) into counter FROM samples \\012\\011\\011\\011\\011where id != NEW.id and code = NEW.code and samp_id_part_of is NULL and grou_id = NEW.grou_id;\\012\\011\\011\\011IF (counter > 0) THEN\\012\\011\\011\\011\\011RAISE EXCEPTION 'Insert/Update of Sample (Code: %) failed because group sample with the same code already exists.', NEW.code;\\012\\011\\011\\011END IF;\\012\\011\\011END IF;\\012        ELSE\\012\\011\\011IF (NEW.dbin_id is not NULL) THEN\\012\\011\\011\\011SELECT count(*) into counter FROM samples \\012\\011\\011\\011\\011where id != NEW.id and code = NEW.code and samp_id_part_of = NEW.samp_id_part_of and dbin_id = NEW.dbin_id;\\012\\011\\011\\011IF (counter > 0) THEN\\012\\011\\011\\011\\011RAISE EXCEPTION 'Insert/Update of Sample (Code: %) failed because database instance sample with the same code and being the part of the same parent already exists.', NEW.code;\\012\\011\\011\\011END IF;\\012\\011\\011ELSIF (NEW.grou_id is not NULL) THEN\\012\\011\\011\\011SELECT count(*) into counter FROM samples \\012\\011\\011\\011\\011where id != NEW.id and code = NEW.code and samp_id_part_of = NEW.samp_id_part_of and grou_id = NEW.grou_id;\\012\\011\\011\\011IF (counter > 0) THEN\\012\\011\\011\\011\\011RAISE EXCEPTION 'Insert/Update of Sample (Code: %) failed because group sample with the same code and being the part of the same parent already exists.', NEW.code;\\012\\011\\011\\011END IF;\\012\\011\\011END IF;\\012        END IF;   \\012   RETURN NEW;\\012END;\\012$$ LANGUAGE 'plpgsql';\\012\\012CREATE TRIGGER SAMPLE_CODE_UNIQUENESS_CHECK BEFORE INSERT OR UPDATE ON SAMPLES\\012    FOR EACH ROW EXECUTE PROCEDURE SAMPLE_CODE_UNIQUENESS_CHECK();\\012	\N
+./sourceTest/sql/postgresql/054/017=database_version_logs.tsv:028	source/sql/postgresql/migration/migration-027-028.sql	SUCCESS	2008-11-18 13:24:17.508	-- Create EXPERIMENT_ATTACHMENT_CONTENTS.\\012CREATE TABLE EXPERIMENT_ATTACHMENT_CONTENTS (ID TECH_ID NOT NULL,VALUE FILE NOT NULL);\\012CREATE SEQUENCE EXPERIMENT_ATTACHMENT_CONTENT_ID_SEQ;\\012ALTER TABLE EXPERIMENT_ATTACHMENT_CONTENTS ADD CONSTRAINT EXAC_PK PRIMARY KEY(ID);\\012\\012-- Alter EXPERIMENT_ATTACHMENTS by adding the new column which has a NULL constraint.\\012-- The NOT NULL constraint is added later on.\\012ALTER TABLE EXPERIMENT_ATTACHMENTS ADD COLUMN EXAC_ID TECH_ID;\\012\\012-- Does the VALUE migration between EXPERIMENT_ATTACHMENTS to EXPERIMENT_ATTACHMENT_CONTENTS.\\012CREATE OR REPLACE FUNCTION move_exp_att_content() RETURNS integer AS $$\\012DECLARE\\012    rec RECORD;\\012    seq BIGINT;\\012BEGIN\\012  FOR rec IN SELECT id, value FROM EXPERIMENT_ATTACHMENTS LOOP\\012  \\011seq := nextval('EXPERIMENT_ATTACHMENT_CONTENT_ID_SEQ');\\012    INSERT INTO EXPERIMENT_ATTACHMENT_CONTENTS (id, value) VALUES (seq, rec.value);\\012    UPDATE EXPERIMENT_ATTACHMENTS SET exac_id = seq WHERE id = rec.id;\\012  END LOOP;\\012  RETURN 1;\\012END;\\012$$ LANGUAGE 'plpgsql';\\012\\012-- Call the function.\\012SELECT move_exp_att_content();\\012DROP FUNCTION move_exp_att_content();\\012\\012\\012-- Finish EXPERIMENT_ATTACHMENTS changes.\\012ALTER TABLE EXPERIMENT_ATTACHMENTS ADD CONSTRAINT EXAT_CONT_FK FOREIGN KEY (EXAC_ID) REFERENCES EXPERIMENT_ATTACHMENT_CONTENTS(ID);\\012ALTER TABLE EXPERIMENT_ATTACHMENTS DROP COLUMN VALUE;\\012ALTER TABLE EXPERIMENT_ATTACHMENTS ALTER COLUMN EXAC_ID SET NOT NULL;\\012	\N
+./sourceTest/sql/postgresql/054/017=database_version_logs.tsv:029	source/sql/postgresql/migration/migration-028-029.sql	SUCCESS	2009-03-18 10:50:20.105	-- -------\\012-- add modification_timestamp field to allow edition with Hibernate\\012-- -------\\012\\012ALTER TABLE samples\\012\\011ADD COLUMN modification_timestamp TIME_STAMP DEFAULT CURRENT_TIMESTAMP;\\012\\012ALTER TABLE experiments\\012\\011ADD COLUMN modification_timestamp TIME_STAMP DEFAULT CURRENT_TIMESTAMP;\\012\\012ALTER TABLE materials\\012\\011ADD COLUMN modification_timestamp TIME_STAMP DEFAULT CURRENT_TIMESTAMP;\\012\\012ALTER TABLE experiment_properties\\012\\011ADD COLUMN modification_timestamp TIME_STAMP DEFAULT CURRENT_TIMESTAMP;\\012\\012ALTER TABLE material_properties\\012\\011ADD COLUMN modification_timestamp TIME_STAMP DEFAULT CURRENT_TIMESTAMP;\\012\\012ALTER TABLE sample_properties\\012\\011ADD COLUMN modification_timestamp TIME_STAMP DEFAULT CURRENT_TIMESTAMP;\\012\\012-- -------\\012-- add property data type which references materials\\012-- -------\\012\\012ALTER TABLE property_types\\012\\011ADD COLUMN maty_prop_id tech_id;\\012\\012ALTER TABLE property_types\\012\\011ADD CONSTRAINT prty_maty_fk FOREIGN KEY (maty_prop_id) REFERENCES material_types(id);\\012\\012ALTER TABLE experiment_properties\\012\\011ADD COLUMN mate_prop_id tech_id;\\012\\012ALTER TABLE material_properties\\012\\011ADD COLUMN mate_prop_id tech_id;\\012\\012ALTER TABLE sample_properties\\012\\011ADD COLUMN mate_prop_id tech_id;\\012\\012ALTER TABLE experiment_properties\\012\\011ADD CONSTRAINT expr_mapr_fk FOREIGN KEY (mate_prop_id) REFERENCES materials(id);\\012\\012ALTER TABLE material_properties\\012\\011ADD CONSTRAINT mapr_mapr_fk FOREIGN KEY (mate_prop_id) REFERENCES materials(id);\\012\\012ALTER TABLE sample_properties\\012\\011ADD CONSTRAINT sapr_mapr_fk FOREIGN KEY (mate_prop_id) REFERENCES materials(id);\\012\\012insert into data_types\\012(id\\012 ,code\\012 ,description)\\012 values \\012 (nextval('DATA_TYPE_ID_SEQ')\\012 ,'MATERIAL'\\012 ,'Reference to a material'\\012);\\012\\012ALTER TABLE MATERIAL_PROPERTIES DROP CONSTRAINT MAPR_CK;\\012ALTER TABLE MATERIAL_PROPERTIES ADD CONSTRAINT MAPR_CK CHECK \\012\\011((VALUE IS NOT NULL AND CVTE_ID IS NULL AND MATE_PROP_ID IS NULL) OR \\012\\011 (VALUE IS NULL AND CVTE_ID IS NOT NULL AND MATE_PROP_ID IS NULL) OR\\012\\011 (VALUE IS NULL AND CVTE_ID IS NULL AND MATE_PROP_ID IS NOT NULL)\\012\\011);\\012\\012ALTER TABLE EXPERIMENT_PROPERTIES DROP CONSTRAINT EXPR_CK;\\012ALTER TABLE EXPERIMENT_PROPERTIES ADD CONSTRAINT EXPR_CK CHECK \\012\\011((VALUE IS NOT NULL AND CVTE_ID IS NULL AND MATE_PROP_ID IS NULL) OR \\012\\011 (VALUE IS NULL AND CVTE_ID IS NOT NULL AND MATE_PROP_ID IS NULL) OR\\012\\011 (VALUE IS NULL AND CVTE_ID IS NULL AND MATE_PROP_ID IS NOT NULL)\\012\\011);\\012\\012ALTER TABLE SAMPLE_PROPERTIES DROP CONSTRAINT SAPR_CK;\\012ALTER TABLE SAMPLE_PROPERTIES ADD CONSTRAINT SAPR_CK CHECK \\012\\011((VALUE IS NOT NULL AND CVTE_ID IS NULL AND MATE_PROP_ID IS NULL) OR \\012\\011 (VALUE IS NULL AND CVTE_ID IS NOT NULL AND MATE_PROP_ID IS NULL) OR\\012\\011 (VALUE IS NULL AND CVTE_ID IS NULL AND MATE_PROP_ID IS NOT NULL)\\012\\011);\\012\\012------------------------------------------------------------------------------------\\012--  Purpose:  Create trigger MATERIAL/SAMPLE/EXPERIMENT _PROPERTY_WITH_MATERIAL_DATA_TYPE_CHECK\\012--            It checks that if material property value is assigned to the entity,\\012--\\011\\011\\011\\011\\011\\011then the material type is equal to the one described by property type.\\012------------------------------------------------------------------------------------\\012\\012CREATE OR REPLACE FUNCTION MATERIAL_PROPERTY_WITH_MATERIAL_DATA_TYPE_CHECK() RETURNS trigger AS $$\\012DECLARE\\012   v_type_id  CODE;\\012   v_type_id_prop  CODE;\\012BEGIN\\012   if NEW.mate_prop_id IS NOT NULL then\\012\\011\\011\\011-- find material type id of the property type \\012\\011\\011\\011select pt.maty_prop_id into v_type_id_prop \\012\\011\\011\\011  from material_type_property_types etpt, property_types pt \\012\\011\\011\\011 where NEW.mtpt_id = etpt.id AND etpt.prty_id = pt.id;\\012\\011\\011\\012\\011\\011\\011if v_type_id_prop IS NOT NULL then\\012\\011\\011\\011\\011-- find material type id of the material which consists the entity's property value\\012\\011\\011\\011\\011select entity.maty_id into v_type_id \\012\\011\\011\\011\\011  from materials entity\\012\\011\\011\\011\\011 where NEW.mate_prop_id = entity.id;\\012\\011\\011\\011\\011if v_type_id != v_type_id_prop then\\012\\011\\011\\011\\011\\011RAISE EXCEPTION 'Insert/Update of property value referencing material (id: %) failed, as referenced material type is different than expected (id %, expected id: %).', \\012\\011\\011\\011\\011\\011\\011\\011 NEW.mate_prop_id, v_type_id, v_type_id_prop;\\012\\011\\011\\011\\011end if;\\012\\011\\011\\011end if;\\012   end if;\\012   RETURN NEW;\\012END;\\012$$ LANGUAGE 'plpgsql';\\012\\012CREATE TRIGGER MATERIAL_PROPERTY_WITH_MATERIAL_DATA_TYPE_CHECK BEFORE INSERT OR UPDATE ON material_properties\\012    FOR EACH ROW EXECUTE PROCEDURE MATERIAL_PROPERTY_WITH_MATERIAL_DATA_TYPE_CHECK();\\012    \\012CREATE OR REPLACE FUNCTION SAMPLE_PROPERTY_WITH_MATERIAL_DATA_TYPE_CHECK() RETURNS trigger AS $$\\012DECLARE\\012   v_type_id  CODE;\\012   v_type_id_prop  CODE;\\012BEGIN\\012   if NEW.mate_prop_id IS NOT NULL then\\012\\011\\011\\011-- find material type id of the property type \\012\\011\\011\\011select pt.maty_prop_id into v_type_id_prop \\012\\011\\011\\011  from sample_type_property_types etpt, property_types pt \\012\\011\\011\\011 where NEW.stpt_id = etpt.id AND etpt.prty_id = pt.id;\\012\\011\\011\\012\\011\\011\\011if v_type_id_prop IS NOT NULL then\\012\\011\\011\\011\\011-- find material type id of the material which consists the entity's property value\\012\\011\\011\\011\\011select entity.maty_id into v_type_id \\012\\011\\011\\011\\011  from materials entity\\012\\011\\011\\011\\011 where NEW.mate_prop_id = entity.id;\\012\\011\\011\\011\\011if v_type_id != v_type_id_prop then\\012\\011\\011\\011\\011\\011RAISE EXCEPTION 'Insert/Update of property value referencing material (id: %) failed, as referenced material type is different than expected (id %, expected id: %).', \\012\\011\\011\\011\\011\\011\\011\\011\\011\\011\\011\\011\\011 NEW.mate_prop_id, v_type_id, v_type_id_prop;\\012\\011\\011\\011\\011end if;\\012\\011\\011\\011end if;\\012   end if;\\012   RETURN NEW;\\012END;\\012$$ LANGUAGE 'plpgsql';\\012\\012CREATE TRIGGER SAMPLE_PROPERTY_WITH_MATERIAL_DATA_TYPE_CHECK BEFORE INSERT OR UPDATE ON sample_properties\\012    FOR EACH ROW EXECUTE PROCEDURE SAMPLE_PROPERTY_WITH_MATERIAL_DATA_TYPE_CHECK();\\012    \\012CREATE OR REPLACE FUNCTION EXPERIMENT_PROPERTY_WITH_MATERIAL_DATA_TYPE_CHECK() RETURNS trigger AS $$\\012DECLARE\\012   v_type_id  CODE;\\012   v_type_id_prop  CODE;\\012BEGIN\\012   if NEW.mate_prop_id IS NOT NULL then\\012\\011\\011\\011-- find material type id of the property type \\012\\011\\011\\011select pt.maty_prop_id into v_type_id_prop \\012\\011\\011\\011  from experiment_type_property_types etpt, property_types pt \\012\\011\\011\\011 where NEW.etpt_id = etpt.id AND etpt.prty_id = pt.id;\\012\\011\\011\\012\\011\\011\\011if v_type_id_prop IS NOT NULL then\\012\\011\\011\\011\\011-- find material type id of the material which consists the entity's property value\\012\\011\\011\\011\\011select entity.maty_id into v_type_id \\012\\011\\011\\011\\011  from materials entity\\012\\011\\011\\011\\011 where NEW.mate_prop_id = entity.id;\\012\\011\\011\\011\\011if v_type_id != v_type_id_prop then\\012\\011\\011\\011\\011\\011RAISE EXCEPTION 'Insert/Update of property value referencing material (id: %) failed, as referenced material type is different than expected (id %, expected id: %).', \\012\\011\\011\\011\\011\\011\\011\\011\\011\\011\\011\\011\\011 NEW.mate_prop_id, v_type_id, v_type_id_prop;\\012\\011\\011\\011\\011end if;\\012\\011\\011\\011end if;\\012   end if;\\012   RETURN NEW;\\012END;\\012$$ LANGUAGE 'plpgsql';\\012\\012CREATE TRIGGER EXPERIMENT_PROPERTY_WITH_MATERIAL_DATA_TYPE_CHECK BEFORE INSERT OR UPDATE ON experiment_properties\\012    FOR EACH ROW EXECUTE PROCEDURE EXPERIMENT_PROPERTY_WITH_MATERIAL_DATA_TYPE_CHECK();\\012       \\012-- -------\\012-- remove the reminescents of the OBSERVABLE_TYPE\\012-- -------\\012\\012ALTER TABLE data\\012\\011DROP CONSTRAINT data_obty_fk;\\012\\012ALTER TABLE data_set_types\\012\\011DROP CONSTRAINT obty_pk;\\012\\012ALTER TABLE data_set_types\\012\\011ADD CONSTRAINT dsty_pk PRIMARY KEY (id);\\012\\012ALTER TABLE data\\012\\011ADD CONSTRAINT data_dsty_fk FOREIGN KEY (dsty_id) REFERENCES data_set_types(id);\\012\\012ALTER TABLE data_set_types\\012\\011DROP CONSTRAINT obty_bk_uk;\\012\\012ALTER TABLE data_set_types\\012\\011DROP CONSTRAINT obty_dbin_fk;\\012\\012ALTER TABLE data_set_types\\012\\011ADD CONSTRAINT dsty_bk_uk UNIQUE (code, dbin_id);\\012\\012ALTER TABLE data_set_types\\012\\011ADD CONSTRAINT dsty_dbin_fk FOREIGN KEY (dbin_id) REFERENCES database_instances(id);\\012\\012DROP INDEX data_obty_fk_i;\\012\\012CREATE INDEX data_dsty_fk_i ON data(dsty_id);\\012	\N
+./sourceTest/sql/postgresql/054/017=database_version_logs.tsv:030	source/sql/postgresql/migration/migration-029-030.sql	SUCCESS	2009-03-23 15:34:44.72	-- -------\\012-- add modification_timestamp field to allow edition with Hibernate\\012-- -------\\012ALTER TABLE data\\012\\011ADD COLUMN modification_timestamp TIME_STAMP DEFAULT CURRENT_TIMESTAMP;\\012ALTER TABLE experiment_types\\012\\011ADD COLUMN modification_timestamp TIME_STAMP DEFAULT CURRENT_TIMESTAMP;\\012ALTER TABLE sample_types\\012\\011ADD COLUMN modification_timestamp TIME_STAMP DEFAULT CURRENT_TIMESTAMP;\\012ALTER TABLE material_types\\012\\011ADD COLUMN modification_timestamp TIME_STAMP DEFAULT CURRENT_TIMESTAMP;\\012ALTER TABLE data_set_types\\012\\011ADD COLUMN modification_timestamp TIME_STAMP DEFAULT CURRENT_TIMESTAMP;\\012ALTER TABLE controlled_vocabularies\\012\\011ADD COLUMN modification_timestamp TIME_STAMP DEFAULT CURRENT_TIMESTAMP;\\012-- -------\\012-- add properties to data sets\\012-- -------\\012CREATE TABLE DATA_SET_PROPERTIES (ID TECH_ID NOT NULL,DS_ID TECH_ID NOT NULL,DSTPT_ID TECH_ID NOT NULL,VALUE GENERIC_VALUE,CVTE_ID TECH_ID, MATE_PROP_ID TECH_ID, PERS_ID_REGISTERER TECH_ID NOT NULL,REGISTRATION_TIMESTAMP TIME_STAMP_DFL NOT NULL DEFAULT CURRENT_TIMESTAMP, MODIFICATION_TIMESTAMP TIME_STAMP DEFAULT CURRENT_TIMESTAMP);\\012CREATE TABLE DATA_SET_TYPE_PROPERTY_TYPES (ID TECH_ID NOT NULL,DSTY_ID TECH_ID NOT NULL,PRTY_ID TECH_ID NOT NULL,IS_MANDATORY BOOLEAN_CHAR NOT NULL DEFAULT 'F',IS_MANAGED_INTERNALLY BOOLEAN_CHAR NOT NULL DEFAULT 'F',PERS_ID_REGISTERER TECH_ID NOT NULL,REGISTRATION_TIMESTAMP TIME_STAMP_DFL NOT NULL DEFAULT CURRENT_TIMESTAMP);\\012\\012CREATE SEQUENCE DATA_SET_PROPERTY_ID_SEQ;\\012CREATE SEQUENCE DSTPT_ID_SEQ;\\012\\012ALTER TABLE DATA_SET_TYPE_PROPERTY_TYPES ADD CONSTRAINT DSTPT_PK PRIMARY KEY(ID);\\012ALTER TABLE DATA_SET_PROPERTIES ADD CONSTRAINT DSPR_PK PRIMARY KEY(ID);\\012\\012ALTER TABLE DATA_SET_TYPE_PROPERTY_TYPES ADD CONSTRAINT DSTPT_BK_UK UNIQUE(DSTY_ID,PRTY_ID);\\012ALTER TABLE DATA_SET_PROPERTIES ADD CONSTRAINT DSPR_BK_UK UNIQUE(DS_ID,DSTPT_ID);\\012\\012\\012ALTER TABLE DATA_SET_TYPE_PROPERTY_TYPES ADD CONSTRAINT DSTPT_DSTY_FK FOREIGN KEY (DSTY_ID) REFERENCES DATA_SET_TYPES(ID);\\012ALTER TABLE DATA_SET_TYPE_PROPERTY_TYPES ADD CONSTRAINT DSTPT_PERS_FK FOREIGN KEY (PERS_ID_REGISTERER) REFERENCES PERSONS(ID);\\012ALTER TABLE DATA_SET_TYPE_PROPERTY_TYPES ADD CONSTRAINT DSTPT_PRTY_FK FOREIGN KEY (PRTY_ID) REFERENCES PROPERTY_TYPES(ID);\\012ALTER TABLE DATA_SET_PROPERTIES ADD CONSTRAINT DSPR_CVTE_FK FOREIGN KEY (CVTE_ID) REFERENCES CONTROLLED_VOCABULARY_TERMS(ID);\\012ALTER TABLE DATA_SET_PROPERTIES ADD CONSTRAINT DSPR_DSTPT_FK FOREIGN KEY (DSTPT_ID) REFERENCES DATA_SET_TYPE_PROPERTY_TYPES(ID) ON DELETE CASCADE;\\012ALTER TABLE DATA_SET_PROPERTIES ADD CONSTRAINT DSPR_DS_FK FOREIGN KEY (DS_ID) REFERENCES DATA(ID);\\012ALTER TABLE DATA_SET_PROPERTIES ADD CONSTRAINT DSPR_PERS_FK FOREIGN KEY (PERS_ID_REGISTERER) REFERENCES PERSONS(ID);\\012ALTER TABLE DATA_SET_PROPERTIES ADD CONSTRAINT DSPR_MAPR_FK FOREIGN KEY (MATE_PROP_ID) REFERENCES MATERIALS(ID);\\012\\012ALTER TABLE DATA_SET_PROPERTIES ADD CONSTRAINT DSPR_CK CHECK \\012\\011((VALUE IS NOT NULL AND CVTE_ID IS NULL AND MATE_PROP_ID IS NULL) OR \\012\\011 (VALUE IS NULL AND CVTE_ID IS NOT NULL AND MATE_PROP_ID IS NULL) OR\\012\\011 (VALUE IS NULL AND CVTE_ID IS NULL AND MATE_PROP_ID IS NOT NULL)\\012\\011);\\012\\012CREATE INDEX DSPR_CVTE_FK_I ON DATA_SET_PROPERTIES (CVTE_ID);\\012CREATE INDEX DSPR_DSTPT_FK_I ON DATA_SET_PROPERTIES (DSTPT_ID);\\012CREATE INDEX DSPR_DS_FK_I ON DATA_SET_PROPERTIES (DS_ID);\\012CREATE INDEX DSPR_PERS_FK_I ON DATA_SET_PROPERTIES (PERS_ID_REGISTERER);\\012CREATE INDEX DSTPT_DSTY_FK_I ON DATA_SET_TYPE_PROPERTY_TYPES (DSTY_ID);\\012CREATE INDEX DSTPT_PERS_FK_I ON DATA_SET_TYPE_PROPERTY_TYPES (PERS_ID_REGISTERER);\\012CREATE INDEX DSTPT_PRTY_FK_I ON DATA_SET_TYPE_PROPERTY_TYPES (PRTY_ID);\\012\\012CREATE OR REPLACE FUNCTION DATA_SET_PROPERTY_WITH_MATERIAL_DATA_TYPE_CHECK() RETURNS trigger AS $$\\012DECLARE\\012   v_type_id  CODE;\\012   v_type_id_prop  CODE;\\012BEGIN\\012   if NEW.mate_prop_id IS NOT NULL then\\012\\011\\011\\011-- find material type id of the property type \\012\\011\\011\\011select pt.maty_prop_id into v_type_id_prop \\012\\011\\011\\011  from data_set_type_property_types dstpt, property_types pt \\012\\011\\011\\011 where NEW.dstpt_id = dstpt.id AND dstpt.prty_id = pt.id;\\012\\011\\011\\012\\011\\011\\011if v_type_id_prop IS NOT NULL then\\012\\011\\011\\011\\011-- find material type id of the material which consists the entity's property value\\012\\011\\011\\011\\011select entity.maty_id into v_type_id \\012\\011\\011\\011\\011  from materials entity\\012\\011\\011\\011\\011 where NEW.mate_prop_id = entity.id;\\012\\011\\011\\011\\011if v_type_id != v_type_id_prop then\\012\\011\\011\\011\\011\\011RAISE EXCEPTION 'Insert/Update of property value referencing material (id: %) failed, as referenced material type is different than expected (id %, expected id: %).', \\012\\011\\011\\011\\011\\011\\011\\011\\011\\011\\011\\011\\011 NEW.mate_prop_id, v_type_id, v_type_id_prop;\\012\\011\\011\\011\\011end if;\\012\\011\\011\\011end if;\\012   end if;\\012   RETURN NEW;\\012END;\\012$$ LANGUAGE 'plpgsql';\\012\\012CREATE TRIGGER DATA_SET_PROPERTY_WITH_MATERIAL_DATA_TYPE_CHECK BEFORE INSERT OR UPDATE ON data_set_properties\\012    FOR EACH ROW EXECUTE PROCEDURE DATA_SET_PROPERTY_WITH_MATERIAL_DATA_TYPE_CHECK();   \\012	\N
+./sourceTest/sql/postgresql/054/017=database_version_logs.tsv:032	source/sql/postgresql/migration/migration-031-032.sql	SUCCESS	2009-04-09 09:36:36.2	-- -------\\012-- Modify MATERIAL_BATCHES\\012-- -------\\012\\012ALTER TABLE material_batches\\012    DROP COLUMN proc_id;\\012\\012-- -------\\012-- Modify SAMPLES\\012-- -------\\012\\012ALTER TABLE samples\\012    ADD COLUMN expe_id tech_id;\\012\\012ALTER TABLE samples\\012    ADD CONSTRAINT samp_expe_fk FOREIGN KEY (expe_id) REFERENCES experiments(id);\\012\\012CREATE INDEX samp_expe_fk_i ON samples USING btree (expe_id);\\012\\012-- relink samples directly to experiments\\012\\012UPDATE samples\\012SET expe_id = (SELECT e.id FROM experiments e, procedures p, sample_inputs si \\012               WHERE si.samp_id = samples.id AND si.proc_id = p.id AND p.expe_id = e.id AND e.inva_id IS NULL);\\012\\012\\012-- -------\\012-- Modify DATA\\012-- -------\\012\\012ALTER TABLE data\\012    ADD COLUMN expe_id tech_id;\\012\\012ALTER TABLE data\\012    ADD CONSTRAINT data_expe_fk FOREIGN KEY (expe_id) REFERENCES experiments(id);\\012\\012CREATE INDEX data_expe_fk_i ON data USING btree (expe_id);\\012\\012UPDATE data\\012SET expe_id = (SELECT e.id FROM experiments e, procedures p \\012               WHERE data.proc_id_produced_by = p.id AND p.expe_id = e.id);\\012\\012ALTER TABLE data\\012    ALTER COLUMN expe_id SET NOT NULL;\\012\\012ALTER TABLE data\\012    DROP COLUMN proc_id_produced_by;\\012\\012-- -------\\012-- Drop PROCEDURES, PROCEDURE_TYPES, and SAMPLE_INPUTS\\012-- -------\\012\\012DROP TABLE sample_inputs;\\012DROP TABLE procedures;\\012DROP TABLE procedure_types;\\012\\012DROP SEQUENCE procedure_id_seq;\\012DROP SEQUENCE procedure_type_id_seq;\\012\\012-- -------\\012-- Add CODE_SEQ\\012-- -------\\012\\012CREATE SEQUENCE CODE_SEQ;\\012\\012-- -------\\012-- Add new columns to DATA_STORES\\012-- -------\\012\\012ALTER TABLE data_stores\\012    ADD COLUMN remote_url character varying(250),\\012    ADD COLUMN session_token character varying(50),\\012    ADD COLUMN modification_timestamp time_stamp DEFAULT now();\\012\\012UPDATE data_stores\\012SET remote_url = '', session_token='';\\012\\012ALTER TABLE data_stores\\012    ALTER COLUMN remote_url SET NOT NULL,\\012    ALTER COLUMN session_token SET NOT NULL;\\012\\012-- -------\\012-- Drop foreign keys onto DATA_STORES\\012-- -------\\012\\012ALTER TABLE database_instances\\012    DROP COLUMN dast_id;\\012\\012ALTER TABLE groups\\012    DROP COLUMN dast_id;\\012\\012ALTER TABLE projects\\012    DROP COLUMN dast_id;\\012\\012ALTER TABLE experiments\\012    DROP COLUMN dast_id;\\012\\012-- -------\\012-- Add foreign key from DATA onto DATA_STORES\\012-- -------\\012\\012ALTER TABLE data\\012    ADD COLUMN dast_id tech_id;\\012\\012ALTER TABLE data\\012    ADD CONSTRAINT data_dast_fk FOREIGN KEY (dast_id) REFERENCES data_stores(id);\\012\\012UPDATE data\\012SET dast_id = (select id from data_stores where code = 'STANDARD');\\012\\012ALTER TABLE data\\012    ALTER COLUMN dast_id SET NOT NULL;\\012\\012\\012------------------------------------------------------------------------------------\\012--  Purpose:  Replace trigger SAMPLE_CODE_UNIQUENESS_CHECK \\012------------------------------------------------------------------------------------\\012\\012CREATE OR REPLACE FUNCTION SAMPLE_CODE_UNIQUENESS_CHECK() RETURNS trigger AS $$\\012DECLARE\\012   counter  INTEGER;\\012BEGIN\\012    LOCK TABLE samples IN EXCLUSIVE MODE;\\012    IF (NEW.samp_id_part_of is NULL) THEN\\012        IF (NEW.dbin_id is not NULL) THEN\\012            SELECT count(*) into counter FROM samples \\012                where id != NEW.id and code = NEW.code and samp_id_part_of is NULL and dbin_id = NEW.dbin_id;\\012            IF (counter > 0) THEN\\012                RAISE EXCEPTION 'Insert/Update of Sample (Code: %) failed because database instance sample with the same code already exists.', NEW.code;\\012            END IF;\\012        ELSIF (NEW.grou_id is not NULL) THEN\\012            SELECT count(*) into counter FROM samples \\012                where id != NEW.id and code = NEW.code and samp_id_part_of is NULL and grou_id = NEW.grou_id;\\012            IF (counter > 0) THEN\\012                RAISE EXCEPTION 'Insert/Update of Sample (Code: %) failed because group sample with the same code already exists.', NEW.code;\\012            END IF;\\012        END IF;\\012        ELSE\\012        IF (NEW.dbin_id is not NULL) THEN\\012            SELECT count(*) into counter FROM samples \\012                where id != NEW.id and code = NEW.code and samp_id_part_of = NEW.samp_id_part_of and dbin_id = NEW.dbin_id;\\012            IF (counter > 0) THEN\\012                RAISE EXCEPTION 'Insert/Update of Sample (Code: %) failed because database instance sample with the same code and being the part of the same parent already exists.', NEW.code;\\012            END IF;\\012        ELSIF (NEW.grou_id is not NULL) THEN\\012            SELECT count(*) into counter FROM samples \\012                where id != NEW.id and code = NEW.code and samp_id_part_of = NEW.samp_id_part_of and grou_id = NEW.grou_id;\\012            IF (counter > 0) THEN\\012                RAISE EXCEPTION 'Insert/Update of Sample (Code: %) failed because group sample with the same code and being the part of the same parent already exists.', NEW.code;\\012            END IF;\\012        END IF;\\012        END IF;   \\012   RETURN NEW;\\012END;\\012$$ LANGUAGE 'plpgsql';\\012\\012\\012\\012	\N
+./sourceTest/sql/postgresql/054/017=database_version_logs.tsv:034	source/sql/postgresql/migration/migration-033-034.sql	SUCCESS	2009-05-26 08:32:49.935	------------------------------------------------------------------------------------\\012-- Create sequence for generating permanent identifiers starting with nextval of existing dataset sequence.\\012------------------------------------------------------------------------------------\\012CREATE FUNCTION CREATE_SEQUENCE(EXISTING_SEQUENCE VARCHAR, NEW_SEQUENCE VARCHAR) RETURNS VOID AS $$\\012DECLARE\\012  CURR_SEQ_VAL   INTEGER;\\012BEGIN\\012  SELECT INTO CURR_SEQ_VAL NEXTVAL(EXISTING_SEQUENCE);\\012  EXECUTE 'CREATE SEQUENCE ' || NEW_SEQUENCE || ' START WITH ' || CURR_SEQ_VAL;\\012  RETURN;\\012END;\\012$$ LANGUAGE 'plpgsql';\\012\\012SELECT CREATE_SEQUENCE('DATA_ID_SEQ', 'PERM_ID_SEQ');\\012DROP FUNCTION CREATE_SEQUENCE(VARCHAR, VARCHAR);\\012\\012------------------------------------------------------------------------------------\\012-- Add perm_id columns to samples and experiments.\\012------------------------------------------------------------------------------------\\012ALTER TABLE SAMPLES ADD COLUMN PERM_ID CODE;\\012ALTER TABLE EXPERIMENTS ADD COLUMN PERM_ID CODE;\\012\\012UPDATE SAMPLES SET PERM_ID = to_char(registration_timestamp,'YYYYMMDDHHSSMS') || '-' || NEXTVAL('PERM_ID_SEQ');\\012UPDATE EXPERIMENTS SET PERM_ID = to_char(registration_timestamp,'YYYYMMDDHHSSMS') || '-' || NEXTVAL('PERM_ID_SEQ');\\012ALTER TABLE SAMPLES ALTER COLUMN PERM_ID SET NOT NULL;\\012ALTER TABLE EXPERIMENTS ALTER COLUMN PERM_ID SET NOT NULL;\\012ALTER TABLE SAMPLES ADD CONSTRAINT SAMP_PI_UK UNIQUE(PERM_ID);\\012ALTER TABLE EXPERIMENTS ADD CONSTRAINT EXPE_PI_UK UNIQUE(PERM_ID);\\012\\012\\012------------------------------------------------------------------------------------\\012-- Add column is_chosen_from_list to controlled_vocabularies.\\012------------------------------------------------------------------------------------\\012ALTER TABLE controlled_vocabularies ADD COLUMN is_chosen_from_list BOOLEAN_CHAR NOT NULL DEFAULT TRUE;\\012ALTER TABLE controlled_vocabularies ADD COLUMN source_uri CHARACTER VARYING(250);\\012------------------------------------------------------------------------------------\\012-- Modify Data table - remove arc connection between Sample and Data table, use a flag instead\\012------------------------------------------------------------------------------------\\012\\012-- add new columns\\012\\012ALTER TABLE data\\012    ADD COLUMN is_derived boolean_char;\\012ALTER TABLE data\\012    ADD COLUMN samp_id tech_id;\\012\\012-- update values in new columns\\012\\012UPDATE data\\012    SET is_derived = (samp_id_derived_from IS NOT NULL); \\012UPDATE data\\012    SET samp_id = samp_id_derived_from \\012    WHERE is_derived = 'TRUE';\\012UPDATE data\\012    SET samp_id = samp_id_acquired_from \\012    WHERE is_derived = 'FALSE';\\012\\012-- add constraints and indexes to new columns\\012\\012ALTER TABLE data\\012    ALTER COLUMN is_derived SET NOT NULL;\\012ALTER TABLE data\\012    ALTER COLUMN samp_id SET NOT NULL;   \\012ALTER TABLE data\\012    ADD CONSTRAINT data_samp_fk FOREIGN KEY (samp_id) REFERENCES samples (id);\\012CREATE INDEX data_samp_fk_i ON data USING btree (samp_id);\\012\\012-- remove old columns\\012\\012ALTER TABLE data\\012    DROP COLUMN samp_id_acquired_from;\\012ALTER TABLE data\\012    DROP COLUMN samp_id_derived_from;\\012    \\012------------------------------------------------------------------------------------\\012-- Granting SELECT privilege to group openbis_readonly\\012------------------------------------------------------------------------------------\\012\\012GRANT SELECT ON SEQUENCE attachment_content_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE attachment_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE code_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE controlled_vocabulary_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE cvte_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE data_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE data_set_property_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE data_set_relationship_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE data_set_type_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE data_store_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE data_type_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE database_instance_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE dstpt_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE etpt_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE event_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE experiment_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE experiment_property_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE experiment_type_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE file_format_type_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE group_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE invalidation_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE locator_type_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE material_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE material_property_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE material_type_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE mtpt_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE perm_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE person_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE project_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE property_type_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE role_assignment_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE sample_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE sample_property_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE sample_type_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE stpt_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE attachment_contents TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE attachments TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE controlled_vocabularies TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE controlled_vocabulary_terms TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE data TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE data_set_properties TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE data_set_relationships TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE data_set_type_property_types TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE data_set_types TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE data_stores TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE data_types TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE database_instances TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE database_version_logs TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE events TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE experiment_properties TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE experiment_type_property_types TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE experiment_types TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE experiments TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE external_data TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE file_format_types TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE groups TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE invalidations TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE locator_types TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE material_properties TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE material_type_property_types TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE material_types TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE materials TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE persons TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE projects TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE property_types TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE role_assignments TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE sample_properties TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE sample_type_property_types TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE sample_types TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE samples TO GROUP OPENBIS_READONLY;\\012\\012------------------------------------------------------------------------------------\\012-- Delete MATERIAL_BATCHES table\\012------------------------------------------------------------------------------------\\012\\012-- WARNING: Potential data lost!!!\\012-- WARNING: Potential data lost!!!\\012-- WARNING: Potential data lost!!!\\012\\012DROP TABLE SAMPLE_MATERIAL_BATCHES;\\012DROP TABLE MATERIAL_BATCHES;\\012DROP SEQUENCE MATERIAL_BATCH_ID_SEQ;\\012\\012------------------------------------------------------------------------------------\\012-- Delete MATE_ID_INHIBITOR_OF from table MATERIALS\\012------------------------------------------------------------------------------------\\012\\012-- WARNING: Potential data lost!!!\\012-- WARNING: Potential data lost!!!\\012-- WARNING: Potential data lost!!!\\012\\012ALTER TABLE MATERIALS DROP COLUMN MATE_ID_INHIBITOR_OF;\\012	\N
+./sourceTest/sql/postgresql/054/017=database_version_logs.tsv:041	source/sql/postgresql/migration/migration-040-041.sql	SUCCESS	2009-09-14 13:48:57.539	-- Create FILTERS table\\012\\012CREATE TABLE FILTERS (ID TECH_ID NOT NULL, DBIN_ID TECH_ID NOT NULL, NAME VARCHAR(200) NOT NULL, DESCRIPTION DESCRIPTION_1000,REGISTRATION_TIMESTAMP TIME_STAMP_DFL NOT NULL DEFAULT CURRENT_TIMESTAMP, PERS_ID_REGISTERER TECH_ID NOT NULL, MODIFICATION_TIMESTAMP TIME_STAMP DEFAULT CURRENT_TIMESTAMP, EXPRESSION VARCHAR(2000) NOT NULL, IS_PUBLIC BOOLEAN NOT NULL, GRID_ID VARCHAR(200) NOT NULL);\\012CREATE SEQUENCE FILTER_ID_SEQ;\\012ALTER TABLE FILTERS ADD CONSTRAINT FILT_PK PRIMARY KEY(ID);\\012ALTER TABLE FILTERS ADD CONSTRAINT FILT_BK_UK UNIQUE(NAME, DBIN_ID, GRID_ID);\\012ALTER TABLE FILTERS ADD CONSTRAINT FILT_PERS_FK FOREIGN KEY (PERS_ID_REGISTERER) REFERENCES PERSONS(ID);\\012ALTER TABLE FILTERS ADD CONSTRAINT FILT_DBIN_FK FOREIGN KEY (DBIN_ID) REFERENCES DATABASE_INSTANCES(ID);\\012CREATE INDEX FILT_PERS_FK_I ON FILTERS (PERS_ID_REGISTERER);\\012CREATE INDEX FILT_DBIN_FK_I ON FILTERS (DBIN_ID);\\012GRANT SELECT ON SEQUENCE filter_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE filters TO GROUP OPENBIS_READONLY;\\012\\012-- Add missing foreign key to role assignments authorization group\\012ALTER TABLE ROLE_ASSIGNMENTS ADD CONSTRAINT ROAS_AG_FK_GRANTEE FOREIGN KEY (AG_ID_GRANTEE) REFERENCES AUTHORIZATION_GROUPS(ID);\\012\\012--------------------------------------------------------------------------------------------------\\012-- Modify dataset connections:\\012-- 1. connection with sample shouldn't be mandatory any more\\012-- 2. introduce an arc condition that dataset cannot be connected with a sample and a parent dataset at the same time\\012--------------------------------------------------------------------------------------------------\\012\\012-- Weaken data-sample connection constraint - allow dataset to have no connection with sample\\012ALTER TABLE data ALTER COLUMN samp_id DROP NOT NULL;\\012\\012-- Remove data-sample connection for datasets that have a parent\\012\\012UPDATE data \\012   SET samp_id = NULL \\012 WHERE id IN (SELECT DISTINCT data_id_child FROM data_set_relationships);\\012\\012-- With PostgreSQL 8.4 one can check that before migration there were no cycles in dataset relationships:\\012--\\012-- WITH RECURSIVE data_set_parents(id, parent_ids, cycle) AS (\\012--         SELECT  r.data_id_child AS id, \\012--                 ARRAY[CAST (r.data_id_parent AS bigint)] AS parent_ids, \\012--                 false AS cycle \\012--         FROM data_set_relationships r\\012--     UNION ALL\\012--         SELECT  r.data_id_child,\\012--                 CAST (r.data_id_parent AS bigint) || p.parent_ids,\\012--                 r.data_id_child = ANY(p.parent_ids)\\012--         FROM data_set_relationships r, data_set_parents p\\012--         WHERE r.data_id_parent = p.id AND NOT cycle\\012-- )\\012-- SELECT count(*) AS cycles FROM data_set_parents WHERE cycle = true;\\012\\012---------------------------------------------------------------------------------------------------\\012--  Purpose:  Create DEFERRED triggers:\\012--            * check_dataset_relationships_on_data_table_modification,\\012--            * check_dataset_relationships_on_relationships_table_modification.\\012--            They check that after all modifications of database (just before commit) \\012--            if 'data'/'data_set_relationships' tables are among modified tables \\012--            dataset is not connected with a sample and a parent dataset at the same time.\\012--            This connections are held in two different tables so simple immediate trigger \\012--            with arc check cannot be used and we need two deferred triggers.\\012----------------------------------------------------------------------------------------------------\\012\\012-- trigger for 'data' table\\012\\012CREATE OR REPLACE FUNCTION check_dataset_relationships_on_data_table_modification() RETURNS trigger AS $$\\012DECLARE\\012\\011counter\\011INTEGER;\\012BEGIN\\012\\011-- if there is a connection with a Sample there should not be any connection with a parent Data Set\\012\\011IF (NEW.samp_id IS NOT NULL) THEN\\012\\011\\011-- count number of parents\\012\\011\\011SELECT count(*) INTO counter \\012\\011\\011\\011FROM data_set_relationships \\012\\011\\011\\011WHERE data_id_child = OLD.id;\\012\\011\\011IF (counter > 0) THEN\\012\\011\\011\\011RAISE EXCEPTION 'Insert/Update of Data Set (Code: %) failed because it cannot be connected with a Sample and a parent Data Set at the same time.', OLD.code;\\012\\011\\011END IF;\\012\\011END IF;\\012  RETURN NEW;\\012END;\\012$$ LANGUAGE 'plpgsql';\\012\\012CREATE CONSTRAINT TRIGGER check_dataset_relationships_on_data_table_modification \\012  AFTER INSERT OR UPDATE ON data\\012\\011DEFERRABLE INITIALLY DEFERRED\\012\\011FOR EACH ROW \\012\\011EXECUTE PROCEDURE check_dataset_relationships_on_data_table_modification();\\012\\012-- trigger for 'data_set_relationships'\\012\\012CREATE OR REPLACE FUNCTION check_dataset_relationships_on_relationships_table_modification() RETURNS trigger AS $$\\012DECLARE\\012\\011counter\\011INTEGER;\\012\\011sample_id\\011TECH_ID;\\012\\011data_code\\011CODE;\\012BEGIN\\012\\011-- child will have a parent added so it should not be connected with any sample\\012\\011SELECT samp_id, code INTO sample_id, data_code \\012\\011\\011FROM data \\012\\011\\011WHERE id = NEW.data_id_child;\\012\\011IF (sample_id IS NOT NULL) THEN\\012\\011\\011RAISE EXCEPTION 'Insert/Update of Data Set (Code: %) failed because it cannot be connected to a Sample and to a parent Data Set at the same time.', data_code;\\012\\011END IF;\\012\\011RETURN NEW;\\012END;\\012$$ LANGUAGE 'plpgsql';\\012  \\012CREATE CONSTRAINT TRIGGER check_dataset_relationships_on_relationships_table_modification \\012  AFTER INSERT OR UPDATE ON data_set_relationships\\012\\011DEFERRABLE INITIALLY DEFERRED\\012\\011FOR EACH ROW \\012\\011EXECUTE PROCEDURE check_dataset_relationships_on_relationships_table_modification();\\012	\N
+./sourceTest/sql/postgresql/054/017=database_version_logs.tsv:053	source/sql/postgresql/migration/migration-052-053.sql	SUCCESS	2010-06-08 15:27:55.032	-- Migration from 052 to 053\\012\\012-- Change code uniqueness check for samples of specific type.\\012-- If sample_types.is_subcode_unique flag is set to 'true', additional check is performed \\012-- on codes of samples of the type. Subcodes will have to be unique as well.\\012\\012ALTER TABLE sample_types ADD COLUMN is_subcode_unique boolean_char NOT NULL DEFAULT false;\\012\\012CREATE OR REPLACE FUNCTION SAMPLE_SUBCODE_UNIQUENESS_CHECK() RETURNS trigger AS $$\\012DECLARE\\012   counter  INTEGER;\\012   unique_subcode  BOOLEAN_CHAR;\\012BEGIN\\012  LOCK TABLE samples IN EXCLUSIVE MODE;\\012  \\012  SELECT is_subcode_unique into unique_subcode FROM sample_types WHERE id = NEW.saty_id;\\012  \\012  IF (unique_subcode) THEN\\012    IF (NEW.dbin_id is not NULL) THEN\\012\\011\\011\\011SELECT count(*) into counter FROM samples \\012\\011\\011\\011\\011where id != NEW.id and code = NEW.code and saty_id = NEW.saty_id and dbin_id = NEW.dbin_id;\\012\\011\\011\\011IF (counter > 0) THEN\\012\\011\\011\\011\\011RAISE EXCEPTION 'Insert/Update of Sample (Code: %) failed because database instance sample of the same type with the same subcode already exists.', NEW.code;\\012\\011\\011\\011END IF;\\012\\011\\011ELSIF (NEW.grou_id is not NULL) THEN\\012\\011\\011\\011SELECT count(*) into counter FROM samples \\012\\011\\011\\011\\011where id != NEW.id and code = NEW.code and saty_id = NEW.saty_id and grou_id = NEW.grou_id;\\012\\011\\011\\011IF (counter > 0) THEN\\012\\011\\011\\011\\011RAISE EXCEPTION 'Insert/Update of Sample (Code: %) failed because space sample of the same type with the same subcode already exists.', NEW.code;\\012\\011\\011\\011END IF;\\012\\011\\011END IF;\\012  END IF;\\012  \\012  RETURN NEW;\\012END;\\012$$ LANGUAGE 'plpgsql';\\012\\012CREATE TRIGGER SAMPLE_SUBCODE_UNIQUENESS_CHECK BEFORE INSERT OR UPDATE ON SAMPLES\\012    FOR EACH ROW EXECUTE PROCEDURE SAMPLE_SUBCODE_UNIQUENESS_CHECK();\\012    \\012-- Fixing error messages in old trigger\\012\\012CREATE OR REPLACE FUNCTION SAMPLE_CODE_UNIQUENESS_CHECK() RETURNS trigger AS $$\\012DECLARE\\012   counter  INTEGER;\\012BEGIN\\012  LOCK TABLE samples IN EXCLUSIVE MODE;\\012  \\012\\011  IF (NEW.samp_id_part_of is NULL) THEN\\012\\011\\011  IF (NEW.dbin_id is not NULL) THEN\\012\\011\\011\\011  SELECT count(*) into counter FROM samples \\012\\011\\011      where id != NEW.id and code = NEW.code and samp_id_part_of is NULL and dbin_id = NEW.dbin_id;\\012        IF (counter > 0) THEN\\012\\011\\011\\011\\011  RAISE EXCEPTION 'Insert/Update of Sample (Code: %) failed because database instance sample with the same code already exists.', NEW.code;\\012        END IF;\\012\\011\\011  ELSIF (NEW.grou_id is not NULL) THEN\\012\\011\\011\\011  SELECT count(*) into counter FROM samples \\012\\011\\011\\011\\011  where id != NEW.id and code = NEW.code and samp_id_part_of is NULL and grou_id = NEW.grou_id;\\012\\011\\011\\011  IF (counter > 0) THEN\\012\\011\\011\\011\\011  RAISE EXCEPTION 'Insert/Update of Sample (Code: %) failed because space sample with the same code already exists.', NEW.code;\\012\\011\\011\\011  END IF;\\012      END IF;\\012    ELSE\\012\\011\\011  IF (NEW.dbin_id is not NULL) THEN\\012\\011\\011\\011  SELECT count(*) into counter FROM samples \\012\\011\\011\\011\\011  where id != NEW.id and code = NEW.code and samp_id_part_of = NEW.samp_id_part_of and dbin_id = NEW.dbin_id;\\012\\011\\011\\011  IF (counter > 0) THEN\\012\\011\\011\\011\\011  RAISE EXCEPTION 'Insert/Update of Sample (Code: %) failed because database instance sample with the same code and being the part of the same container already exists.', NEW.code;\\012\\011\\011\\011  END IF;\\012\\011\\011  ELSIF (NEW.grou_id is not NULL) THEN\\012\\011\\011\\011  SELECT count(*) into counter FROM samples \\012\\011\\011\\011\\011  where id != NEW.id and code = NEW.code and samp_id_part_of = NEW.samp_id_part_of and grou_id = NEW.grou_id;\\012\\011\\011\\011  IF (counter > 0) THEN\\012\\011\\011\\011\\011  RAISE EXCEPTION 'Insert/Update of Sample (Code: %) failed because space sample with the same code and being the part of the same container already exists.', NEW.code;\\012\\011\\011\\011  END IF;\\012\\011\\011  END IF;\\012     END IF;   \\012  \\012  RETURN NEW;\\012END;\\012$$ LANGUAGE 'plpgsql';\\012	\N
+./sourceTest/sql/postgresql/054/017=database_version_logs.tsv:054	source/sql/postgresql/migration/migration-053-054.sql	SUCCESS	2010-07-27 11:30:46.766	-- Migration from 053 to 054\\012\\012\\012-- Add RELATIONSHIP_TYPES table\\012CREATE TABLE relationship_types (id TECH_ID NOT NULL, code CODE NOT NULL, label COLUMN_LABEL, parent_label COLUMN_LABEL, child_label COLUMN_LABEL, description DESCRIPTION_2000, registration_timestamp TIME_STAMP_DFL NOT NULL DEFAULT CURRENT_TIMESTAMP, pers_id_registerer TECH_ID NOT NULL, is_managed_internally BOOLEAN_CHAR NOT NULL DEFAULT 'F', is_internal_namespace BOOLEAN_CHAR NOT NULL DEFAULT 'F', dbin_id TECH_ID NOT NULL);\\012\\012-- Add SAMPLE_RELATIONSHIPS table\\012CREATE TABLE sample_relationships (id TECH_ID NOT NULL, sample_id_parent TECH_ID NOT NULL, relationship_id TECH_ID NOT NULL, sample_id_child TECH_ID NOT NULL);\\012\\012-- Add/update constraints\\012ALTER TABLE relationship_types ADD CONSTRAINT rety_pk PRIMARY KEY (id);\\012ALTER TABLE relationship_types ADD CONSTRAINT rety_uk UNIQUE(code,dbin_id);\\012ALTER TABLE sample_relationships ADD CONSTRAINT sare_pk PRIMARY KEY (id);\\012ALTER TABLE sample_relationships ADD CONSTRAINT sare_bk_uk UNIQUE(sample_id_child,sample_id_parent,relationship_id);\\012ALTER TABLE sample_relationships ADD CONSTRAINT sare_data_fk_child FOREIGN KEY (sample_id_child) REFERENCES samples(id) ON DELETE CASCADE;\\012ALTER TABLE sample_relationships ADD CONSTRAINT sare_data_fk_parent FOREIGN KEY (sample_id_parent) REFERENCES samples(id) ON DELETE CASCADE;\\012ALTER TABLE sample_relationships ADD CONSTRAINT sare_data_fk_relationship FOREIGN KEY (relationship_id) REFERENCES relationship_types(id);\\012\\012-- Create index\\012CREATE INDEX sare_data_fk_i_child ON sample_relationships (sample_id_child);\\012CREATE INDEX sare_data_fk_i_parent ON sample_relationships (sample_id_parent);\\012CREATE INDEX sare_data_fk_i_relationship ON sample_relationships (relationship_id);\\012\\012-- Create sequence for RELATIONSHIP_TYPES\\012CREATE SEQUENCE RELATIONSHIP_TYPE_ID_SEQ;\\012CREATE SEQUENCE SAMPLE_RELATIONSHIP_ID_SEQ;\\012\\012-- Create initial relationships\\012insert into relationship_types\\012(id, \\012code, \\012label, \\012parent_label, \\012child_label, \\012description, \\012pers_id_registerer, \\012is_managed_internally, \\012is_internal_namespace, \\012dbin_id) \\012values\\012(\\012nextval('RELATIONSHIP_TYPE_ID_SEQ'),\\012'PARENT_CHILD',\\012'Parent - Child', \\012'Parent', \\012'Child', \\012'Parent - Child relationship', \\012(select id from persons where user_id ='system'), \\012'T', \\012'T', \\012(select id from database_instances where is_original_source = 'T')\\012);\\012\\012insert into relationship_types\\012(id, \\012code, \\012label, \\012parent_label, \\012child_label, \\012description, \\012pers_id_registerer, \\012is_managed_internally, \\012is_internal_namespace, \\012dbin_id) \\012values\\012(\\012nextval('RELATIONSHIP_TYPE_ID_SEQ'),\\012'PLATE_CONTROL_LAYOUT',\\012'Plate - Control Layout', \\012'Plate', \\012'Control Layout', \\012'Plate - Control Layout relationship', \\012(select id from persons where user_id ='system'), \\012'T', \\012'T', \\012(select id from database_instances where is_original_source = 'T')\\012); \\012\\012\\012-- Migrate sample relationships to new schema\\012INSERT INTO sample_relationships (id, sample_id_parent,sample_id_child,relationship_id) (select distinct nextval('SAMPLE_RELATIONSHIP_ID_SEQ') as id, s.SAMP_ID_GENERATED_FROM as parent_id, s.ID as child_id, rt.id as relationship_id from samples s, relationship_types rt  WHERE rt.code = 'PARENT_CHILD' and s.SAMP_ID_GENERATED_FROM is not null); \\012INSERT INTO sample_relationships (id, sample_id_parent,sample_id_child,relationship_id) (select distinct nextval('SAMPLE_RELATIONSHIP_ID_SEQ') as id, s.SAMP_ID_CONTROL_LAYOUT as parent_id, s.ID as child_id, rt.id as relationship_id from samples s, relationship_types rt  WHERE rt.code = 'PLATE_CONTROL_LAYOUT' and s.SAMP_ID_CONTROL_LAYOUT is not null);\\012\\012-- Drop old sample relations\\012ALTER TABLE SAMPLES DROP COLUMN SAMP_ID_TOP;\\012ALTER TABLE SAMPLES DROP COLUMN SAMP_ID_GENERATED_FROM;\\012ALTER TABLE SAMPLES DROP COLUMN SAMP_ID_CONTROL_LAYOUT;\\012\\012--------------------------------------------------------------------------------------\\012--------------------------------------------------------------------------------------\\012-- This is a screening specific migration. Nothing will be performed on openBIS databases \\012-- which are not screening specific.\\012-- \\012-- This migration for each existing connection between oligo well, oligo material and gene material\\012-- creates a direct connection between the well and the gene. \\012--------------------------------------------------------------------------------------\\012--------------------------------------------------------------------------------------\\012 \\012\\011\\012CREATE OR REPLACE FUNCTION CONNECT_WELLS_WITH_GENES() RETURNS void AS $$\\012DECLARE\\012\\011counter  int;\\012\\011oligo_well_exists bool;\\012BEGIN\\012\\011--------------------------------------------------\\012\\011-- create a gene property and assign it to oligo well\\012\\011--------------------------------------------------\\012\\011\\012\\011select true \\012\\011into oligo_well_exists\\012\\011from sample_types \\012\\011where code = 'OLIGO_WELL';\\012\\011\\012\\011if oligo_well_exists IS NULL then \\012\\011\\011-- skip migration if there are no oligo wells\\012\\011\\011return;\\012\\011end if;   \\012\\011\\012\\011insert into property_types(\\012\\011\\011id, \\012\\011\\011code, description, label, \\012\\011\\011daty_id,\\012\\011\\011pers_id_registerer,\\012\\011\\011dbin_id,\\012\\011\\011maty_prop_id) \\012\\011values(\\012\\011\\011\\011nextval('PROPERTY_TYPE_ID_SEQ'), \\012\\011\\011\\011'GENE','Inhibited gene','Gene',\\012\\011\\011\\011(select id from data_types where code = 'MATERIAL'), \\012\\011\\011\\011(select id from persons where user_id ='system'), \\012\\011\\011\\011(select id from database_instances where is_original_source = 'T'), \\012\\011\\011\\011(select id from material_types where code = 'GENE')\\012\\011\\011);\\012\\011\\011\\012\\011insert into sample_type_property_types( \\012\\011  id,\\012\\011  saty_id,\\012\\011  prty_id,\\012\\011  is_mandatory,\\012\\011  pers_id_registerer,\\012\\011  ordinal\\012\\011) values(\\012\\011\\011\\011nextval('stpt_id_seq'), \\012\\011\\011\\011(select id from sample_types where code = 'OLIGO_WELL'),\\012\\011\\011\\011(select id from property_types where code = 'GENE'),\\012\\011\\011\\011false,\\012\\011\\011\\011(select id from persons where user_id ='system'),\\012\\011\\011\\011(select max(ordinal)+1 from sample_type_property_types \\012\\011\\011\\011\\011where saty_id = (select id from sample_types where code = 'OLIGO_WELL'))\\012\\011\\011);\\012\\012\\011--------------------------------------------------\\012\\011-- create a gene material property for each oligo well\\012\\011--------------------------------------------------\\012\\011\\011\\012\\011select \\011count(*)\\012\\011into counter\\012\\011from\\012\\011\\011samples well, sample_types well_type, sample_properties well_props, \\012\\011\\011materials well_material, material_properties well_material_props,\\012\\011\\011materials nested_well_material\\012\\011where\\012\\011\\011well_type.code = 'OLIGO_WELL' and\\012\\011\\011-- find 'well_material' assigned to the well\\012\\011\\011well_props.samp_id = well.id and well_material.id = well_props.mate_prop_id and \\012\\011\\011-- additional joins to entity type tables\\012\\011\\011well_type.id = well.saty_id and\\012\\011\\011-- well content material property\\012\\011\\011well_material_props.mate_id = well_material.id and \\012\\011\\011-- material connected to the material in the well (e.g. gene)\\012\\011\\011well_material_props.mate_prop_id = nested_well_material.id and\\012\\011\\011nested_well_material.maty_id = (select id from material_types where code = 'GENE');\\012\\011\\012\\011if counter = 0 then \\012\\011\\011-- skip migration if there are no genes indirectly connected to oligo wells\\012\\011\\011return;\\012\\011end if;   \\012\\012\\011insert into sample_properties(id, samp_id, stpt_id, mate_prop_id, pers_id_registerer) (\\012\\011\\011select \\011nextval('sample_property_id_seq') id, \\012\\011\\011\\011well.id samp_id, \\012\\011\\011\\011(select stpt.id from sample_type_property_types stpt, property_types props where stpt.prty_id = props.id and props.code='GENE') stpt_id,\\012\\011\\011\\011nested_well_material.id mate_prop_id,\\012\\011\\011\\011(select id from persons where user_id ='system') pers_id_registerer \\012\\011\\011from\\012\\011\\011\\011samples well, sample_types well_type, sample_properties well_props, \\012\\011\\011\\011materials well_material, material_properties well_material_props,\\012\\011\\011\\011materials nested_well_material\\012\\011\\011where\\012\\011\\011\\011well_type.code = 'OLIGO_WELL' and\\012\\011\\011\\011-- find 'well_material' assigned to the well\\012\\011\\011\\011well_props.samp_id = well.id and well_material.id = well_props.mate_prop_id and \\012\\011\\011\\011-- additional joins to entity type tables\\012\\011\\011\\011well_type.id = well.saty_id and\\012\\011\\011\\011-- well content material property\\012\\011\\011\\011well_material_props.mate_id = well_material.id and \\012\\011\\011\\011-- material connected to the material in the well (e.g. gene)\\012\\011\\011\\011well_material_props.mate_prop_id = nested_well_material.id and\\012\\011\\011\\011nested_well_material.maty_id = (select id from material_types where code = 'GENE')\\012\\011);\\012\\012END;\\012$$ LANGUAGE 'plpgsql';\\012\\012select CONNECT_WELLS_WITH_GENES();\\012drop function CONNECT_WELLS_WITH_GENES();\\012\\012--------------------------------------------------------------------------------------\\012--------------------------------------------------------------------------------------\\012\\012-- drop dataset triggers\\012\\012DROP TRIGGER check_dataset_relationships_on_data_table_modification ON data;\\012DROP FUNCTION check_dataset_relationships_on_data_table_modification();\\012DROP TRIGGER check_dataset_relationships_on_relationships_table_modification ON data_set_relationships;\\012DROP FUNCTION check_dataset_relationships_on_relationships_table_modification();\\012 \\012\\012\\012\\012\\012\\012\\012\\012	\N
+./sourceTest/sql/postgresql/054/schema-054.sql:    LANGUAGE plpgsql
+./sourceTest/sql/postgresql/054/schema-054.sql:    LANGUAGE plpgsql
+./sourceTest/sql/postgresql/054/schema-054.sql:    LANGUAGE plpgsql
+./sourceTest/sql/postgresql/054/schema-054.sql:    LANGUAGE plpgsql
+./sourceTest/sql/postgresql/054/schema-054.sql:    LANGUAGE plpgsql
+./sourceTest/sql/postgresql/054/schema-054.sql:    LANGUAGE plpgsql
+./sourceTest/sql/postgresql/054/schema-054.sql:    LANGUAGE plpgsql
+./sourceTest/sql/postgresql/054/schema-054.sql:    LANGUAGE plpgsql
+./sourceTest/sql/postgresql/054/schema-054.sql:    LANGUAGE plpgsql
+./sourceTest/sql/postgresql/055/.svn/text-base/017=database_version_logs.tsv.svn-base:027	D:\\User\\felmer\\dev-workspace\\openbis/source/sql/postgresql/027/function-027.sql	SUCCESS	2008-11-05 09:18:00.403	-- Creating Functions\\012\\012------------------------------------------------------------------------------------\\012--  Purpose:  Create function RENAME_SEQUENCE() that is required for renaming the sequences belonging to tables\\012------------------------------------------------------------------------------------\\012CREATE FUNCTION RENAME_SEQUENCE(OLD_NAME VARCHAR, NEW_NAME VARCHAR) RETURNS INTEGER AS $$\\012DECLARE\\012  CURR_SEQ_VAL   INTEGER;\\012BEGIN\\012  SELECT INTO CURR_SEQ_VAL NEXTVAL(OLD_NAME);\\012  EXECUTE 'CREATE SEQUENCE ' || NEW_NAME || ' START WITH ' || CURR_SEQ_VAL;\\012  EXECUTE 'DROP SEQUENCE ' || OLD_NAME;\\012  RETURN CURR_SEQ_VAL;\\012END;\\012$$ LANGUAGE 'plpgsql';\\012\\012\\012------------------------------------------------------------------------------------\\012--  Purpose:  Create trigger CONTROLLED_VOCABULARY_CHECK \\012------------------------------------------------------------------------------------\\012\\012CREATE OR REPLACE FUNCTION CONTROLLED_VOCABULARY_CHECK() RETURNS trigger AS $$\\012DECLARE\\012   v_code  CODE;\\012BEGIN\\012\\012   select code into v_code from data_types where id = NEW.daty_id;\\012\\012   -- Check if the data is of type "CONTROLLEDVOCABULARY"\\012   if v_code = 'CONTROLLEDVOCABULARY' then\\012      if NEW.covo_id IS NULL then\\012         RAISE EXCEPTION 'Insert/Update of Property Type (Code: %) failed, as its Data Type is CONTROLLEDVOCABULARY, but it is not linked to a Controlled Vocabulary.', NEW.code;\\012      end if;\\012   end if;\\012\\012   RETURN NEW;\\012\\012END;\\012$$ LANGUAGE 'plpgsql';\\012\\012CREATE TRIGGER CONTROLLED_VOCABULARY_CHECK BEFORE INSERT OR UPDATE ON PROPERTY_TYPES\\012    FOR EACH ROW EXECUTE PROCEDURE CONTROLLED_VOCABULARY_CHECK();\\012\\012\\012------------------------------------------------------------------------------------\\012--  Purpose:  Create trigger EXTERNAL_DATA_STORAGE_FORMAT_CHECK \\012------------------------------------------------------------------------------------\\012\\012CREATE OR REPLACE FUNCTION EXTERNAL_DATA_STORAGE_FORMAT_CHECK() RETURNS trigger AS $$\\012DECLARE\\012   v_covo_code  CODE;\\012   data_code CODE;\\012BEGIN\\012\\012   select code into v_covo_code from controlled_vocabularies\\012      where is_internal_namespace = true and \\012         id = (select covo_id from controlled_vocabulary_terms where id = NEW.cvte_id_stor_fmt);\\012   -- Check if the data storage format is a term of the controlled vocabulary "STORAGE_FORMAT"\\012   if v_covo_code != 'STORAGE_FORMAT' then\\012      select code into data_code from data where id = NEW.data_id; \\012      RAISE EXCEPTION 'Insert/Update of Data (Code: %) failed, as its Storage Format is %, but is required to be STORAGE_FORMAT.', data_code, v_covo_code;\\012   end if;\\012\\012   RETURN NEW;\\012\\012END;\\012$$ LANGUAGE 'plpgsql';\\012\\012CREATE TRIGGER EXTERNAL_DATA_STORAGE_FORMAT_CHECK BEFORE INSERT OR UPDATE ON EXTERNAL_DATA\\012    FOR EACH ROW EXECUTE PROCEDURE EXTERNAL_DATA_STORAGE_FORMAT_CHECK();\\012\\012------------------------------------------------------------------------------------\\012--  Purpose:  Create trigger SAMPLE_CODE_UNIQUENESS_CHECK \\012------------------------------------------------------------------------------------\\012\\012CREATE OR REPLACE FUNCTION SAMPLE_CODE_UNIQUENESS_CHECK() RETURNS trigger AS $$\\012DECLARE\\012   counter  INTEGER;\\012BEGIN\\012\\011IF (NEW.samp_id_part_of is NULL) THEN\\012\\011\\011IF (NEW.dbin_id is not NULL) THEN\\012\\011\\011\\011SELECT count(*) into counter FROM samples \\012\\011\\011\\011\\011where id != NEW.id and code = NEW.code and samp_id_part_of is NULL and dbin_id = NEW.dbin_id;\\012\\011\\011\\011IF (counter > 0) THEN\\012\\011\\011\\011\\011RAISE EXCEPTION 'Insert/Update of Sample (Code: %) failed because database instance sample with the same code already exists.', NEW.code;\\012\\011\\011\\011END IF;\\012\\011\\011ELSIF (NEW.grou_id is not NULL) THEN\\012\\011\\011\\011SELECT count(*) into counter FROM samples \\012\\011\\011\\011\\011where id != NEW.id and code = NEW.code and samp_id_part_of is NULL and grou_id = NEW.grou_id;\\012\\011\\011\\011IF (counter > 0) THEN\\012\\011\\011\\011\\011RAISE EXCEPTION 'Insert/Update of Sample (Code: %) failed because group sample with the same code already exists.', NEW.code;\\012\\011\\011\\011END IF;\\012\\011\\011END IF;\\012        ELSE\\012\\011\\011IF (NEW.dbin_id is not NULL) THEN\\012\\011\\011\\011SELECT count(*) into counter FROM samples \\012\\011\\011\\011\\011where id != NEW.id and code = NEW.code and samp_id_part_of = NEW.samp_id_part_of and dbin_id = NEW.dbin_id;\\012\\011\\011\\011IF (counter > 0) THEN\\012\\011\\011\\011\\011RAISE EXCEPTION 'Insert/Update of Sample (Code: %) failed because database instance sample with the same code and being the part of the same parent already exists.', NEW.code;\\012\\011\\011\\011END IF;\\012\\011\\011ELSIF (NEW.grou_id is not NULL) THEN\\012\\011\\011\\011SELECT count(*) into counter FROM samples \\012\\011\\011\\011\\011where id != NEW.id and code = NEW.code and samp_id_part_of = NEW.samp_id_part_of and grou_id = NEW.grou_id;\\012\\011\\011\\011IF (counter > 0) THEN\\012\\011\\011\\011\\011RAISE EXCEPTION 'Insert/Update of Sample (Code: %) failed because group sample with the same code and being the part of the same parent already exists.', NEW.code;\\012\\011\\011\\011END IF;\\012\\011\\011END IF;\\012        END IF;   \\012   RETURN NEW;\\012END;\\012$$ LANGUAGE 'plpgsql';\\012\\012CREATE TRIGGER SAMPLE_CODE_UNIQUENESS_CHECK BEFORE INSERT OR UPDATE ON SAMPLES\\012    FOR EACH ROW EXECUTE PROCEDURE SAMPLE_CODE_UNIQUENESS_CHECK();\\012	\N
+./sourceTest/sql/postgresql/055/.svn/text-base/017=database_version_logs.tsv.svn-base:028	source/sql/postgresql/migration/migration-027-028.sql	SUCCESS	2008-11-18 13:24:17.508	-- Create EXPERIMENT_ATTACHMENT_CONTENTS.\\012CREATE TABLE EXPERIMENT_ATTACHMENT_CONTENTS (ID TECH_ID NOT NULL,VALUE FILE NOT NULL);\\012CREATE SEQUENCE EXPERIMENT_ATTACHMENT_CONTENT_ID_SEQ;\\012ALTER TABLE EXPERIMENT_ATTACHMENT_CONTENTS ADD CONSTRAINT EXAC_PK PRIMARY KEY(ID);\\012\\012-- Alter EXPERIMENT_ATTACHMENTS by adding the new column which has a NULL constraint.\\012-- The NOT NULL constraint is added later on.\\012ALTER TABLE EXPERIMENT_ATTACHMENTS ADD COLUMN EXAC_ID TECH_ID;\\012\\012-- Does the VALUE migration between EXPERIMENT_ATTACHMENTS to EXPERIMENT_ATTACHMENT_CONTENTS.\\012CREATE OR REPLACE FUNCTION move_exp_att_content() RETURNS integer AS $$\\012DECLARE\\012    rec RECORD;\\012    seq BIGINT;\\012BEGIN\\012  FOR rec IN SELECT id, value FROM EXPERIMENT_ATTACHMENTS LOOP\\012  \\011seq := nextval('EXPERIMENT_ATTACHMENT_CONTENT_ID_SEQ');\\012    INSERT INTO EXPERIMENT_ATTACHMENT_CONTENTS (id, value) VALUES (seq, rec.value);\\012    UPDATE EXPERIMENT_ATTACHMENTS SET exac_id = seq WHERE id = rec.id;\\012  END LOOP;\\012  RETURN 1;\\012END;\\012$$ LANGUAGE 'plpgsql';\\012\\012-- Call the function.\\012SELECT move_exp_att_content();\\012DROP FUNCTION move_exp_att_content();\\012\\012\\012-- Finish EXPERIMENT_ATTACHMENTS changes.\\012ALTER TABLE EXPERIMENT_ATTACHMENTS ADD CONSTRAINT EXAT_CONT_FK FOREIGN KEY (EXAC_ID) REFERENCES EXPERIMENT_ATTACHMENT_CONTENTS(ID);\\012ALTER TABLE EXPERIMENT_ATTACHMENTS DROP COLUMN VALUE;\\012ALTER TABLE EXPERIMENT_ATTACHMENTS ALTER COLUMN EXAC_ID SET NOT NULL;\\012	\N
+./sourceTest/sql/postgresql/055/.svn/text-base/017=database_version_logs.tsv.svn-base:029	source/sql/postgresql/migration/migration-028-029.sql	SUCCESS	2009-03-18 10:50:20.105	-- -------\\012-- add modification_timestamp field to allow edition with Hibernate\\012-- -------\\012\\012ALTER TABLE samples\\012\\011ADD COLUMN modification_timestamp TIME_STAMP DEFAULT CURRENT_TIMESTAMP;\\012\\012ALTER TABLE experiments\\012\\011ADD COLUMN modification_timestamp TIME_STAMP DEFAULT CURRENT_TIMESTAMP;\\012\\012ALTER TABLE materials\\012\\011ADD COLUMN modification_timestamp TIME_STAMP DEFAULT CURRENT_TIMESTAMP;\\012\\012ALTER TABLE experiment_properties\\012\\011ADD COLUMN modification_timestamp TIME_STAMP DEFAULT CURRENT_TIMESTAMP;\\012\\012ALTER TABLE material_properties\\012\\011ADD COLUMN modification_timestamp TIME_STAMP DEFAULT CURRENT_TIMESTAMP;\\012\\012ALTER TABLE sample_properties\\012\\011ADD COLUMN modification_timestamp TIME_STAMP DEFAULT CURRENT_TIMESTAMP;\\012\\012-- -------\\012-- add property data type which references materials\\012-- -------\\012\\012ALTER TABLE property_types\\012\\011ADD COLUMN maty_prop_id tech_id;\\012\\012ALTER TABLE property_types\\012\\011ADD CONSTRAINT prty_maty_fk FOREIGN KEY (maty_prop_id) REFERENCES material_types(id);\\012\\012ALTER TABLE experiment_properties\\012\\011ADD COLUMN mate_prop_id tech_id;\\012\\012ALTER TABLE material_properties\\012\\011ADD COLUMN mate_prop_id tech_id;\\012\\012ALTER TABLE sample_properties\\012\\011ADD COLUMN mate_prop_id tech_id;\\012\\012ALTER TABLE experiment_properties\\012\\011ADD CONSTRAINT expr_mapr_fk FOREIGN KEY (mate_prop_id) REFERENCES materials(id);\\012\\012ALTER TABLE material_properties\\012\\011ADD CONSTRAINT mapr_mapr_fk FOREIGN KEY (mate_prop_id) REFERENCES materials(id);\\012\\012ALTER TABLE sample_properties\\012\\011ADD CONSTRAINT sapr_mapr_fk FOREIGN KEY (mate_prop_id) REFERENCES materials(id);\\012\\012insert into data_types\\012(id\\012 ,code\\012 ,description)\\012 values \\012 (nextval('DATA_TYPE_ID_SEQ')\\012 ,'MATERIAL'\\012 ,'Reference to a material'\\012);\\012\\012ALTER TABLE MATERIAL_PROPERTIES DROP CONSTRAINT MAPR_CK;\\012ALTER TABLE MATERIAL_PROPERTIES ADD CONSTRAINT MAPR_CK CHECK \\012\\011((VALUE IS NOT NULL AND CVTE_ID IS NULL AND MATE_PROP_ID IS NULL) OR \\012\\011 (VALUE IS NULL AND CVTE_ID IS NOT NULL AND MATE_PROP_ID IS NULL) OR\\012\\011 (VALUE IS NULL AND CVTE_ID IS NULL AND MATE_PROP_ID IS NOT NULL)\\012\\011);\\012\\012ALTER TABLE EXPERIMENT_PROPERTIES DROP CONSTRAINT EXPR_CK;\\012ALTER TABLE EXPERIMENT_PROPERTIES ADD CONSTRAINT EXPR_CK CHECK \\012\\011((VALUE IS NOT NULL AND CVTE_ID IS NULL AND MATE_PROP_ID IS NULL) OR \\012\\011 (VALUE IS NULL AND CVTE_ID IS NOT NULL AND MATE_PROP_ID IS NULL) OR\\012\\011 (VALUE IS NULL AND CVTE_ID IS NULL AND MATE_PROP_ID IS NOT NULL)\\012\\011);\\012\\012ALTER TABLE SAMPLE_PROPERTIES DROP CONSTRAINT SAPR_CK;\\012ALTER TABLE SAMPLE_PROPERTIES ADD CONSTRAINT SAPR_CK CHECK \\012\\011((VALUE IS NOT NULL AND CVTE_ID IS NULL AND MATE_PROP_ID IS NULL) OR \\012\\011 (VALUE IS NULL AND CVTE_ID IS NOT NULL AND MATE_PROP_ID IS NULL) OR\\012\\011 (VALUE IS NULL AND CVTE_ID IS NULL AND MATE_PROP_ID IS NOT NULL)\\012\\011);\\012\\012------------------------------------------------------------------------------------\\012--  Purpose:  Create trigger MATERIAL/SAMPLE/EXPERIMENT _PROPERTY_WITH_MATERIAL_DATA_TYPE_CHECK\\012--            It checks that if material property value is assigned to the entity,\\012--\\011\\011\\011\\011\\011\\011then the material type is equal to the one described by property type.\\012------------------------------------------------------------------------------------\\012\\012CREATE OR REPLACE FUNCTION MATERIAL_PROPERTY_WITH_MATERIAL_DATA_TYPE_CHECK() RETURNS trigger AS $$\\012DECLARE\\012   v_type_id  CODE;\\012   v_type_id_prop  CODE;\\012BEGIN\\012   if NEW.mate_prop_id IS NOT NULL then\\012\\011\\011\\011-- find material type id of the property type \\012\\011\\011\\011select pt.maty_prop_id into v_type_id_prop \\012\\011\\011\\011  from material_type_property_types etpt, property_types pt \\012\\011\\011\\011 where NEW.mtpt_id = etpt.id AND etpt.prty_id = pt.id;\\012\\011\\011\\012\\011\\011\\011if v_type_id_prop IS NOT NULL then\\012\\011\\011\\011\\011-- find material type id of the material which consists the entity's property value\\012\\011\\011\\011\\011select entity.maty_id into v_type_id \\012\\011\\011\\011\\011  from materials entity\\012\\011\\011\\011\\011 where NEW.mate_prop_id = entity.id;\\012\\011\\011\\011\\011if v_type_id != v_type_id_prop then\\012\\011\\011\\011\\011\\011RAISE EXCEPTION 'Insert/Update of property value referencing material (id: %) failed, as referenced material type is different than expected (id %, expected id: %).', \\012\\011\\011\\011\\011\\011\\011\\011 NEW.mate_prop_id, v_type_id, v_type_id_prop;\\012\\011\\011\\011\\011end if;\\012\\011\\011\\011end if;\\012   end if;\\012   RETURN NEW;\\012END;\\012$$ LANGUAGE 'plpgsql';\\012\\012CREATE TRIGGER MATERIAL_PROPERTY_WITH_MATERIAL_DATA_TYPE_CHECK BEFORE INSERT OR UPDATE ON material_properties\\012    FOR EACH ROW EXECUTE PROCEDURE MATERIAL_PROPERTY_WITH_MATERIAL_DATA_TYPE_CHECK();\\012    \\012CREATE OR REPLACE FUNCTION SAMPLE_PROPERTY_WITH_MATERIAL_DATA_TYPE_CHECK() RETURNS trigger AS $$\\012DECLARE\\012   v_type_id  CODE;\\012   v_type_id_prop  CODE;\\012BEGIN\\012   if NEW.mate_prop_id IS NOT NULL then\\012\\011\\011\\011-- find material type id of the property type \\012\\011\\011\\011select pt.maty_prop_id into v_type_id_prop \\012\\011\\011\\011  from sample_type_property_types etpt, property_types pt \\012\\011\\011\\011 where NEW.stpt_id = etpt.id AND etpt.prty_id = pt.id;\\012\\011\\011\\012\\011\\011\\011if v_type_id_prop IS NOT NULL then\\012\\011\\011\\011\\011-- find material type id of the material which consists the entity's property value\\012\\011\\011\\011\\011select entity.maty_id into v_type_id \\012\\011\\011\\011\\011  from materials entity\\012\\011\\011\\011\\011 where NEW.mate_prop_id = entity.id;\\012\\011\\011\\011\\011if v_type_id != v_type_id_prop then\\012\\011\\011\\011\\011\\011RAISE EXCEPTION 'Insert/Update of property value referencing material (id: %) failed, as referenced material type is different than expected (id %, expected id: %).', \\012\\011\\011\\011\\011\\011\\011\\011\\011\\011\\011\\011\\011 NEW.mate_prop_id, v_type_id, v_type_id_prop;\\012\\011\\011\\011\\011end if;\\012\\011\\011\\011end if;\\012   end if;\\012   RETURN NEW;\\012END;\\012$$ LANGUAGE 'plpgsql';\\012\\012CREATE TRIGGER SAMPLE_PROPERTY_WITH_MATERIAL_DATA_TYPE_CHECK BEFORE INSERT OR UPDATE ON sample_properties\\012    FOR EACH ROW EXECUTE PROCEDURE SAMPLE_PROPERTY_WITH_MATERIAL_DATA_TYPE_CHECK();\\012    \\012CREATE OR REPLACE FUNCTION EXPERIMENT_PROPERTY_WITH_MATERIAL_DATA_TYPE_CHECK() RETURNS trigger AS $$\\012DECLARE\\012   v_type_id  CODE;\\012   v_type_id_prop  CODE;\\012BEGIN\\012   if NEW.mate_prop_id IS NOT NULL then\\012\\011\\011\\011-- find material type id of the property type \\012\\011\\011\\011select pt.maty_prop_id into v_type_id_prop \\012\\011\\011\\011  from experiment_type_property_types etpt, property_types pt \\012\\011\\011\\011 where NEW.etpt_id = etpt.id AND etpt.prty_id = pt.id;\\012\\011\\011\\012\\011\\011\\011if v_type_id_prop IS NOT NULL then\\012\\011\\011\\011\\011-- find material type id of the material which consists the entity's property value\\012\\011\\011\\011\\011select entity.maty_id into v_type_id \\012\\011\\011\\011\\011  from materials entity\\012\\011\\011\\011\\011 where NEW.mate_prop_id = entity.id;\\012\\011\\011\\011\\011if v_type_id != v_type_id_prop then\\012\\011\\011\\011\\011\\011RAISE EXCEPTION 'Insert/Update of property value referencing material (id: %) failed, as referenced material type is different than expected (id %, expected id: %).', \\012\\011\\011\\011\\011\\011\\011\\011\\011\\011\\011\\011\\011 NEW.mate_prop_id, v_type_id, v_type_id_prop;\\012\\011\\011\\011\\011end if;\\012\\011\\011\\011end if;\\012   end if;\\012   RETURN NEW;\\012END;\\012$$ LANGUAGE 'plpgsql';\\012\\012CREATE TRIGGER EXPERIMENT_PROPERTY_WITH_MATERIAL_DATA_TYPE_CHECK BEFORE INSERT OR UPDATE ON experiment_properties\\012    FOR EACH ROW EXECUTE PROCEDURE EXPERIMENT_PROPERTY_WITH_MATERIAL_DATA_TYPE_CHECK();\\012       \\012-- -------\\012-- remove the reminescents of the OBSERVABLE_TYPE\\012-- -------\\012\\012ALTER TABLE data\\012\\011DROP CONSTRAINT data_obty_fk;\\012\\012ALTER TABLE data_set_types\\012\\011DROP CONSTRAINT obty_pk;\\012\\012ALTER TABLE data_set_types\\012\\011ADD CONSTRAINT dsty_pk PRIMARY KEY (id);\\012\\012ALTER TABLE data\\012\\011ADD CONSTRAINT data_dsty_fk FOREIGN KEY (dsty_id) REFERENCES data_set_types(id);\\012\\012ALTER TABLE data_set_types\\012\\011DROP CONSTRAINT obty_bk_uk;\\012\\012ALTER TABLE data_set_types\\012\\011DROP CONSTRAINT obty_dbin_fk;\\012\\012ALTER TABLE data_set_types\\012\\011ADD CONSTRAINT dsty_bk_uk UNIQUE (code, dbin_id);\\012\\012ALTER TABLE data_set_types\\012\\011ADD CONSTRAINT dsty_dbin_fk FOREIGN KEY (dbin_id) REFERENCES database_instances(id);\\012\\012DROP INDEX data_obty_fk_i;\\012\\012CREATE INDEX data_dsty_fk_i ON data(dsty_id);\\012	\N
+./sourceTest/sql/postgresql/055/.svn/text-base/017=database_version_logs.tsv.svn-base:030	source/sql/postgresql/migration/migration-029-030.sql	SUCCESS	2009-03-23 15:34:44.72	-- -------\\012-- add modification_timestamp field to allow edition with Hibernate\\012-- -------\\012ALTER TABLE data\\012\\011ADD COLUMN modification_timestamp TIME_STAMP DEFAULT CURRENT_TIMESTAMP;\\012ALTER TABLE experiment_types\\012\\011ADD COLUMN modification_timestamp TIME_STAMP DEFAULT CURRENT_TIMESTAMP;\\012ALTER TABLE sample_types\\012\\011ADD COLUMN modification_timestamp TIME_STAMP DEFAULT CURRENT_TIMESTAMP;\\012ALTER TABLE material_types\\012\\011ADD COLUMN modification_timestamp TIME_STAMP DEFAULT CURRENT_TIMESTAMP;\\012ALTER TABLE data_set_types\\012\\011ADD COLUMN modification_timestamp TIME_STAMP DEFAULT CURRENT_TIMESTAMP;\\012ALTER TABLE controlled_vocabularies\\012\\011ADD COLUMN modification_timestamp TIME_STAMP DEFAULT CURRENT_TIMESTAMP;\\012-- -------\\012-- add properties to data sets\\012-- -------\\012CREATE TABLE DATA_SET_PROPERTIES (ID TECH_ID NOT NULL,DS_ID TECH_ID NOT NULL,DSTPT_ID TECH_ID NOT NULL,VALUE GENERIC_VALUE,CVTE_ID TECH_ID, MATE_PROP_ID TECH_ID, PERS_ID_REGISTERER TECH_ID NOT NULL,REGISTRATION_TIMESTAMP TIME_STAMP_DFL NOT NULL DEFAULT CURRENT_TIMESTAMP, MODIFICATION_TIMESTAMP TIME_STAMP DEFAULT CURRENT_TIMESTAMP);\\012CREATE TABLE DATA_SET_TYPE_PROPERTY_TYPES (ID TECH_ID NOT NULL,DSTY_ID TECH_ID NOT NULL,PRTY_ID TECH_ID NOT NULL,IS_MANDATORY BOOLEAN_CHAR NOT NULL DEFAULT 'F',IS_MANAGED_INTERNALLY BOOLEAN_CHAR NOT NULL DEFAULT 'F',PERS_ID_REGISTERER TECH_ID NOT NULL,REGISTRATION_TIMESTAMP TIME_STAMP_DFL NOT NULL DEFAULT CURRENT_TIMESTAMP);\\012\\012CREATE SEQUENCE DATA_SET_PROPERTY_ID_SEQ;\\012CREATE SEQUENCE DSTPT_ID_SEQ;\\012\\012ALTER TABLE DATA_SET_TYPE_PROPERTY_TYPES ADD CONSTRAINT DSTPT_PK PRIMARY KEY(ID);\\012ALTER TABLE DATA_SET_PROPERTIES ADD CONSTRAINT DSPR_PK PRIMARY KEY(ID);\\012\\012ALTER TABLE DATA_SET_TYPE_PROPERTY_TYPES ADD CONSTRAINT DSTPT_BK_UK UNIQUE(DSTY_ID,PRTY_ID);\\012ALTER TABLE DATA_SET_PROPERTIES ADD CONSTRAINT DSPR_BK_UK UNIQUE(DS_ID,DSTPT_ID);\\012\\012\\012ALTER TABLE DATA_SET_TYPE_PROPERTY_TYPES ADD CONSTRAINT DSTPT_DSTY_FK FOREIGN KEY (DSTY_ID) REFERENCES DATA_SET_TYPES(ID);\\012ALTER TABLE DATA_SET_TYPE_PROPERTY_TYPES ADD CONSTRAINT DSTPT_PERS_FK FOREIGN KEY (PERS_ID_REGISTERER) REFERENCES PERSONS(ID);\\012ALTER TABLE DATA_SET_TYPE_PROPERTY_TYPES ADD CONSTRAINT DSTPT_PRTY_FK FOREIGN KEY (PRTY_ID) REFERENCES PROPERTY_TYPES(ID);\\012ALTER TABLE DATA_SET_PROPERTIES ADD CONSTRAINT DSPR_CVTE_FK FOREIGN KEY (CVTE_ID) REFERENCES CONTROLLED_VOCABULARY_TERMS(ID);\\012ALTER TABLE DATA_SET_PROPERTIES ADD CONSTRAINT DSPR_DSTPT_FK FOREIGN KEY (DSTPT_ID) REFERENCES DATA_SET_TYPE_PROPERTY_TYPES(ID) ON DELETE CASCADE;\\012ALTER TABLE DATA_SET_PROPERTIES ADD CONSTRAINT DSPR_DS_FK FOREIGN KEY (DS_ID) REFERENCES DATA(ID);\\012ALTER TABLE DATA_SET_PROPERTIES ADD CONSTRAINT DSPR_PERS_FK FOREIGN KEY (PERS_ID_REGISTERER) REFERENCES PERSONS(ID);\\012ALTER TABLE DATA_SET_PROPERTIES ADD CONSTRAINT DSPR_MAPR_FK FOREIGN KEY (MATE_PROP_ID) REFERENCES MATERIALS(ID);\\012\\012ALTER TABLE DATA_SET_PROPERTIES ADD CONSTRAINT DSPR_CK CHECK \\012\\011((VALUE IS NOT NULL AND CVTE_ID IS NULL AND MATE_PROP_ID IS NULL) OR \\012\\011 (VALUE IS NULL AND CVTE_ID IS NOT NULL AND MATE_PROP_ID IS NULL) OR\\012\\011 (VALUE IS NULL AND CVTE_ID IS NULL AND MATE_PROP_ID IS NOT NULL)\\012\\011);\\012\\012CREATE INDEX DSPR_CVTE_FK_I ON DATA_SET_PROPERTIES (CVTE_ID);\\012CREATE INDEX DSPR_DSTPT_FK_I ON DATA_SET_PROPERTIES (DSTPT_ID);\\012CREATE INDEX DSPR_DS_FK_I ON DATA_SET_PROPERTIES (DS_ID);\\012CREATE INDEX DSPR_PERS_FK_I ON DATA_SET_PROPERTIES (PERS_ID_REGISTERER);\\012CREATE INDEX DSTPT_DSTY_FK_I ON DATA_SET_TYPE_PROPERTY_TYPES (DSTY_ID);\\012CREATE INDEX DSTPT_PERS_FK_I ON DATA_SET_TYPE_PROPERTY_TYPES (PERS_ID_REGISTERER);\\012CREATE INDEX DSTPT_PRTY_FK_I ON DATA_SET_TYPE_PROPERTY_TYPES (PRTY_ID);\\012\\012CREATE OR REPLACE FUNCTION DATA_SET_PROPERTY_WITH_MATERIAL_DATA_TYPE_CHECK() RETURNS trigger AS $$\\012DECLARE\\012   v_type_id  CODE;\\012   v_type_id_prop  CODE;\\012BEGIN\\012   if NEW.mate_prop_id IS NOT NULL then\\012\\011\\011\\011-- find material type id of the property type \\012\\011\\011\\011select pt.maty_prop_id into v_type_id_prop \\012\\011\\011\\011  from data_set_type_property_types dstpt, property_types pt \\012\\011\\011\\011 where NEW.dstpt_id = dstpt.id AND dstpt.prty_id = pt.id;\\012\\011\\011\\012\\011\\011\\011if v_type_id_prop IS NOT NULL then\\012\\011\\011\\011\\011-- find material type id of the material which consists the entity's property value\\012\\011\\011\\011\\011select entity.maty_id into v_type_id \\012\\011\\011\\011\\011  from materials entity\\012\\011\\011\\011\\011 where NEW.mate_prop_id = entity.id;\\012\\011\\011\\011\\011if v_type_id != v_type_id_prop then\\012\\011\\011\\011\\011\\011RAISE EXCEPTION 'Insert/Update of property value referencing material (id: %) failed, as referenced material type is different than expected (id %, expected id: %).', \\012\\011\\011\\011\\011\\011\\011\\011\\011\\011\\011\\011\\011 NEW.mate_prop_id, v_type_id, v_type_id_prop;\\012\\011\\011\\011\\011end if;\\012\\011\\011\\011end if;\\012   end if;\\012   RETURN NEW;\\012END;\\012$$ LANGUAGE 'plpgsql';\\012\\012CREATE TRIGGER DATA_SET_PROPERTY_WITH_MATERIAL_DATA_TYPE_CHECK BEFORE INSERT OR UPDATE ON data_set_properties\\012    FOR EACH ROW EXECUTE PROCEDURE DATA_SET_PROPERTY_WITH_MATERIAL_DATA_TYPE_CHECK();   \\012	\N
+./sourceTest/sql/postgresql/055/.svn/text-base/017=database_version_logs.tsv.svn-base:032	source/sql/postgresql/migration/migration-031-032.sql	SUCCESS	2009-04-09 09:36:36.2	-- -------\\012-- Modify MATERIAL_BATCHES\\012-- -------\\012\\012ALTER TABLE material_batches\\012    DROP COLUMN proc_id;\\012\\012-- -------\\012-- Modify SAMPLES\\012-- -------\\012\\012ALTER TABLE samples\\012    ADD COLUMN expe_id tech_id;\\012\\012ALTER TABLE samples\\012    ADD CONSTRAINT samp_expe_fk FOREIGN KEY (expe_id) REFERENCES experiments(id);\\012\\012CREATE INDEX samp_expe_fk_i ON samples USING btree (expe_id);\\012\\012-- relink samples directly to experiments\\012\\012UPDATE samples\\012SET expe_id = (SELECT e.id FROM experiments e, procedures p, sample_inputs si \\012               WHERE si.samp_id = samples.id AND si.proc_id = p.id AND p.expe_id = e.id AND e.inva_id IS NULL);\\012\\012\\012-- -------\\012-- Modify DATA\\012-- -------\\012\\012ALTER TABLE data\\012    ADD COLUMN expe_id tech_id;\\012\\012ALTER TABLE data\\012    ADD CONSTRAINT data_expe_fk FOREIGN KEY (expe_id) REFERENCES experiments(id);\\012\\012CREATE INDEX data_expe_fk_i ON data USING btree (expe_id);\\012\\012UPDATE data\\012SET expe_id = (SELECT e.id FROM experiments e, procedures p \\012               WHERE data.proc_id_produced_by = p.id AND p.expe_id = e.id);\\012\\012ALTER TABLE data\\012    ALTER COLUMN expe_id SET NOT NULL;\\012\\012ALTER TABLE data\\012    DROP COLUMN proc_id_produced_by;\\012\\012-- -------\\012-- Drop PROCEDURES, PROCEDURE_TYPES, and SAMPLE_INPUTS\\012-- -------\\012\\012DROP TABLE sample_inputs;\\012DROP TABLE procedures;\\012DROP TABLE procedure_types;\\012\\012DROP SEQUENCE procedure_id_seq;\\012DROP SEQUENCE procedure_type_id_seq;\\012\\012-- -------\\012-- Add CODE_SEQ\\012-- -------\\012\\012CREATE SEQUENCE CODE_SEQ;\\012\\012-- -------\\012-- Add new columns to DATA_STORES\\012-- -------\\012\\012ALTER TABLE data_stores\\012    ADD COLUMN remote_url character varying(250),\\012    ADD COLUMN session_token character varying(50),\\012    ADD COLUMN modification_timestamp time_stamp DEFAULT now();\\012\\012UPDATE data_stores\\012SET remote_url = '', session_token='';\\012\\012ALTER TABLE data_stores\\012    ALTER COLUMN remote_url SET NOT NULL,\\012    ALTER COLUMN session_token SET NOT NULL;\\012\\012-- -------\\012-- Drop foreign keys onto DATA_STORES\\012-- -------\\012\\012ALTER TABLE database_instances\\012    DROP COLUMN dast_id;\\012\\012ALTER TABLE groups\\012    DROP COLUMN dast_id;\\012\\012ALTER TABLE projects\\012    DROP COLUMN dast_id;\\012\\012ALTER TABLE experiments\\012    DROP COLUMN dast_id;\\012\\012-- -------\\012-- Add foreign key from DATA onto DATA_STORES\\012-- -------\\012\\012ALTER TABLE data\\012    ADD COLUMN dast_id tech_id;\\012\\012ALTER TABLE data\\012    ADD CONSTRAINT data_dast_fk FOREIGN KEY (dast_id) REFERENCES data_stores(id);\\012\\012UPDATE data\\012SET dast_id = (select id from data_stores where code = 'STANDARD');\\012\\012ALTER TABLE data\\012    ALTER COLUMN dast_id SET NOT NULL;\\012\\012\\012------------------------------------------------------------------------------------\\012--  Purpose:  Replace trigger SAMPLE_CODE_UNIQUENESS_CHECK \\012------------------------------------------------------------------------------------\\012\\012CREATE OR REPLACE FUNCTION SAMPLE_CODE_UNIQUENESS_CHECK() RETURNS trigger AS $$\\012DECLARE\\012   counter  INTEGER;\\012BEGIN\\012    LOCK TABLE samples IN EXCLUSIVE MODE;\\012    IF (NEW.samp_id_part_of is NULL) THEN\\012        IF (NEW.dbin_id is not NULL) THEN\\012            SELECT count(*) into counter FROM samples \\012                where id != NEW.id and code = NEW.code and samp_id_part_of is NULL and dbin_id = NEW.dbin_id;\\012            IF (counter > 0) THEN\\012                RAISE EXCEPTION 'Insert/Update of Sample (Code: %) failed because database instance sample with the same code already exists.', NEW.code;\\012            END IF;\\012        ELSIF (NEW.grou_id is not NULL) THEN\\012            SELECT count(*) into counter FROM samples \\012                where id != NEW.id and code = NEW.code and samp_id_part_of is NULL and grou_id = NEW.grou_id;\\012            IF (counter > 0) THEN\\012                RAISE EXCEPTION 'Insert/Update of Sample (Code: %) failed because group sample with the same code already exists.', NEW.code;\\012            END IF;\\012        END IF;\\012        ELSE\\012        IF (NEW.dbin_id is not NULL) THEN\\012            SELECT count(*) into counter FROM samples \\012                where id != NEW.id and code = NEW.code and samp_id_part_of = NEW.samp_id_part_of and dbin_id = NEW.dbin_id;\\012            IF (counter > 0) THEN\\012                RAISE EXCEPTION 'Insert/Update of Sample (Code: %) failed because database instance sample with the same code and being the part of the same parent already exists.', NEW.code;\\012            END IF;\\012        ELSIF (NEW.grou_id is not NULL) THEN\\012            SELECT count(*) into counter FROM samples \\012                where id != NEW.id and code = NEW.code and samp_id_part_of = NEW.samp_id_part_of and grou_id = NEW.grou_id;\\012            IF (counter > 0) THEN\\012                RAISE EXCEPTION 'Insert/Update of Sample (Code: %) failed because group sample with the same code and being the part of the same parent already exists.', NEW.code;\\012            END IF;\\012        END IF;\\012        END IF;   \\012   RETURN NEW;\\012END;\\012$$ LANGUAGE 'plpgsql';\\012\\012\\012\\012	\N
+./sourceTest/sql/postgresql/055/.svn/text-base/017=database_version_logs.tsv.svn-base:034	source/sql/postgresql/migration/migration-033-034.sql	SUCCESS	2009-05-26 08:32:49.935	------------------------------------------------------------------------------------\\012-- Create sequence for generating permanent identifiers starting with nextval of existing dataset sequence.\\012------------------------------------------------------------------------------------\\012CREATE FUNCTION CREATE_SEQUENCE(EXISTING_SEQUENCE VARCHAR, NEW_SEQUENCE VARCHAR) RETURNS VOID AS $$\\012DECLARE\\012  CURR_SEQ_VAL   INTEGER;\\012BEGIN\\012  SELECT INTO CURR_SEQ_VAL NEXTVAL(EXISTING_SEQUENCE);\\012  EXECUTE 'CREATE SEQUENCE ' || NEW_SEQUENCE || ' START WITH ' || CURR_SEQ_VAL;\\012  RETURN;\\012END;\\012$$ LANGUAGE 'plpgsql';\\012\\012SELECT CREATE_SEQUENCE('DATA_ID_SEQ', 'PERM_ID_SEQ');\\012DROP FUNCTION CREATE_SEQUENCE(VARCHAR, VARCHAR);\\012\\012------------------------------------------------------------------------------------\\012-- Add perm_id columns to samples and experiments.\\012------------------------------------------------------------------------------------\\012ALTER TABLE SAMPLES ADD COLUMN PERM_ID CODE;\\012ALTER TABLE EXPERIMENTS ADD COLUMN PERM_ID CODE;\\012\\012UPDATE SAMPLES SET PERM_ID = to_char(registration_timestamp,'YYYYMMDDHHSSMS') || '-' || NEXTVAL('PERM_ID_SEQ');\\012UPDATE EXPERIMENTS SET PERM_ID = to_char(registration_timestamp,'YYYYMMDDHHSSMS') || '-' || NEXTVAL('PERM_ID_SEQ');\\012ALTER TABLE SAMPLES ALTER COLUMN PERM_ID SET NOT NULL;\\012ALTER TABLE EXPERIMENTS ALTER COLUMN PERM_ID SET NOT NULL;\\012ALTER TABLE SAMPLES ADD CONSTRAINT SAMP_PI_UK UNIQUE(PERM_ID);\\012ALTER TABLE EXPERIMENTS ADD CONSTRAINT EXPE_PI_UK UNIQUE(PERM_ID);\\012\\012\\012------------------------------------------------------------------------------------\\012-- Add column is_chosen_from_list to controlled_vocabularies.\\012------------------------------------------------------------------------------------\\012ALTER TABLE controlled_vocabularies ADD COLUMN is_chosen_from_list BOOLEAN_CHAR NOT NULL DEFAULT TRUE;\\012ALTER TABLE controlled_vocabularies ADD COLUMN source_uri CHARACTER VARYING(250);\\012------------------------------------------------------------------------------------\\012-- Modify Data table - remove arc connection between Sample and Data table, use a flag instead\\012------------------------------------------------------------------------------------\\012\\012-- add new columns\\012\\012ALTER TABLE data\\012    ADD COLUMN is_derived boolean_char;\\012ALTER TABLE data\\012    ADD COLUMN samp_id tech_id;\\012\\012-- update values in new columns\\012\\012UPDATE data\\012    SET is_derived = (samp_id_derived_from IS NOT NULL); \\012UPDATE data\\012    SET samp_id = samp_id_derived_from \\012    WHERE is_derived = 'TRUE';\\012UPDATE data\\012    SET samp_id = samp_id_acquired_from \\012    WHERE is_derived = 'FALSE';\\012\\012-- add constraints and indexes to new columns\\012\\012ALTER TABLE data\\012    ALTER COLUMN is_derived SET NOT NULL;\\012ALTER TABLE data\\012    ALTER COLUMN samp_id SET NOT NULL;   \\012ALTER TABLE data\\012    ADD CONSTRAINT data_samp_fk FOREIGN KEY (samp_id) REFERENCES samples (id);\\012CREATE INDEX data_samp_fk_i ON data USING btree (samp_id);\\012\\012-- remove old columns\\012\\012ALTER TABLE data\\012    DROP COLUMN samp_id_acquired_from;\\012ALTER TABLE data\\012    DROP COLUMN samp_id_derived_from;\\012    \\012------------------------------------------------------------------------------------\\012-- Granting SELECT privilege to group openbis_readonly\\012------------------------------------------------------------------------------------\\012\\012GRANT SELECT ON SEQUENCE attachment_content_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE attachment_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE code_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE controlled_vocabulary_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE cvte_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE data_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE data_set_property_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE data_set_relationship_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE data_set_type_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE data_store_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE data_type_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE database_instance_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE dstpt_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE etpt_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE event_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE experiment_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE experiment_property_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE experiment_type_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE file_format_type_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE group_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE invalidation_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE locator_type_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE material_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE material_property_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE material_type_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE mtpt_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE perm_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE person_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE project_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE property_type_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE role_assignment_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE sample_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE sample_property_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE sample_type_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE stpt_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE attachment_contents TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE attachments TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE controlled_vocabularies TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE controlled_vocabulary_terms TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE data TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE data_set_properties TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE data_set_relationships TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE data_set_type_property_types TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE data_set_types TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE data_stores TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE data_types TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE database_instances TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE database_version_logs TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE events TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE experiment_properties TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE experiment_type_property_types TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE experiment_types TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE experiments TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE external_data TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE file_format_types TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE groups TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE invalidations TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE locator_types TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE material_properties TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE material_type_property_types TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE material_types TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE materials TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE persons TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE projects TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE property_types TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE role_assignments TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE sample_properties TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE sample_type_property_types TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE sample_types TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE samples TO GROUP OPENBIS_READONLY;\\012\\012------------------------------------------------------------------------------------\\012-- Delete MATERIAL_BATCHES table\\012------------------------------------------------------------------------------------\\012\\012-- WARNING: Potential data lost!!!\\012-- WARNING: Potential data lost!!!\\012-- WARNING: Potential data lost!!!\\012\\012DROP TABLE SAMPLE_MATERIAL_BATCHES;\\012DROP TABLE MATERIAL_BATCHES;\\012DROP SEQUENCE MATERIAL_BATCH_ID_SEQ;\\012\\012------------------------------------------------------------------------------------\\012-- Delete MATE_ID_INHIBITOR_OF from table MATERIALS\\012------------------------------------------------------------------------------------\\012\\012-- WARNING: Potential data lost!!!\\012-- WARNING: Potential data lost!!!\\012-- WARNING: Potential data lost!!!\\012\\012ALTER TABLE MATERIALS DROP COLUMN MATE_ID_INHIBITOR_OF;\\012	\N
+./sourceTest/sql/postgresql/055/.svn/text-base/017=database_version_logs.tsv.svn-base:041	source/sql/postgresql/migration/migration-040-041.sql	SUCCESS	2009-09-14 13:48:57.539	-- Create FILTERS table\\012\\012CREATE TABLE FILTERS (ID TECH_ID NOT NULL, DBIN_ID TECH_ID NOT NULL, NAME VARCHAR(200) NOT NULL, DESCRIPTION DESCRIPTION_1000,REGISTRATION_TIMESTAMP TIME_STAMP_DFL NOT NULL DEFAULT CURRENT_TIMESTAMP, PERS_ID_REGISTERER TECH_ID NOT NULL, MODIFICATION_TIMESTAMP TIME_STAMP DEFAULT CURRENT_TIMESTAMP, EXPRESSION VARCHAR(2000) NOT NULL, IS_PUBLIC BOOLEAN NOT NULL, GRID_ID VARCHAR(200) NOT NULL);\\012CREATE SEQUENCE FILTER_ID_SEQ;\\012ALTER TABLE FILTERS ADD CONSTRAINT FILT_PK PRIMARY KEY(ID);\\012ALTER TABLE FILTERS ADD CONSTRAINT FILT_BK_UK UNIQUE(NAME, DBIN_ID, GRID_ID);\\012ALTER TABLE FILTERS ADD CONSTRAINT FILT_PERS_FK FOREIGN KEY (PERS_ID_REGISTERER) REFERENCES PERSONS(ID);\\012ALTER TABLE FILTERS ADD CONSTRAINT FILT_DBIN_FK FOREIGN KEY (DBIN_ID) REFERENCES DATABASE_INSTANCES(ID);\\012CREATE INDEX FILT_PERS_FK_I ON FILTERS (PERS_ID_REGISTERER);\\012CREATE INDEX FILT_DBIN_FK_I ON FILTERS (DBIN_ID);\\012GRANT SELECT ON SEQUENCE filter_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE filters TO GROUP OPENBIS_READONLY;\\012\\012-- Add missing foreign key to role assignments authorization group\\012ALTER TABLE ROLE_ASSIGNMENTS ADD CONSTRAINT ROAS_AG_FK_GRANTEE FOREIGN KEY (AG_ID_GRANTEE) REFERENCES AUTHORIZATION_GROUPS(ID);\\012\\012--------------------------------------------------------------------------------------------------\\012-- Modify dataset connections:\\012-- 1. connection with sample shouldn't be mandatory any more\\012-- 2. introduce an arc condition that dataset cannot be connected with a sample and a parent dataset at the same time\\012--------------------------------------------------------------------------------------------------\\012\\012-- Weaken data-sample connection constraint - allow dataset to have no connection with sample\\012ALTER TABLE data ALTER COLUMN samp_id DROP NOT NULL;\\012\\012-- Remove data-sample connection for datasets that have a parent\\012\\012UPDATE data \\012   SET samp_id = NULL \\012 WHERE id IN (SELECT DISTINCT data_id_child FROM data_set_relationships);\\012\\012-- With PostgreSQL 8.4 one can check that before migration there were no cycles in dataset relationships:\\012--\\012-- WITH RECURSIVE data_set_parents(id, parent_ids, cycle) AS (\\012--         SELECT  r.data_id_child AS id, \\012--                 ARRAY[CAST (r.data_id_parent AS bigint)] AS parent_ids, \\012--                 false AS cycle \\012--         FROM data_set_relationships r\\012--     UNION ALL\\012--         SELECT  r.data_id_child,\\012--                 CAST (r.data_id_parent AS bigint) || p.parent_ids,\\012--                 r.data_id_child = ANY(p.parent_ids)\\012--         FROM data_set_relationships r, data_set_parents p\\012--         WHERE r.data_id_parent = p.id AND NOT cycle\\012-- )\\012-- SELECT count(*) AS cycles FROM data_set_parents WHERE cycle = true;\\012\\012---------------------------------------------------------------------------------------------------\\012--  Purpose:  Create DEFERRED triggers:\\012--            * check_dataset_relationships_on_data_table_modification,\\012--            * check_dataset_relationships_on_relationships_table_modification.\\012--            They check that after all modifications of database (just before commit) \\012--            if 'data'/'data_set_relationships' tables are among modified tables \\012--            dataset is not connected with a sample and a parent dataset at the same time.\\012--            This connections are held in two different tables so simple immediate trigger \\012--            with arc check cannot be used and we need two deferred triggers.\\012----------------------------------------------------------------------------------------------------\\012\\012-- trigger for 'data' table\\012\\012CREATE OR REPLACE FUNCTION check_dataset_relationships_on_data_table_modification() RETURNS trigger AS $$\\012DECLARE\\012\\011counter\\011INTEGER;\\012BEGIN\\012\\011-- if there is a connection with a Sample there should not be any connection with a parent Data Set\\012\\011IF (NEW.samp_id IS NOT NULL) THEN\\012\\011\\011-- count number of parents\\012\\011\\011SELECT count(*) INTO counter \\012\\011\\011\\011FROM data_set_relationships \\012\\011\\011\\011WHERE data_id_child = OLD.id;\\012\\011\\011IF (counter > 0) THEN\\012\\011\\011\\011RAISE EXCEPTION 'Insert/Update of Data Set (Code: %) failed because it cannot be connected with a Sample and a parent Data Set at the same time.', OLD.code;\\012\\011\\011END IF;\\012\\011END IF;\\012  RETURN NEW;\\012END;\\012$$ LANGUAGE 'plpgsql';\\012\\012CREATE CONSTRAINT TRIGGER check_dataset_relationships_on_data_table_modification \\012  AFTER INSERT OR UPDATE ON data\\012\\011DEFERRABLE INITIALLY DEFERRED\\012\\011FOR EACH ROW \\012\\011EXECUTE PROCEDURE check_dataset_relationships_on_data_table_modification();\\012\\012-- trigger for 'data_set_relationships'\\012\\012CREATE OR REPLACE FUNCTION check_dataset_relationships_on_relationships_table_modification() RETURNS trigger AS $$\\012DECLARE\\012\\011counter\\011INTEGER;\\012\\011sample_id\\011TECH_ID;\\012\\011data_code\\011CODE;\\012BEGIN\\012\\011-- child will have a parent added so it should not be connected with any sample\\012\\011SELECT samp_id, code INTO sample_id, data_code \\012\\011\\011FROM data \\012\\011\\011WHERE id = NEW.data_id_child;\\012\\011IF (sample_id IS NOT NULL) THEN\\012\\011\\011RAISE EXCEPTION 'Insert/Update of Data Set (Code: %) failed because it cannot be connected to a Sample and to a parent Data Set at the same time.', data_code;\\012\\011END IF;\\012\\011RETURN NEW;\\012END;\\012$$ LANGUAGE 'plpgsql';\\012  \\012CREATE CONSTRAINT TRIGGER check_dataset_relationships_on_relationships_table_modification \\012  AFTER INSERT OR UPDATE ON data_set_relationships\\012\\011DEFERRABLE INITIALLY DEFERRED\\012\\011FOR EACH ROW \\012\\011EXECUTE PROCEDURE check_dataset_relationships_on_relationships_table_modification();\\012	\N
+./sourceTest/sql/postgresql/055/.svn/text-base/017=database_version_logs.tsv.svn-base:053	source/sql/postgresql/migration/migration-052-053.sql	SUCCESS	2010-06-08 15:27:55.032	-- Migration from 052 to 053\\012\\012-- Change code uniqueness check for samples of specific type.\\012-- If sample_types.is_subcode_unique flag is set to 'true', additional check is performed \\012-- on codes of samples of the type. Subcodes will have to be unique as well.\\012\\012ALTER TABLE sample_types ADD COLUMN is_subcode_unique boolean_char NOT NULL DEFAULT false;\\012\\012CREATE OR REPLACE FUNCTION SAMPLE_SUBCODE_UNIQUENESS_CHECK() RETURNS trigger AS $$\\012DECLARE\\012   counter  INTEGER;\\012   unique_subcode  BOOLEAN_CHAR;\\012BEGIN\\012  LOCK TABLE samples IN EXCLUSIVE MODE;\\012  \\012  SELECT is_subcode_unique into unique_subcode FROM sample_types WHERE id = NEW.saty_id;\\012  \\012  IF (unique_subcode) THEN\\012    IF (NEW.dbin_id is not NULL) THEN\\012\\011\\011\\011SELECT count(*) into counter FROM samples \\012\\011\\011\\011\\011where id != NEW.id and code = NEW.code and saty_id = NEW.saty_id and dbin_id = NEW.dbin_id;\\012\\011\\011\\011IF (counter > 0) THEN\\012\\011\\011\\011\\011RAISE EXCEPTION 'Insert/Update of Sample (Code: %) failed because database instance sample of the same type with the same subcode already exists.', NEW.code;\\012\\011\\011\\011END IF;\\012\\011\\011ELSIF (NEW.grou_id is not NULL) THEN\\012\\011\\011\\011SELECT count(*) into counter FROM samples \\012\\011\\011\\011\\011where id != NEW.id and code = NEW.code and saty_id = NEW.saty_id and grou_id = NEW.grou_id;\\012\\011\\011\\011IF (counter > 0) THEN\\012\\011\\011\\011\\011RAISE EXCEPTION 'Insert/Update of Sample (Code: %) failed because space sample of the same type with the same subcode already exists.', NEW.code;\\012\\011\\011\\011END IF;\\012\\011\\011END IF;\\012  END IF;\\012  \\012  RETURN NEW;\\012END;\\012$$ LANGUAGE 'plpgsql';\\012\\012CREATE TRIGGER SAMPLE_SUBCODE_UNIQUENESS_CHECK BEFORE INSERT OR UPDATE ON SAMPLES\\012    FOR EACH ROW EXECUTE PROCEDURE SAMPLE_SUBCODE_UNIQUENESS_CHECK();\\012    \\012-- Fixing error messages in old trigger\\012\\012CREATE OR REPLACE FUNCTION SAMPLE_CODE_UNIQUENESS_CHECK() RETURNS trigger AS $$\\012DECLARE\\012   counter  INTEGER;\\012BEGIN\\012  LOCK TABLE samples IN EXCLUSIVE MODE;\\012  \\012\\011  IF (NEW.samp_id_part_of is NULL) THEN\\012\\011\\011  IF (NEW.dbin_id is not NULL) THEN\\012\\011\\011\\011  SELECT count(*) into counter FROM samples \\012\\011\\011      where id != NEW.id and code = NEW.code and samp_id_part_of is NULL and dbin_id = NEW.dbin_id;\\012        IF (counter > 0) THEN\\012\\011\\011\\011\\011  RAISE EXCEPTION 'Insert/Update of Sample (Code: %) failed because database instance sample with the same code already exists.', NEW.code;\\012        END IF;\\012\\011\\011  ELSIF (NEW.grou_id is not NULL) THEN\\012\\011\\011\\011  SELECT count(*) into counter FROM samples \\012\\011\\011\\011\\011  where id != NEW.id and code = NEW.code and samp_id_part_of is NULL and grou_id = NEW.grou_id;\\012\\011\\011\\011  IF (counter > 0) THEN\\012\\011\\011\\011\\011  RAISE EXCEPTION 'Insert/Update of Sample (Code: %) failed because space sample with the same code already exists.', NEW.code;\\012\\011\\011\\011  END IF;\\012      END IF;\\012    ELSE\\012\\011\\011  IF (NEW.dbin_id is not NULL) THEN\\012\\011\\011\\011  SELECT count(*) into counter FROM samples \\012\\011\\011\\011\\011  where id != NEW.id and code = NEW.code and samp_id_part_of = NEW.samp_id_part_of and dbin_id = NEW.dbin_id;\\012\\011\\011\\011  IF (counter > 0) THEN\\012\\011\\011\\011\\011  RAISE EXCEPTION 'Insert/Update of Sample (Code: %) failed because database instance sample with the same code and being the part of the same container already exists.', NEW.code;\\012\\011\\011\\011  END IF;\\012\\011\\011  ELSIF (NEW.grou_id is not NULL) THEN\\012\\011\\011\\011  SELECT count(*) into counter FROM samples \\012\\011\\011\\011\\011  where id != NEW.id and code = NEW.code and samp_id_part_of = NEW.samp_id_part_of and grou_id = NEW.grou_id;\\012\\011\\011\\011  IF (counter > 0) THEN\\012\\011\\011\\011\\011  RAISE EXCEPTION 'Insert/Update of Sample (Code: %) failed because space sample with the same code and being the part of the same container already exists.', NEW.code;\\012\\011\\011\\011  END IF;\\012\\011\\011  END IF;\\012     END IF;   \\012  \\012  RETURN NEW;\\012END;\\012$$ LANGUAGE 'plpgsql';\\012	\N
+./sourceTest/sql/postgresql/055/.svn/text-base/017=database_version_logs.tsv.svn-base:054	source/sql/postgresql/migration/migration-053-054.sql	SUCCESS	2010-07-27 11:30:46.766	-- Migration from 053 to 054\\012\\012\\012-- Add RELATIONSHIP_TYPES table\\012CREATE TABLE relationship_types (id TECH_ID NOT NULL, code CODE NOT NULL, label COLUMN_LABEL, parent_label COLUMN_LABEL, child_label COLUMN_LABEL, description DESCRIPTION_2000, registration_timestamp TIME_STAMP_DFL NOT NULL DEFAULT CURRENT_TIMESTAMP, pers_id_registerer TECH_ID NOT NULL, is_managed_internally BOOLEAN_CHAR NOT NULL DEFAULT 'F', is_internal_namespace BOOLEAN_CHAR NOT NULL DEFAULT 'F', dbin_id TECH_ID NOT NULL);\\012\\012-- Add SAMPLE_RELATIONSHIPS table\\012CREATE TABLE sample_relationships (id TECH_ID NOT NULL, sample_id_parent TECH_ID NOT NULL, relationship_id TECH_ID NOT NULL, sample_id_child TECH_ID NOT NULL);\\012\\012-- Add/update constraints\\012ALTER TABLE relationship_types ADD CONSTRAINT rety_pk PRIMARY KEY (id);\\012ALTER TABLE relationship_types ADD CONSTRAINT rety_uk UNIQUE(code,dbin_id);\\012ALTER TABLE sample_relationships ADD CONSTRAINT sare_pk PRIMARY KEY (id);\\012ALTER TABLE sample_relationships ADD CONSTRAINT sare_bk_uk UNIQUE(sample_id_child,sample_id_parent,relationship_id);\\012ALTER TABLE sample_relationships ADD CONSTRAINT sare_data_fk_child FOREIGN KEY (sample_id_child) REFERENCES samples(id) ON DELETE CASCADE;\\012ALTER TABLE sample_relationships ADD CONSTRAINT sare_data_fk_parent FOREIGN KEY (sample_id_parent) REFERENCES samples(id) ON DELETE CASCADE;\\012ALTER TABLE sample_relationships ADD CONSTRAINT sare_data_fk_relationship FOREIGN KEY (relationship_id) REFERENCES relationship_types(id);\\012\\012-- Create index\\012CREATE INDEX sare_data_fk_i_child ON sample_relationships (sample_id_child);\\012CREATE INDEX sare_data_fk_i_parent ON sample_relationships (sample_id_parent);\\012CREATE INDEX sare_data_fk_i_relationship ON sample_relationships (relationship_id);\\012\\012-- Create sequence for RELATIONSHIP_TYPES\\012CREATE SEQUENCE RELATIONSHIP_TYPE_ID_SEQ;\\012CREATE SEQUENCE SAMPLE_RELATIONSHIP_ID_SEQ;\\012\\012-- Create initial relationships\\012insert into relationship_types\\012(id, \\012code, \\012label, \\012parent_label, \\012child_label, \\012description, \\012pers_id_registerer, \\012is_managed_internally, \\012is_internal_namespace, \\012dbin_id) \\012values\\012(\\012nextval('RELATIONSHIP_TYPE_ID_SEQ'),\\012'PARENT_CHILD',\\012'Parent - Child', \\012'Parent', \\012'Child', \\012'Parent - Child relationship', \\012(select id from persons where user_id ='system'), \\012'T', \\012'T', \\012(select id from database_instances where is_original_source = 'T')\\012);\\012\\012insert into relationship_types\\012(id, \\012code, \\012label, \\012parent_label, \\012child_label, \\012description, \\012pers_id_registerer, \\012is_managed_internally, \\012is_internal_namespace, \\012dbin_id) \\012values\\012(\\012nextval('RELATIONSHIP_TYPE_ID_SEQ'),\\012'PLATE_CONTROL_LAYOUT',\\012'Plate - Control Layout', \\012'Plate', \\012'Control Layout', \\012'Plate - Control Layout relationship', \\012(select id from persons where user_id ='system'), \\012'T', \\012'T', \\012(select id from database_instances where is_original_source = 'T')\\012); \\012\\012\\012-- Migrate sample relationships to new schema\\012INSERT INTO sample_relationships (id, sample_id_parent,sample_id_child,relationship_id) (select distinct nextval('SAMPLE_RELATIONSHIP_ID_SEQ') as id, s.SAMP_ID_GENERATED_FROM as parent_id, s.ID as child_id, rt.id as relationship_id from samples s, relationship_types rt  WHERE rt.code = 'PARENT_CHILD' and s.SAMP_ID_GENERATED_FROM is not null); \\012INSERT INTO sample_relationships (id, sample_id_parent,sample_id_child,relationship_id) (select distinct nextval('SAMPLE_RELATIONSHIP_ID_SEQ') as id, s.SAMP_ID_CONTROL_LAYOUT as parent_id, s.ID as child_id, rt.id as relationship_id from samples s, relationship_types rt  WHERE rt.code = 'PLATE_CONTROL_LAYOUT' and s.SAMP_ID_CONTROL_LAYOUT is not null);\\012\\012-- Drop old sample relations\\012ALTER TABLE SAMPLES DROP COLUMN SAMP_ID_TOP;\\012ALTER TABLE SAMPLES DROP COLUMN SAMP_ID_GENERATED_FROM;\\012ALTER TABLE SAMPLES DROP COLUMN SAMP_ID_CONTROL_LAYOUT;\\012\\012--------------------------------------------------------------------------------------\\012--------------------------------------------------------------------------------------\\012-- This is a screening specific migration. Nothing will be performed on openBIS databases \\012-- which are not screening specific.\\012-- \\012-- This migration for each existing connection between oligo well, oligo material and gene material\\012-- creates a direct connection between the well and the gene. \\012--------------------------------------------------------------------------------------\\012--------------------------------------------------------------------------------------\\012 \\012\\011\\012CREATE OR REPLACE FUNCTION CONNECT_WELLS_WITH_GENES() RETURNS void AS $$\\012DECLARE\\012\\011counter  int;\\012\\011oligo_well_exists bool;\\012BEGIN\\012\\011--------------------------------------------------\\012\\011-- create a gene property and assign it to oligo well\\012\\011--------------------------------------------------\\012\\011\\012\\011select true \\012\\011into oligo_well_exists\\012\\011from sample_types \\012\\011where code = 'OLIGO_WELL';\\012\\011\\012\\011if oligo_well_exists IS NULL then \\012\\011\\011-- skip migration if there are no oligo wells\\012\\011\\011return;\\012\\011end if;   \\012\\011\\012\\011insert into property_types(\\012\\011\\011id, \\012\\011\\011code, description, label, \\012\\011\\011daty_id,\\012\\011\\011pers_id_registerer,\\012\\011\\011dbin_id,\\012\\011\\011maty_prop_id) \\012\\011values(\\012\\011\\011\\011nextval('PROPERTY_TYPE_ID_SEQ'), \\012\\011\\011\\011'GENE','Inhibited gene','Gene',\\012\\011\\011\\011(select id from data_types where code = 'MATERIAL'), \\012\\011\\011\\011(select id from persons where user_id ='system'), \\012\\011\\011\\011(select id from database_instances where is_original_source = 'T'), \\012\\011\\011\\011(select id from material_types where code = 'GENE')\\012\\011\\011);\\012\\011\\011\\012\\011insert into sample_type_property_types( \\012\\011  id,\\012\\011  saty_id,\\012\\011  prty_id,\\012\\011  is_mandatory,\\012\\011  pers_id_registerer,\\012\\011  ordinal\\012\\011) values(\\012\\011\\011\\011nextval('stpt_id_seq'), \\012\\011\\011\\011(select id from sample_types where code = 'OLIGO_WELL'),\\012\\011\\011\\011(select id from property_types where code = 'GENE'),\\012\\011\\011\\011false,\\012\\011\\011\\011(select id from persons where user_id ='system'),\\012\\011\\011\\011(select max(ordinal)+1 from sample_type_property_types \\012\\011\\011\\011\\011where saty_id = (select id from sample_types where code = 'OLIGO_WELL'))\\012\\011\\011);\\012\\012\\011--------------------------------------------------\\012\\011-- create a gene material property for each oligo well\\012\\011--------------------------------------------------\\012\\011\\011\\012\\011select \\011count(*)\\012\\011into counter\\012\\011from\\012\\011\\011samples well, sample_types well_type, sample_properties well_props, \\012\\011\\011materials well_material, material_properties well_material_props,\\012\\011\\011materials nested_well_material\\012\\011where\\012\\011\\011well_type.code = 'OLIGO_WELL' and\\012\\011\\011-- find 'well_material' assigned to the well\\012\\011\\011well_props.samp_id = well.id and well_material.id = well_props.mate_prop_id and \\012\\011\\011-- additional joins to entity type tables\\012\\011\\011well_type.id = well.saty_id and\\012\\011\\011-- well content material property\\012\\011\\011well_material_props.mate_id = well_material.id and \\012\\011\\011-- material connected to the material in the well (e.g. gene)\\012\\011\\011well_material_props.mate_prop_id = nested_well_material.id and\\012\\011\\011nested_well_material.maty_id = (select id from material_types where code = 'GENE');\\012\\011\\012\\011if counter = 0 then \\012\\011\\011-- skip migration if there are no genes indirectly connected to oligo wells\\012\\011\\011return;\\012\\011end if;   \\012\\012\\011insert into sample_properties(id, samp_id, stpt_id, mate_prop_id, pers_id_registerer) (\\012\\011\\011select \\011nextval('sample_property_id_seq') id, \\012\\011\\011\\011well.id samp_id, \\012\\011\\011\\011(select stpt.id from sample_type_property_types stpt, property_types props where stpt.prty_id = props.id and props.code='GENE') stpt_id,\\012\\011\\011\\011nested_well_material.id mate_prop_id,\\012\\011\\011\\011(select id from persons where user_id ='system') pers_id_registerer \\012\\011\\011from\\012\\011\\011\\011samples well, sample_types well_type, sample_properties well_props, \\012\\011\\011\\011materials well_material, material_properties well_material_props,\\012\\011\\011\\011materials nested_well_material\\012\\011\\011where\\012\\011\\011\\011well_type.code = 'OLIGO_WELL' and\\012\\011\\011\\011-- find 'well_material' assigned to the well\\012\\011\\011\\011well_props.samp_id = well.id and well_material.id = well_props.mate_prop_id and \\012\\011\\011\\011-- additional joins to entity type tables\\012\\011\\011\\011well_type.id = well.saty_id and\\012\\011\\011\\011-- well content material property\\012\\011\\011\\011well_material_props.mate_id = well_material.id and \\012\\011\\011\\011-- material connected to the material in the well (e.g. gene)\\012\\011\\011\\011well_material_props.mate_prop_id = nested_well_material.id and\\012\\011\\011\\011nested_well_material.maty_id = (select id from material_types where code = 'GENE')\\012\\011);\\012\\012END;\\012$$ LANGUAGE 'plpgsql';\\012\\012select CONNECT_WELLS_WITH_GENES();\\012drop function CONNECT_WELLS_WITH_GENES();\\012\\012--------------------------------------------------------------------------------------\\012--------------------------------------------------------------------------------------\\012\\012-- drop dataset triggers\\012\\012DROP TRIGGER check_dataset_relationships_on_data_table_modification ON data;\\012DROP FUNCTION check_dataset_relationships_on_data_table_modification();\\012DROP TRIGGER check_dataset_relationships_on_relationships_table_modification ON data_set_relationships;\\012DROP FUNCTION check_dataset_relationships_on_relationships_table_modification();\\012 \\012\\012\\012\\012\\012\\012\\012\\012	\N
+./sourceTest/sql/postgresql/055/.svn/text-base/schema-055.sql.svn-base:    LANGUAGE plpgsql
+./sourceTest/sql/postgresql/055/.svn/text-base/schema-055.sql.svn-base:    LANGUAGE plpgsql
+./sourceTest/sql/postgresql/055/.svn/text-base/schema-055.sql.svn-base:    LANGUAGE plpgsql
+./sourceTest/sql/postgresql/055/.svn/text-base/schema-055.sql.svn-base:    LANGUAGE plpgsql
+./sourceTest/sql/postgresql/055/.svn/text-base/schema-055.sql.svn-base:    LANGUAGE plpgsql
+./sourceTest/sql/postgresql/055/.svn/text-base/schema-055.sql.svn-base:    LANGUAGE plpgsql
+./sourceTest/sql/postgresql/055/.svn/text-base/schema-055.sql.svn-base:    LANGUAGE plpgsql
+./sourceTest/sql/postgresql/055/.svn/text-base/schema-055.sql.svn-base:    LANGUAGE plpgsql
+./sourceTest/sql/postgresql/055/.svn/text-base/schema-055.sql.svn-base:    LANGUAGE plpgsql
+./sourceTest/sql/postgresql/055/017=database_version_logs.tsv:027	D:\\User\\felmer\\dev-workspace\\openbis/source/sql/postgresql/027/function-027.sql	SUCCESS	2008-11-05 09:18:00.403	-- Creating Functions\\012\\012------------------------------------------------------------------------------------\\012--  Purpose:  Create function RENAME_SEQUENCE() that is required for renaming the sequences belonging to tables\\012------------------------------------------------------------------------------------\\012CREATE FUNCTION RENAME_SEQUENCE(OLD_NAME VARCHAR, NEW_NAME VARCHAR) RETURNS INTEGER AS $$\\012DECLARE\\012  CURR_SEQ_VAL   INTEGER;\\012BEGIN\\012  SELECT INTO CURR_SEQ_VAL NEXTVAL(OLD_NAME);\\012  EXECUTE 'CREATE SEQUENCE ' || NEW_NAME || ' START WITH ' || CURR_SEQ_VAL;\\012  EXECUTE 'DROP SEQUENCE ' || OLD_NAME;\\012  RETURN CURR_SEQ_VAL;\\012END;\\012$$ LANGUAGE 'plpgsql';\\012\\012\\012------------------------------------------------------------------------------------\\012--  Purpose:  Create trigger CONTROLLED_VOCABULARY_CHECK \\012------------------------------------------------------------------------------------\\012\\012CREATE OR REPLACE FUNCTION CONTROLLED_VOCABULARY_CHECK() RETURNS trigger AS $$\\012DECLARE\\012   v_code  CODE;\\012BEGIN\\012\\012   select code into v_code from data_types where id = NEW.daty_id;\\012\\012   -- Check if the data is of type "CONTROLLEDVOCABULARY"\\012   if v_code = 'CONTROLLEDVOCABULARY' then\\012      if NEW.covo_id IS NULL then\\012         RAISE EXCEPTION 'Insert/Update of Property Type (Code: %) failed, as its Data Type is CONTROLLEDVOCABULARY, but it is not linked to a Controlled Vocabulary.', NEW.code;\\012      end if;\\012   end if;\\012\\012   RETURN NEW;\\012\\012END;\\012$$ LANGUAGE 'plpgsql';\\012\\012CREATE TRIGGER CONTROLLED_VOCABULARY_CHECK BEFORE INSERT OR UPDATE ON PROPERTY_TYPES\\012    FOR EACH ROW EXECUTE PROCEDURE CONTROLLED_VOCABULARY_CHECK();\\012\\012\\012------------------------------------------------------------------------------------\\012--  Purpose:  Create trigger EXTERNAL_DATA_STORAGE_FORMAT_CHECK \\012------------------------------------------------------------------------------------\\012\\012CREATE OR REPLACE FUNCTION EXTERNAL_DATA_STORAGE_FORMAT_CHECK() RETURNS trigger AS $$\\012DECLARE\\012   v_covo_code  CODE;\\012   data_code CODE;\\012BEGIN\\012\\012   select code into v_covo_code from controlled_vocabularies\\012      where is_internal_namespace = true and \\012         id = (select covo_id from controlled_vocabulary_terms where id = NEW.cvte_id_stor_fmt);\\012   -- Check if the data storage format is a term of the controlled vocabulary "STORAGE_FORMAT"\\012   if v_covo_code != 'STORAGE_FORMAT' then\\012      select code into data_code from data where id = NEW.data_id; \\012      RAISE EXCEPTION 'Insert/Update of Data (Code: %) failed, as its Storage Format is %, but is required to be STORAGE_FORMAT.', data_code, v_covo_code;\\012   end if;\\012\\012   RETURN NEW;\\012\\012END;\\012$$ LANGUAGE 'plpgsql';\\012\\012CREATE TRIGGER EXTERNAL_DATA_STORAGE_FORMAT_CHECK BEFORE INSERT OR UPDATE ON EXTERNAL_DATA\\012    FOR EACH ROW EXECUTE PROCEDURE EXTERNAL_DATA_STORAGE_FORMAT_CHECK();\\012\\012------------------------------------------------------------------------------------\\012--  Purpose:  Create trigger SAMPLE_CODE_UNIQUENESS_CHECK \\012------------------------------------------------------------------------------------\\012\\012CREATE OR REPLACE FUNCTION SAMPLE_CODE_UNIQUENESS_CHECK() RETURNS trigger AS $$\\012DECLARE\\012   counter  INTEGER;\\012BEGIN\\012\\011IF (NEW.samp_id_part_of is NULL) THEN\\012\\011\\011IF (NEW.dbin_id is not NULL) THEN\\012\\011\\011\\011SELECT count(*) into counter FROM samples \\012\\011\\011\\011\\011where id != NEW.id and code = NEW.code and samp_id_part_of is NULL and dbin_id = NEW.dbin_id;\\012\\011\\011\\011IF (counter > 0) THEN\\012\\011\\011\\011\\011RAISE EXCEPTION 'Insert/Update of Sample (Code: %) failed because database instance sample with the same code already exists.', NEW.code;\\012\\011\\011\\011END IF;\\012\\011\\011ELSIF (NEW.grou_id is not NULL) THEN\\012\\011\\011\\011SELECT count(*) into counter FROM samples \\012\\011\\011\\011\\011where id != NEW.id and code = NEW.code and samp_id_part_of is NULL and grou_id = NEW.grou_id;\\012\\011\\011\\011IF (counter > 0) THEN\\012\\011\\011\\011\\011RAISE EXCEPTION 'Insert/Update of Sample (Code: %) failed because group sample with the same code already exists.', NEW.code;\\012\\011\\011\\011END IF;\\012\\011\\011END IF;\\012        ELSE\\012\\011\\011IF (NEW.dbin_id is not NULL) THEN\\012\\011\\011\\011SELECT count(*) into counter FROM samples \\012\\011\\011\\011\\011where id != NEW.id and code = NEW.code and samp_id_part_of = NEW.samp_id_part_of and dbin_id = NEW.dbin_id;\\012\\011\\011\\011IF (counter > 0) THEN\\012\\011\\011\\011\\011RAISE EXCEPTION 'Insert/Update of Sample (Code: %) failed because database instance sample with the same code and being the part of the same parent already exists.', NEW.code;\\012\\011\\011\\011END IF;\\012\\011\\011ELSIF (NEW.grou_id is not NULL) THEN\\012\\011\\011\\011SELECT count(*) into counter FROM samples \\012\\011\\011\\011\\011where id != NEW.id and code = NEW.code and samp_id_part_of = NEW.samp_id_part_of and grou_id = NEW.grou_id;\\012\\011\\011\\011IF (counter > 0) THEN\\012\\011\\011\\011\\011RAISE EXCEPTION 'Insert/Update of Sample (Code: %) failed because group sample with the same code and being the part of the same parent already exists.', NEW.code;\\012\\011\\011\\011END IF;\\012\\011\\011END IF;\\012        END IF;   \\012   RETURN NEW;\\012END;\\012$$ LANGUAGE 'plpgsql';\\012\\012CREATE TRIGGER SAMPLE_CODE_UNIQUENESS_CHECK BEFORE INSERT OR UPDATE ON SAMPLES\\012    FOR EACH ROW EXECUTE PROCEDURE SAMPLE_CODE_UNIQUENESS_CHECK();\\012	\N
+./sourceTest/sql/postgresql/055/017=database_version_logs.tsv:028	source/sql/postgresql/migration/migration-027-028.sql	SUCCESS	2008-11-18 13:24:17.508	-- Create EXPERIMENT_ATTACHMENT_CONTENTS.\\012CREATE TABLE EXPERIMENT_ATTACHMENT_CONTENTS (ID TECH_ID NOT NULL,VALUE FILE NOT NULL);\\012CREATE SEQUENCE EXPERIMENT_ATTACHMENT_CONTENT_ID_SEQ;\\012ALTER TABLE EXPERIMENT_ATTACHMENT_CONTENTS ADD CONSTRAINT EXAC_PK PRIMARY KEY(ID);\\012\\012-- Alter EXPERIMENT_ATTACHMENTS by adding the new column which has a NULL constraint.\\012-- The NOT NULL constraint is added later on.\\012ALTER TABLE EXPERIMENT_ATTACHMENTS ADD COLUMN EXAC_ID TECH_ID;\\012\\012-- Does the VALUE migration between EXPERIMENT_ATTACHMENTS to EXPERIMENT_ATTACHMENT_CONTENTS.\\012CREATE OR REPLACE FUNCTION move_exp_att_content() RETURNS integer AS $$\\012DECLARE\\012    rec RECORD;\\012    seq BIGINT;\\012BEGIN\\012  FOR rec IN SELECT id, value FROM EXPERIMENT_ATTACHMENTS LOOP\\012  \\011seq := nextval('EXPERIMENT_ATTACHMENT_CONTENT_ID_SEQ');\\012    INSERT INTO EXPERIMENT_ATTACHMENT_CONTENTS (id, value) VALUES (seq, rec.value);\\012    UPDATE EXPERIMENT_ATTACHMENTS SET exac_id = seq WHERE id = rec.id;\\012  END LOOP;\\012  RETURN 1;\\012END;\\012$$ LANGUAGE 'plpgsql';\\012\\012-- Call the function.\\012SELECT move_exp_att_content();\\012DROP FUNCTION move_exp_att_content();\\012\\012\\012-- Finish EXPERIMENT_ATTACHMENTS changes.\\012ALTER TABLE EXPERIMENT_ATTACHMENTS ADD CONSTRAINT EXAT_CONT_FK FOREIGN KEY (EXAC_ID) REFERENCES EXPERIMENT_ATTACHMENT_CONTENTS(ID);\\012ALTER TABLE EXPERIMENT_ATTACHMENTS DROP COLUMN VALUE;\\012ALTER TABLE EXPERIMENT_ATTACHMENTS ALTER COLUMN EXAC_ID SET NOT NULL;\\012	\N
+./sourceTest/sql/postgresql/055/017=database_version_logs.tsv:029	source/sql/postgresql/migration/migration-028-029.sql	SUCCESS	2009-03-18 10:50:20.105	-- -------\\012-- add modification_timestamp field to allow edition with Hibernate\\012-- -------\\012\\012ALTER TABLE samples\\012\\011ADD COLUMN modification_timestamp TIME_STAMP DEFAULT CURRENT_TIMESTAMP;\\012\\012ALTER TABLE experiments\\012\\011ADD COLUMN modification_timestamp TIME_STAMP DEFAULT CURRENT_TIMESTAMP;\\012\\012ALTER TABLE materials\\012\\011ADD COLUMN modification_timestamp TIME_STAMP DEFAULT CURRENT_TIMESTAMP;\\012\\012ALTER TABLE experiment_properties\\012\\011ADD COLUMN modification_timestamp TIME_STAMP DEFAULT CURRENT_TIMESTAMP;\\012\\012ALTER TABLE material_properties\\012\\011ADD COLUMN modification_timestamp TIME_STAMP DEFAULT CURRENT_TIMESTAMP;\\012\\012ALTER TABLE sample_properties\\012\\011ADD COLUMN modification_timestamp TIME_STAMP DEFAULT CURRENT_TIMESTAMP;\\012\\012-- -------\\012-- add property data type which references materials\\012-- -------\\012\\012ALTER TABLE property_types\\012\\011ADD COLUMN maty_prop_id tech_id;\\012\\012ALTER TABLE property_types\\012\\011ADD CONSTRAINT prty_maty_fk FOREIGN KEY (maty_prop_id) REFERENCES material_types(id);\\012\\012ALTER TABLE experiment_properties\\012\\011ADD COLUMN mate_prop_id tech_id;\\012\\012ALTER TABLE material_properties\\012\\011ADD COLUMN mate_prop_id tech_id;\\012\\012ALTER TABLE sample_properties\\012\\011ADD COLUMN mate_prop_id tech_id;\\012\\012ALTER TABLE experiment_properties\\012\\011ADD CONSTRAINT expr_mapr_fk FOREIGN KEY (mate_prop_id) REFERENCES materials(id);\\012\\012ALTER TABLE material_properties\\012\\011ADD CONSTRAINT mapr_mapr_fk FOREIGN KEY (mate_prop_id) REFERENCES materials(id);\\012\\012ALTER TABLE sample_properties\\012\\011ADD CONSTRAINT sapr_mapr_fk FOREIGN KEY (mate_prop_id) REFERENCES materials(id);\\012\\012insert into data_types\\012(id\\012 ,code\\012 ,description)\\012 values \\012 (nextval('DATA_TYPE_ID_SEQ')\\012 ,'MATERIAL'\\012 ,'Reference to a material'\\012);\\012\\012ALTER TABLE MATERIAL_PROPERTIES DROP CONSTRAINT MAPR_CK;\\012ALTER TABLE MATERIAL_PROPERTIES ADD CONSTRAINT MAPR_CK CHECK \\012\\011((VALUE IS NOT NULL AND CVTE_ID IS NULL AND MATE_PROP_ID IS NULL) OR \\012\\011 (VALUE IS NULL AND CVTE_ID IS NOT NULL AND MATE_PROP_ID IS NULL) OR\\012\\011 (VALUE IS NULL AND CVTE_ID IS NULL AND MATE_PROP_ID IS NOT NULL)\\012\\011);\\012\\012ALTER TABLE EXPERIMENT_PROPERTIES DROP CONSTRAINT EXPR_CK;\\012ALTER TABLE EXPERIMENT_PROPERTIES ADD CONSTRAINT EXPR_CK CHECK \\012\\011((VALUE IS NOT NULL AND CVTE_ID IS NULL AND MATE_PROP_ID IS NULL) OR \\012\\011 (VALUE IS NULL AND CVTE_ID IS NOT NULL AND MATE_PROP_ID IS NULL) OR\\012\\011 (VALUE IS NULL AND CVTE_ID IS NULL AND MATE_PROP_ID IS NOT NULL)\\012\\011);\\012\\012ALTER TABLE SAMPLE_PROPERTIES DROP CONSTRAINT SAPR_CK;\\012ALTER TABLE SAMPLE_PROPERTIES ADD CONSTRAINT SAPR_CK CHECK \\012\\011((VALUE IS NOT NULL AND CVTE_ID IS NULL AND MATE_PROP_ID IS NULL) OR \\012\\011 (VALUE IS NULL AND CVTE_ID IS NOT NULL AND MATE_PROP_ID IS NULL) OR\\012\\011 (VALUE IS NULL AND CVTE_ID IS NULL AND MATE_PROP_ID IS NOT NULL)\\012\\011);\\012\\012------------------------------------------------------------------------------------\\012--  Purpose:  Create trigger MATERIAL/SAMPLE/EXPERIMENT _PROPERTY_WITH_MATERIAL_DATA_TYPE_CHECK\\012--            It checks that if material property value is assigned to the entity,\\012--\\011\\011\\011\\011\\011\\011then the material type is equal to the one described by property type.\\012------------------------------------------------------------------------------------\\012\\012CREATE OR REPLACE FUNCTION MATERIAL_PROPERTY_WITH_MATERIAL_DATA_TYPE_CHECK() RETURNS trigger AS $$\\012DECLARE\\012   v_type_id  CODE;\\012   v_type_id_prop  CODE;\\012BEGIN\\012   if NEW.mate_prop_id IS NOT NULL then\\012\\011\\011\\011-- find material type id of the property type \\012\\011\\011\\011select pt.maty_prop_id into v_type_id_prop \\012\\011\\011\\011  from material_type_property_types etpt, property_types pt \\012\\011\\011\\011 where NEW.mtpt_id = etpt.id AND etpt.prty_id = pt.id;\\012\\011\\011\\012\\011\\011\\011if v_type_id_prop IS NOT NULL then\\012\\011\\011\\011\\011-- find material type id of the material which consists the entity's property value\\012\\011\\011\\011\\011select entity.maty_id into v_type_id \\012\\011\\011\\011\\011  from materials entity\\012\\011\\011\\011\\011 where NEW.mate_prop_id = entity.id;\\012\\011\\011\\011\\011if v_type_id != v_type_id_prop then\\012\\011\\011\\011\\011\\011RAISE EXCEPTION 'Insert/Update of property value referencing material (id: %) failed, as referenced material type is different than expected (id %, expected id: %).', \\012\\011\\011\\011\\011\\011\\011\\011 NEW.mate_prop_id, v_type_id, v_type_id_prop;\\012\\011\\011\\011\\011end if;\\012\\011\\011\\011end if;\\012   end if;\\012   RETURN NEW;\\012END;\\012$$ LANGUAGE 'plpgsql';\\012\\012CREATE TRIGGER MATERIAL_PROPERTY_WITH_MATERIAL_DATA_TYPE_CHECK BEFORE INSERT OR UPDATE ON material_properties\\012    FOR EACH ROW EXECUTE PROCEDURE MATERIAL_PROPERTY_WITH_MATERIAL_DATA_TYPE_CHECK();\\012    \\012CREATE OR REPLACE FUNCTION SAMPLE_PROPERTY_WITH_MATERIAL_DATA_TYPE_CHECK() RETURNS trigger AS $$\\012DECLARE\\012   v_type_id  CODE;\\012   v_type_id_prop  CODE;\\012BEGIN\\012   if NEW.mate_prop_id IS NOT NULL then\\012\\011\\011\\011-- find material type id of the property type \\012\\011\\011\\011select pt.maty_prop_id into v_type_id_prop \\012\\011\\011\\011  from sample_type_property_types etpt, property_types pt \\012\\011\\011\\011 where NEW.stpt_id = etpt.id AND etpt.prty_id = pt.id;\\012\\011\\011\\012\\011\\011\\011if v_type_id_prop IS NOT NULL then\\012\\011\\011\\011\\011-- find material type id of the material which consists the entity's property value\\012\\011\\011\\011\\011select entity.maty_id into v_type_id \\012\\011\\011\\011\\011  from materials entity\\012\\011\\011\\011\\011 where NEW.mate_prop_id = entity.id;\\012\\011\\011\\011\\011if v_type_id != v_type_id_prop then\\012\\011\\011\\011\\011\\011RAISE EXCEPTION 'Insert/Update of property value referencing material (id: %) failed, as referenced material type is different than expected (id %, expected id: %).', \\012\\011\\011\\011\\011\\011\\011\\011\\011\\011\\011\\011\\011 NEW.mate_prop_id, v_type_id, v_type_id_prop;\\012\\011\\011\\011\\011end if;\\012\\011\\011\\011end if;\\012   end if;\\012   RETURN NEW;\\012END;\\012$$ LANGUAGE 'plpgsql';\\012\\012CREATE TRIGGER SAMPLE_PROPERTY_WITH_MATERIAL_DATA_TYPE_CHECK BEFORE INSERT OR UPDATE ON sample_properties\\012    FOR EACH ROW EXECUTE PROCEDURE SAMPLE_PROPERTY_WITH_MATERIAL_DATA_TYPE_CHECK();\\012    \\012CREATE OR REPLACE FUNCTION EXPERIMENT_PROPERTY_WITH_MATERIAL_DATA_TYPE_CHECK() RETURNS trigger AS $$\\012DECLARE\\012   v_type_id  CODE;\\012   v_type_id_prop  CODE;\\012BEGIN\\012   if NEW.mate_prop_id IS NOT NULL then\\012\\011\\011\\011-- find material type id of the property type \\012\\011\\011\\011select pt.maty_prop_id into v_type_id_prop \\012\\011\\011\\011  from experiment_type_property_types etpt, property_types pt \\012\\011\\011\\011 where NEW.etpt_id = etpt.id AND etpt.prty_id = pt.id;\\012\\011\\011\\012\\011\\011\\011if v_type_id_prop IS NOT NULL then\\012\\011\\011\\011\\011-- find material type id of the material which consists the entity's property value\\012\\011\\011\\011\\011select entity.maty_id into v_type_id \\012\\011\\011\\011\\011  from materials entity\\012\\011\\011\\011\\011 where NEW.mate_prop_id = entity.id;\\012\\011\\011\\011\\011if v_type_id != v_type_id_prop then\\012\\011\\011\\011\\011\\011RAISE EXCEPTION 'Insert/Update of property value referencing material (id: %) failed, as referenced material type is different than expected (id %, expected id: %).', \\012\\011\\011\\011\\011\\011\\011\\011\\011\\011\\011\\011\\011 NEW.mate_prop_id, v_type_id, v_type_id_prop;\\012\\011\\011\\011\\011end if;\\012\\011\\011\\011end if;\\012   end if;\\012   RETURN NEW;\\012END;\\012$$ LANGUAGE 'plpgsql';\\012\\012CREATE TRIGGER EXPERIMENT_PROPERTY_WITH_MATERIAL_DATA_TYPE_CHECK BEFORE INSERT OR UPDATE ON experiment_properties\\012    FOR EACH ROW EXECUTE PROCEDURE EXPERIMENT_PROPERTY_WITH_MATERIAL_DATA_TYPE_CHECK();\\012       \\012-- -------\\012-- remove the reminescents of the OBSERVABLE_TYPE\\012-- -------\\012\\012ALTER TABLE data\\012\\011DROP CONSTRAINT data_obty_fk;\\012\\012ALTER TABLE data_set_types\\012\\011DROP CONSTRAINT obty_pk;\\012\\012ALTER TABLE data_set_types\\012\\011ADD CONSTRAINT dsty_pk PRIMARY KEY (id);\\012\\012ALTER TABLE data\\012\\011ADD CONSTRAINT data_dsty_fk FOREIGN KEY (dsty_id) REFERENCES data_set_types(id);\\012\\012ALTER TABLE data_set_types\\012\\011DROP CONSTRAINT obty_bk_uk;\\012\\012ALTER TABLE data_set_types\\012\\011DROP CONSTRAINT obty_dbin_fk;\\012\\012ALTER TABLE data_set_types\\012\\011ADD CONSTRAINT dsty_bk_uk UNIQUE (code, dbin_id);\\012\\012ALTER TABLE data_set_types\\012\\011ADD CONSTRAINT dsty_dbin_fk FOREIGN KEY (dbin_id) REFERENCES database_instances(id);\\012\\012DROP INDEX data_obty_fk_i;\\012\\012CREATE INDEX data_dsty_fk_i ON data(dsty_id);\\012	\N
+./sourceTest/sql/postgresql/055/017=database_version_logs.tsv:030	source/sql/postgresql/migration/migration-029-030.sql	SUCCESS	2009-03-23 15:34:44.72	-- -------\\012-- add modification_timestamp field to allow edition with Hibernate\\012-- -------\\012ALTER TABLE data\\012\\011ADD COLUMN modification_timestamp TIME_STAMP DEFAULT CURRENT_TIMESTAMP;\\012ALTER TABLE experiment_types\\012\\011ADD COLUMN modification_timestamp TIME_STAMP DEFAULT CURRENT_TIMESTAMP;\\012ALTER TABLE sample_types\\012\\011ADD COLUMN modification_timestamp TIME_STAMP DEFAULT CURRENT_TIMESTAMP;\\012ALTER TABLE material_types\\012\\011ADD COLUMN modification_timestamp TIME_STAMP DEFAULT CURRENT_TIMESTAMP;\\012ALTER TABLE data_set_types\\012\\011ADD COLUMN modification_timestamp TIME_STAMP DEFAULT CURRENT_TIMESTAMP;\\012ALTER TABLE controlled_vocabularies\\012\\011ADD COLUMN modification_timestamp TIME_STAMP DEFAULT CURRENT_TIMESTAMP;\\012-- -------\\012-- add properties to data sets\\012-- -------\\012CREATE TABLE DATA_SET_PROPERTIES (ID TECH_ID NOT NULL,DS_ID TECH_ID NOT NULL,DSTPT_ID TECH_ID NOT NULL,VALUE GENERIC_VALUE,CVTE_ID TECH_ID, MATE_PROP_ID TECH_ID, PERS_ID_REGISTERER TECH_ID NOT NULL,REGISTRATION_TIMESTAMP TIME_STAMP_DFL NOT NULL DEFAULT CURRENT_TIMESTAMP, MODIFICATION_TIMESTAMP TIME_STAMP DEFAULT CURRENT_TIMESTAMP);\\012CREATE TABLE DATA_SET_TYPE_PROPERTY_TYPES (ID TECH_ID NOT NULL,DSTY_ID TECH_ID NOT NULL,PRTY_ID TECH_ID NOT NULL,IS_MANDATORY BOOLEAN_CHAR NOT NULL DEFAULT 'F',IS_MANAGED_INTERNALLY BOOLEAN_CHAR NOT NULL DEFAULT 'F',PERS_ID_REGISTERER TECH_ID NOT NULL,REGISTRATION_TIMESTAMP TIME_STAMP_DFL NOT NULL DEFAULT CURRENT_TIMESTAMP);\\012\\012CREATE SEQUENCE DATA_SET_PROPERTY_ID_SEQ;\\012CREATE SEQUENCE DSTPT_ID_SEQ;\\012\\012ALTER TABLE DATA_SET_TYPE_PROPERTY_TYPES ADD CONSTRAINT DSTPT_PK PRIMARY KEY(ID);\\012ALTER TABLE DATA_SET_PROPERTIES ADD CONSTRAINT DSPR_PK PRIMARY KEY(ID);\\012\\012ALTER TABLE DATA_SET_TYPE_PROPERTY_TYPES ADD CONSTRAINT DSTPT_BK_UK UNIQUE(DSTY_ID,PRTY_ID);\\012ALTER TABLE DATA_SET_PROPERTIES ADD CONSTRAINT DSPR_BK_UK UNIQUE(DS_ID,DSTPT_ID);\\012\\012\\012ALTER TABLE DATA_SET_TYPE_PROPERTY_TYPES ADD CONSTRAINT DSTPT_DSTY_FK FOREIGN KEY (DSTY_ID) REFERENCES DATA_SET_TYPES(ID);\\012ALTER TABLE DATA_SET_TYPE_PROPERTY_TYPES ADD CONSTRAINT DSTPT_PERS_FK FOREIGN KEY (PERS_ID_REGISTERER) REFERENCES PERSONS(ID);\\012ALTER TABLE DATA_SET_TYPE_PROPERTY_TYPES ADD CONSTRAINT DSTPT_PRTY_FK FOREIGN KEY (PRTY_ID) REFERENCES PROPERTY_TYPES(ID);\\012ALTER TABLE DATA_SET_PROPERTIES ADD CONSTRAINT DSPR_CVTE_FK FOREIGN KEY (CVTE_ID) REFERENCES CONTROLLED_VOCABULARY_TERMS(ID);\\012ALTER TABLE DATA_SET_PROPERTIES ADD CONSTRAINT DSPR_DSTPT_FK FOREIGN KEY (DSTPT_ID) REFERENCES DATA_SET_TYPE_PROPERTY_TYPES(ID) ON DELETE CASCADE;\\012ALTER TABLE DATA_SET_PROPERTIES ADD CONSTRAINT DSPR_DS_FK FOREIGN KEY (DS_ID) REFERENCES DATA(ID);\\012ALTER TABLE DATA_SET_PROPERTIES ADD CONSTRAINT DSPR_PERS_FK FOREIGN KEY (PERS_ID_REGISTERER) REFERENCES PERSONS(ID);\\012ALTER TABLE DATA_SET_PROPERTIES ADD CONSTRAINT DSPR_MAPR_FK FOREIGN KEY (MATE_PROP_ID) REFERENCES MATERIALS(ID);\\012\\012ALTER TABLE DATA_SET_PROPERTIES ADD CONSTRAINT DSPR_CK CHECK \\012\\011((VALUE IS NOT NULL AND CVTE_ID IS NULL AND MATE_PROP_ID IS NULL) OR \\012\\011 (VALUE IS NULL AND CVTE_ID IS NOT NULL AND MATE_PROP_ID IS NULL) OR\\012\\011 (VALUE IS NULL AND CVTE_ID IS NULL AND MATE_PROP_ID IS NOT NULL)\\012\\011);\\012\\012CREATE INDEX DSPR_CVTE_FK_I ON DATA_SET_PROPERTIES (CVTE_ID);\\012CREATE INDEX DSPR_DSTPT_FK_I ON DATA_SET_PROPERTIES (DSTPT_ID);\\012CREATE INDEX DSPR_DS_FK_I ON DATA_SET_PROPERTIES (DS_ID);\\012CREATE INDEX DSPR_PERS_FK_I ON DATA_SET_PROPERTIES (PERS_ID_REGISTERER);\\012CREATE INDEX DSTPT_DSTY_FK_I ON DATA_SET_TYPE_PROPERTY_TYPES (DSTY_ID);\\012CREATE INDEX DSTPT_PERS_FK_I ON DATA_SET_TYPE_PROPERTY_TYPES (PERS_ID_REGISTERER);\\012CREATE INDEX DSTPT_PRTY_FK_I ON DATA_SET_TYPE_PROPERTY_TYPES (PRTY_ID);\\012\\012CREATE OR REPLACE FUNCTION DATA_SET_PROPERTY_WITH_MATERIAL_DATA_TYPE_CHECK() RETURNS trigger AS $$\\012DECLARE\\012   v_type_id  CODE;\\012   v_type_id_prop  CODE;\\012BEGIN\\012   if NEW.mate_prop_id IS NOT NULL then\\012\\011\\011\\011-- find material type id of the property type \\012\\011\\011\\011select pt.maty_prop_id into v_type_id_prop \\012\\011\\011\\011  from data_set_type_property_types dstpt, property_types pt \\012\\011\\011\\011 where NEW.dstpt_id = dstpt.id AND dstpt.prty_id = pt.id;\\012\\011\\011\\012\\011\\011\\011if v_type_id_prop IS NOT NULL then\\012\\011\\011\\011\\011-- find material type id of the material which consists the entity's property value\\012\\011\\011\\011\\011select entity.maty_id into v_type_id \\012\\011\\011\\011\\011  from materials entity\\012\\011\\011\\011\\011 where NEW.mate_prop_id = entity.id;\\012\\011\\011\\011\\011if v_type_id != v_type_id_prop then\\012\\011\\011\\011\\011\\011RAISE EXCEPTION 'Insert/Update of property value referencing material (id: %) failed, as referenced material type is different than expected (id %, expected id: %).', \\012\\011\\011\\011\\011\\011\\011\\011\\011\\011\\011\\011\\011 NEW.mate_prop_id, v_type_id, v_type_id_prop;\\012\\011\\011\\011\\011end if;\\012\\011\\011\\011end if;\\012   end if;\\012   RETURN NEW;\\012END;\\012$$ LANGUAGE 'plpgsql';\\012\\012CREATE TRIGGER DATA_SET_PROPERTY_WITH_MATERIAL_DATA_TYPE_CHECK BEFORE INSERT OR UPDATE ON data_set_properties\\012    FOR EACH ROW EXECUTE PROCEDURE DATA_SET_PROPERTY_WITH_MATERIAL_DATA_TYPE_CHECK();   \\012	\N
+./sourceTest/sql/postgresql/055/017=database_version_logs.tsv:032	source/sql/postgresql/migration/migration-031-032.sql	SUCCESS	2009-04-09 09:36:36.2	-- -------\\012-- Modify MATERIAL_BATCHES\\012-- -------\\012\\012ALTER TABLE material_batches\\012    DROP COLUMN proc_id;\\012\\012-- -------\\012-- Modify SAMPLES\\012-- -------\\012\\012ALTER TABLE samples\\012    ADD COLUMN expe_id tech_id;\\012\\012ALTER TABLE samples\\012    ADD CONSTRAINT samp_expe_fk FOREIGN KEY (expe_id) REFERENCES experiments(id);\\012\\012CREATE INDEX samp_expe_fk_i ON samples USING btree (expe_id);\\012\\012-- relink samples directly to experiments\\012\\012UPDATE samples\\012SET expe_id = (SELECT e.id FROM experiments e, procedures p, sample_inputs si \\012               WHERE si.samp_id = samples.id AND si.proc_id = p.id AND p.expe_id = e.id AND e.inva_id IS NULL);\\012\\012\\012-- -------\\012-- Modify DATA\\012-- -------\\012\\012ALTER TABLE data\\012    ADD COLUMN expe_id tech_id;\\012\\012ALTER TABLE data\\012    ADD CONSTRAINT data_expe_fk FOREIGN KEY (expe_id) REFERENCES experiments(id);\\012\\012CREATE INDEX data_expe_fk_i ON data USING btree (expe_id);\\012\\012UPDATE data\\012SET expe_id = (SELECT e.id FROM experiments e, procedures p \\012               WHERE data.proc_id_produced_by = p.id AND p.expe_id = e.id);\\012\\012ALTER TABLE data\\012    ALTER COLUMN expe_id SET NOT NULL;\\012\\012ALTER TABLE data\\012    DROP COLUMN proc_id_produced_by;\\012\\012-- -------\\012-- Drop PROCEDURES, PROCEDURE_TYPES, and SAMPLE_INPUTS\\012-- -------\\012\\012DROP TABLE sample_inputs;\\012DROP TABLE procedures;\\012DROP TABLE procedure_types;\\012\\012DROP SEQUENCE procedure_id_seq;\\012DROP SEQUENCE procedure_type_id_seq;\\012\\012-- -------\\012-- Add CODE_SEQ\\012-- -------\\012\\012CREATE SEQUENCE CODE_SEQ;\\012\\012-- -------\\012-- Add new columns to DATA_STORES\\012-- -------\\012\\012ALTER TABLE data_stores\\012    ADD COLUMN remote_url character varying(250),\\012    ADD COLUMN session_token character varying(50),\\012    ADD COLUMN modification_timestamp time_stamp DEFAULT now();\\012\\012UPDATE data_stores\\012SET remote_url = '', session_token='';\\012\\012ALTER TABLE data_stores\\012    ALTER COLUMN remote_url SET NOT NULL,\\012    ALTER COLUMN session_token SET NOT NULL;\\012\\012-- -------\\012-- Drop foreign keys onto DATA_STORES\\012-- -------\\012\\012ALTER TABLE database_instances\\012    DROP COLUMN dast_id;\\012\\012ALTER TABLE groups\\012    DROP COLUMN dast_id;\\012\\012ALTER TABLE projects\\012    DROP COLUMN dast_id;\\012\\012ALTER TABLE experiments\\012    DROP COLUMN dast_id;\\012\\012-- -------\\012-- Add foreign key from DATA onto DATA_STORES\\012-- -------\\012\\012ALTER TABLE data\\012    ADD COLUMN dast_id tech_id;\\012\\012ALTER TABLE data\\012    ADD CONSTRAINT data_dast_fk FOREIGN KEY (dast_id) REFERENCES data_stores(id);\\012\\012UPDATE data\\012SET dast_id = (select id from data_stores where code = 'STANDARD');\\012\\012ALTER TABLE data\\012    ALTER COLUMN dast_id SET NOT NULL;\\012\\012\\012------------------------------------------------------------------------------------\\012--  Purpose:  Replace trigger SAMPLE_CODE_UNIQUENESS_CHECK \\012------------------------------------------------------------------------------------\\012\\012CREATE OR REPLACE FUNCTION SAMPLE_CODE_UNIQUENESS_CHECK() RETURNS trigger AS $$\\012DECLARE\\012   counter  INTEGER;\\012BEGIN\\012    LOCK TABLE samples IN EXCLUSIVE MODE;\\012    IF (NEW.samp_id_part_of is NULL) THEN\\012        IF (NEW.dbin_id is not NULL) THEN\\012            SELECT count(*) into counter FROM samples \\012                where id != NEW.id and code = NEW.code and samp_id_part_of is NULL and dbin_id = NEW.dbin_id;\\012            IF (counter > 0) THEN\\012                RAISE EXCEPTION 'Insert/Update of Sample (Code: %) failed because database instance sample with the same code already exists.', NEW.code;\\012            END IF;\\012        ELSIF (NEW.grou_id is not NULL) THEN\\012            SELECT count(*) into counter FROM samples \\012                where id != NEW.id and code = NEW.code and samp_id_part_of is NULL and grou_id = NEW.grou_id;\\012            IF (counter > 0) THEN\\012                RAISE EXCEPTION 'Insert/Update of Sample (Code: %) failed because group sample with the same code already exists.', NEW.code;\\012            END IF;\\012        END IF;\\012        ELSE\\012        IF (NEW.dbin_id is not NULL) THEN\\012            SELECT count(*) into counter FROM samples \\012                where id != NEW.id and code = NEW.code and samp_id_part_of = NEW.samp_id_part_of and dbin_id = NEW.dbin_id;\\012            IF (counter > 0) THEN\\012                RAISE EXCEPTION 'Insert/Update of Sample (Code: %) failed because database instance sample with the same code and being the part of the same parent already exists.', NEW.code;\\012            END IF;\\012        ELSIF (NEW.grou_id is not NULL) THEN\\012            SELECT count(*) into counter FROM samples \\012                where id != NEW.id and code = NEW.code and samp_id_part_of = NEW.samp_id_part_of and grou_id = NEW.grou_id;\\012            IF (counter > 0) THEN\\012                RAISE EXCEPTION 'Insert/Update of Sample (Code: %) failed because group sample with the same code and being the part of the same parent already exists.', NEW.code;\\012            END IF;\\012        END IF;\\012        END IF;   \\012   RETURN NEW;\\012END;\\012$$ LANGUAGE 'plpgsql';\\012\\012\\012\\012	\N
+./sourceTest/sql/postgresql/055/017=database_version_logs.tsv:034	source/sql/postgresql/migration/migration-033-034.sql	SUCCESS	2009-05-26 08:32:49.935	------------------------------------------------------------------------------------\\012-- Create sequence for generating permanent identifiers starting with nextval of existing dataset sequence.\\012------------------------------------------------------------------------------------\\012CREATE FUNCTION CREATE_SEQUENCE(EXISTING_SEQUENCE VARCHAR, NEW_SEQUENCE VARCHAR) RETURNS VOID AS $$\\012DECLARE\\012  CURR_SEQ_VAL   INTEGER;\\012BEGIN\\012  SELECT INTO CURR_SEQ_VAL NEXTVAL(EXISTING_SEQUENCE);\\012  EXECUTE 'CREATE SEQUENCE ' || NEW_SEQUENCE || ' START WITH ' || CURR_SEQ_VAL;\\012  RETURN;\\012END;\\012$$ LANGUAGE 'plpgsql';\\012\\012SELECT CREATE_SEQUENCE('DATA_ID_SEQ', 'PERM_ID_SEQ');\\012DROP FUNCTION CREATE_SEQUENCE(VARCHAR, VARCHAR);\\012\\012------------------------------------------------------------------------------------\\012-- Add perm_id columns to samples and experiments.\\012------------------------------------------------------------------------------------\\012ALTER TABLE SAMPLES ADD COLUMN PERM_ID CODE;\\012ALTER TABLE EXPERIMENTS ADD COLUMN PERM_ID CODE;\\012\\012UPDATE SAMPLES SET PERM_ID = to_char(registration_timestamp,'YYYYMMDDHHSSMS') || '-' || NEXTVAL('PERM_ID_SEQ');\\012UPDATE EXPERIMENTS SET PERM_ID = to_char(registration_timestamp,'YYYYMMDDHHSSMS') || '-' || NEXTVAL('PERM_ID_SEQ');\\012ALTER TABLE SAMPLES ALTER COLUMN PERM_ID SET NOT NULL;\\012ALTER TABLE EXPERIMENTS ALTER COLUMN PERM_ID SET NOT NULL;\\012ALTER TABLE SAMPLES ADD CONSTRAINT SAMP_PI_UK UNIQUE(PERM_ID);\\012ALTER TABLE EXPERIMENTS ADD CONSTRAINT EXPE_PI_UK UNIQUE(PERM_ID);\\012\\012\\012------------------------------------------------------------------------------------\\012-- Add column is_chosen_from_list to controlled_vocabularies.\\012------------------------------------------------------------------------------------\\012ALTER TABLE controlled_vocabularies ADD COLUMN is_chosen_from_list BOOLEAN_CHAR NOT NULL DEFAULT TRUE;\\012ALTER TABLE controlled_vocabularies ADD COLUMN source_uri CHARACTER VARYING(250);\\012------------------------------------------------------------------------------------\\012-- Modify Data table - remove arc connection between Sample and Data table, use a flag instead\\012------------------------------------------------------------------------------------\\012\\012-- add new columns\\012\\012ALTER TABLE data\\012    ADD COLUMN is_derived boolean_char;\\012ALTER TABLE data\\012    ADD COLUMN samp_id tech_id;\\012\\012-- update values in new columns\\012\\012UPDATE data\\012    SET is_derived = (samp_id_derived_from IS NOT NULL); \\012UPDATE data\\012    SET samp_id = samp_id_derived_from \\012    WHERE is_derived = 'TRUE';\\012UPDATE data\\012    SET samp_id = samp_id_acquired_from \\012    WHERE is_derived = 'FALSE';\\012\\012-- add constraints and indexes to new columns\\012\\012ALTER TABLE data\\012    ALTER COLUMN is_derived SET NOT NULL;\\012ALTER TABLE data\\012    ALTER COLUMN samp_id SET NOT NULL;   \\012ALTER TABLE data\\012    ADD CONSTRAINT data_samp_fk FOREIGN KEY (samp_id) REFERENCES samples (id);\\012CREATE INDEX data_samp_fk_i ON data USING btree (samp_id);\\012\\012-- remove old columns\\012\\012ALTER TABLE data\\012    DROP COLUMN samp_id_acquired_from;\\012ALTER TABLE data\\012    DROP COLUMN samp_id_derived_from;\\012    \\012------------------------------------------------------------------------------------\\012-- Granting SELECT privilege to group openbis_readonly\\012------------------------------------------------------------------------------------\\012\\012GRANT SELECT ON SEQUENCE attachment_content_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE attachment_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE code_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE controlled_vocabulary_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE cvte_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE data_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE data_set_property_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE data_set_relationship_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE data_set_type_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE data_store_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE data_type_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE database_instance_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE dstpt_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE etpt_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE event_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE experiment_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE experiment_property_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE experiment_type_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE file_format_type_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE group_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE invalidation_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE locator_type_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE material_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE material_property_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE material_type_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE mtpt_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE perm_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE person_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE project_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE property_type_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE role_assignment_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE sample_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE sample_property_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE sample_type_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE stpt_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE attachment_contents TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE attachments TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE controlled_vocabularies TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE controlled_vocabulary_terms TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE data TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE data_set_properties TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE data_set_relationships TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE data_set_type_property_types TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE data_set_types TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE data_stores TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE data_types TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE database_instances TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE database_version_logs TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE events TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE experiment_properties TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE experiment_type_property_types TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE experiment_types TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE experiments TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE external_data TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE file_format_types TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE groups TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE invalidations TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE locator_types TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE material_properties TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE material_type_property_types TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE material_types TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE materials TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE persons TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE projects TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE property_types TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE role_assignments TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE sample_properties TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE sample_type_property_types TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE sample_types TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE samples TO GROUP OPENBIS_READONLY;\\012\\012------------------------------------------------------------------------------------\\012-- Delete MATERIAL_BATCHES table\\012------------------------------------------------------------------------------------\\012\\012-- WARNING: Potential data lost!!!\\012-- WARNING: Potential data lost!!!\\012-- WARNING: Potential data lost!!!\\012\\012DROP TABLE SAMPLE_MATERIAL_BATCHES;\\012DROP TABLE MATERIAL_BATCHES;\\012DROP SEQUENCE MATERIAL_BATCH_ID_SEQ;\\012\\012------------------------------------------------------------------------------------\\012-- Delete MATE_ID_INHIBITOR_OF from table MATERIALS\\012------------------------------------------------------------------------------------\\012\\012-- WARNING: Potential data lost!!!\\012-- WARNING: Potential data lost!!!\\012-- WARNING: Potential data lost!!!\\012\\012ALTER TABLE MATERIALS DROP COLUMN MATE_ID_INHIBITOR_OF;\\012	\N
+./sourceTest/sql/postgresql/055/017=database_version_logs.tsv:041	source/sql/postgresql/migration/migration-040-041.sql	SUCCESS	2009-09-14 13:48:57.539	-- Create FILTERS table\\012\\012CREATE TABLE FILTERS (ID TECH_ID NOT NULL, DBIN_ID TECH_ID NOT NULL, NAME VARCHAR(200) NOT NULL, DESCRIPTION DESCRIPTION_1000,REGISTRATION_TIMESTAMP TIME_STAMP_DFL NOT NULL DEFAULT CURRENT_TIMESTAMP, PERS_ID_REGISTERER TECH_ID NOT NULL, MODIFICATION_TIMESTAMP TIME_STAMP DEFAULT CURRENT_TIMESTAMP, EXPRESSION VARCHAR(2000) NOT NULL, IS_PUBLIC BOOLEAN NOT NULL, GRID_ID VARCHAR(200) NOT NULL);\\012CREATE SEQUENCE FILTER_ID_SEQ;\\012ALTER TABLE FILTERS ADD CONSTRAINT FILT_PK PRIMARY KEY(ID);\\012ALTER TABLE FILTERS ADD CONSTRAINT FILT_BK_UK UNIQUE(NAME, DBIN_ID, GRID_ID);\\012ALTER TABLE FILTERS ADD CONSTRAINT FILT_PERS_FK FOREIGN KEY (PERS_ID_REGISTERER) REFERENCES PERSONS(ID);\\012ALTER TABLE FILTERS ADD CONSTRAINT FILT_DBIN_FK FOREIGN KEY (DBIN_ID) REFERENCES DATABASE_INSTANCES(ID);\\012CREATE INDEX FILT_PERS_FK_I ON FILTERS (PERS_ID_REGISTERER);\\012CREATE INDEX FILT_DBIN_FK_I ON FILTERS (DBIN_ID);\\012GRANT SELECT ON SEQUENCE filter_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE filters TO GROUP OPENBIS_READONLY;\\012\\012-- Add missing foreign key to role assignments authorization group\\012ALTER TABLE ROLE_ASSIGNMENTS ADD CONSTRAINT ROAS_AG_FK_GRANTEE FOREIGN KEY (AG_ID_GRANTEE) REFERENCES AUTHORIZATION_GROUPS(ID);\\012\\012--------------------------------------------------------------------------------------------------\\012-- Modify dataset connections:\\012-- 1. connection with sample shouldn't be mandatory any more\\012-- 2. introduce an arc condition that dataset cannot be connected with a sample and a parent dataset at the same time\\012--------------------------------------------------------------------------------------------------\\012\\012-- Weaken data-sample connection constraint - allow dataset to have no connection with sample\\012ALTER TABLE data ALTER COLUMN samp_id DROP NOT NULL;\\012\\012-- Remove data-sample connection for datasets that have a parent\\012\\012UPDATE data \\012   SET samp_id = NULL \\012 WHERE id IN (SELECT DISTINCT data_id_child FROM data_set_relationships);\\012\\012-- With PostgreSQL 8.4 one can check that before migration there were no cycles in dataset relationships:\\012--\\012-- WITH RECURSIVE data_set_parents(id, parent_ids, cycle) AS (\\012--         SELECT  r.data_id_child AS id, \\012--                 ARRAY[CAST (r.data_id_parent AS bigint)] AS parent_ids, \\012--                 false AS cycle \\012--         FROM data_set_relationships r\\012--     UNION ALL\\012--         SELECT  r.data_id_child,\\012--                 CAST (r.data_id_parent AS bigint) || p.parent_ids,\\012--                 r.data_id_child = ANY(p.parent_ids)\\012--         FROM data_set_relationships r, data_set_parents p\\012--         WHERE r.data_id_parent = p.id AND NOT cycle\\012-- )\\012-- SELECT count(*) AS cycles FROM data_set_parents WHERE cycle = true;\\012\\012---------------------------------------------------------------------------------------------------\\012--  Purpose:  Create DEFERRED triggers:\\012--            * check_dataset_relationships_on_data_table_modification,\\012--            * check_dataset_relationships_on_relationships_table_modification.\\012--            They check that after all modifications of database (just before commit) \\012--            if 'data'/'data_set_relationships' tables are among modified tables \\012--            dataset is not connected with a sample and a parent dataset at the same time.\\012--            This connections are held in two different tables so simple immediate trigger \\012--            with arc check cannot be used and we need two deferred triggers.\\012----------------------------------------------------------------------------------------------------\\012\\012-- trigger for 'data' table\\012\\012CREATE OR REPLACE FUNCTION check_dataset_relationships_on_data_table_modification() RETURNS trigger AS $$\\012DECLARE\\012\\011counter\\011INTEGER;\\012BEGIN\\012\\011-- if there is a connection with a Sample there should not be any connection with a parent Data Set\\012\\011IF (NEW.samp_id IS NOT NULL) THEN\\012\\011\\011-- count number of parents\\012\\011\\011SELECT count(*) INTO counter \\012\\011\\011\\011FROM data_set_relationships \\012\\011\\011\\011WHERE data_id_child = OLD.id;\\012\\011\\011IF (counter > 0) THEN\\012\\011\\011\\011RAISE EXCEPTION 'Insert/Update of Data Set (Code: %) failed because it cannot be connected with a Sample and a parent Data Set at the same time.', OLD.code;\\012\\011\\011END IF;\\012\\011END IF;\\012  RETURN NEW;\\012END;\\012$$ LANGUAGE 'plpgsql';\\012\\012CREATE CONSTRAINT TRIGGER check_dataset_relationships_on_data_table_modification \\012  AFTER INSERT OR UPDATE ON data\\012\\011DEFERRABLE INITIALLY DEFERRED\\012\\011FOR EACH ROW \\012\\011EXECUTE PROCEDURE check_dataset_relationships_on_data_table_modification();\\012\\012-- trigger for 'data_set_relationships'\\012\\012CREATE OR REPLACE FUNCTION check_dataset_relationships_on_relationships_table_modification() RETURNS trigger AS $$\\012DECLARE\\012\\011counter\\011INTEGER;\\012\\011sample_id\\011TECH_ID;\\012\\011data_code\\011CODE;\\012BEGIN\\012\\011-- child will have a parent added so it should not be connected with any sample\\012\\011SELECT samp_id, code INTO sample_id, data_code \\012\\011\\011FROM data \\012\\011\\011WHERE id = NEW.data_id_child;\\012\\011IF (sample_id IS NOT NULL) THEN\\012\\011\\011RAISE EXCEPTION 'Insert/Update of Data Set (Code: %) failed because it cannot be connected to a Sample and to a parent Data Set at the same time.', data_code;\\012\\011END IF;\\012\\011RETURN NEW;\\012END;\\012$$ LANGUAGE 'plpgsql';\\012  \\012CREATE CONSTRAINT TRIGGER check_dataset_relationships_on_relationships_table_modification \\012  AFTER INSERT OR UPDATE ON data_set_relationships\\012\\011DEFERRABLE INITIALLY DEFERRED\\012\\011FOR EACH ROW \\012\\011EXECUTE PROCEDURE check_dataset_relationships_on_relationships_table_modification();\\012	\N
+./sourceTest/sql/postgresql/055/017=database_version_logs.tsv:053	source/sql/postgresql/migration/migration-052-053.sql	SUCCESS	2010-06-08 15:27:55.032	-- Migration from 052 to 053\\012\\012-- Change code uniqueness check for samples of specific type.\\012-- If sample_types.is_subcode_unique flag is set to 'true', additional check is performed \\012-- on codes of samples of the type. Subcodes will have to be unique as well.\\012\\012ALTER TABLE sample_types ADD COLUMN is_subcode_unique boolean_char NOT NULL DEFAULT false;\\012\\012CREATE OR REPLACE FUNCTION SAMPLE_SUBCODE_UNIQUENESS_CHECK() RETURNS trigger AS $$\\012DECLARE\\012   counter  INTEGER;\\012   unique_subcode  BOOLEAN_CHAR;\\012BEGIN\\012  LOCK TABLE samples IN EXCLUSIVE MODE;\\012  \\012  SELECT is_subcode_unique into unique_subcode FROM sample_types WHERE id = NEW.saty_id;\\012  \\012  IF (unique_subcode) THEN\\012    IF (NEW.dbin_id is not NULL) THEN\\012\\011\\011\\011SELECT count(*) into counter FROM samples \\012\\011\\011\\011\\011where id != NEW.id and code = NEW.code and saty_id = NEW.saty_id and dbin_id = NEW.dbin_id;\\012\\011\\011\\011IF (counter > 0) THEN\\012\\011\\011\\011\\011RAISE EXCEPTION 'Insert/Update of Sample (Code: %) failed because database instance sample of the same type with the same subcode already exists.', NEW.code;\\012\\011\\011\\011END IF;\\012\\011\\011ELSIF (NEW.grou_id is not NULL) THEN\\012\\011\\011\\011SELECT count(*) into counter FROM samples \\012\\011\\011\\011\\011where id != NEW.id and code = NEW.code and saty_id = NEW.saty_id and grou_id = NEW.grou_id;\\012\\011\\011\\011IF (counter > 0) THEN\\012\\011\\011\\011\\011RAISE EXCEPTION 'Insert/Update of Sample (Code: %) failed because space sample of the same type with the same subcode already exists.', NEW.code;\\012\\011\\011\\011END IF;\\012\\011\\011END IF;\\012  END IF;\\012  \\012  RETURN NEW;\\012END;\\012$$ LANGUAGE 'plpgsql';\\012\\012CREATE TRIGGER SAMPLE_SUBCODE_UNIQUENESS_CHECK BEFORE INSERT OR UPDATE ON SAMPLES\\012    FOR EACH ROW EXECUTE PROCEDURE SAMPLE_SUBCODE_UNIQUENESS_CHECK();\\012    \\012-- Fixing error messages in old trigger\\012\\012CREATE OR REPLACE FUNCTION SAMPLE_CODE_UNIQUENESS_CHECK() RETURNS trigger AS $$\\012DECLARE\\012   counter  INTEGER;\\012BEGIN\\012  LOCK TABLE samples IN EXCLUSIVE MODE;\\012  \\012\\011  IF (NEW.samp_id_part_of is NULL) THEN\\012\\011\\011  IF (NEW.dbin_id is not NULL) THEN\\012\\011\\011\\011  SELECT count(*) into counter FROM samples \\012\\011\\011      where id != NEW.id and code = NEW.code and samp_id_part_of is NULL and dbin_id = NEW.dbin_id;\\012        IF (counter > 0) THEN\\012\\011\\011\\011\\011  RAISE EXCEPTION 'Insert/Update of Sample (Code: %) failed because database instance sample with the same code already exists.', NEW.code;\\012        END IF;\\012\\011\\011  ELSIF (NEW.grou_id is not NULL) THEN\\012\\011\\011\\011  SELECT count(*) into counter FROM samples \\012\\011\\011\\011\\011  where id != NEW.id and code = NEW.code and samp_id_part_of is NULL and grou_id = NEW.grou_id;\\012\\011\\011\\011  IF (counter > 0) THEN\\012\\011\\011\\011\\011  RAISE EXCEPTION 'Insert/Update of Sample (Code: %) failed because space sample with the same code already exists.', NEW.code;\\012\\011\\011\\011  END IF;\\012      END IF;\\012    ELSE\\012\\011\\011  IF (NEW.dbin_id is not NULL) THEN\\012\\011\\011\\011  SELECT count(*) into counter FROM samples \\012\\011\\011\\011\\011  where id != NEW.id and code = NEW.code and samp_id_part_of = NEW.samp_id_part_of and dbin_id = NEW.dbin_id;\\012\\011\\011\\011  IF (counter > 0) THEN\\012\\011\\011\\011\\011  RAISE EXCEPTION 'Insert/Update of Sample (Code: %) failed because database instance sample with the same code and being the part of the same container already exists.', NEW.code;\\012\\011\\011\\011  END IF;\\012\\011\\011  ELSIF (NEW.grou_id is not NULL) THEN\\012\\011\\011\\011  SELECT count(*) into counter FROM samples \\012\\011\\011\\011\\011  where id != NEW.id and code = NEW.code and samp_id_part_of = NEW.samp_id_part_of and grou_id = NEW.grou_id;\\012\\011\\011\\011  IF (counter > 0) THEN\\012\\011\\011\\011\\011  RAISE EXCEPTION 'Insert/Update of Sample (Code: %) failed because space sample with the same code and being the part of the same container already exists.', NEW.code;\\012\\011\\011\\011  END IF;\\012\\011\\011  END IF;\\012     END IF;   \\012  \\012  RETURN NEW;\\012END;\\012$$ LANGUAGE 'plpgsql';\\012	\N
+./sourceTest/sql/postgresql/055/017=database_version_logs.tsv:054	source/sql/postgresql/migration/migration-053-054.sql	SUCCESS	2010-07-27 11:30:46.766	-- Migration from 053 to 054\\012\\012\\012-- Add RELATIONSHIP_TYPES table\\012CREATE TABLE relationship_types (id TECH_ID NOT NULL, code CODE NOT NULL, label COLUMN_LABEL, parent_label COLUMN_LABEL, child_label COLUMN_LABEL, description DESCRIPTION_2000, registration_timestamp TIME_STAMP_DFL NOT NULL DEFAULT CURRENT_TIMESTAMP, pers_id_registerer TECH_ID NOT NULL, is_managed_internally BOOLEAN_CHAR NOT NULL DEFAULT 'F', is_internal_namespace BOOLEAN_CHAR NOT NULL DEFAULT 'F', dbin_id TECH_ID NOT NULL);\\012\\012-- Add SAMPLE_RELATIONSHIPS table\\012CREATE TABLE sample_relationships (id TECH_ID NOT NULL, sample_id_parent TECH_ID NOT NULL, relationship_id TECH_ID NOT NULL, sample_id_child TECH_ID NOT NULL);\\012\\012-- Add/update constraints\\012ALTER TABLE relationship_types ADD CONSTRAINT rety_pk PRIMARY KEY (id);\\012ALTER TABLE relationship_types ADD CONSTRAINT rety_uk UNIQUE(code,dbin_id);\\012ALTER TABLE sample_relationships ADD CONSTRAINT sare_pk PRIMARY KEY (id);\\012ALTER TABLE sample_relationships ADD CONSTRAINT sare_bk_uk UNIQUE(sample_id_child,sample_id_parent,relationship_id);\\012ALTER TABLE sample_relationships ADD CONSTRAINT sare_data_fk_child FOREIGN KEY (sample_id_child) REFERENCES samples(id) ON DELETE CASCADE;\\012ALTER TABLE sample_relationships ADD CONSTRAINT sare_data_fk_parent FOREIGN KEY (sample_id_parent) REFERENCES samples(id) ON DELETE CASCADE;\\012ALTER TABLE sample_relationships ADD CONSTRAINT sare_data_fk_relationship FOREIGN KEY (relationship_id) REFERENCES relationship_types(id);\\012\\012-- Create index\\012CREATE INDEX sare_data_fk_i_child ON sample_relationships (sample_id_child);\\012CREATE INDEX sare_data_fk_i_parent ON sample_relationships (sample_id_parent);\\012CREATE INDEX sare_data_fk_i_relationship ON sample_relationships (relationship_id);\\012\\012-- Create sequence for RELATIONSHIP_TYPES\\012CREATE SEQUENCE RELATIONSHIP_TYPE_ID_SEQ;\\012CREATE SEQUENCE SAMPLE_RELATIONSHIP_ID_SEQ;\\012\\012-- Create initial relationships\\012insert into relationship_types\\012(id, \\012code, \\012label, \\012parent_label, \\012child_label, \\012description, \\012pers_id_registerer, \\012is_managed_internally, \\012is_internal_namespace, \\012dbin_id) \\012values\\012(\\012nextval('RELATIONSHIP_TYPE_ID_SEQ'),\\012'PARENT_CHILD',\\012'Parent - Child', \\012'Parent', \\012'Child', \\012'Parent - Child relationship', \\012(select id from persons where user_id ='system'), \\012'T', \\012'T', \\012(select id from database_instances where is_original_source = 'T')\\012);\\012\\012insert into relationship_types\\012(id, \\012code, \\012label, \\012parent_label, \\012child_label, \\012description, \\012pers_id_registerer, \\012is_managed_internally, \\012is_internal_namespace, \\012dbin_id) \\012values\\012(\\012nextval('RELATIONSHIP_TYPE_ID_SEQ'),\\012'PLATE_CONTROL_LAYOUT',\\012'Plate - Control Layout', \\012'Plate', \\012'Control Layout', \\012'Plate - Control Layout relationship', \\012(select id from persons where user_id ='system'), \\012'T', \\012'T', \\012(select id from database_instances where is_original_source = 'T')\\012); \\012\\012\\012-- Migrate sample relationships to new schema\\012INSERT INTO sample_relationships (id, sample_id_parent,sample_id_child,relationship_id) (select distinct nextval('SAMPLE_RELATIONSHIP_ID_SEQ') as id, s.SAMP_ID_GENERATED_FROM as parent_id, s.ID as child_id, rt.id as relationship_id from samples s, relationship_types rt  WHERE rt.code = 'PARENT_CHILD' and s.SAMP_ID_GENERATED_FROM is not null); \\012INSERT INTO sample_relationships (id, sample_id_parent,sample_id_child,relationship_id) (select distinct nextval('SAMPLE_RELATIONSHIP_ID_SEQ') as id, s.SAMP_ID_CONTROL_LAYOUT as parent_id, s.ID as child_id, rt.id as relationship_id from samples s, relationship_types rt  WHERE rt.code = 'PLATE_CONTROL_LAYOUT' and s.SAMP_ID_CONTROL_LAYOUT is not null);\\012\\012-- Drop old sample relations\\012ALTER TABLE SAMPLES DROP COLUMN SAMP_ID_TOP;\\012ALTER TABLE SAMPLES DROP COLUMN SAMP_ID_GENERATED_FROM;\\012ALTER TABLE SAMPLES DROP COLUMN SAMP_ID_CONTROL_LAYOUT;\\012\\012--------------------------------------------------------------------------------------\\012--------------------------------------------------------------------------------------\\012-- This is a screening specific migration. Nothing will be performed on openBIS databases \\012-- which are not screening specific.\\012-- \\012-- This migration for each existing connection between oligo well, oligo material and gene material\\012-- creates a direct connection between the well and the gene. \\012--------------------------------------------------------------------------------------\\012--------------------------------------------------------------------------------------\\012 \\012\\011\\012CREATE OR REPLACE FUNCTION CONNECT_WELLS_WITH_GENES() RETURNS void AS $$\\012DECLARE\\012\\011counter  int;\\012\\011oligo_well_exists bool;\\012BEGIN\\012\\011--------------------------------------------------\\012\\011-- create a gene property and assign it to oligo well\\012\\011--------------------------------------------------\\012\\011\\012\\011select true \\012\\011into oligo_well_exists\\012\\011from sample_types \\012\\011where code = 'OLIGO_WELL';\\012\\011\\012\\011if oligo_well_exists IS NULL then \\012\\011\\011-- skip migration if there are no oligo wells\\012\\011\\011return;\\012\\011end if;   \\012\\011\\012\\011insert into property_types(\\012\\011\\011id, \\012\\011\\011code, description, label, \\012\\011\\011daty_id,\\012\\011\\011pers_id_registerer,\\012\\011\\011dbin_id,\\012\\011\\011maty_prop_id) \\012\\011values(\\012\\011\\011\\011nextval('PROPERTY_TYPE_ID_SEQ'), \\012\\011\\011\\011'GENE','Inhibited gene','Gene',\\012\\011\\011\\011(select id from data_types where code = 'MATERIAL'), \\012\\011\\011\\011(select id from persons where user_id ='system'), \\012\\011\\011\\011(select id from database_instances where is_original_source = 'T'), \\012\\011\\011\\011(select id from material_types where code = 'GENE')\\012\\011\\011);\\012\\011\\011\\012\\011insert into sample_type_property_types( \\012\\011  id,\\012\\011  saty_id,\\012\\011  prty_id,\\012\\011  is_mandatory,\\012\\011  pers_id_registerer,\\012\\011  ordinal\\012\\011) values(\\012\\011\\011\\011nextval('stpt_id_seq'), \\012\\011\\011\\011(select id from sample_types where code = 'OLIGO_WELL'),\\012\\011\\011\\011(select id from property_types where code = 'GENE'),\\012\\011\\011\\011false,\\012\\011\\011\\011(select id from persons where user_id ='system'),\\012\\011\\011\\011(select max(ordinal)+1 from sample_type_property_types \\012\\011\\011\\011\\011where saty_id = (select id from sample_types where code = 'OLIGO_WELL'))\\012\\011\\011);\\012\\012\\011--------------------------------------------------\\012\\011-- create a gene material property for each oligo well\\012\\011--------------------------------------------------\\012\\011\\011\\012\\011select \\011count(*)\\012\\011into counter\\012\\011from\\012\\011\\011samples well, sample_types well_type, sample_properties well_props, \\012\\011\\011materials well_material, material_properties well_material_props,\\012\\011\\011materials nested_well_material\\012\\011where\\012\\011\\011well_type.code = 'OLIGO_WELL' and\\012\\011\\011-- find 'well_material' assigned to the well\\012\\011\\011well_props.samp_id = well.id and well_material.id = well_props.mate_prop_id and \\012\\011\\011-- additional joins to entity type tables\\012\\011\\011well_type.id = well.saty_id and\\012\\011\\011-- well content material property\\012\\011\\011well_material_props.mate_id = well_material.id and \\012\\011\\011-- material connected to the material in the well (e.g. gene)\\012\\011\\011well_material_props.mate_prop_id = nested_well_material.id and\\012\\011\\011nested_well_material.maty_id = (select id from material_types where code = 'GENE');\\012\\011\\012\\011if counter = 0 then \\012\\011\\011-- skip migration if there are no genes indirectly connected to oligo wells\\012\\011\\011return;\\012\\011end if;   \\012\\012\\011insert into sample_properties(id, samp_id, stpt_id, mate_prop_id, pers_id_registerer) (\\012\\011\\011select \\011nextval('sample_property_id_seq') id, \\012\\011\\011\\011well.id samp_id, \\012\\011\\011\\011(select stpt.id from sample_type_property_types stpt, property_types props where stpt.prty_id = props.id and props.code='GENE') stpt_id,\\012\\011\\011\\011nested_well_material.id mate_prop_id,\\012\\011\\011\\011(select id from persons where user_id ='system') pers_id_registerer \\012\\011\\011from\\012\\011\\011\\011samples well, sample_types well_type, sample_properties well_props, \\012\\011\\011\\011materials well_material, material_properties well_material_props,\\012\\011\\011\\011materials nested_well_material\\012\\011\\011where\\012\\011\\011\\011well_type.code = 'OLIGO_WELL' and\\012\\011\\011\\011-- find 'well_material' assigned to the well\\012\\011\\011\\011well_props.samp_id = well.id and well_material.id = well_props.mate_prop_id and \\012\\011\\011\\011-- additional joins to entity type tables\\012\\011\\011\\011well_type.id = well.saty_id and\\012\\011\\011\\011-- well content material property\\012\\011\\011\\011well_material_props.mate_id = well_material.id and \\012\\011\\011\\011-- material connected to the material in the well (e.g. gene)\\012\\011\\011\\011well_material_props.mate_prop_id = nested_well_material.id and\\012\\011\\011\\011nested_well_material.maty_id = (select id from material_types where code = 'GENE')\\012\\011);\\012\\012END;\\012$$ LANGUAGE 'plpgsql';\\012\\012select CONNECT_WELLS_WITH_GENES();\\012drop function CONNECT_WELLS_WITH_GENES();\\012\\012--------------------------------------------------------------------------------------\\012--------------------------------------------------------------------------------------\\012\\012-- drop dataset triggers\\012\\012DROP TRIGGER check_dataset_relationships_on_data_table_modification ON data;\\012DROP FUNCTION check_dataset_relationships_on_data_table_modification();\\012DROP TRIGGER check_dataset_relationships_on_relationships_table_modification ON data_set_relationships;\\012DROP FUNCTION check_dataset_relationships_on_relationships_table_modification();\\012 \\012\\012\\012\\012\\012\\012\\012\\012	\N
+./sourceTest/sql/postgresql/055/schema-055.sql:    LANGUAGE plpgsql
+./sourceTest/sql/postgresql/055/schema-055.sql:    LANGUAGE plpgsql
+./sourceTest/sql/postgresql/055/schema-055.sql:    LANGUAGE plpgsql
+./sourceTest/sql/postgresql/055/schema-055.sql:    LANGUAGE plpgsql
+./sourceTest/sql/postgresql/055/schema-055.sql:    LANGUAGE plpgsql
+./sourceTest/sql/postgresql/055/schema-055.sql:    LANGUAGE plpgsql
+./sourceTest/sql/postgresql/055/schema-055.sql:    LANGUAGE plpgsql
+./sourceTest/sql/postgresql/055/schema-055.sql:    LANGUAGE plpgsql
+./sourceTest/sql/postgresql/055/schema-055.sql:    LANGUAGE plpgsql
+./sourceTest/sql/postgresql/056/.svn/text-base/017=database_version_logs.tsv.svn-base:027	D:\\User\\felmer\\dev-workspace\\openbis/source/sql/postgresql/027/function-027.sql	SUCCESS	2008-11-05 09:18:00.403	-- Creating Functions\\012\\012------------------------------------------------------------------------------------\\012--  Purpose:  Create function RENAME_SEQUENCE() that is required for renaming the sequences belonging to tables\\012------------------------------------------------------------------------------------\\012CREATE FUNCTION RENAME_SEQUENCE(OLD_NAME VARCHAR, NEW_NAME VARCHAR) RETURNS INTEGER AS $$\\012DECLARE\\012  CURR_SEQ_VAL   INTEGER;\\012BEGIN\\012  SELECT INTO CURR_SEQ_VAL NEXTVAL(OLD_NAME);\\012  EXECUTE 'CREATE SEQUENCE ' || NEW_NAME || ' START WITH ' || CURR_SEQ_VAL;\\012  EXECUTE 'DROP SEQUENCE ' || OLD_NAME;\\012  RETURN CURR_SEQ_VAL;\\012END;\\012$$ LANGUAGE 'plpgsql';\\012\\012\\012------------------------------------------------------------------------------------\\012--  Purpose:  Create trigger CONTROLLED_VOCABULARY_CHECK \\012------------------------------------------------------------------------------------\\012\\012CREATE OR REPLACE FUNCTION CONTROLLED_VOCABULARY_CHECK() RETURNS trigger AS $$\\012DECLARE\\012   v_code  CODE;\\012BEGIN\\012\\012   select code into v_code from data_types where id = NEW.daty_id;\\012\\012   -- Check if the data is of type "CONTROLLEDVOCABULARY"\\012   if v_code = 'CONTROLLEDVOCABULARY' then\\012      if NEW.covo_id IS NULL then\\012         RAISE EXCEPTION 'Insert/Update of Property Type (Code: %) failed, as its Data Type is CONTROLLEDVOCABULARY, but it is not linked to a Controlled Vocabulary.', NEW.code;\\012      end if;\\012   end if;\\012\\012   RETURN NEW;\\012\\012END;\\012$$ LANGUAGE 'plpgsql';\\012\\012CREATE TRIGGER CONTROLLED_VOCABULARY_CHECK BEFORE INSERT OR UPDATE ON PROPERTY_TYPES\\012    FOR EACH ROW EXECUTE PROCEDURE CONTROLLED_VOCABULARY_CHECK();\\012\\012\\012------------------------------------------------------------------------------------\\012--  Purpose:  Create trigger EXTERNAL_DATA_STORAGE_FORMAT_CHECK \\012------------------------------------------------------------------------------------\\012\\012CREATE OR REPLACE FUNCTION EXTERNAL_DATA_STORAGE_FORMAT_CHECK() RETURNS trigger AS $$\\012DECLARE\\012   v_covo_code  CODE;\\012   data_code CODE;\\012BEGIN\\012\\012   select code into v_covo_code from controlled_vocabularies\\012      where is_internal_namespace = true and \\012         id = (select covo_id from controlled_vocabulary_terms where id = NEW.cvte_id_stor_fmt);\\012   -- Check if the data storage format is a term of the controlled vocabulary "STORAGE_FORMAT"\\012   if v_covo_code != 'STORAGE_FORMAT' then\\012      select code into data_code from data where id = NEW.data_id; \\012      RAISE EXCEPTION 'Insert/Update of Data (Code: %) failed, as its Storage Format is %, but is required to be STORAGE_FORMAT.', data_code, v_covo_code;\\012   end if;\\012\\012   RETURN NEW;\\012\\012END;\\012$$ LANGUAGE 'plpgsql';\\012\\012CREATE TRIGGER EXTERNAL_DATA_STORAGE_FORMAT_CHECK BEFORE INSERT OR UPDATE ON EXTERNAL_DATA\\012    FOR EACH ROW EXECUTE PROCEDURE EXTERNAL_DATA_STORAGE_FORMAT_CHECK();\\012\\012------------------------------------------------------------------------------------\\012--  Purpose:  Create trigger SAMPLE_CODE_UNIQUENESS_CHECK \\012------------------------------------------------------------------------------------\\012\\012CREATE OR REPLACE FUNCTION SAMPLE_CODE_UNIQUENESS_CHECK() RETURNS trigger AS $$\\012DECLARE\\012   counter  INTEGER;\\012BEGIN\\012\\011IF (NEW.samp_id_part_of is NULL) THEN\\012\\011\\011IF (NEW.dbin_id is not NULL) THEN\\012\\011\\011\\011SELECT count(*) into counter FROM samples \\012\\011\\011\\011\\011where id != NEW.id and code = NEW.code and samp_id_part_of is NULL and dbin_id = NEW.dbin_id;\\012\\011\\011\\011IF (counter > 0) THEN\\012\\011\\011\\011\\011RAISE EXCEPTION 'Insert/Update of Sample (Code: %) failed because database instance sample with the same code already exists.', NEW.code;\\012\\011\\011\\011END IF;\\012\\011\\011ELSIF (NEW.grou_id is not NULL) THEN\\012\\011\\011\\011SELECT count(*) into counter FROM samples \\012\\011\\011\\011\\011where id != NEW.id and code = NEW.code and samp_id_part_of is NULL and grou_id = NEW.grou_id;\\012\\011\\011\\011IF (counter > 0) THEN\\012\\011\\011\\011\\011RAISE EXCEPTION 'Insert/Update of Sample (Code: %) failed because group sample with the same code already exists.', NEW.code;\\012\\011\\011\\011END IF;\\012\\011\\011END IF;\\012        ELSE\\012\\011\\011IF (NEW.dbin_id is not NULL) THEN\\012\\011\\011\\011SELECT count(*) into counter FROM samples \\012\\011\\011\\011\\011where id != NEW.id and code = NEW.code and samp_id_part_of = NEW.samp_id_part_of and dbin_id = NEW.dbin_id;\\012\\011\\011\\011IF (counter > 0) THEN\\012\\011\\011\\011\\011RAISE EXCEPTION 'Insert/Update of Sample (Code: %) failed because database instance sample with the same code and being the part of the same parent already exists.', NEW.code;\\012\\011\\011\\011END IF;\\012\\011\\011ELSIF (NEW.grou_id is not NULL) THEN\\012\\011\\011\\011SELECT count(*) into counter FROM samples \\012\\011\\011\\011\\011where id != NEW.id and code = NEW.code and samp_id_part_of = NEW.samp_id_part_of and grou_id = NEW.grou_id;\\012\\011\\011\\011IF (counter > 0) THEN\\012\\011\\011\\011\\011RAISE EXCEPTION 'Insert/Update of Sample (Code: %) failed because group sample with the same code and being the part of the same parent already exists.', NEW.code;\\012\\011\\011\\011END IF;\\012\\011\\011END IF;\\012        END IF;   \\012   RETURN NEW;\\012END;\\012$$ LANGUAGE 'plpgsql';\\012\\012CREATE TRIGGER SAMPLE_CODE_UNIQUENESS_CHECK BEFORE INSERT OR UPDATE ON SAMPLES\\012    FOR EACH ROW EXECUTE PROCEDURE SAMPLE_CODE_UNIQUENESS_CHECK();\\012	\N
+./sourceTest/sql/postgresql/056/.svn/text-base/017=database_version_logs.tsv.svn-base:028	source/sql/postgresql/migration/migration-027-028.sql	SUCCESS	2008-11-18 13:24:17.508	-- Create EXPERIMENT_ATTACHMENT_CONTENTS.\\012CREATE TABLE EXPERIMENT_ATTACHMENT_CONTENTS (ID TECH_ID NOT NULL,VALUE FILE NOT NULL);\\012CREATE SEQUENCE EXPERIMENT_ATTACHMENT_CONTENT_ID_SEQ;\\012ALTER TABLE EXPERIMENT_ATTACHMENT_CONTENTS ADD CONSTRAINT EXAC_PK PRIMARY KEY(ID);\\012\\012-- Alter EXPERIMENT_ATTACHMENTS by adding the new column which has a NULL constraint.\\012-- The NOT NULL constraint is added later on.\\012ALTER TABLE EXPERIMENT_ATTACHMENTS ADD COLUMN EXAC_ID TECH_ID;\\012\\012-- Does the VALUE migration between EXPERIMENT_ATTACHMENTS to EXPERIMENT_ATTACHMENT_CONTENTS.\\012CREATE OR REPLACE FUNCTION move_exp_att_content() RETURNS integer AS $$\\012DECLARE\\012    rec RECORD;\\012    seq BIGINT;\\012BEGIN\\012  FOR rec IN SELECT id, value FROM EXPERIMENT_ATTACHMENTS LOOP\\012  \\011seq := nextval('EXPERIMENT_ATTACHMENT_CONTENT_ID_SEQ');\\012    INSERT INTO EXPERIMENT_ATTACHMENT_CONTENTS (id, value) VALUES (seq, rec.value);\\012    UPDATE EXPERIMENT_ATTACHMENTS SET exac_id = seq WHERE id = rec.id;\\012  END LOOP;\\012  RETURN 1;\\012END;\\012$$ LANGUAGE 'plpgsql';\\012\\012-- Call the function.\\012SELECT move_exp_att_content();\\012DROP FUNCTION move_exp_att_content();\\012\\012\\012-- Finish EXPERIMENT_ATTACHMENTS changes.\\012ALTER TABLE EXPERIMENT_ATTACHMENTS ADD CONSTRAINT EXAT_CONT_FK FOREIGN KEY (EXAC_ID) REFERENCES EXPERIMENT_ATTACHMENT_CONTENTS(ID);\\012ALTER TABLE EXPERIMENT_ATTACHMENTS DROP COLUMN VALUE;\\012ALTER TABLE EXPERIMENT_ATTACHMENTS ALTER COLUMN EXAC_ID SET NOT NULL;\\012	\N
+./sourceTest/sql/postgresql/056/.svn/text-base/017=database_version_logs.tsv.svn-base:029	source/sql/postgresql/migration/migration-028-029.sql	SUCCESS	2009-03-18 10:50:20.105	-- -------\\012-- add modification_timestamp field to allow edition with Hibernate\\012-- -------\\012\\012ALTER TABLE samples\\012\\011ADD COLUMN modification_timestamp TIME_STAMP DEFAULT CURRENT_TIMESTAMP;\\012\\012ALTER TABLE experiments\\012\\011ADD COLUMN modification_timestamp TIME_STAMP DEFAULT CURRENT_TIMESTAMP;\\012\\012ALTER TABLE materials\\012\\011ADD COLUMN modification_timestamp TIME_STAMP DEFAULT CURRENT_TIMESTAMP;\\012\\012ALTER TABLE experiment_properties\\012\\011ADD COLUMN modification_timestamp TIME_STAMP DEFAULT CURRENT_TIMESTAMP;\\012\\012ALTER TABLE material_properties\\012\\011ADD COLUMN modification_timestamp TIME_STAMP DEFAULT CURRENT_TIMESTAMP;\\012\\012ALTER TABLE sample_properties\\012\\011ADD COLUMN modification_timestamp TIME_STAMP DEFAULT CURRENT_TIMESTAMP;\\012\\012-- -------\\012-- add property data type which references materials\\012-- -------\\012\\012ALTER TABLE property_types\\012\\011ADD COLUMN maty_prop_id tech_id;\\012\\012ALTER TABLE property_types\\012\\011ADD CONSTRAINT prty_maty_fk FOREIGN KEY (maty_prop_id) REFERENCES material_types(id);\\012\\012ALTER TABLE experiment_properties\\012\\011ADD COLUMN mate_prop_id tech_id;\\012\\012ALTER TABLE material_properties\\012\\011ADD COLUMN mate_prop_id tech_id;\\012\\012ALTER TABLE sample_properties\\012\\011ADD COLUMN mate_prop_id tech_id;\\012\\012ALTER TABLE experiment_properties\\012\\011ADD CONSTRAINT expr_mapr_fk FOREIGN KEY (mate_prop_id) REFERENCES materials(id);\\012\\012ALTER TABLE material_properties\\012\\011ADD CONSTRAINT mapr_mapr_fk FOREIGN KEY (mate_prop_id) REFERENCES materials(id);\\012\\012ALTER TABLE sample_properties\\012\\011ADD CONSTRAINT sapr_mapr_fk FOREIGN KEY (mate_prop_id) REFERENCES materials(id);\\012\\012insert into data_types\\012(id\\012 ,code\\012 ,description)\\012 values \\012 (nextval('DATA_TYPE_ID_SEQ')\\012 ,'MATERIAL'\\012 ,'Reference to a material'\\012);\\012\\012ALTER TABLE MATERIAL_PROPERTIES DROP CONSTRAINT MAPR_CK;\\012ALTER TABLE MATERIAL_PROPERTIES ADD CONSTRAINT MAPR_CK CHECK \\012\\011((VALUE IS NOT NULL AND CVTE_ID IS NULL AND MATE_PROP_ID IS NULL) OR \\012\\011 (VALUE IS NULL AND CVTE_ID IS NOT NULL AND MATE_PROP_ID IS NULL) OR\\012\\011 (VALUE IS NULL AND CVTE_ID IS NULL AND MATE_PROP_ID IS NOT NULL)\\012\\011);\\012\\012ALTER TABLE EXPERIMENT_PROPERTIES DROP CONSTRAINT EXPR_CK;\\012ALTER TABLE EXPERIMENT_PROPERTIES ADD CONSTRAINT EXPR_CK CHECK \\012\\011((VALUE IS NOT NULL AND CVTE_ID IS NULL AND MATE_PROP_ID IS NULL) OR \\012\\011 (VALUE IS NULL AND CVTE_ID IS NOT NULL AND MATE_PROP_ID IS NULL) OR\\012\\011 (VALUE IS NULL AND CVTE_ID IS NULL AND MATE_PROP_ID IS NOT NULL)\\012\\011);\\012\\012ALTER TABLE SAMPLE_PROPERTIES DROP CONSTRAINT SAPR_CK;\\012ALTER TABLE SAMPLE_PROPERTIES ADD CONSTRAINT SAPR_CK CHECK \\012\\011((VALUE IS NOT NULL AND CVTE_ID IS NULL AND MATE_PROP_ID IS NULL) OR \\012\\011 (VALUE IS NULL AND CVTE_ID IS NOT NULL AND MATE_PROP_ID IS NULL) OR\\012\\011 (VALUE IS NULL AND CVTE_ID IS NULL AND MATE_PROP_ID IS NOT NULL)\\012\\011);\\012\\012------------------------------------------------------------------------------------\\012--  Purpose:  Create trigger MATERIAL/SAMPLE/EXPERIMENT _PROPERTY_WITH_MATERIAL_DATA_TYPE_CHECK\\012--            It checks that if material property value is assigned to the entity,\\012--\\011\\011\\011\\011\\011\\011then the material type is equal to the one described by property type.\\012------------------------------------------------------------------------------------\\012\\012CREATE OR REPLACE FUNCTION MATERIAL_PROPERTY_WITH_MATERIAL_DATA_TYPE_CHECK() RETURNS trigger AS $$\\012DECLARE\\012   v_type_id  CODE;\\012   v_type_id_prop  CODE;\\012BEGIN\\012   if NEW.mate_prop_id IS NOT NULL then\\012\\011\\011\\011-- find material type id of the property type \\012\\011\\011\\011select pt.maty_prop_id into v_type_id_prop \\012\\011\\011\\011  from material_type_property_types etpt, property_types pt \\012\\011\\011\\011 where NEW.mtpt_id = etpt.id AND etpt.prty_id = pt.id;\\012\\011\\011\\012\\011\\011\\011if v_type_id_prop IS NOT NULL then\\012\\011\\011\\011\\011-- find material type id of the material which consists the entity's property value\\012\\011\\011\\011\\011select entity.maty_id into v_type_id \\012\\011\\011\\011\\011  from materials entity\\012\\011\\011\\011\\011 where NEW.mate_prop_id = entity.id;\\012\\011\\011\\011\\011if v_type_id != v_type_id_prop then\\012\\011\\011\\011\\011\\011RAISE EXCEPTION 'Insert/Update of property value referencing material (id: %) failed, as referenced material type is different than expected (id %, expected id: %).', \\012\\011\\011\\011\\011\\011\\011\\011 NEW.mate_prop_id, v_type_id, v_type_id_prop;\\012\\011\\011\\011\\011end if;\\012\\011\\011\\011end if;\\012   end if;\\012   RETURN NEW;\\012END;\\012$$ LANGUAGE 'plpgsql';\\012\\012CREATE TRIGGER MATERIAL_PROPERTY_WITH_MATERIAL_DATA_TYPE_CHECK BEFORE INSERT OR UPDATE ON material_properties\\012    FOR EACH ROW EXECUTE PROCEDURE MATERIAL_PROPERTY_WITH_MATERIAL_DATA_TYPE_CHECK();\\012    \\012CREATE OR REPLACE FUNCTION SAMPLE_PROPERTY_WITH_MATERIAL_DATA_TYPE_CHECK() RETURNS trigger AS $$\\012DECLARE\\012   v_type_id  CODE;\\012   v_type_id_prop  CODE;\\012BEGIN\\012   if NEW.mate_prop_id IS NOT NULL then\\012\\011\\011\\011-- find material type id of the property type \\012\\011\\011\\011select pt.maty_prop_id into v_type_id_prop \\012\\011\\011\\011  from sample_type_property_types etpt, property_types pt \\012\\011\\011\\011 where NEW.stpt_id = etpt.id AND etpt.prty_id = pt.id;\\012\\011\\011\\012\\011\\011\\011if v_type_id_prop IS NOT NULL then\\012\\011\\011\\011\\011-- find material type id of the material which consists the entity's property value\\012\\011\\011\\011\\011select entity.maty_id into v_type_id \\012\\011\\011\\011\\011  from materials entity\\012\\011\\011\\011\\011 where NEW.mate_prop_id = entity.id;\\012\\011\\011\\011\\011if v_type_id != v_type_id_prop then\\012\\011\\011\\011\\011\\011RAISE EXCEPTION 'Insert/Update of property value referencing material (id: %) failed, as referenced material type is different than expected (id %, expected id: %).', \\012\\011\\011\\011\\011\\011\\011\\011\\011\\011\\011\\011\\011 NEW.mate_prop_id, v_type_id, v_type_id_prop;\\012\\011\\011\\011\\011end if;\\012\\011\\011\\011end if;\\012   end if;\\012   RETURN NEW;\\012END;\\012$$ LANGUAGE 'plpgsql';\\012\\012CREATE TRIGGER SAMPLE_PROPERTY_WITH_MATERIAL_DATA_TYPE_CHECK BEFORE INSERT OR UPDATE ON sample_properties\\012    FOR EACH ROW EXECUTE PROCEDURE SAMPLE_PROPERTY_WITH_MATERIAL_DATA_TYPE_CHECK();\\012    \\012CREATE OR REPLACE FUNCTION EXPERIMENT_PROPERTY_WITH_MATERIAL_DATA_TYPE_CHECK() RETURNS trigger AS $$\\012DECLARE\\012   v_type_id  CODE;\\012   v_type_id_prop  CODE;\\012BEGIN\\012   if NEW.mate_prop_id IS NOT NULL then\\012\\011\\011\\011-- find material type id of the property type \\012\\011\\011\\011select pt.maty_prop_id into v_type_id_prop \\012\\011\\011\\011  from experiment_type_property_types etpt, property_types pt \\012\\011\\011\\011 where NEW.etpt_id = etpt.id AND etpt.prty_id = pt.id;\\012\\011\\011\\012\\011\\011\\011if v_type_id_prop IS NOT NULL then\\012\\011\\011\\011\\011-- find material type id of the material which consists the entity's property value\\012\\011\\011\\011\\011select entity.maty_id into v_type_id \\012\\011\\011\\011\\011  from materials entity\\012\\011\\011\\011\\011 where NEW.mate_prop_id = entity.id;\\012\\011\\011\\011\\011if v_type_id != v_type_id_prop then\\012\\011\\011\\011\\011\\011RAISE EXCEPTION 'Insert/Update of property value referencing material (id: %) failed, as referenced material type is different than expected (id %, expected id: %).', \\012\\011\\011\\011\\011\\011\\011\\011\\011\\011\\011\\011\\011 NEW.mate_prop_id, v_type_id, v_type_id_prop;\\012\\011\\011\\011\\011end if;\\012\\011\\011\\011end if;\\012   end if;\\012   RETURN NEW;\\012END;\\012$$ LANGUAGE 'plpgsql';\\012\\012CREATE TRIGGER EXPERIMENT_PROPERTY_WITH_MATERIAL_DATA_TYPE_CHECK BEFORE INSERT OR UPDATE ON experiment_properties\\012    FOR EACH ROW EXECUTE PROCEDURE EXPERIMENT_PROPERTY_WITH_MATERIAL_DATA_TYPE_CHECK();\\012       \\012-- -------\\012-- remove the reminescents of the OBSERVABLE_TYPE\\012-- -------\\012\\012ALTER TABLE data\\012\\011DROP CONSTRAINT data_obty_fk;\\012\\012ALTER TABLE data_set_types\\012\\011DROP CONSTRAINT obty_pk;\\012\\012ALTER TABLE data_set_types\\012\\011ADD CONSTRAINT dsty_pk PRIMARY KEY (id);\\012\\012ALTER TABLE data\\012\\011ADD CONSTRAINT data_dsty_fk FOREIGN KEY (dsty_id) REFERENCES data_set_types(id);\\012\\012ALTER TABLE data_set_types\\012\\011DROP CONSTRAINT obty_bk_uk;\\012\\012ALTER TABLE data_set_types\\012\\011DROP CONSTRAINT obty_dbin_fk;\\012\\012ALTER TABLE data_set_types\\012\\011ADD CONSTRAINT dsty_bk_uk UNIQUE (code, dbin_id);\\012\\012ALTER TABLE data_set_types\\012\\011ADD CONSTRAINT dsty_dbin_fk FOREIGN KEY (dbin_id) REFERENCES database_instances(id);\\012\\012DROP INDEX data_obty_fk_i;\\012\\012CREATE INDEX data_dsty_fk_i ON data(dsty_id);\\012	\N
+./sourceTest/sql/postgresql/056/.svn/text-base/017=database_version_logs.tsv.svn-base:030	source/sql/postgresql/migration/migration-029-030.sql	SUCCESS	2009-03-23 15:34:44.72	-- -------\\012-- add modification_timestamp field to allow edition with Hibernate\\012-- -------\\012ALTER TABLE data\\012\\011ADD COLUMN modification_timestamp TIME_STAMP DEFAULT CURRENT_TIMESTAMP;\\012ALTER TABLE experiment_types\\012\\011ADD COLUMN modification_timestamp TIME_STAMP DEFAULT CURRENT_TIMESTAMP;\\012ALTER TABLE sample_types\\012\\011ADD COLUMN modification_timestamp TIME_STAMP DEFAULT CURRENT_TIMESTAMP;\\012ALTER TABLE material_types\\012\\011ADD COLUMN modification_timestamp TIME_STAMP DEFAULT CURRENT_TIMESTAMP;\\012ALTER TABLE data_set_types\\012\\011ADD COLUMN modification_timestamp TIME_STAMP DEFAULT CURRENT_TIMESTAMP;\\012ALTER TABLE controlled_vocabularies\\012\\011ADD COLUMN modification_timestamp TIME_STAMP DEFAULT CURRENT_TIMESTAMP;\\012-- -------\\012-- add properties to data sets\\012-- -------\\012CREATE TABLE DATA_SET_PROPERTIES (ID TECH_ID NOT NULL,DS_ID TECH_ID NOT NULL,DSTPT_ID TECH_ID NOT NULL,VALUE GENERIC_VALUE,CVTE_ID TECH_ID, MATE_PROP_ID TECH_ID, PERS_ID_REGISTERER TECH_ID NOT NULL,REGISTRATION_TIMESTAMP TIME_STAMP_DFL NOT NULL DEFAULT CURRENT_TIMESTAMP, MODIFICATION_TIMESTAMP TIME_STAMP DEFAULT CURRENT_TIMESTAMP);\\012CREATE TABLE DATA_SET_TYPE_PROPERTY_TYPES (ID TECH_ID NOT NULL,DSTY_ID TECH_ID NOT NULL,PRTY_ID TECH_ID NOT NULL,IS_MANDATORY BOOLEAN_CHAR NOT NULL DEFAULT 'F',IS_MANAGED_INTERNALLY BOOLEAN_CHAR NOT NULL DEFAULT 'F',PERS_ID_REGISTERER TECH_ID NOT NULL,REGISTRATION_TIMESTAMP TIME_STAMP_DFL NOT NULL DEFAULT CURRENT_TIMESTAMP);\\012\\012CREATE SEQUENCE DATA_SET_PROPERTY_ID_SEQ;\\012CREATE SEQUENCE DSTPT_ID_SEQ;\\012\\012ALTER TABLE DATA_SET_TYPE_PROPERTY_TYPES ADD CONSTRAINT DSTPT_PK PRIMARY KEY(ID);\\012ALTER TABLE DATA_SET_PROPERTIES ADD CONSTRAINT DSPR_PK PRIMARY KEY(ID);\\012\\012ALTER TABLE DATA_SET_TYPE_PROPERTY_TYPES ADD CONSTRAINT DSTPT_BK_UK UNIQUE(DSTY_ID,PRTY_ID);\\012ALTER TABLE DATA_SET_PROPERTIES ADD CONSTRAINT DSPR_BK_UK UNIQUE(DS_ID,DSTPT_ID);\\012\\012\\012ALTER TABLE DATA_SET_TYPE_PROPERTY_TYPES ADD CONSTRAINT DSTPT_DSTY_FK FOREIGN KEY (DSTY_ID) REFERENCES DATA_SET_TYPES(ID);\\012ALTER TABLE DATA_SET_TYPE_PROPERTY_TYPES ADD CONSTRAINT DSTPT_PERS_FK FOREIGN KEY (PERS_ID_REGISTERER) REFERENCES PERSONS(ID);\\012ALTER TABLE DATA_SET_TYPE_PROPERTY_TYPES ADD CONSTRAINT DSTPT_PRTY_FK FOREIGN KEY (PRTY_ID) REFERENCES PROPERTY_TYPES(ID);\\012ALTER TABLE DATA_SET_PROPERTIES ADD CONSTRAINT DSPR_CVTE_FK FOREIGN KEY (CVTE_ID) REFERENCES CONTROLLED_VOCABULARY_TERMS(ID);\\012ALTER TABLE DATA_SET_PROPERTIES ADD CONSTRAINT DSPR_DSTPT_FK FOREIGN KEY (DSTPT_ID) REFERENCES DATA_SET_TYPE_PROPERTY_TYPES(ID) ON DELETE CASCADE;\\012ALTER TABLE DATA_SET_PROPERTIES ADD CONSTRAINT DSPR_DS_FK FOREIGN KEY (DS_ID) REFERENCES DATA(ID);\\012ALTER TABLE DATA_SET_PROPERTIES ADD CONSTRAINT DSPR_PERS_FK FOREIGN KEY (PERS_ID_REGISTERER) REFERENCES PERSONS(ID);\\012ALTER TABLE DATA_SET_PROPERTIES ADD CONSTRAINT DSPR_MAPR_FK FOREIGN KEY (MATE_PROP_ID) REFERENCES MATERIALS(ID);\\012\\012ALTER TABLE DATA_SET_PROPERTIES ADD CONSTRAINT DSPR_CK CHECK \\012\\011((VALUE IS NOT NULL AND CVTE_ID IS NULL AND MATE_PROP_ID IS NULL) OR \\012\\011 (VALUE IS NULL AND CVTE_ID IS NOT NULL AND MATE_PROP_ID IS NULL) OR\\012\\011 (VALUE IS NULL AND CVTE_ID IS NULL AND MATE_PROP_ID IS NOT NULL)\\012\\011);\\012\\012CREATE INDEX DSPR_CVTE_FK_I ON DATA_SET_PROPERTIES (CVTE_ID);\\012CREATE INDEX DSPR_DSTPT_FK_I ON DATA_SET_PROPERTIES (DSTPT_ID);\\012CREATE INDEX DSPR_DS_FK_I ON DATA_SET_PROPERTIES (DS_ID);\\012CREATE INDEX DSPR_PERS_FK_I ON DATA_SET_PROPERTIES (PERS_ID_REGISTERER);\\012CREATE INDEX DSTPT_DSTY_FK_I ON DATA_SET_TYPE_PROPERTY_TYPES (DSTY_ID);\\012CREATE INDEX DSTPT_PERS_FK_I ON DATA_SET_TYPE_PROPERTY_TYPES (PERS_ID_REGISTERER);\\012CREATE INDEX DSTPT_PRTY_FK_I ON DATA_SET_TYPE_PROPERTY_TYPES (PRTY_ID);\\012\\012CREATE OR REPLACE FUNCTION DATA_SET_PROPERTY_WITH_MATERIAL_DATA_TYPE_CHECK() RETURNS trigger AS $$\\012DECLARE\\012   v_type_id  CODE;\\012   v_type_id_prop  CODE;\\012BEGIN\\012   if NEW.mate_prop_id IS NOT NULL then\\012\\011\\011\\011-- find material type id of the property type \\012\\011\\011\\011select pt.maty_prop_id into v_type_id_prop \\012\\011\\011\\011  from data_set_type_property_types dstpt, property_types pt \\012\\011\\011\\011 where NEW.dstpt_id = dstpt.id AND dstpt.prty_id = pt.id;\\012\\011\\011\\012\\011\\011\\011if v_type_id_prop IS NOT NULL then\\012\\011\\011\\011\\011-- find material type id of the material which consists the entity's property value\\012\\011\\011\\011\\011select entity.maty_id into v_type_id \\012\\011\\011\\011\\011  from materials entity\\012\\011\\011\\011\\011 where NEW.mate_prop_id = entity.id;\\012\\011\\011\\011\\011if v_type_id != v_type_id_prop then\\012\\011\\011\\011\\011\\011RAISE EXCEPTION 'Insert/Update of property value referencing material (id: %) failed, as referenced material type is different than expected (id %, expected id: %).', \\012\\011\\011\\011\\011\\011\\011\\011\\011\\011\\011\\011\\011 NEW.mate_prop_id, v_type_id, v_type_id_prop;\\012\\011\\011\\011\\011end if;\\012\\011\\011\\011end if;\\012   end if;\\012   RETURN NEW;\\012END;\\012$$ LANGUAGE 'plpgsql';\\012\\012CREATE TRIGGER DATA_SET_PROPERTY_WITH_MATERIAL_DATA_TYPE_CHECK BEFORE INSERT OR UPDATE ON data_set_properties\\012    FOR EACH ROW EXECUTE PROCEDURE DATA_SET_PROPERTY_WITH_MATERIAL_DATA_TYPE_CHECK();   \\012	\N
+./sourceTest/sql/postgresql/056/.svn/text-base/017=database_version_logs.tsv.svn-base:032	source/sql/postgresql/migration/migration-031-032.sql	SUCCESS	2009-04-09 09:36:36.2	-- -------\\012-- Modify MATERIAL_BATCHES\\012-- -------\\012\\012ALTER TABLE material_batches\\012    DROP COLUMN proc_id;\\012\\012-- -------\\012-- Modify SAMPLES\\012-- -------\\012\\012ALTER TABLE samples\\012    ADD COLUMN expe_id tech_id;\\012\\012ALTER TABLE samples\\012    ADD CONSTRAINT samp_expe_fk FOREIGN KEY (expe_id) REFERENCES experiments(id);\\012\\012CREATE INDEX samp_expe_fk_i ON samples USING btree (expe_id);\\012\\012-- relink samples directly to experiments\\012\\012UPDATE samples\\012SET expe_id = (SELECT e.id FROM experiments e, procedures p, sample_inputs si \\012               WHERE si.samp_id = samples.id AND si.proc_id = p.id AND p.expe_id = e.id AND e.inva_id IS NULL);\\012\\012\\012-- -------\\012-- Modify DATA\\012-- -------\\012\\012ALTER TABLE data\\012    ADD COLUMN expe_id tech_id;\\012\\012ALTER TABLE data\\012    ADD CONSTRAINT data_expe_fk FOREIGN KEY (expe_id) REFERENCES experiments(id);\\012\\012CREATE INDEX data_expe_fk_i ON data USING btree (expe_id);\\012\\012UPDATE data\\012SET expe_id = (SELECT e.id FROM experiments e, procedures p \\012               WHERE data.proc_id_produced_by = p.id AND p.expe_id = e.id);\\012\\012ALTER TABLE data\\012    ALTER COLUMN expe_id SET NOT NULL;\\012\\012ALTER TABLE data\\012    DROP COLUMN proc_id_produced_by;\\012\\012-- -------\\012-- Drop PROCEDURES, PROCEDURE_TYPES, and SAMPLE_INPUTS\\012-- -------\\012\\012DROP TABLE sample_inputs;\\012DROP TABLE procedures;\\012DROP TABLE procedure_types;\\012\\012DROP SEQUENCE procedure_id_seq;\\012DROP SEQUENCE procedure_type_id_seq;\\012\\012-- -------\\012-- Add CODE_SEQ\\012-- -------\\012\\012CREATE SEQUENCE CODE_SEQ;\\012\\012-- -------\\012-- Add new columns to DATA_STORES\\012-- -------\\012\\012ALTER TABLE data_stores\\012    ADD COLUMN remote_url character varying(250),\\012    ADD COLUMN session_token character varying(50),\\012    ADD COLUMN modification_timestamp time_stamp DEFAULT now();\\012\\012UPDATE data_stores\\012SET remote_url = '', session_token='';\\012\\012ALTER TABLE data_stores\\012    ALTER COLUMN remote_url SET NOT NULL,\\012    ALTER COLUMN session_token SET NOT NULL;\\012\\012-- -------\\012-- Drop foreign keys onto DATA_STORES\\012-- -------\\012\\012ALTER TABLE database_instances\\012    DROP COLUMN dast_id;\\012\\012ALTER TABLE groups\\012    DROP COLUMN dast_id;\\012\\012ALTER TABLE projects\\012    DROP COLUMN dast_id;\\012\\012ALTER TABLE experiments\\012    DROP COLUMN dast_id;\\012\\012-- -------\\012-- Add foreign key from DATA onto DATA_STORES\\012-- -------\\012\\012ALTER TABLE data\\012    ADD COLUMN dast_id tech_id;\\012\\012ALTER TABLE data\\012    ADD CONSTRAINT data_dast_fk FOREIGN KEY (dast_id) REFERENCES data_stores(id);\\012\\012UPDATE data\\012SET dast_id = (select id from data_stores where code = 'STANDARD');\\012\\012ALTER TABLE data\\012    ALTER COLUMN dast_id SET NOT NULL;\\012\\012\\012------------------------------------------------------------------------------------\\012--  Purpose:  Replace trigger SAMPLE_CODE_UNIQUENESS_CHECK \\012------------------------------------------------------------------------------------\\012\\012CREATE OR REPLACE FUNCTION SAMPLE_CODE_UNIQUENESS_CHECK() RETURNS trigger AS $$\\012DECLARE\\012   counter  INTEGER;\\012BEGIN\\012    LOCK TABLE samples IN EXCLUSIVE MODE;\\012    IF (NEW.samp_id_part_of is NULL) THEN\\012        IF (NEW.dbin_id is not NULL) THEN\\012            SELECT count(*) into counter FROM samples \\012                where id != NEW.id and code = NEW.code and samp_id_part_of is NULL and dbin_id = NEW.dbin_id;\\012            IF (counter > 0) THEN\\012                RAISE EXCEPTION 'Insert/Update of Sample (Code: %) failed because database instance sample with the same code already exists.', NEW.code;\\012            END IF;\\012        ELSIF (NEW.grou_id is not NULL) THEN\\012            SELECT count(*) into counter FROM samples \\012                where id != NEW.id and code = NEW.code and samp_id_part_of is NULL and grou_id = NEW.grou_id;\\012            IF (counter > 0) THEN\\012                RAISE EXCEPTION 'Insert/Update of Sample (Code: %) failed because group sample with the same code already exists.', NEW.code;\\012            END IF;\\012        END IF;\\012        ELSE\\012        IF (NEW.dbin_id is not NULL) THEN\\012            SELECT count(*) into counter FROM samples \\012                where id != NEW.id and code = NEW.code and samp_id_part_of = NEW.samp_id_part_of and dbin_id = NEW.dbin_id;\\012            IF (counter > 0) THEN\\012                RAISE EXCEPTION 'Insert/Update of Sample (Code: %) failed because database instance sample with the same code and being the part of the same parent already exists.', NEW.code;\\012            END IF;\\012        ELSIF (NEW.grou_id is not NULL) THEN\\012            SELECT count(*) into counter FROM samples \\012                where id != NEW.id and code = NEW.code and samp_id_part_of = NEW.samp_id_part_of and grou_id = NEW.grou_id;\\012            IF (counter > 0) THEN\\012                RAISE EXCEPTION 'Insert/Update of Sample (Code: %) failed because group sample with the same code and being the part of the same parent already exists.', NEW.code;\\012            END IF;\\012        END IF;\\012        END IF;   \\012   RETURN NEW;\\012END;\\012$$ LANGUAGE 'plpgsql';\\012\\012\\012\\012	\N
+./sourceTest/sql/postgresql/056/.svn/text-base/017=database_version_logs.tsv.svn-base:034	source/sql/postgresql/migration/migration-033-034.sql	SUCCESS	2009-05-26 08:32:49.935	------------------------------------------------------------------------------------\\012-- Create sequence for generating permanent identifiers starting with nextval of existing dataset sequence.\\012------------------------------------------------------------------------------------\\012CREATE FUNCTION CREATE_SEQUENCE(EXISTING_SEQUENCE VARCHAR, NEW_SEQUENCE VARCHAR) RETURNS VOID AS $$\\012DECLARE\\012  CURR_SEQ_VAL   INTEGER;\\012BEGIN\\012  SELECT INTO CURR_SEQ_VAL NEXTVAL(EXISTING_SEQUENCE);\\012  EXECUTE 'CREATE SEQUENCE ' || NEW_SEQUENCE || ' START WITH ' || CURR_SEQ_VAL;\\012  RETURN;\\012END;\\012$$ LANGUAGE 'plpgsql';\\012\\012SELECT CREATE_SEQUENCE('DATA_ID_SEQ', 'PERM_ID_SEQ');\\012DROP FUNCTION CREATE_SEQUENCE(VARCHAR, VARCHAR);\\012\\012------------------------------------------------------------------------------------\\012-- Add perm_id columns to samples and experiments.\\012------------------------------------------------------------------------------------\\012ALTER TABLE SAMPLES ADD COLUMN PERM_ID CODE;\\012ALTER TABLE EXPERIMENTS ADD COLUMN PERM_ID CODE;\\012\\012UPDATE SAMPLES SET PERM_ID = to_char(registration_timestamp,'YYYYMMDDHHSSMS') || '-' || NEXTVAL('PERM_ID_SEQ');\\012UPDATE EXPERIMENTS SET PERM_ID = to_char(registration_timestamp,'YYYYMMDDHHSSMS') || '-' || NEXTVAL('PERM_ID_SEQ');\\012ALTER TABLE SAMPLES ALTER COLUMN PERM_ID SET NOT NULL;\\012ALTER TABLE EXPERIMENTS ALTER COLUMN PERM_ID SET NOT NULL;\\012ALTER TABLE SAMPLES ADD CONSTRAINT SAMP_PI_UK UNIQUE(PERM_ID);\\012ALTER TABLE EXPERIMENTS ADD CONSTRAINT EXPE_PI_UK UNIQUE(PERM_ID);\\012\\012\\012------------------------------------------------------------------------------------\\012-- Add column is_chosen_from_list to controlled_vocabularies.\\012------------------------------------------------------------------------------------\\012ALTER TABLE controlled_vocabularies ADD COLUMN is_chosen_from_list BOOLEAN_CHAR NOT NULL DEFAULT TRUE;\\012ALTER TABLE controlled_vocabularies ADD COLUMN source_uri CHARACTER VARYING(250);\\012------------------------------------------------------------------------------------\\012-- Modify Data table - remove arc connection between Sample and Data table, use a flag instead\\012------------------------------------------------------------------------------------\\012\\012-- add new columns\\012\\012ALTER TABLE data\\012    ADD COLUMN is_derived boolean_char;\\012ALTER TABLE data\\012    ADD COLUMN samp_id tech_id;\\012\\012-- update values in new columns\\012\\012UPDATE data\\012    SET is_derived = (samp_id_derived_from IS NOT NULL); \\012UPDATE data\\012    SET samp_id = samp_id_derived_from \\012    WHERE is_derived = 'TRUE';\\012UPDATE data\\012    SET samp_id = samp_id_acquired_from \\012    WHERE is_derived = 'FALSE';\\012\\012-- add constraints and indexes to new columns\\012\\012ALTER TABLE data\\012    ALTER COLUMN is_derived SET NOT NULL;\\012ALTER TABLE data\\012    ALTER COLUMN samp_id SET NOT NULL;   \\012ALTER TABLE data\\012    ADD CONSTRAINT data_samp_fk FOREIGN KEY (samp_id) REFERENCES samples (id);\\012CREATE INDEX data_samp_fk_i ON data USING btree (samp_id);\\012\\012-- remove old columns\\012\\012ALTER TABLE data\\012    DROP COLUMN samp_id_acquired_from;\\012ALTER TABLE data\\012    DROP COLUMN samp_id_derived_from;\\012    \\012------------------------------------------------------------------------------------\\012-- Granting SELECT privilege to group openbis_readonly\\012------------------------------------------------------------------------------------\\012\\012GRANT SELECT ON SEQUENCE attachment_content_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE attachment_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE code_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE controlled_vocabulary_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE cvte_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE data_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE data_set_property_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE data_set_relationship_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE data_set_type_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE data_store_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE data_type_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE database_instance_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE dstpt_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE etpt_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE event_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE experiment_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE experiment_property_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE experiment_type_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE file_format_type_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE group_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE invalidation_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE locator_type_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE material_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE material_property_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE material_type_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE mtpt_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE perm_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE person_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE project_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE property_type_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE role_assignment_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE sample_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE sample_property_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE sample_type_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE stpt_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE attachment_contents TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE attachments TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE controlled_vocabularies TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE controlled_vocabulary_terms TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE data TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE data_set_properties TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE data_set_relationships TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE data_set_type_property_types TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE data_set_types TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE data_stores TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE data_types TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE database_instances TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE database_version_logs TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE events TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE experiment_properties TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE experiment_type_property_types TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE experiment_types TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE experiments TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE external_data TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE file_format_types TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE groups TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE invalidations TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE locator_types TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE material_properties TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE material_type_property_types TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE material_types TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE materials TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE persons TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE projects TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE property_types TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE role_assignments TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE sample_properties TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE sample_type_property_types TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE sample_types TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE samples TO GROUP OPENBIS_READONLY;\\012\\012------------------------------------------------------------------------------------\\012-- Delete MATERIAL_BATCHES table\\012------------------------------------------------------------------------------------\\012\\012-- WARNING: Potential data lost!!!\\012-- WARNING: Potential data lost!!!\\012-- WARNING: Potential data lost!!!\\012\\012DROP TABLE SAMPLE_MATERIAL_BATCHES;\\012DROP TABLE MATERIAL_BATCHES;\\012DROP SEQUENCE MATERIAL_BATCH_ID_SEQ;\\012\\012------------------------------------------------------------------------------------\\012-- Delete MATE_ID_INHIBITOR_OF from table MATERIALS\\012------------------------------------------------------------------------------------\\012\\012-- WARNING: Potential data lost!!!\\012-- WARNING: Potential data lost!!!\\012-- WARNING: Potential data lost!!!\\012\\012ALTER TABLE MATERIALS DROP COLUMN MATE_ID_INHIBITOR_OF;\\012	\N
+./sourceTest/sql/postgresql/056/.svn/text-base/017=database_version_logs.tsv.svn-base:041	source/sql/postgresql/migration/migration-040-041.sql	SUCCESS	2009-09-14 13:48:57.539	-- Create FILTERS table\\012\\012CREATE TABLE FILTERS (ID TECH_ID NOT NULL, DBIN_ID TECH_ID NOT NULL, NAME VARCHAR(200) NOT NULL, DESCRIPTION DESCRIPTION_1000,REGISTRATION_TIMESTAMP TIME_STAMP_DFL NOT NULL DEFAULT CURRENT_TIMESTAMP, PERS_ID_REGISTERER TECH_ID NOT NULL, MODIFICATION_TIMESTAMP TIME_STAMP DEFAULT CURRENT_TIMESTAMP, EXPRESSION VARCHAR(2000) NOT NULL, IS_PUBLIC BOOLEAN NOT NULL, GRID_ID VARCHAR(200) NOT NULL);\\012CREATE SEQUENCE FILTER_ID_SEQ;\\012ALTER TABLE FILTERS ADD CONSTRAINT FILT_PK PRIMARY KEY(ID);\\012ALTER TABLE FILTERS ADD CONSTRAINT FILT_BK_UK UNIQUE(NAME, DBIN_ID, GRID_ID);\\012ALTER TABLE FILTERS ADD CONSTRAINT FILT_PERS_FK FOREIGN KEY (PERS_ID_REGISTERER) REFERENCES PERSONS(ID);\\012ALTER TABLE FILTERS ADD CONSTRAINT FILT_DBIN_FK FOREIGN KEY (DBIN_ID) REFERENCES DATABASE_INSTANCES(ID);\\012CREATE INDEX FILT_PERS_FK_I ON FILTERS (PERS_ID_REGISTERER);\\012CREATE INDEX FILT_DBIN_FK_I ON FILTERS (DBIN_ID);\\012GRANT SELECT ON SEQUENCE filter_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE filters TO GROUP OPENBIS_READONLY;\\012\\012-- Add missing foreign key to role assignments authorization group\\012ALTER TABLE ROLE_ASSIGNMENTS ADD CONSTRAINT ROAS_AG_FK_GRANTEE FOREIGN KEY (AG_ID_GRANTEE) REFERENCES AUTHORIZATION_GROUPS(ID);\\012\\012--------------------------------------------------------------------------------------------------\\012-- Modify dataset connections:\\012-- 1. connection with sample shouldn't be mandatory any more\\012-- 2. introduce an arc condition that dataset cannot be connected with a sample and a parent dataset at the same time\\012--------------------------------------------------------------------------------------------------\\012\\012-- Weaken data-sample connection constraint - allow dataset to have no connection with sample\\012ALTER TABLE data ALTER COLUMN samp_id DROP NOT NULL;\\012\\012-- Remove data-sample connection for datasets that have a parent\\012\\012UPDATE data \\012   SET samp_id = NULL \\012 WHERE id IN (SELECT DISTINCT data_id_child FROM data_set_relationships);\\012\\012-- With PostgreSQL 8.4 one can check that before migration there were no cycles in dataset relationships:\\012--\\012-- WITH RECURSIVE data_set_parents(id, parent_ids, cycle) AS (\\012--         SELECT  r.data_id_child AS id, \\012--                 ARRAY[CAST (r.data_id_parent AS bigint)] AS parent_ids, \\012--                 false AS cycle \\012--         FROM data_set_relationships r\\012--     UNION ALL\\012--         SELECT  r.data_id_child,\\012--                 CAST (r.data_id_parent AS bigint) || p.parent_ids,\\012--                 r.data_id_child = ANY(p.parent_ids)\\012--         FROM data_set_relationships r, data_set_parents p\\012--         WHERE r.data_id_parent = p.id AND NOT cycle\\012-- )\\012-- SELECT count(*) AS cycles FROM data_set_parents WHERE cycle = true;\\012\\012---------------------------------------------------------------------------------------------------\\012--  Purpose:  Create DEFERRED triggers:\\012--            * check_dataset_relationships_on_data_table_modification,\\012--            * check_dataset_relationships_on_relationships_table_modification.\\012--            They check that after all modifications of database (just before commit) \\012--            if 'data'/'data_set_relationships' tables are among modified tables \\012--            dataset is not connected with a sample and a parent dataset at the same time.\\012--            This connections are held in two different tables so simple immediate trigger \\012--            with arc check cannot be used and we need two deferred triggers.\\012----------------------------------------------------------------------------------------------------\\012\\012-- trigger for 'data' table\\012\\012CREATE OR REPLACE FUNCTION check_dataset_relationships_on_data_table_modification() RETURNS trigger AS $$\\012DECLARE\\012\\011counter\\011INTEGER;\\012BEGIN\\012\\011-- if there is a connection with a Sample there should not be any connection with a parent Data Set\\012\\011IF (NEW.samp_id IS NOT NULL) THEN\\012\\011\\011-- count number of parents\\012\\011\\011SELECT count(*) INTO counter \\012\\011\\011\\011FROM data_set_relationships \\012\\011\\011\\011WHERE data_id_child = OLD.id;\\012\\011\\011IF (counter > 0) THEN\\012\\011\\011\\011RAISE EXCEPTION 'Insert/Update of Data Set (Code: %) failed because it cannot be connected with a Sample and a parent Data Set at the same time.', OLD.code;\\012\\011\\011END IF;\\012\\011END IF;\\012  RETURN NEW;\\012END;\\012$$ LANGUAGE 'plpgsql';\\012\\012CREATE CONSTRAINT TRIGGER check_dataset_relationships_on_data_table_modification \\012  AFTER INSERT OR UPDATE ON data\\012\\011DEFERRABLE INITIALLY DEFERRED\\012\\011FOR EACH ROW \\012\\011EXECUTE PROCEDURE check_dataset_relationships_on_data_table_modification();\\012\\012-- trigger for 'data_set_relationships'\\012\\012CREATE OR REPLACE FUNCTION check_dataset_relationships_on_relationships_table_modification() RETURNS trigger AS $$\\012DECLARE\\012\\011counter\\011INTEGER;\\012\\011sample_id\\011TECH_ID;\\012\\011data_code\\011CODE;\\012BEGIN\\012\\011-- child will have a parent added so it should not be connected with any sample\\012\\011SELECT samp_id, code INTO sample_id, data_code \\012\\011\\011FROM data \\012\\011\\011WHERE id = NEW.data_id_child;\\012\\011IF (sample_id IS NOT NULL) THEN\\012\\011\\011RAISE EXCEPTION 'Insert/Update of Data Set (Code: %) failed because it cannot be connected to a Sample and to a parent Data Set at the same time.', data_code;\\012\\011END IF;\\012\\011RETURN NEW;\\012END;\\012$$ LANGUAGE 'plpgsql';\\012  \\012CREATE CONSTRAINT TRIGGER check_dataset_relationships_on_relationships_table_modification \\012  AFTER INSERT OR UPDATE ON data_set_relationships\\012\\011DEFERRABLE INITIALLY DEFERRED\\012\\011FOR EACH ROW \\012\\011EXECUTE PROCEDURE check_dataset_relationships_on_relationships_table_modification();\\012	\N
+./sourceTest/sql/postgresql/056/.svn/text-base/017=database_version_logs.tsv.svn-base:053	source/sql/postgresql/migration/migration-052-053.sql	SUCCESS	2010-06-08 15:27:55.032	-- Migration from 052 to 053\\012\\012-- Change code uniqueness check for samples of specific type.\\012-- If sample_types.is_subcode_unique flag is set to 'true', additional check is performed \\012-- on codes of samples of the type. Subcodes will have to be unique as well.\\012\\012ALTER TABLE sample_types ADD COLUMN is_subcode_unique boolean_char NOT NULL DEFAULT false;\\012\\012CREATE OR REPLACE FUNCTION SAMPLE_SUBCODE_UNIQUENESS_CHECK() RETURNS trigger AS $$\\012DECLARE\\012   counter  INTEGER;\\012   unique_subcode  BOOLEAN_CHAR;\\012BEGIN\\012  LOCK TABLE samples IN EXCLUSIVE MODE;\\012  \\012  SELECT is_subcode_unique into unique_subcode FROM sample_types WHERE id = NEW.saty_id;\\012  \\012  IF (unique_subcode) THEN\\012    IF (NEW.dbin_id is not NULL) THEN\\012\\011\\011\\011SELECT count(*) into counter FROM samples \\012\\011\\011\\011\\011where id != NEW.id and code = NEW.code and saty_id = NEW.saty_id and dbin_id = NEW.dbin_id;\\012\\011\\011\\011IF (counter > 0) THEN\\012\\011\\011\\011\\011RAISE EXCEPTION 'Insert/Update of Sample (Code: %) failed because database instance sample of the same type with the same subcode already exists.', NEW.code;\\012\\011\\011\\011END IF;\\012\\011\\011ELSIF (NEW.grou_id is not NULL) THEN\\012\\011\\011\\011SELECT count(*) into counter FROM samples \\012\\011\\011\\011\\011where id != NEW.id and code = NEW.code and saty_id = NEW.saty_id and grou_id = NEW.grou_id;\\012\\011\\011\\011IF (counter > 0) THEN\\012\\011\\011\\011\\011RAISE EXCEPTION 'Insert/Update of Sample (Code: %) failed because space sample of the same type with the same subcode already exists.', NEW.code;\\012\\011\\011\\011END IF;\\012\\011\\011END IF;\\012  END IF;\\012  \\012  RETURN NEW;\\012END;\\012$$ LANGUAGE 'plpgsql';\\012\\012CREATE TRIGGER SAMPLE_SUBCODE_UNIQUENESS_CHECK BEFORE INSERT OR UPDATE ON SAMPLES\\012    FOR EACH ROW EXECUTE PROCEDURE SAMPLE_SUBCODE_UNIQUENESS_CHECK();\\012    \\012-- Fixing error messages in old trigger\\012\\012CREATE OR REPLACE FUNCTION SAMPLE_CODE_UNIQUENESS_CHECK() RETURNS trigger AS $$\\012DECLARE\\012   counter  INTEGER;\\012BEGIN\\012  LOCK TABLE samples IN EXCLUSIVE MODE;\\012  \\012\\011  IF (NEW.samp_id_part_of is NULL) THEN\\012\\011\\011  IF (NEW.dbin_id is not NULL) THEN\\012\\011\\011\\011  SELECT count(*) into counter FROM samples \\012\\011\\011      where id != NEW.id and code = NEW.code and samp_id_part_of is NULL and dbin_id = NEW.dbin_id;\\012        IF (counter > 0) THEN\\012\\011\\011\\011\\011  RAISE EXCEPTION 'Insert/Update of Sample (Code: %) failed because database instance sample with the same code already exists.', NEW.code;\\012        END IF;\\012\\011\\011  ELSIF (NEW.grou_id is not NULL) THEN\\012\\011\\011\\011  SELECT count(*) into counter FROM samples \\012\\011\\011\\011\\011  where id != NEW.id and code = NEW.code and samp_id_part_of is NULL and grou_id = NEW.grou_id;\\012\\011\\011\\011  IF (counter > 0) THEN\\012\\011\\011\\011\\011  RAISE EXCEPTION 'Insert/Update of Sample (Code: %) failed because space sample with the same code already exists.', NEW.code;\\012\\011\\011\\011  END IF;\\012      END IF;\\012    ELSE\\012\\011\\011  IF (NEW.dbin_id is not NULL) THEN\\012\\011\\011\\011  SELECT count(*) into counter FROM samples \\012\\011\\011\\011\\011  where id != NEW.id and code = NEW.code and samp_id_part_of = NEW.samp_id_part_of and dbin_id = NEW.dbin_id;\\012\\011\\011\\011  IF (counter > 0) THEN\\012\\011\\011\\011\\011  RAISE EXCEPTION 'Insert/Update of Sample (Code: %) failed because database instance sample with the same code and being the part of the same container already exists.', NEW.code;\\012\\011\\011\\011  END IF;\\012\\011\\011  ELSIF (NEW.grou_id is not NULL) THEN\\012\\011\\011\\011  SELECT count(*) into counter FROM samples \\012\\011\\011\\011\\011  where id != NEW.id and code = NEW.code and samp_id_part_of = NEW.samp_id_part_of and grou_id = NEW.grou_id;\\012\\011\\011\\011  IF (counter > 0) THEN\\012\\011\\011\\011\\011  RAISE EXCEPTION 'Insert/Update of Sample (Code: %) failed because space sample with the same code and being the part of the same container already exists.', NEW.code;\\012\\011\\011\\011  END IF;\\012\\011\\011  END IF;\\012     END IF;   \\012  \\012  RETURN NEW;\\012END;\\012$$ LANGUAGE 'plpgsql';\\012	\N
+./sourceTest/sql/postgresql/056/.svn/text-base/017=database_version_logs.tsv.svn-base:054	source/sql/postgresql/migration/migration-053-054.sql	SUCCESS	2010-07-27 11:30:46.766	-- Migration from 053 to 054\\012\\012\\012-- Add RELATIONSHIP_TYPES table\\012CREATE TABLE relationship_types (id TECH_ID NOT NULL, code CODE NOT NULL, label COLUMN_LABEL, parent_label COLUMN_LABEL, child_label COLUMN_LABEL, description DESCRIPTION_2000, registration_timestamp TIME_STAMP_DFL NOT NULL DEFAULT CURRENT_TIMESTAMP, pers_id_registerer TECH_ID NOT NULL, is_managed_internally BOOLEAN_CHAR NOT NULL DEFAULT 'F', is_internal_namespace BOOLEAN_CHAR NOT NULL DEFAULT 'F', dbin_id TECH_ID NOT NULL);\\012\\012-- Add SAMPLE_RELATIONSHIPS table\\012CREATE TABLE sample_relationships (id TECH_ID NOT NULL, sample_id_parent TECH_ID NOT NULL, relationship_id TECH_ID NOT NULL, sample_id_child TECH_ID NOT NULL);\\012\\012-- Add/update constraints\\012ALTER TABLE relationship_types ADD CONSTRAINT rety_pk PRIMARY KEY (id);\\012ALTER TABLE relationship_types ADD CONSTRAINT rety_uk UNIQUE(code,dbin_id);\\012ALTER TABLE sample_relationships ADD CONSTRAINT sare_pk PRIMARY KEY (id);\\012ALTER TABLE sample_relationships ADD CONSTRAINT sare_bk_uk UNIQUE(sample_id_child,sample_id_parent,relationship_id);\\012ALTER TABLE sample_relationships ADD CONSTRAINT sare_data_fk_child FOREIGN KEY (sample_id_child) REFERENCES samples(id) ON DELETE CASCADE;\\012ALTER TABLE sample_relationships ADD CONSTRAINT sare_data_fk_parent FOREIGN KEY (sample_id_parent) REFERENCES samples(id) ON DELETE CASCADE;\\012ALTER TABLE sample_relationships ADD CONSTRAINT sare_data_fk_relationship FOREIGN KEY (relationship_id) REFERENCES relationship_types(id);\\012\\012-- Create index\\012CREATE INDEX sare_data_fk_i_child ON sample_relationships (sample_id_child);\\012CREATE INDEX sare_data_fk_i_parent ON sample_relationships (sample_id_parent);\\012CREATE INDEX sare_data_fk_i_relationship ON sample_relationships (relationship_id);\\012\\012-- Create sequence for RELATIONSHIP_TYPES\\012CREATE SEQUENCE RELATIONSHIP_TYPE_ID_SEQ;\\012CREATE SEQUENCE SAMPLE_RELATIONSHIP_ID_SEQ;\\012\\012-- Create initial relationships\\012insert into relationship_types\\012(id, \\012code, \\012label, \\012parent_label, \\012child_label, \\012description, \\012pers_id_registerer, \\012is_managed_internally, \\012is_internal_namespace, \\012dbin_id) \\012values\\012(\\012nextval('RELATIONSHIP_TYPE_ID_SEQ'),\\012'PARENT_CHILD',\\012'Parent - Child', \\012'Parent', \\012'Child', \\012'Parent - Child relationship', \\012(select id from persons where user_id ='system'), \\012'T', \\012'T', \\012(select id from database_instances where is_original_source = 'T')\\012);\\012\\012insert into relationship_types\\012(id, \\012code, \\012label, \\012parent_label, \\012child_label, \\012description, \\012pers_id_registerer, \\012is_managed_internally, \\012is_internal_namespace, \\012dbin_id) \\012values\\012(\\012nextval('RELATIONSHIP_TYPE_ID_SEQ'),\\012'PLATE_CONTROL_LAYOUT',\\012'Plate - Control Layout', \\012'Plate', \\012'Control Layout', \\012'Plate - Control Layout relationship', \\012(select id from persons where user_id ='system'), \\012'T', \\012'T', \\012(select id from database_instances where is_original_source = 'T')\\012); \\012\\012\\012-- Migrate sample relationships to new schema\\012INSERT INTO sample_relationships (id, sample_id_parent,sample_id_child,relationship_id) (select distinct nextval('SAMPLE_RELATIONSHIP_ID_SEQ') as id, s.SAMP_ID_GENERATED_FROM as parent_id, s.ID as child_id, rt.id as relationship_id from samples s, relationship_types rt  WHERE rt.code = 'PARENT_CHILD' and s.SAMP_ID_GENERATED_FROM is not null); \\012INSERT INTO sample_relationships (id, sample_id_parent,sample_id_child,relationship_id) (select distinct nextval('SAMPLE_RELATIONSHIP_ID_SEQ') as id, s.SAMP_ID_CONTROL_LAYOUT as parent_id, s.ID as child_id, rt.id as relationship_id from samples s, relationship_types rt  WHERE rt.code = 'PLATE_CONTROL_LAYOUT' and s.SAMP_ID_CONTROL_LAYOUT is not null);\\012\\012-- Drop old sample relations\\012ALTER TABLE SAMPLES DROP COLUMN SAMP_ID_TOP;\\012ALTER TABLE SAMPLES DROP COLUMN SAMP_ID_GENERATED_FROM;\\012ALTER TABLE SAMPLES DROP COLUMN SAMP_ID_CONTROL_LAYOUT;\\012\\012--------------------------------------------------------------------------------------\\012--------------------------------------------------------------------------------------\\012-- This is a screening specific migration. Nothing will be performed on openBIS databases \\012-- which are not screening specific.\\012-- \\012-- This migration for each existing connection between oligo well, oligo material and gene material\\012-- creates a direct connection between the well and the gene. \\012--------------------------------------------------------------------------------------\\012--------------------------------------------------------------------------------------\\012 \\012\\011\\012CREATE OR REPLACE FUNCTION CONNECT_WELLS_WITH_GENES() RETURNS void AS $$\\012DECLARE\\012\\011counter  int;\\012\\011oligo_well_exists bool;\\012BEGIN\\012\\011--------------------------------------------------\\012\\011-- create a gene property and assign it to oligo well\\012\\011--------------------------------------------------\\012\\011\\012\\011select true \\012\\011into oligo_well_exists\\012\\011from sample_types \\012\\011where code = 'OLIGO_WELL';\\012\\011\\012\\011if oligo_well_exists IS NULL then \\012\\011\\011-- skip migration if there are no oligo wells\\012\\011\\011return;\\012\\011end if;   \\012\\011\\012\\011insert into property_types(\\012\\011\\011id, \\012\\011\\011code, description, label, \\012\\011\\011daty_id,\\012\\011\\011pers_id_registerer,\\012\\011\\011dbin_id,\\012\\011\\011maty_prop_id) \\012\\011values(\\012\\011\\011\\011nextval('PROPERTY_TYPE_ID_SEQ'), \\012\\011\\011\\011'GENE','Inhibited gene','Gene',\\012\\011\\011\\011(select id from data_types where code = 'MATERIAL'), \\012\\011\\011\\011(select id from persons where user_id ='system'), \\012\\011\\011\\011(select id from database_instances where is_original_source = 'T'), \\012\\011\\011\\011(select id from material_types where code = 'GENE')\\012\\011\\011);\\012\\011\\011\\012\\011insert into sample_type_property_types( \\012\\011  id,\\012\\011  saty_id,\\012\\011  prty_id,\\012\\011  is_mandatory,\\012\\011  pers_id_registerer,\\012\\011  ordinal\\012\\011) values(\\012\\011\\011\\011nextval('stpt_id_seq'), \\012\\011\\011\\011(select id from sample_types where code = 'OLIGO_WELL'),\\012\\011\\011\\011(select id from property_types where code = 'GENE'),\\012\\011\\011\\011false,\\012\\011\\011\\011(select id from persons where user_id ='system'),\\012\\011\\011\\011(select max(ordinal)+1 from sample_type_property_types \\012\\011\\011\\011\\011where saty_id = (select id from sample_types where code = 'OLIGO_WELL'))\\012\\011\\011);\\012\\012\\011--------------------------------------------------\\012\\011-- create a gene material property for each oligo well\\012\\011--------------------------------------------------\\012\\011\\011\\012\\011select \\011count(*)\\012\\011into counter\\012\\011from\\012\\011\\011samples well, sample_types well_type, sample_properties well_props, \\012\\011\\011materials well_material, material_properties well_material_props,\\012\\011\\011materials nested_well_material\\012\\011where\\012\\011\\011well_type.code = 'OLIGO_WELL' and\\012\\011\\011-- find 'well_material' assigned to the well\\012\\011\\011well_props.samp_id = well.id and well_material.id = well_props.mate_prop_id and \\012\\011\\011-- additional joins to entity type tables\\012\\011\\011well_type.id = well.saty_id and\\012\\011\\011-- well content material property\\012\\011\\011well_material_props.mate_id = well_material.id and \\012\\011\\011-- material connected to the material in the well (e.g. gene)\\012\\011\\011well_material_props.mate_prop_id = nested_well_material.id and\\012\\011\\011nested_well_material.maty_id = (select id from material_types where code = 'GENE');\\012\\011\\012\\011if counter = 0 then \\012\\011\\011-- skip migration if there are no genes indirectly connected to oligo wells\\012\\011\\011return;\\012\\011end if;   \\012\\012\\011insert into sample_properties(id, samp_id, stpt_id, mate_prop_id, pers_id_registerer) (\\012\\011\\011select \\011nextval('sample_property_id_seq') id, \\012\\011\\011\\011well.id samp_id, \\012\\011\\011\\011(select stpt.id from sample_type_property_types stpt, property_types props where stpt.prty_id = props.id and props.code='GENE') stpt_id,\\012\\011\\011\\011nested_well_material.id mate_prop_id,\\012\\011\\011\\011(select id from persons where user_id ='system') pers_id_registerer \\012\\011\\011from\\012\\011\\011\\011samples well, sample_types well_type, sample_properties well_props, \\012\\011\\011\\011materials well_material, material_properties well_material_props,\\012\\011\\011\\011materials nested_well_material\\012\\011\\011where\\012\\011\\011\\011well_type.code = 'OLIGO_WELL' and\\012\\011\\011\\011-- find 'well_material' assigned to the well\\012\\011\\011\\011well_props.samp_id = well.id and well_material.id = well_props.mate_prop_id and \\012\\011\\011\\011-- additional joins to entity type tables\\012\\011\\011\\011well_type.id = well.saty_id and\\012\\011\\011\\011-- well content material property\\012\\011\\011\\011well_material_props.mate_id = well_material.id and \\012\\011\\011\\011-- material connected to the material in the well (e.g. gene)\\012\\011\\011\\011well_material_props.mate_prop_id = nested_well_material.id and\\012\\011\\011\\011nested_well_material.maty_id = (select id from material_types where code = 'GENE')\\012\\011);\\012\\012END;\\012$$ LANGUAGE 'plpgsql';\\012\\012select CONNECT_WELLS_WITH_GENES();\\012drop function CONNECT_WELLS_WITH_GENES();\\012\\012--------------------------------------------------------------------------------------\\012--------------------------------------------------------------------------------------\\012\\012-- drop dataset triggers\\012\\012DROP TRIGGER check_dataset_relationships_on_data_table_modification ON data;\\012DROP FUNCTION check_dataset_relationships_on_data_table_modification();\\012DROP TRIGGER check_dataset_relationships_on_relationships_table_modification ON data_set_relationships;\\012DROP FUNCTION check_dataset_relationships_on_relationships_table_modification();\\012 \\012\\012\\012\\012\\012\\012\\012\\012	\N
+./sourceTest/sql/postgresql/056/.svn/text-base/017=database_version_logs.tsv.svn-base:056	source/sql/postgresql/migration/migration-055-056.sql	SUCCESS	2010-09-08 13:44:23.134	-- Migration from 055 to 056\\012\\012--------------------------------------------------------------------------------------\\012--------------------------------------------------------------------------------------\\012-- Screening specific migration. Nothing will be performed on openBIS databases \\012-- which are not screening specific.\\012--------------------------------------------------------------------------------------\\012--------------------------------------------------------------------------------------\\012\\012CREATE OR REPLACE FUNCTION merge_words(text, text) RETURNS text AS $$\\012DECLARE\\012  BEGIN\\012    IF  character_length($1) > 0 THEN\\012      RETURN $1 || ' ' || $2;\\012    ELSE\\012      RETURN $2;\\012    END IF;\\012  END;\\012$$ LANGUAGE plpgsql;\\012\\012CREATE AGGREGATE merge_words(text)\\012(\\012  SFUNC = merge_words,\\012  STYPE = text\\012);\\012\\012\\012CREATE OR REPLACE FUNCTION REPLACE_GENE_SYMBOL_BY_GENE_ID() RETURNS void AS $$\\012DECLARE\\012\\011counter  int;\\012\\011library_id_assigned_to_gene bool;\\012BEGIN\\012\\011--------------------------------------------------\\012\\011-- create a GENE_SYMBOL property and assign it to GENE\\012\\011--------------------------------------------------\\012\\011\\012\\011select true  \\012\\011into library_id_assigned_to_gene \\012\\011from material_type_property_types mtpt, material_types mt, property_types pt  \\012\\011where mtpt.maty_id = mt.id and mtpt.prty_id = pt.id \\012\\011\\011and mt.code = 'GENE' and pt.code = 'LIBRARY_ID';\\012\\011\\012\\011if library_id_assigned_to_gene IS NULL then \\012\\011\\011-- skip migration if gene has no library_id property\\012\\011\\011return;\\012\\011end if; \\012\\011\\012\\011\\012\\011select count(*)\\012\\011into counter \\012\\011from  \\012\\011\\011(select m.id, count(mp.id) as c \\012\\011\\011\\011from materials m, material_types mt, material_properties mp, material_type_property_types mtpt, property_types pt \\012\\011\\011\\011where m.maty_id = mt.id and mp.mate_id = m.id and mp.mtpt_id = mtpt.id and mtpt.maty_id = mt.id and pt.id = mtpt.prty_id\\012\\011\\011\\011\\011and mt.code = 'GENE' and pt.code = 'LIBRARY_ID' \\012\\011\\011\\011group by m.id) as counter_table \\012\\011where c < 1; \\012\\011\\012\\011if counter > 0 then \\012\\011\\011-- skip migration if there is at least one gene without library_id\\012\\011\\011return;\\012\\011end if;\\012\\011\\012\\011\\012\\011insert into property_types\\012\\011\\011(id\\012\\011\\011,code\\012\\011\\011,description\\012\\011\\011,label\\012\\011\\011,daty_id\\012\\011\\011,pers_id_registerer\\012\\011\\011,dbin_id)\\012\\011values \\012\\011\\011(nextval('PROPERTY_TYPE_ID_SEQ')\\012\\011\\011,'GENE_SYMBOLS'\\012\\011\\011,'Gene symbols'\\012\\011\\011,'Gene symbols'\\012\\011\\011,(select id from data_types where code ='VARCHAR')\\012\\011\\011,(select id from persons where user_id ='system')\\012\\011\\011,(select id from database_instances where is_original_source = 'T')\\012\\011);\\012\\011\\011\\012\\011insert into material_type_property_types( \\012\\011  id,\\012\\011  maty_id,\\012\\011  prty_id,\\012\\011  is_mandatory,\\012\\011  pers_id_registerer,\\012\\011  ordinal\\012\\011) values(\\012\\011\\011\\011nextval('mtpt_id_seq'), \\012\\011\\011\\011(select id from material_types where code = 'GENE'),\\012\\011\\011\\011(select id from property_types where code = 'GENE_SYMBOLS'),\\012\\011\\011\\011false,\\012\\011\\011\\011(select id from persons where user_id ='system'),\\012\\011\\011\\011(select max(ordinal)+1 from material_type_property_types \\012\\011\\011\\011\\011where maty_id = (select id from material_types where code = 'GENE'))\\012\\011\\011);\\012\\012\\011--------------------------------------------------\\012\\011-- create temporary table with all gene migration information\\012\\011--------------------------------------------------\\012\\012\\011create temp table genes \\012\\011(\\012\\011\\011id tech_id,\\012\\011\\011code code,\\012\\011\\011library_id generic_value,\\012\\011\\011gene_codes generic_value,\\012\\011\\011new_id tech_id,\\012\\011\\011library_tech_id tech_id\\011\\011\\012\\011);\\012\\011\\012\\011insert into genes (id, code, library_id, library_tech_id)\\012\\011\\011(select m.id, m.code, mp.value as library_id, mp.id as library_tech_id from materials m, material_properties mp, material_type_property_types mtpt, property_types pt, material_types mt\\012\\011\\011where mp.mate_id = m.id and  mp.mtpt_id = mtpt.id and pt.id = mtpt.prty_id and pt.code = 'LIBRARY_ID' and mt.id = m.maty_id and mt.id = mtpt.maty_id and mt.code = 'GENE');\\012\\011\\012\\011update genes set new_id = map.to_id from (select g_from.id as from_id, min(g_to.id) as to_id  from genes g_from, genes g_to where g_from.library_id = g_to.library_id group by g_from.id) as map where map.from_id = id;\\011\\012\\011\\012\\011update genes set gene_codes = map.gene_codes from (select g_from.library_id as lib_id, merge_words(distinct g_to.code) as gene_codes from genes g_from, genes g_to where g_from.library_id = g_to.library_id group by g_from.library_id) as map where map.lib_id = library_id;\\011\\012\\012\\011--------------------------------------------------\\012\\011-- update gene references\\012\\011--------------------------------------------------\\012\\012\\011update EXPERIMENTS set MATE_ID_STUDY_OBJECT = genes.new_id from genes where genes.id = MATE_ID_STUDY_OBJECT and not genes.id = genes.new_id;\\012\\011update EXPERIMENT_PROPERTIES set  MATE_PROP_ID = genes.new_id from genes where genes.id = MATE_PROP_ID and not genes.id = genes.new_id;\\012\\011update MATERIAL_PROPERTIES set  MATE_PROP_ID = genes.new_id from genes where genes.id = MATE_PROP_ID and not genes.id = genes.new_id;\\012\\011update SAMPLE_PROPERTIES set  MATE_PROP_ID = genes.new_id from genes where genes.id = MATE_PROP_ID and not genes.id = genes.new_id;\\012\\011update DATA_SET_PROPERTIES set  MATE_PROP_ID = genes.new_id from genes where genes.id = MATE_PROP_ID and not genes.id = genes.new_id;\\012\\011\\012\\011delete from  material_properties where mate_id in (select id from genes where not genes.id = genes.new_id);\\012\\011delete from MATERIALS where id in (select id from genes where not genes.id = genes.new_id);\\012\\012\\011delete from genes where id in (select id from genes where not genes.id = genes.new_id);\\012\\012\\012\\011--------------------------------------------------\\012\\011-- replace gene code with library_id\\012\\011--------------------------------------------------\\012\\011\\012\\011update materials set code = genes.library_id from genes where materials.id = genes.id ;\\012\\011delete from material_properties where id in (select library_tech_id from genes);\\012\\011\\012\\011--------------------------------------------------\\012\\011-- create a gene symbols property for each gene\\012\\011--------------------------------------------------\\012\\011\\012\\011insert into material_properties\\012\\011\\011(id\\012\\011  , mate_id\\012\\011  , mtpt_id\\012\\011  , "value"\\012\\011  , pers_id_registerer)\\012\\011\\011(select nextval('material_property_id_seq') id\\012\\011  \\011, genes.id  mate_id\\012\\011    , (select mtpt.id\\012\\011    \\011\\011from   material_type_property_types mtpt, material_types mt, property_types pt\\012\\011    \\011\\011where  pt.code = 'GENE_SYMBOLS' and mt.code = 'GENE' and mtpt.prty_id = pt.id\\012\\011        \\011and mtpt.maty_id = mt.id) mtpt_id\\012\\011    , genes.gene_codes "value"\\012\\011    , (select id from persons where user_id = 'system') pers_id_registerer\\012\\011 \\011from genes); \\012\\012\\011--------------------------------------------------\\012\\011-- delete temporary table\\012\\011--------------------------------------------------\\012\\011\\012\\011drop table genes;\\012\\011\\012\\011delete from material_type_property_types where id = \\012\\011\\011(select mtpt.id from material_type_property_types mtpt, material_types mt, property_types pt \\012\\011\\011\\011where pt.id = mtpt.prty_id and mtpt.maty_id = mt.id \\012\\011\\011\\011and pt.code = 'LIBRARY_ID' and mt.code = 'GENE');\\012\\011\\012END;\\012$$ LANGUAGE 'plpgsql';\\012\\012select REPLACE_GENE_SYMBOL_BY_GENE_ID();\\012drop function REPLACE_GENE_SYMBOL_BY_GENE_ID();\\012DROP AGGREGATE merge_words(text);\\012drop function merge_words(text,text);\\012\\012\\012--------------------------------------------------------------------------------------\\012--------------------------------------------------------------------------------------\\012\\012UPDATE sample_types SET code = 'SIRNA_WELL' WHERE code = 'OLIGO_WELL';\\012UPDATE material_types SET code = 'SIRNA' WHERE code = 'OLIGO';\\012UPDATE property_types SET code = 'SIRNA', label = 'siRNA' WHERE code = 'OLIGO';\\012\\012\\012\\012\\012\\012\\012\\012\\012\\012\\012\\012\\012\\012\\012\\012\\012\\012\\012\\012	\N
+./sourceTest/sql/postgresql/056/.svn/text-base/schema-056.sql.svn-base:    LANGUAGE plpgsql
+./sourceTest/sql/postgresql/056/.svn/text-base/schema-056.sql.svn-base:    LANGUAGE plpgsql
+./sourceTest/sql/postgresql/056/.svn/text-base/schema-056.sql.svn-base:    LANGUAGE plpgsql
+./sourceTest/sql/postgresql/056/.svn/text-base/schema-056.sql.svn-base:    LANGUAGE plpgsql
+./sourceTest/sql/postgresql/056/.svn/text-base/schema-056.sql.svn-base:    LANGUAGE plpgsql
+./sourceTest/sql/postgresql/056/.svn/text-base/schema-056.sql.svn-base:    LANGUAGE plpgsql
+./sourceTest/sql/postgresql/056/.svn/text-base/schema-056.sql.svn-base:    LANGUAGE plpgsql
+./sourceTest/sql/postgresql/056/.svn/text-base/schema-056.sql.svn-base:    LANGUAGE plpgsql
+./sourceTest/sql/postgresql/056/.svn/text-base/schema-056.sql.svn-base:    LANGUAGE plpgsql
+./sourceTest/sql/postgresql/056/017=database_version_logs.tsv:027	D:\\User\\felmer\\dev-workspace\\openbis/source/sql/postgresql/027/function-027.sql	SUCCESS	2008-11-05 09:18:00.403	-- Creating Functions\\012\\012------------------------------------------------------------------------------------\\012--  Purpose:  Create function RENAME_SEQUENCE() that is required for renaming the sequences belonging to tables\\012------------------------------------------------------------------------------------\\012CREATE FUNCTION RENAME_SEQUENCE(OLD_NAME VARCHAR, NEW_NAME VARCHAR) RETURNS INTEGER AS $$\\012DECLARE\\012  CURR_SEQ_VAL   INTEGER;\\012BEGIN\\012  SELECT INTO CURR_SEQ_VAL NEXTVAL(OLD_NAME);\\012  EXECUTE 'CREATE SEQUENCE ' || NEW_NAME || ' START WITH ' || CURR_SEQ_VAL;\\012  EXECUTE 'DROP SEQUENCE ' || OLD_NAME;\\012  RETURN CURR_SEQ_VAL;\\012END;\\012$$ LANGUAGE 'plpgsql';\\012\\012\\012------------------------------------------------------------------------------------\\012--  Purpose:  Create trigger CONTROLLED_VOCABULARY_CHECK \\012------------------------------------------------------------------------------------\\012\\012CREATE OR REPLACE FUNCTION CONTROLLED_VOCABULARY_CHECK() RETURNS trigger AS $$\\012DECLARE\\012   v_code  CODE;\\012BEGIN\\012\\012   select code into v_code from data_types where id = NEW.daty_id;\\012\\012   -- Check if the data is of type "CONTROLLEDVOCABULARY"\\012   if v_code = 'CONTROLLEDVOCABULARY' then\\012      if NEW.covo_id IS NULL then\\012         RAISE EXCEPTION 'Insert/Update of Property Type (Code: %) failed, as its Data Type is CONTROLLEDVOCABULARY, but it is not linked to a Controlled Vocabulary.', NEW.code;\\012      end if;\\012   end if;\\012\\012   RETURN NEW;\\012\\012END;\\012$$ LANGUAGE 'plpgsql';\\012\\012CREATE TRIGGER CONTROLLED_VOCABULARY_CHECK BEFORE INSERT OR UPDATE ON PROPERTY_TYPES\\012    FOR EACH ROW EXECUTE PROCEDURE CONTROLLED_VOCABULARY_CHECK();\\012\\012\\012------------------------------------------------------------------------------------\\012--  Purpose:  Create trigger EXTERNAL_DATA_STORAGE_FORMAT_CHECK \\012------------------------------------------------------------------------------------\\012\\012CREATE OR REPLACE FUNCTION EXTERNAL_DATA_STORAGE_FORMAT_CHECK() RETURNS trigger AS $$\\012DECLARE\\012   v_covo_code  CODE;\\012   data_code CODE;\\012BEGIN\\012\\012   select code into v_covo_code from controlled_vocabularies\\012      where is_internal_namespace = true and \\012         id = (select covo_id from controlled_vocabulary_terms where id = NEW.cvte_id_stor_fmt);\\012   -- Check if the data storage format is a term of the controlled vocabulary "STORAGE_FORMAT"\\012   if v_covo_code != 'STORAGE_FORMAT' then\\012      select code into data_code from data where id = NEW.data_id; \\012      RAISE EXCEPTION 'Insert/Update of Data (Code: %) failed, as its Storage Format is %, but is required to be STORAGE_FORMAT.', data_code, v_covo_code;\\012   end if;\\012\\012   RETURN NEW;\\012\\012END;\\012$$ LANGUAGE 'plpgsql';\\012\\012CREATE TRIGGER EXTERNAL_DATA_STORAGE_FORMAT_CHECK BEFORE INSERT OR UPDATE ON EXTERNAL_DATA\\012    FOR EACH ROW EXECUTE PROCEDURE EXTERNAL_DATA_STORAGE_FORMAT_CHECK();\\012\\012------------------------------------------------------------------------------------\\012--  Purpose:  Create trigger SAMPLE_CODE_UNIQUENESS_CHECK \\012------------------------------------------------------------------------------------\\012\\012CREATE OR REPLACE FUNCTION SAMPLE_CODE_UNIQUENESS_CHECK() RETURNS trigger AS $$\\012DECLARE\\012   counter  INTEGER;\\012BEGIN\\012\\011IF (NEW.samp_id_part_of is NULL) THEN\\012\\011\\011IF (NEW.dbin_id is not NULL) THEN\\012\\011\\011\\011SELECT count(*) into counter FROM samples \\012\\011\\011\\011\\011where id != NEW.id and code = NEW.code and samp_id_part_of is NULL and dbin_id = NEW.dbin_id;\\012\\011\\011\\011IF (counter > 0) THEN\\012\\011\\011\\011\\011RAISE EXCEPTION 'Insert/Update of Sample (Code: %) failed because database instance sample with the same code already exists.', NEW.code;\\012\\011\\011\\011END IF;\\012\\011\\011ELSIF (NEW.grou_id is not NULL) THEN\\012\\011\\011\\011SELECT count(*) into counter FROM samples \\012\\011\\011\\011\\011where id != NEW.id and code = NEW.code and samp_id_part_of is NULL and grou_id = NEW.grou_id;\\012\\011\\011\\011IF (counter > 0) THEN\\012\\011\\011\\011\\011RAISE EXCEPTION 'Insert/Update of Sample (Code: %) failed because group sample with the same code already exists.', NEW.code;\\012\\011\\011\\011END IF;\\012\\011\\011END IF;\\012        ELSE\\012\\011\\011IF (NEW.dbin_id is not NULL) THEN\\012\\011\\011\\011SELECT count(*) into counter FROM samples \\012\\011\\011\\011\\011where id != NEW.id and code = NEW.code and samp_id_part_of = NEW.samp_id_part_of and dbin_id = NEW.dbin_id;\\012\\011\\011\\011IF (counter > 0) THEN\\012\\011\\011\\011\\011RAISE EXCEPTION 'Insert/Update of Sample (Code: %) failed because database instance sample with the same code and being the part of the same parent already exists.', NEW.code;\\012\\011\\011\\011END IF;\\012\\011\\011ELSIF (NEW.grou_id is not NULL) THEN\\012\\011\\011\\011SELECT count(*) into counter FROM samples \\012\\011\\011\\011\\011where id != NEW.id and code = NEW.code and samp_id_part_of = NEW.samp_id_part_of and grou_id = NEW.grou_id;\\012\\011\\011\\011IF (counter > 0) THEN\\012\\011\\011\\011\\011RAISE EXCEPTION 'Insert/Update of Sample (Code: %) failed because group sample with the same code and being the part of the same parent already exists.', NEW.code;\\012\\011\\011\\011END IF;\\012\\011\\011END IF;\\012        END IF;   \\012   RETURN NEW;\\012END;\\012$$ LANGUAGE 'plpgsql';\\012\\012CREATE TRIGGER SAMPLE_CODE_UNIQUENESS_CHECK BEFORE INSERT OR UPDATE ON SAMPLES\\012    FOR EACH ROW EXECUTE PROCEDURE SAMPLE_CODE_UNIQUENESS_CHECK();\\012	\N
+./sourceTest/sql/postgresql/056/017=database_version_logs.tsv:028	source/sql/postgresql/migration/migration-027-028.sql	SUCCESS	2008-11-18 13:24:17.508	-- Create EXPERIMENT_ATTACHMENT_CONTENTS.\\012CREATE TABLE EXPERIMENT_ATTACHMENT_CONTENTS (ID TECH_ID NOT NULL,VALUE FILE NOT NULL);\\012CREATE SEQUENCE EXPERIMENT_ATTACHMENT_CONTENT_ID_SEQ;\\012ALTER TABLE EXPERIMENT_ATTACHMENT_CONTENTS ADD CONSTRAINT EXAC_PK PRIMARY KEY(ID);\\012\\012-- Alter EXPERIMENT_ATTACHMENTS by adding the new column which has a NULL constraint.\\012-- The NOT NULL constraint is added later on.\\012ALTER TABLE EXPERIMENT_ATTACHMENTS ADD COLUMN EXAC_ID TECH_ID;\\012\\012-- Does the VALUE migration between EXPERIMENT_ATTACHMENTS to EXPERIMENT_ATTACHMENT_CONTENTS.\\012CREATE OR REPLACE FUNCTION move_exp_att_content() RETURNS integer AS $$\\012DECLARE\\012    rec RECORD;\\012    seq BIGINT;\\012BEGIN\\012  FOR rec IN SELECT id, value FROM EXPERIMENT_ATTACHMENTS LOOP\\012  \\011seq := nextval('EXPERIMENT_ATTACHMENT_CONTENT_ID_SEQ');\\012    INSERT INTO EXPERIMENT_ATTACHMENT_CONTENTS (id, value) VALUES (seq, rec.value);\\012    UPDATE EXPERIMENT_ATTACHMENTS SET exac_id = seq WHERE id = rec.id;\\012  END LOOP;\\012  RETURN 1;\\012END;\\012$$ LANGUAGE 'plpgsql';\\012\\012-- Call the function.\\012SELECT move_exp_att_content();\\012DROP FUNCTION move_exp_att_content();\\012\\012\\012-- Finish EXPERIMENT_ATTACHMENTS changes.\\012ALTER TABLE EXPERIMENT_ATTACHMENTS ADD CONSTRAINT EXAT_CONT_FK FOREIGN KEY (EXAC_ID) REFERENCES EXPERIMENT_ATTACHMENT_CONTENTS(ID);\\012ALTER TABLE EXPERIMENT_ATTACHMENTS DROP COLUMN VALUE;\\012ALTER TABLE EXPERIMENT_ATTACHMENTS ALTER COLUMN EXAC_ID SET NOT NULL;\\012	\N
+./sourceTest/sql/postgresql/056/017=database_version_logs.tsv:029	source/sql/postgresql/migration/migration-028-029.sql	SUCCESS	2009-03-18 10:50:20.105	-- -------\\012-- add modification_timestamp field to allow edition with Hibernate\\012-- -------\\012\\012ALTER TABLE samples\\012\\011ADD COLUMN modification_timestamp TIME_STAMP DEFAULT CURRENT_TIMESTAMP;\\012\\012ALTER TABLE experiments\\012\\011ADD COLUMN modification_timestamp TIME_STAMP DEFAULT CURRENT_TIMESTAMP;\\012\\012ALTER TABLE materials\\012\\011ADD COLUMN modification_timestamp TIME_STAMP DEFAULT CURRENT_TIMESTAMP;\\012\\012ALTER TABLE experiment_properties\\012\\011ADD COLUMN modification_timestamp TIME_STAMP DEFAULT CURRENT_TIMESTAMP;\\012\\012ALTER TABLE material_properties\\012\\011ADD COLUMN modification_timestamp TIME_STAMP DEFAULT CURRENT_TIMESTAMP;\\012\\012ALTER TABLE sample_properties\\012\\011ADD COLUMN modification_timestamp TIME_STAMP DEFAULT CURRENT_TIMESTAMP;\\012\\012-- -------\\012-- add property data type which references materials\\012-- -------\\012\\012ALTER TABLE property_types\\012\\011ADD COLUMN maty_prop_id tech_id;\\012\\012ALTER TABLE property_types\\012\\011ADD CONSTRAINT prty_maty_fk FOREIGN KEY (maty_prop_id) REFERENCES material_types(id);\\012\\012ALTER TABLE experiment_properties\\012\\011ADD COLUMN mate_prop_id tech_id;\\012\\012ALTER TABLE material_properties\\012\\011ADD COLUMN mate_prop_id tech_id;\\012\\012ALTER TABLE sample_properties\\012\\011ADD COLUMN mate_prop_id tech_id;\\012\\012ALTER TABLE experiment_properties\\012\\011ADD CONSTRAINT expr_mapr_fk FOREIGN KEY (mate_prop_id) REFERENCES materials(id);\\012\\012ALTER TABLE material_properties\\012\\011ADD CONSTRAINT mapr_mapr_fk FOREIGN KEY (mate_prop_id) REFERENCES materials(id);\\012\\012ALTER TABLE sample_properties\\012\\011ADD CONSTRAINT sapr_mapr_fk FOREIGN KEY (mate_prop_id) REFERENCES materials(id);\\012\\012insert into data_types\\012(id\\012 ,code\\012 ,description)\\012 values \\012 (nextval('DATA_TYPE_ID_SEQ')\\012 ,'MATERIAL'\\012 ,'Reference to a material'\\012);\\012\\012ALTER TABLE MATERIAL_PROPERTIES DROP CONSTRAINT MAPR_CK;\\012ALTER TABLE MATERIAL_PROPERTIES ADD CONSTRAINT MAPR_CK CHECK \\012\\011((VALUE IS NOT NULL AND CVTE_ID IS NULL AND MATE_PROP_ID IS NULL) OR \\012\\011 (VALUE IS NULL AND CVTE_ID IS NOT NULL AND MATE_PROP_ID IS NULL) OR\\012\\011 (VALUE IS NULL AND CVTE_ID IS NULL AND MATE_PROP_ID IS NOT NULL)\\012\\011);\\012\\012ALTER TABLE EXPERIMENT_PROPERTIES DROP CONSTRAINT EXPR_CK;\\012ALTER TABLE EXPERIMENT_PROPERTIES ADD CONSTRAINT EXPR_CK CHECK \\012\\011((VALUE IS NOT NULL AND CVTE_ID IS NULL AND MATE_PROP_ID IS NULL) OR \\012\\011 (VALUE IS NULL AND CVTE_ID IS NOT NULL AND MATE_PROP_ID IS NULL) OR\\012\\011 (VALUE IS NULL AND CVTE_ID IS NULL AND MATE_PROP_ID IS NOT NULL)\\012\\011);\\012\\012ALTER TABLE SAMPLE_PROPERTIES DROP CONSTRAINT SAPR_CK;\\012ALTER TABLE SAMPLE_PROPERTIES ADD CONSTRAINT SAPR_CK CHECK \\012\\011((VALUE IS NOT NULL AND CVTE_ID IS NULL AND MATE_PROP_ID IS NULL) OR \\012\\011 (VALUE IS NULL AND CVTE_ID IS NOT NULL AND MATE_PROP_ID IS NULL) OR\\012\\011 (VALUE IS NULL AND CVTE_ID IS NULL AND MATE_PROP_ID IS NOT NULL)\\012\\011);\\012\\012------------------------------------------------------------------------------------\\012--  Purpose:  Create trigger MATERIAL/SAMPLE/EXPERIMENT _PROPERTY_WITH_MATERIAL_DATA_TYPE_CHECK\\012--            It checks that if material property value is assigned to the entity,\\012--\\011\\011\\011\\011\\011\\011then the material type is equal to the one described by property type.\\012------------------------------------------------------------------------------------\\012\\012CREATE OR REPLACE FUNCTION MATERIAL_PROPERTY_WITH_MATERIAL_DATA_TYPE_CHECK() RETURNS trigger AS $$\\012DECLARE\\012   v_type_id  CODE;\\012   v_type_id_prop  CODE;\\012BEGIN\\012   if NEW.mate_prop_id IS NOT NULL then\\012\\011\\011\\011-- find material type id of the property type \\012\\011\\011\\011select pt.maty_prop_id into v_type_id_prop \\012\\011\\011\\011  from material_type_property_types etpt, property_types pt \\012\\011\\011\\011 where NEW.mtpt_id = etpt.id AND etpt.prty_id = pt.id;\\012\\011\\011\\012\\011\\011\\011if v_type_id_prop IS NOT NULL then\\012\\011\\011\\011\\011-- find material type id of the material which consists the entity's property value\\012\\011\\011\\011\\011select entity.maty_id into v_type_id \\012\\011\\011\\011\\011  from materials entity\\012\\011\\011\\011\\011 where NEW.mate_prop_id = entity.id;\\012\\011\\011\\011\\011if v_type_id != v_type_id_prop then\\012\\011\\011\\011\\011\\011RAISE EXCEPTION 'Insert/Update of property value referencing material (id: %) failed, as referenced material type is different than expected (id %, expected id: %).', \\012\\011\\011\\011\\011\\011\\011\\011 NEW.mate_prop_id, v_type_id, v_type_id_prop;\\012\\011\\011\\011\\011end if;\\012\\011\\011\\011end if;\\012   end if;\\012   RETURN NEW;\\012END;\\012$$ LANGUAGE 'plpgsql';\\012\\012CREATE TRIGGER MATERIAL_PROPERTY_WITH_MATERIAL_DATA_TYPE_CHECK BEFORE INSERT OR UPDATE ON material_properties\\012    FOR EACH ROW EXECUTE PROCEDURE MATERIAL_PROPERTY_WITH_MATERIAL_DATA_TYPE_CHECK();\\012    \\012CREATE OR REPLACE FUNCTION SAMPLE_PROPERTY_WITH_MATERIAL_DATA_TYPE_CHECK() RETURNS trigger AS $$\\012DECLARE\\012   v_type_id  CODE;\\012   v_type_id_prop  CODE;\\012BEGIN\\012   if NEW.mate_prop_id IS NOT NULL then\\012\\011\\011\\011-- find material type id of the property type \\012\\011\\011\\011select pt.maty_prop_id into v_type_id_prop \\012\\011\\011\\011  from sample_type_property_types etpt, property_types pt \\012\\011\\011\\011 where NEW.stpt_id = etpt.id AND etpt.prty_id = pt.id;\\012\\011\\011\\012\\011\\011\\011if v_type_id_prop IS NOT NULL then\\012\\011\\011\\011\\011-- find material type id of the material which consists the entity's property value\\012\\011\\011\\011\\011select entity.maty_id into v_type_id \\012\\011\\011\\011\\011  from materials entity\\012\\011\\011\\011\\011 where NEW.mate_prop_id = entity.id;\\012\\011\\011\\011\\011if v_type_id != v_type_id_prop then\\012\\011\\011\\011\\011\\011RAISE EXCEPTION 'Insert/Update of property value referencing material (id: %) failed, as referenced material type is different than expected (id %, expected id: %).', \\012\\011\\011\\011\\011\\011\\011\\011\\011\\011\\011\\011\\011 NEW.mate_prop_id, v_type_id, v_type_id_prop;\\012\\011\\011\\011\\011end if;\\012\\011\\011\\011end if;\\012   end if;\\012   RETURN NEW;\\012END;\\012$$ LANGUAGE 'plpgsql';\\012\\012CREATE TRIGGER SAMPLE_PROPERTY_WITH_MATERIAL_DATA_TYPE_CHECK BEFORE INSERT OR UPDATE ON sample_properties\\012    FOR EACH ROW EXECUTE PROCEDURE SAMPLE_PROPERTY_WITH_MATERIAL_DATA_TYPE_CHECK();\\012    \\012CREATE OR REPLACE FUNCTION EXPERIMENT_PROPERTY_WITH_MATERIAL_DATA_TYPE_CHECK() RETURNS trigger AS $$\\012DECLARE\\012   v_type_id  CODE;\\012   v_type_id_prop  CODE;\\012BEGIN\\012   if NEW.mate_prop_id IS NOT NULL then\\012\\011\\011\\011-- find material type id of the property type \\012\\011\\011\\011select pt.maty_prop_id into v_type_id_prop \\012\\011\\011\\011  from experiment_type_property_types etpt, property_types pt \\012\\011\\011\\011 where NEW.etpt_id = etpt.id AND etpt.prty_id = pt.id;\\012\\011\\011\\012\\011\\011\\011if v_type_id_prop IS NOT NULL then\\012\\011\\011\\011\\011-- find material type id of the material which consists the entity's property value\\012\\011\\011\\011\\011select entity.maty_id into v_type_id \\012\\011\\011\\011\\011  from materials entity\\012\\011\\011\\011\\011 where NEW.mate_prop_id = entity.id;\\012\\011\\011\\011\\011if v_type_id != v_type_id_prop then\\012\\011\\011\\011\\011\\011RAISE EXCEPTION 'Insert/Update of property value referencing material (id: %) failed, as referenced material type is different than expected (id %, expected id: %).', \\012\\011\\011\\011\\011\\011\\011\\011\\011\\011\\011\\011\\011 NEW.mate_prop_id, v_type_id, v_type_id_prop;\\012\\011\\011\\011\\011end if;\\012\\011\\011\\011end if;\\012   end if;\\012   RETURN NEW;\\012END;\\012$$ LANGUAGE 'plpgsql';\\012\\012CREATE TRIGGER EXPERIMENT_PROPERTY_WITH_MATERIAL_DATA_TYPE_CHECK BEFORE INSERT OR UPDATE ON experiment_properties\\012    FOR EACH ROW EXECUTE PROCEDURE EXPERIMENT_PROPERTY_WITH_MATERIAL_DATA_TYPE_CHECK();\\012       \\012-- -------\\012-- remove the reminescents of the OBSERVABLE_TYPE\\012-- -------\\012\\012ALTER TABLE data\\012\\011DROP CONSTRAINT data_obty_fk;\\012\\012ALTER TABLE data_set_types\\012\\011DROP CONSTRAINT obty_pk;\\012\\012ALTER TABLE data_set_types\\012\\011ADD CONSTRAINT dsty_pk PRIMARY KEY (id);\\012\\012ALTER TABLE data\\012\\011ADD CONSTRAINT data_dsty_fk FOREIGN KEY (dsty_id) REFERENCES data_set_types(id);\\012\\012ALTER TABLE data_set_types\\012\\011DROP CONSTRAINT obty_bk_uk;\\012\\012ALTER TABLE data_set_types\\012\\011DROP CONSTRAINT obty_dbin_fk;\\012\\012ALTER TABLE data_set_types\\012\\011ADD CONSTRAINT dsty_bk_uk UNIQUE (code, dbin_id);\\012\\012ALTER TABLE data_set_types\\012\\011ADD CONSTRAINT dsty_dbin_fk FOREIGN KEY (dbin_id) REFERENCES database_instances(id);\\012\\012DROP INDEX data_obty_fk_i;\\012\\012CREATE INDEX data_dsty_fk_i ON data(dsty_id);\\012	\N
+./sourceTest/sql/postgresql/056/017=database_version_logs.tsv:030	source/sql/postgresql/migration/migration-029-030.sql	SUCCESS	2009-03-23 15:34:44.72	-- -------\\012-- add modification_timestamp field to allow edition with Hibernate\\012-- -------\\012ALTER TABLE data\\012\\011ADD COLUMN modification_timestamp TIME_STAMP DEFAULT CURRENT_TIMESTAMP;\\012ALTER TABLE experiment_types\\012\\011ADD COLUMN modification_timestamp TIME_STAMP DEFAULT CURRENT_TIMESTAMP;\\012ALTER TABLE sample_types\\012\\011ADD COLUMN modification_timestamp TIME_STAMP DEFAULT CURRENT_TIMESTAMP;\\012ALTER TABLE material_types\\012\\011ADD COLUMN modification_timestamp TIME_STAMP DEFAULT CURRENT_TIMESTAMP;\\012ALTER TABLE data_set_types\\012\\011ADD COLUMN modification_timestamp TIME_STAMP DEFAULT CURRENT_TIMESTAMP;\\012ALTER TABLE controlled_vocabularies\\012\\011ADD COLUMN modification_timestamp TIME_STAMP DEFAULT CURRENT_TIMESTAMP;\\012-- -------\\012-- add properties to data sets\\012-- -------\\012CREATE TABLE DATA_SET_PROPERTIES (ID TECH_ID NOT NULL,DS_ID TECH_ID NOT NULL,DSTPT_ID TECH_ID NOT NULL,VALUE GENERIC_VALUE,CVTE_ID TECH_ID, MATE_PROP_ID TECH_ID, PERS_ID_REGISTERER TECH_ID NOT NULL,REGISTRATION_TIMESTAMP TIME_STAMP_DFL NOT NULL DEFAULT CURRENT_TIMESTAMP, MODIFICATION_TIMESTAMP TIME_STAMP DEFAULT CURRENT_TIMESTAMP);\\012CREATE TABLE DATA_SET_TYPE_PROPERTY_TYPES (ID TECH_ID NOT NULL,DSTY_ID TECH_ID NOT NULL,PRTY_ID TECH_ID NOT NULL,IS_MANDATORY BOOLEAN_CHAR NOT NULL DEFAULT 'F',IS_MANAGED_INTERNALLY BOOLEAN_CHAR NOT NULL DEFAULT 'F',PERS_ID_REGISTERER TECH_ID NOT NULL,REGISTRATION_TIMESTAMP TIME_STAMP_DFL NOT NULL DEFAULT CURRENT_TIMESTAMP);\\012\\012CREATE SEQUENCE DATA_SET_PROPERTY_ID_SEQ;\\012CREATE SEQUENCE DSTPT_ID_SEQ;\\012\\012ALTER TABLE DATA_SET_TYPE_PROPERTY_TYPES ADD CONSTRAINT DSTPT_PK PRIMARY KEY(ID);\\012ALTER TABLE DATA_SET_PROPERTIES ADD CONSTRAINT DSPR_PK PRIMARY KEY(ID);\\012\\012ALTER TABLE DATA_SET_TYPE_PROPERTY_TYPES ADD CONSTRAINT DSTPT_BK_UK UNIQUE(DSTY_ID,PRTY_ID);\\012ALTER TABLE DATA_SET_PROPERTIES ADD CONSTRAINT DSPR_BK_UK UNIQUE(DS_ID,DSTPT_ID);\\012\\012\\012ALTER TABLE DATA_SET_TYPE_PROPERTY_TYPES ADD CONSTRAINT DSTPT_DSTY_FK FOREIGN KEY (DSTY_ID) REFERENCES DATA_SET_TYPES(ID);\\012ALTER TABLE DATA_SET_TYPE_PROPERTY_TYPES ADD CONSTRAINT DSTPT_PERS_FK FOREIGN KEY (PERS_ID_REGISTERER) REFERENCES PERSONS(ID);\\012ALTER TABLE DATA_SET_TYPE_PROPERTY_TYPES ADD CONSTRAINT DSTPT_PRTY_FK FOREIGN KEY (PRTY_ID) REFERENCES PROPERTY_TYPES(ID);\\012ALTER TABLE DATA_SET_PROPERTIES ADD CONSTRAINT DSPR_CVTE_FK FOREIGN KEY (CVTE_ID) REFERENCES CONTROLLED_VOCABULARY_TERMS(ID);\\012ALTER TABLE DATA_SET_PROPERTIES ADD CONSTRAINT DSPR_DSTPT_FK FOREIGN KEY (DSTPT_ID) REFERENCES DATA_SET_TYPE_PROPERTY_TYPES(ID) ON DELETE CASCADE;\\012ALTER TABLE DATA_SET_PROPERTIES ADD CONSTRAINT DSPR_DS_FK FOREIGN KEY (DS_ID) REFERENCES DATA(ID);\\012ALTER TABLE DATA_SET_PROPERTIES ADD CONSTRAINT DSPR_PERS_FK FOREIGN KEY (PERS_ID_REGISTERER) REFERENCES PERSONS(ID);\\012ALTER TABLE DATA_SET_PROPERTIES ADD CONSTRAINT DSPR_MAPR_FK FOREIGN KEY (MATE_PROP_ID) REFERENCES MATERIALS(ID);\\012\\012ALTER TABLE DATA_SET_PROPERTIES ADD CONSTRAINT DSPR_CK CHECK \\012\\011((VALUE IS NOT NULL AND CVTE_ID IS NULL AND MATE_PROP_ID IS NULL) OR \\012\\011 (VALUE IS NULL AND CVTE_ID IS NOT NULL AND MATE_PROP_ID IS NULL) OR\\012\\011 (VALUE IS NULL AND CVTE_ID IS NULL AND MATE_PROP_ID IS NOT NULL)\\012\\011);\\012\\012CREATE INDEX DSPR_CVTE_FK_I ON DATA_SET_PROPERTIES (CVTE_ID);\\012CREATE INDEX DSPR_DSTPT_FK_I ON DATA_SET_PROPERTIES (DSTPT_ID);\\012CREATE INDEX DSPR_DS_FK_I ON DATA_SET_PROPERTIES (DS_ID);\\012CREATE INDEX DSPR_PERS_FK_I ON DATA_SET_PROPERTIES (PERS_ID_REGISTERER);\\012CREATE INDEX DSTPT_DSTY_FK_I ON DATA_SET_TYPE_PROPERTY_TYPES (DSTY_ID);\\012CREATE INDEX DSTPT_PERS_FK_I ON DATA_SET_TYPE_PROPERTY_TYPES (PERS_ID_REGISTERER);\\012CREATE INDEX DSTPT_PRTY_FK_I ON DATA_SET_TYPE_PROPERTY_TYPES (PRTY_ID);\\012\\012CREATE OR REPLACE FUNCTION DATA_SET_PROPERTY_WITH_MATERIAL_DATA_TYPE_CHECK() RETURNS trigger AS $$\\012DECLARE\\012   v_type_id  CODE;\\012   v_type_id_prop  CODE;\\012BEGIN\\012   if NEW.mate_prop_id IS NOT NULL then\\012\\011\\011\\011-- find material type id of the property type \\012\\011\\011\\011select pt.maty_prop_id into v_type_id_prop \\012\\011\\011\\011  from data_set_type_property_types dstpt, property_types pt \\012\\011\\011\\011 where NEW.dstpt_id = dstpt.id AND dstpt.prty_id = pt.id;\\012\\011\\011\\012\\011\\011\\011if v_type_id_prop IS NOT NULL then\\012\\011\\011\\011\\011-- find material type id of the material which consists the entity's property value\\012\\011\\011\\011\\011select entity.maty_id into v_type_id \\012\\011\\011\\011\\011  from materials entity\\012\\011\\011\\011\\011 where NEW.mate_prop_id = entity.id;\\012\\011\\011\\011\\011if v_type_id != v_type_id_prop then\\012\\011\\011\\011\\011\\011RAISE EXCEPTION 'Insert/Update of property value referencing material (id: %) failed, as referenced material type is different than expected (id %, expected id: %).', \\012\\011\\011\\011\\011\\011\\011\\011\\011\\011\\011\\011\\011 NEW.mate_prop_id, v_type_id, v_type_id_prop;\\012\\011\\011\\011\\011end if;\\012\\011\\011\\011end if;\\012   end if;\\012   RETURN NEW;\\012END;\\012$$ LANGUAGE 'plpgsql';\\012\\012CREATE TRIGGER DATA_SET_PROPERTY_WITH_MATERIAL_DATA_TYPE_CHECK BEFORE INSERT OR UPDATE ON data_set_properties\\012    FOR EACH ROW EXECUTE PROCEDURE DATA_SET_PROPERTY_WITH_MATERIAL_DATA_TYPE_CHECK();   \\012	\N
+./sourceTest/sql/postgresql/056/017=database_version_logs.tsv:032	source/sql/postgresql/migration/migration-031-032.sql	SUCCESS	2009-04-09 09:36:36.2	-- -------\\012-- Modify MATERIAL_BATCHES\\012-- -------\\012\\012ALTER TABLE material_batches\\012    DROP COLUMN proc_id;\\012\\012-- -------\\012-- Modify SAMPLES\\012-- -------\\012\\012ALTER TABLE samples\\012    ADD COLUMN expe_id tech_id;\\012\\012ALTER TABLE samples\\012    ADD CONSTRAINT samp_expe_fk FOREIGN KEY (expe_id) REFERENCES experiments(id);\\012\\012CREATE INDEX samp_expe_fk_i ON samples USING btree (expe_id);\\012\\012-- relink samples directly to experiments\\012\\012UPDATE samples\\012SET expe_id = (SELECT e.id FROM experiments e, procedures p, sample_inputs si \\012               WHERE si.samp_id = samples.id AND si.proc_id = p.id AND p.expe_id = e.id AND e.inva_id IS NULL);\\012\\012\\012-- -------\\012-- Modify DATA\\012-- -------\\012\\012ALTER TABLE data\\012    ADD COLUMN expe_id tech_id;\\012\\012ALTER TABLE data\\012    ADD CONSTRAINT data_expe_fk FOREIGN KEY (expe_id) REFERENCES experiments(id);\\012\\012CREATE INDEX data_expe_fk_i ON data USING btree (expe_id);\\012\\012UPDATE data\\012SET expe_id = (SELECT e.id FROM experiments e, procedures p \\012               WHERE data.proc_id_produced_by = p.id AND p.expe_id = e.id);\\012\\012ALTER TABLE data\\012    ALTER COLUMN expe_id SET NOT NULL;\\012\\012ALTER TABLE data\\012    DROP COLUMN proc_id_produced_by;\\012\\012-- -------\\012-- Drop PROCEDURES, PROCEDURE_TYPES, and SAMPLE_INPUTS\\012-- -------\\012\\012DROP TABLE sample_inputs;\\012DROP TABLE procedures;\\012DROP TABLE procedure_types;\\012\\012DROP SEQUENCE procedure_id_seq;\\012DROP SEQUENCE procedure_type_id_seq;\\012\\012-- -------\\012-- Add CODE_SEQ\\012-- -------\\012\\012CREATE SEQUENCE CODE_SEQ;\\012\\012-- -------\\012-- Add new columns to DATA_STORES\\012-- -------\\012\\012ALTER TABLE data_stores\\012    ADD COLUMN remote_url character varying(250),\\012    ADD COLUMN session_token character varying(50),\\012    ADD COLUMN modification_timestamp time_stamp DEFAULT now();\\012\\012UPDATE data_stores\\012SET remote_url = '', session_token='';\\012\\012ALTER TABLE data_stores\\012    ALTER COLUMN remote_url SET NOT NULL,\\012    ALTER COLUMN session_token SET NOT NULL;\\012\\012-- -------\\012-- Drop foreign keys onto DATA_STORES\\012-- -------\\012\\012ALTER TABLE database_instances\\012    DROP COLUMN dast_id;\\012\\012ALTER TABLE groups\\012    DROP COLUMN dast_id;\\012\\012ALTER TABLE projects\\012    DROP COLUMN dast_id;\\012\\012ALTER TABLE experiments\\012    DROP COLUMN dast_id;\\012\\012-- -------\\012-- Add foreign key from DATA onto DATA_STORES\\012-- -------\\012\\012ALTER TABLE data\\012    ADD COLUMN dast_id tech_id;\\012\\012ALTER TABLE data\\012    ADD CONSTRAINT data_dast_fk FOREIGN KEY (dast_id) REFERENCES data_stores(id);\\012\\012UPDATE data\\012SET dast_id = (select id from data_stores where code = 'STANDARD');\\012\\012ALTER TABLE data\\012    ALTER COLUMN dast_id SET NOT NULL;\\012\\012\\012------------------------------------------------------------------------------------\\012--  Purpose:  Replace trigger SAMPLE_CODE_UNIQUENESS_CHECK \\012------------------------------------------------------------------------------------\\012\\012CREATE OR REPLACE FUNCTION SAMPLE_CODE_UNIQUENESS_CHECK() RETURNS trigger AS $$\\012DECLARE\\012   counter  INTEGER;\\012BEGIN\\012    LOCK TABLE samples IN EXCLUSIVE MODE;\\012    IF (NEW.samp_id_part_of is NULL) THEN\\012        IF (NEW.dbin_id is not NULL) THEN\\012            SELECT count(*) into counter FROM samples \\012                where id != NEW.id and code = NEW.code and samp_id_part_of is NULL and dbin_id = NEW.dbin_id;\\012            IF (counter > 0) THEN\\012                RAISE EXCEPTION 'Insert/Update of Sample (Code: %) failed because database instance sample with the same code already exists.', NEW.code;\\012            END IF;\\012        ELSIF (NEW.grou_id is not NULL) THEN\\012            SELECT count(*) into counter FROM samples \\012                where id != NEW.id and code = NEW.code and samp_id_part_of is NULL and grou_id = NEW.grou_id;\\012            IF (counter > 0) THEN\\012                RAISE EXCEPTION 'Insert/Update of Sample (Code: %) failed because group sample with the same code already exists.', NEW.code;\\012            END IF;\\012        END IF;\\012        ELSE\\012        IF (NEW.dbin_id is not NULL) THEN\\012            SELECT count(*) into counter FROM samples \\012                where id != NEW.id and code = NEW.code and samp_id_part_of = NEW.samp_id_part_of and dbin_id = NEW.dbin_id;\\012            IF (counter > 0) THEN\\012                RAISE EXCEPTION 'Insert/Update of Sample (Code: %) failed because database instance sample with the same code and being the part of the same parent already exists.', NEW.code;\\012            END IF;\\012        ELSIF (NEW.grou_id is not NULL) THEN\\012            SELECT count(*) into counter FROM samples \\012                where id != NEW.id and code = NEW.code and samp_id_part_of = NEW.samp_id_part_of and grou_id = NEW.grou_id;\\012            IF (counter > 0) THEN\\012                RAISE EXCEPTION 'Insert/Update of Sample (Code: %) failed because group sample with the same code and being the part of the same parent already exists.', NEW.code;\\012            END IF;\\012        END IF;\\012        END IF;   \\012   RETURN NEW;\\012END;\\012$$ LANGUAGE 'plpgsql';\\012\\012\\012\\012	\N
+./sourceTest/sql/postgresql/056/017=database_version_logs.tsv:034	source/sql/postgresql/migration/migration-033-034.sql	SUCCESS	2009-05-26 08:32:49.935	------------------------------------------------------------------------------------\\012-- Create sequence for generating permanent identifiers starting with nextval of existing dataset sequence.\\012------------------------------------------------------------------------------------\\012CREATE FUNCTION CREATE_SEQUENCE(EXISTING_SEQUENCE VARCHAR, NEW_SEQUENCE VARCHAR) RETURNS VOID AS $$\\012DECLARE\\012  CURR_SEQ_VAL   INTEGER;\\012BEGIN\\012  SELECT INTO CURR_SEQ_VAL NEXTVAL(EXISTING_SEQUENCE);\\012  EXECUTE 'CREATE SEQUENCE ' || NEW_SEQUENCE || ' START WITH ' || CURR_SEQ_VAL;\\012  RETURN;\\012END;\\012$$ LANGUAGE 'plpgsql';\\012\\012SELECT CREATE_SEQUENCE('DATA_ID_SEQ', 'PERM_ID_SEQ');\\012DROP FUNCTION CREATE_SEQUENCE(VARCHAR, VARCHAR);\\012\\012------------------------------------------------------------------------------------\\012-- Add perm_id columns to samples and experiments.\\012------------------------------------------------------------------------------------\\012ALTER TABLE SAMPLES ADD COLUMN PERM_ID CODE;\\012ALTER TABLE EXPERIMENTS ADD COLUMN PERM_ID CODE;\\012\\012UPDATE SAMPLES SET PERM_ID = to_char(registration_timestamp,'YYYYMMDDHHSSMS') || '-' || NEXTVAL('PERM_ID_SEQ');\\012UPDATE EXPERIMENTS SET PERM_ID = to_char(registration_timestamp,'YYYYMMDDHHSSMS') || '-' || NEXTVAL('PERM_ID_SEQ');\\012ALTER TABLE SAMPLES ALTER COLUMN PERM_ID SET NOT NULL;\\012ALTER TABLE EXPERIMENTS ALTER COLUMN PERM_ID SET NOT NULL;\\012ALTER TABLE SAMPLES ADD CONSTRAINT SAMP_PI_UK UNIQUE(PERM_ID);\\012ALTER TABLE EXPERIMENTS ADD CONSTRAINT EXPE_PI_UK UNIQUE(PERM_ID);\\012\\012\\012------------------------------------------------------------------------------------\\012-- Add column is_chosen_from_list to controlled_vocabularies.\\012------------------------------------------------------------------------------------\\012ALTER TABLE controlled_vocabularies ADD COLUMN is_chosen_from_list BOOLEAN_CHAR NOT NULL DEFAULT TRUE;\\012ALTER TABLE controlled_vocabularies ADD COLUMN source_uri CHARACTER VARYING(250);\\012------------------------------------------------------------------------------------\\012-- Modify Data table - remove arc connection between Sample and Data table, use a flag instead\\012------------------------------------------------------------------------------------\\012\\012-- add new columns\\012\\012ALTER TABLE data\\012    ADD COLUMN is_derived boolean_char;\\012ALTER TABLE data\\012    ADD COLUMN samp_id tech_id;\\012\\012-- update values in new columns\\012\\012UPDATE data\\012    SET is_derived = (samp_id_derived_from IS NOT NULL); \\012UPDATE data\\012    SET samp_id = samp_id_derived_from \\012    WHERE is_derived = 'TRUE';\\012UPDATE data\\012    SET samp_id = samp_id_acquired_from \\012    WHERE is_derived = 'FALSE';\\012\\012-- add constraints and indexes to new columns\\012\\012ALTER TABLE data\\012    ALTER COLUMN is_derived SET NOT NULL;\\012ALTER TABLE data\\012    ALTER COLUMN samp_id SET NOT NULL;   \\012ALTER TABLE data\\012    ADD CONSTRAINT data_samp_fk FOREIGN KEY (samp_id) REFERENCES samples (id);\\012CREATE INDEX data_samp_fk_i ON data USING btree (samp_id);\\012\\012-- remove old columns\\012\\012ALTER TABLE data\\012    DROP COLUMN samp_id_acquired_from;\\012ALTER TABLE data\\012    DROP COLUMN samp_id_derived_from;\\012    \\012------------------------------------------------------------------------------------\\012-- Granting SELECT privilege to group openbis_readonly\\012------------------------------------------------------------------------------------\\012\\012GRANT SELECT ON SEQUENCE attachment_content_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE attachment_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE code_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE controlled_vocabulary_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE cvte_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE data_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE data_set_property_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE data_set_relationship_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE data_set_type_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE data_store_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE data_type_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE database_instance_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE dstpt_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE etpt_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE event_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE experiment_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE experiment_property_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE experiment_type_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE file_format_type_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE group_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE invalidation_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE locator_type_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE material_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE material_property_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE material_type_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE mtpt_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE perm_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE person_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE project_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE property_type_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE role_assignment_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE sample_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE sample_property_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE sample_type_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE stpt_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE attachment_contents TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE attachments TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE controlled_vocabularies TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE controlled_vocabulary_terms TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE data TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE data_set_properties TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE data_set_relationships TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE data_set_type_property_types TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE data_set_types TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE data_stores TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE data_types TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE database_instances TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE database_version_logs TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE events TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE experiment_properties TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE experiment_type_property_types TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE experiment_types TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE experiments TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE external_data TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE file_format_types TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE groups TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE invalidations TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE locator_types TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE material_properties TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE material_type_property_types TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE material_types TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE materials TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE persons TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE projects TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE property_types TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE role_assignments TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE sample_properties TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE sample_type_property_types TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE sample_types TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE samples TO GROUP OPENBIS_READONLY;\\012\\012------------------------------------------------------------------------------------\\012-- Delete MATERIAL_BATCHES table\\012------------------------------------------------------------------------------------\\012\\012-- WARNING: Potential data lost!!!\\012-- WARNING: Potential data lost!!!\\012-- WARNING: Potential data lost!!!\\012\\012DROP TABLE SAMPLE_MATERIAL_BATCHES;\\012DROP TABLE MATERIAL_BATCHES;\\012DROP SEQUENCE MATERIAL_BATCH_ID_SEQ;\\012\\012------------------------------------------------------------------------------------\\012-- Delete MATE_ID_INHIBITOR_OF from table MATERIALS\\012------------------------------------------------------------------------------------\\012\\012-- WARNING: Potential data lost!!!\\012-- WARNING: Potential data lost!!!\\012-- WARNING: Potential data lost!!!\\012\\012ALTER TABLE MATERIALS DROP COLUMN MATE_ID_INHIBITOR_OF;\\012	\N
+./sourceTest/sql/postgresql/056/017=database_version_logs.tsv:041	source/sql/postgresql/migration/migration-040-041.sql	SUCCESS	2009-09-14 13:48:57.539	-- Create FILTERS table\\012\\012CREATE TABLE FILTERS (ID TECH_ID NOT NULL, DBIN_ID TECH_ID NOT NULL, NAME VARCHAR(200) NOT NULL, DESCRIPTION DESCRIPTION_1000,REGISTRATION_TIMESTAMP TIME_STAMP_DFL NOT NULL DEFAULT CURRENT_TIMESTAMP, PERS_ID_REGISTERER TECH_ID NOT NULL, MODIFICATION_TIMESTAMP TIME_STAMP DEFAULT CURRENT_TIMESTAMP, EXPRESSION VARCHAR(2000) NOT NULL, IS_PUBLIC BOOLEAN NOT NULL, GRID_ID VARCHAR(200) NOT NULL);\\012CREATE SEQUENCE FILTER_ID_SEQ;\\012ALTER TABLE FILTERS ADD CONSTRAINT FILT_PK PRIMARY KEY(ID);\\012ALTER TABLE FILTERS ADD CONSTRAINT FILT_BK_UK UNIQUE(NAME, DBIN_ID, GRID_ID);\\012ALTER TABLE FILTERS ADD CONSTRAINT FILT_PERS_FK FOREIGN KEY (PERS_ID_REGISTERER) REFERENCES PERSONS(ID);\\012ALTER TABLE FILTERS ADD CONSTRAINT FILT_DBIN_FK FOREIGN KEY (DBIN_ID) REFERENCES DATABASE_INSTANCES(ID);\\012CREATE INDEX FILT_PERS_FK_I ON FILTERS (PERS_ID_REGISTERER);\\012CREATE INDEX FILT_DBIN_FK_I ON FILTERS (DBIN_ID);\\012GRANT SELECT ON SEQUENCE filter_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE filters TO GROUP OPENBIS_READONLY;\\012\\012-- Add missing foreign key to role assignments authorization group\\012ALTER TABLE ROLE_ASSIGNMENTS ADD CONSTRAINT ROAS_AG_FK_GRANTEE FOREIGN KEY (AG_ID_GRANTEE) REFERENCES AUTHORIZATION_GROUPS(ID);\\012\\012--------------------------------------------------------------------------------------------------\\012-- Modify dataset connections:\\012-- 1. connection with sample shouldn't be mandatory any more\\012-- 2. introduce an arc condition that dataset cannot be connected with a sample and a parent dataset at the same time\\012--------------------------------------------------------------------------------------------------\\012\\012-- Weaken data-sample connection constraint - allow dataset to have no connection with sample\\012ALTER TABLE data ALTER COLUMN samp_id DROP NOT NULL;\\012\\012-- Remove data-sample connection for datasets that have a parent\\012\\012UPDATE data \\012   SET samp_id = NULL \\012 WHERE id IN (SELECT DISTINCT data_id_child FROM data_set_relationships);\\012\\012-- With PostgreSQL 8.4 one can check that before migration there were no cycles in dataset relationships:\\012--\\012-- WITH RECURSIVE data_set_parents(id, parent_ids, cycle) AS (\\012--         SELECT  r.data_id_child AS id, \\012--                 ARRAY[CAST (r.data_id_parent AS bigint)] AS parent_ids, \\012--                 false AS cycle \\012--         FROM data_set_relationships r\\012--     UNION ALL\\012--         SELECT  r.data_id_child,\\012--                 CAST (r.data_id_parent AS bigint) || p.parent_ids,\\012--                 r.data_id_child = ANY(p.parent_ids)\\012--         FROM data_set_relationships r, data_set_parents p\\012--         WHERE r.data_id_parent = p.id AND NOT cycle\\012-- )\\012-- SELECT count(*) AS cycles FROM data_set_parents WHERE cycle = true;\\012\\012---------------------------------------------------------------------------------------------------\\012--  Purpose:  Create DEFERRED triggers:\\012--            * check_dataset_relationships_on_data_table_modification,\\012--            * check_dataset_relationships_on_relationships_table_modification.\\012--            They check that after all modifications of database (just before commit) \\012--            if 'data'/'data_set_relationships' tables are among modified tables \\012--            dataset is not connected with a sample and a parent dataset at the same time.\\012--            This connections are held in two different tables so simple immediate trigger \\012--            with arc check cannot be used and we need two deferred triggers.\\012----------------------------------------------------------------------------------------------------\\012\\012-- trigger for 'data' table\\012\\012CREATE OR REPLACE FUNCTION check_dataset_relationships_on_data_table_modification() RETURNS trigger AS $$\\012DECLARE\\012\\011counter\\011INTEGER;\\012BEGIN\\012\\011-- if there is a connection with a Sample there should not be any connection with a parent Data Set\\012\\011IF (NEW.samp_id IS NOT NULL) THEN\\012\\011\\011-- count number of parents\\012\\011\\011SELECT count(*) INTO counter \\012\\011\\011\\011FROM data_set_relationships \\012\\011\\011\\011WHERE data_id_child = OLD.id;\\012\\011\\011IF (counter > 0) THEN\\012\\011\\011\\011RAISE EXCEPTION 'Insert/Update of Data Set (Code: %) failed because it cannot be connected with a Sample and a parent Data Set at the same time.', OLD.code;\\012\\011\\011END IF;\\012\\011END IF;\\012  RETURN NEW;\\012END;\\012$$ LANGUAGE 'plpgsql';\\012\\012CREATE CONSTRAINT TRIGGER check_dataset_relationships_on_data_table_modification \\012  AFTER INSERT OR UPDATE ON data\\012\\011DEFERRABLE INITIALLY DEFERRED\\012\\011FOR EACH ROW \\012\\011EXECUTE PROCEDURE check_dataset_relationships_on_data_table_modification();\\012\\012-- trigger for 'data_set_relationships'\\012\\012CREATE OR REPLACE FUNCTION check_dataset_relationships_on_relationships_table_modification() RETURNS trigger AS $$\\012DECLARE\\012\\011counter\\011INTEGER;\\012\\011sample_id\\011TECH_ID;\\012\\011data_code\\011CODE;\\012BEGIN\\012\\011-- child will have a parent added so it should not be connected with any sample\\012\\011SELECT samp_id, code INTO sample_id, data_code \\012\\011\\011FROM data \\012\\011\\011WHERE id = NEW.data_id_child;\\012\\011IF (sample_id IS NOT NULL) THEN\\012\\011\\011RAISE EXCEPTION 'Insert/Update of Data Set (Code: %) failed because it cannot be connected to a Sample and to a parent Data Set at the same time.', data_code;\\012\\011END IF;\\012\\011RETURN NEW;\\012END;\\012$$ LANGUAGE 'plpgsql';\\012  \\012CREATE CONSTRAINT TRIGGER check_dataset_relationships_on_relationships_table_modification \\012  AFTER INSERT OR UPDATE ON data_set_relationships\\012\\011DEFERRABLE INITIALLY DEFERRED\\012\\011FOR EACH ROW \\012\\011EXECUTE PROCEDURE check_dataset_relationships_on_relationships_table_modification();\\012	\N
+./sourceTest/sql/postgresql/056/017=database_version_logs.tsv:053	source/sql/postgresql/migration/migration-052-053.sql	SUCCESS	2010-06-08 15:27:55.032	-- Migration from 052 to 053\\012\\012-- Change code uniqueness check for samples of specific type.\\012-- If sample_types.is_subcode_unique flag is set to 'true', additional check is performed \\012-- on codes of samples of the type. Subcodes will have to be unique as well.\\012\\012ALTER TABLE sample_types ADD COLUMN is_subcode_unique boolean_char NOT NULL DEFAULT false;\\012\\012CREATE OR REPLACE FUNCTION SAMPLE_SUBCODE_UNIQUENESS_CHECK() RETURNS trigger AS $$\\012DECLARE\\012   counter  INTEGER;\\012   unique_subcode  BOOLEAN_CHAR;\\012BEGIN\\012  LOCK TABLE samples IN EXCLUSIVE MODE;\\012  \\012  SELECT is_subcode_unique into unique_subcode FROM sample_types WHERE id = NEW.saty_id;\\012  \\012  IF (unique_subcode) THEN\\012    IF (NEW.dbin_id is not NULL) THEN\\012\\011\\011\\011SELECT count(*) into counter FROM samples \\012\\011\\011\\011\\011where id != NEW.id and code = NEW.code and saty_id = NEW.saty_id and dbin_id = NEW.dbin_id;\\012\\011\\011\\011IF (counter > 0) THEN\\012\\011\\011\\011\\011RAISE EXCEPTION 'Insert/Update of Sample (Code: %) failed because database instance sample of the same type with the same subcode already exists.', NEW.code;\\012\\011\\011\\011END IF;\\012\\011\\011ELSIF (NEW.grou_id is not NULL) THEN\\012\\011\\011\\011SELECT count(*) into counter FROM samples \\012\\011\\011\\011\\011where id != NEW.id and code = NEW.code and saty_id = NEW.saty_id and grou_id = NEW.grou_id;\\012\\011\\011\\011IF (counter > 0) THEN\\012\\011\\011\\011\\011RAISE EXCEPTION 'Insert/Update of Sample (Code: %) failed because space sample of the same type with the same subcode already exists.', NEW.code;\\012\\011\\011\\011END IF;\\012\\011\\011END IF;\\012  END IF;\\012  \\012  RETURN NEW;\\012END;\\012$$ LANGUAGE 'plpgsql';\\012\\012CREATE TRIGGER SAMPLE_SUBCODE_UNIQUENESS_CHECK BEFORE INSERT OR UPDATE ON SAMPLES\\012    FOR EACH ROW EXECUTE PROCEDURE SAMPLE_SUBCODE_UNIQUENESS_CHECK();\\012    \\012-- Fixing error messages in old trigger\\012\\012CREATE OR REPLACE FUNCTION SAMPLE_CODE_UNIQUENESS_CHECK() RETURNS trigger AS $$\\012DECLARE\\012   counter  INTEGER;\\012BEGIN\\012  LOCK TABLE samples IN EXCLUSIVE MODE;\\012  \\012\\011  IF (NEW.samp_id_part_of is NULL) THEN\\012\\011\\011  IF (NEW.dbin_id is not NULL) THEN\\012\\011\\011\\011  SELECT count(*) into counter FROM samples \\012\\011\\011      where id != NEW.id and code = NEW.code and samp_id_part_of is NULL and dbin_id = NEW.dbin_id;\\012        IF (counter > 0) THEN\\012\\011\\011\\011\\011  RAISE EXCEPTION 'Insert/Update of Sample (Code: %) failed because database instance sample with the same code already exists.', NEW.code;\\012        END IF;\\012\\011\\011  ELSIF (NEW.grou_id is not NULL) THEN\\012\\011\\011\\011  SELECT count(*) into counter FROM samples \\012\\011\\011\\011\\011  where id != NEW.id and code = NEW.code and samp_id_part_of is NULL and grou_id = NEW.grou_id;\\012\\011\\011\\011  IF (counter > 0) THEN\\012\\011\\011\\011\\011  RAISE EXCEPTION 'Insert/Update of Sample (Code: %) failed because space sample with the same code already exists.', NEW.code;\\012\\011\\011\\011  END IF;\\012      END IF;\\012    ELSE\\012\\011\\011  IF (NEW.dbin_id is not NULL) THEN\\012\\011\\011\\011  SELECT count(*) into counter FROM samples \\012\\011\\011\\011\\011  where id != NEW.id and code = NEW.code and samp_id_part_of = NEW.samp_id_part_of and dbin_id = NEW.dbin_id;\\012\\011\\011\\011  IF (counter > 0) THEN\\012\\011\\011\\011\\011  RAISE EXCEPTION 'Insert/Update of Sample (Code: %) failed because database instance sample with the same code and being the part of the same container already exists.', NEW.code;\\012\\011\\011\\011  END IF;\\012\\011\\011  ELSIF (NEW.grou_id is not NULL) THEN\\012\\011\\011\\011  SELECT count(*) into counter FROM samples \\012\\011\\011\\011\\011  where id != NEW.id and code = NEW.code and samp_id_part_of = NEW.samp_id_part_of and grou_id = NEW.grou_id;\\012\\011\\011\\011  IF (counter > 0) THEN\\012\\011\\011\\011\\011  RAISE EXCEPTION 'Insert/Update of Sample (Code: %) failed because space sample with the same code and being the part of the same container already exists.', NEW.code;\\012\\011\\011\\011  END IF;\\012\\011\\011  END IF;\\012     END IF;   \\012  \\012  RETURN NEW;\\012END;\\012$$ LANGUAGE 'plpgsql';\\012	\N
+./sourceTest/sql/postgresql/056/017=database_version_logs.tsv:054	source/sql/postgresql/migration/migration-053-054.sql	SUCCESS	2010-07-27 11:30:46.766	-- Migration from 053 to 054\\012\\012\\012-- Add RELATIONSHIP_TYPES table\\012CREATE TABLE relationship_types (id TECH_ID NOT NULL, code CODE NOT NULL, label COLUMN_LABEL, parent_label COLUMN_LABEL, child_label COLUMN_LABEL, description DESCRIPTION_2000, registration_timestamp TIME_STAMP_DFL NOT NULL DEFAULT CURRENT_TIMESTAMP, pers_id_registerer TECH_ID NOT NULL, is_managed_internally BOOLEAN_CHAR NOT NULL DEFAULT 'F', is_internal_namespace BOOLEAN_CHAR NOT NULL DEFAULT 'F', dbin_id TECH_ID NOT NULL);\\012\\012-- Add SAMPLE_RELATIONSHIPS table\\012CREATE TABLE sample_relationships (id TECH_ID NOT NULL, sample_id_parent TECH_ID NOT NULL, relationship_id TECH_ID NOT NULL, sample_id_child TECH_ID NOT NULL);\\012\\012-- Add/update constraints\\012ALTER TABLE relationship_types ADD CONSTRAINT rety_pk PRIMARY KEY (id);\\012ALTER TABLE relationship_types ADD CONSTRAINT rety_uk UNIQUE(code,dbin_id);\\012ALTER TABLE sample_relationships ADD CONSTRAINT sare_pk PRIMARY KEY (id);\\012ALTER TABLE sample_relationships ADD CONSTRAINT sare_bk_uk UNIQUE(sample_id_child,sample_id_parent,relationship_id);\\012ALTER TABLE sample_relationships ADD CONSTRAINT sare_data_fk_child FOREIGN KEY (sample_id_child) REFERENCES samples(id) ON DELETE CASCADE;\\012ALTER TABLE sample_relationships ADD CONSTRAINT sare_data_fk_parent FOREIGN KEY (sample_id_parent) REFERENCES samples(id) ON DELETE CASCADE;\\012ALTER TABLE sample_relationships ADD CONSTRAINT sare_data_fk_relationship FOREIGN KEY (relationship_id) REFERENCES relationship_types(id);\\012\\012-- Create index\\012CREATE INDEX sare_data_fk_i_child ON sample_relationships (sample_id_child);\\012CREATE INDEX sare_data_fk_i_parent ON sample_relationships (sample_id_parent);\\012CREATE INDEX sare_data_fk_i_relationship ON sample_relationships (relationship_id);\\012\\012-- Create sequence for RELATIONSHIP_TYPES\\012CREATE SEQUENCE RELATIONSHIP_TYPE_ID_SEQ;\\012CREATE SEQUENCE SAMPLE_RELATIONSHIP_ID_SEQ;\\012\\012-- Create initial relationships\\012insert into relationship_types\\012(id, \\012code, \\012label, \\012parent_label, \\012child_label, \\012description, \\012pers_id_registerer, \\012is_managed_internally, \\012is_internal_namespace, \\012dbin_id) \\012values\\012(\\012nextval('RELATIONSHIP_TYPE_ID_SEQ'),\\012'PARENT_CHILD',\\012'Parent - Child', \\012'Parent', \\012'Child', \\012'Parent - Child relationship', \\012(select id from persons where user_id ='system'), \\012'T', \\012'T', \\012(select id from database_instances where is_original_source = 'T')\\012);\\012\\012insert into relationship_types\\012(id, \\012code, \\012label, \\012parent_label, \\012child_label, \\012description, \\012pers_id_registerer, \\012is_managed_internally, \\012is_internal_namespace, \\012dbin_id) \\012values\\012(\\012nextval('RELATIONSHIP_TYPE_ID_SEQ'),\\012'PLATE_CONTROL_LAYOUT',\\012'Plate - Control Layout', \\012'Plate', \\012'Control Layout', \\012'Plate - Control Layout relationship', \\012(select id from persons where user_id ='system'), \\012'T', \\012'T', \\012(select id from database_instances where is_original_source = 'T')\\012); \\012\\012\\012-- Migrate sample relationships to new schema\\012INSERT INTO sample_relationships (id, sample_id_parent,sample_id_child,relationship_id) (select distinct nextval('SAMPLE_RELATIONSHIP_ID_SEQ') as id, s.SAMP_ID_GENERATED_FROM as parent_id, s.ID as child_id, rt.id as relationship_id from samples s, relationship_types rt  WHERE rt.code = 'PARENT_CHILD' and s.SAMP_ID_GENERATED_FROM is not null); \\012INSERT INTO sample_relationships (id, sample_id_parent,sample_id_child,relationship_id) (select distinct nextval('SAMPLE_RELATIONSHIP_ID_SEQ') as id, s.SAMP_ID_CONTROL_LAYOUT as parent_id, s.ID as child_id, rt.id as relationship_id from samples s, relationship_types rt  WHERE rt.code = 'PLATE_CONTROL_LAYOUT' and s.SAMP_ID_CONTROL_LAYOUT is not null);\\012\\012-- Drop old sample relations\\012ALTER TABLE SAMPLES DROP COLUMN SAMP_ID_TOP;\\012ALTER TABLE SAMPLES DROP COLUMN SAMP_ID_GENERATED_FROM;\\012ALTER TABLE SAMPLES DROP COLUMN SAMP_ID_CONTROL_LAYOUT;\\012\\012--------------------------------------------------------------------------------------\\012--------------------------------------------------------------------------------------\\012-- This is a screening specific migration. Nothing will be performed on openBIS databases \\012-- which are not screening specific.\\012-- \\012-- This migration for each existing connection between oligo well, oligo material and gene material\\012-- creates a direct connection between the well and the gene. \\012--------------------------------------------------------------------------------------\\012--------------------------------------------------------------------------------------\\012 \\012\\011\\012CREATE OR REPLACE FUNCTION CONNECT_WELLS_WITH_GENES() RETURNS void AS $$\\012DECLARE\\012\\011counter  int;\\012\\011oligo_well_exists bool;\\012BEGIN\\012\\011--------------------------------------------------\\012\\011-- create a gene property and assign it to oligo well\\012\\011--------------------------------------------------\\012\\011\\012\\011select true \\012\\011into oligo_well_exists\\012\\011from sample_types \\012\\011where code = 'OLIGO_WELL';\\012\\011\\012\\011if oligo_well_exists IS NULL then \\012\\011\\011-- skip migration if there are no oligo wells\\012\\011\\011return;\\012\\011end if;   \\012\\011\\012\\011insert into property_types(\\012\\011\\011id, \\012\\011\\011code, description, label, \\012\\011\\011daty_id,\\012\\011\\011pers_id_registerer,\\012\\011\\011dbin_id,\\012\\011\\011maty_prop_id) \\012\\011values(\\012\\011\\011\\011nextval('PROPERTY_TYPE_ID_SEQ'), \\012\\011\\011\\011'GENE','Inhibited gene','Gene',\\012\\011\\011\\011(select id from data_types where code = 'MATERIAL'), \\012\\011\\011\\011(select id from persons where user_id ='system'), \\012\\011\\011\\011(select id from database_instances where is_original_source = 'T'), \\012\\011\\011\\011(select id from material_types where code = 'GENE')\\012\\011\\011);\\012\\011\\011\\012\\011insert into sample_type_property_types( \\012\\011  id,\\012\\011  saty_id,\\012\\011  prty_id,\\012\\011  is_mandatory,\\012\\011  pers_id_registerer,\\012\\011  ordinal\\012\\011) values(\\012\\011\\011\\011nextval('stpt_id_seq'), \\012\\011\\011\\011(select id from sample_types where code = 'OLIGO_WELL'),\\012\\011\\011\\011(select id from property_types where code = 'GENE'),\\012\\011\\011\\011false,\\012\\011\\011\\011(select id from persons where user_id ='system'),\\012\\011\\011\\011(select max(ordinal)+1 from sample_type_property_types \\012\\011\\011\\011\\011where saty_id = (select id from sample_types where code = 'OLIGO_WELL'))\\012\\011\\011);\\012\\012\\011--------------------------------------------------\\012\\011-- create a gene material property for each oligo well\\012\\011--------------------------------------------------\\012\\011\\011\\012\\011select \\011count(*)\\012\\011into counter\\012\\011from\\012\\011\\011samples well, sample_types well_type, sample_properties well_props, \\012\\011\\011materials well_material, material_properties well_material_props,\\012\\011\\011materials nested_well_material\\012\\011where\\012\\011\\011well_type.code = 'OLIGO_WELL' and\\012\\011\\011-- find 'well_material' assigned to the well\\012\\011\\011well_props.samp_id = well.id and well_material.id = well_props.mate_prop_id and \\012\\011\\011-- additional joins to entity type tables\\012\\011\\011well_type.id = well.saty_id and\\012\\011\\011-- well content material property\\012\\011\\011well_material_props.mate_id = well_material.id and \\012\\011\\011-- material connected to the material in the well (e.g. gene)\\012\\011\\011well_material_props.mate_prop_id = nested_well_material.id and\\012\\011\\011nested_well_material.maty_id = (select id from material_types where code = 'GENE');\\012\\011\\012\\011if counter = 0 then \\012\\011\\011-- skip migration if there are no genes indirectly connected to oligo wells\\012\\011\\011return;\\012\\011end if;   \\012\\012\\011insert into sample_properties(id, samp_id, stpt_id, mate_prop_id, pers_id_registerer) (\\012\\011\\011select \\011nextval('sample_property_id_seq') id, \\012\\011\\011\\011well.id samp_id, \\012\\011\\011\\011(select stpt.id from sample_type_property_types stpt, property_types props where stpt.prty_id = props.id and props.code='GENE') stpt_id,\\012\\011\\011\\011nested_well_material.id mate_prop_id,\\012\\011\\011\\011(select id from persons where user_id ='system') pers_id_registerer \\012\\011\\011from\\012\\011\\011\\011samples well, sample_types well_type, sample_properties well_props, \\012\\011\\011\\011materials well_material, material_properties well_material_props,\\012\\011\\011\\011materials nested_well_material\\012\\011\\011where\\012\\011\\011\\011well_type.code = 'OLIGO_WELL' and\\012\\011\\011\\011-- find 'well_material' assigned to the well\\012\\011\\011\\011well_props.samp_id = well.id and well_material.id = well_props.mate_prop_id and \\012\\011\\011\\011-- additional joins to entity type tables\\012\\011\\011\\011well_type.id = well.saty_id and\\012\\011\\011\\011-- well content material property\\012\\011\\011\\011well_material_props.mate_id = well_material.id and \\012\\011\\011\\011-- material connected to the material in the well (e.g. gene)\\012\\011\\011\\011well_material_props.mate_prop_id = nested_well_material.id and\\012\\011\\011\\011nested_well_material.maty_id = (select id from material_types where code = 'GENE')\\012\\011);\\012\\012END;\\012$$ LANGUAGE 'plpgsql';\\012\\012select CONNECT_WELLS_WITH_GENES();\\012drop function CONNECT_WELLS_WITH_GENES();\\012\\012--------------------------------------------------------------------------------------\\012--------------------------------------------------------------------------------------\\012\\012-- drop dataset triggers\\012\\012DROP TRIGGER check_dataset_relationships_on_data_table_modification ON data;\\012DROP FUNCTION check_dataset_relationships_on_data_table_modification();\\012DROP TRIGGER check_dataset_relationships_on_relationships_table_modification ON data_set_relationships;\\012DROP FUNCTION check_dataset_relationships_on_relationships_table_modification();\\012 \\012\\012\\012\\012\\012\\012\\012\\012	\N
+./sourceTest/sql/postgresql/056/017=database_version_logs.tsv:056	source/sql/postgresql/migration/migration-055-056.sql	SUCCESS	2010-09-08 13:44:23.134	-- Migration from 055 to 056\\012\\012--------------------------------------------------------------------------------------\\012--------------------------------------------------------------------------------------\\012-- Screening specific migration. Nothing will be performed on openBIS databases \\012-- which are not screening specific.\\012--------------------------------------------------------------------------------------\\012--------------------------------------------------------------------------------------\\012\\012CREATE OR REPLACE FUNCTION merge_words(text, text) RETURNS text AS $$\\012DECLARE\\012  BEGIN\\012    IF  character_length($1) > 0 THEN\\012      RETURN $1 || ' ' || $2;\\012    ELSE\\012      RETURN $2;\\012    END IF;\\012  END;\\012$$ LANGUAGE plpgsql;\\012\\012CREATE AGGREGATE merge_words(text)\\012(\\012  SFUNC = merge_words,\\012  STYPE = text\\012);\\012\\012\\012CREATE OR REPLACE FUNCTION REPLACE_GENE_SYMBOL_BY_GENE_ID() RETURNS void AS $$\\012DECLARE\\012\\011counter  int;\\012\\011library_id_assigned_to_gene bool;\\012BEGIN\\012\\011--------------------------------------------------\\012\\011-- create a GENE_SYMBOL property and assign it to GENE\\012\\011--------------------------------------------------\\012\\011\\012\\011select true  \\012\\011into library_id_assigned_to_gene \\012\\011from material_type_property_types mtpt, material_types mt, property_types pt  \\012\\011where mtpt.maty_id = mt.id and mtpt.prty_id = pt.id \\012\\011\\011and mt.code = 'GENE' and pt.code = 'LIBRARY_ID';\\012\\011\\012\\011if library_id_assigned_to_gene IS NULL then \\012\\011\\011-- skip migration if gene has no library_id property\\012\\011\\011return;\\012\\011end if; \\012\\011\\012\\011\\012\\011select count(*)\\012\\011into counter \\012\\011from  \\012\\011\\011(select m.id, count(mp.id) as c \\012\\011\\011\\011from materials m, material_types mt, material_properties mp, material_type_property_types mtpt, property_types pt \\012\\011\\011\\011where m.maty_id = mt.id and mp.mate_id = m.id and mp.mtpt_id = mtpt.id and mtpt.maty_id = mt.id and pt.id = mtpt.prty_id\\012\\011\\011\\011\\011and mt.code = 'GENE' and pt.code = 'LIBRARY_ID' \\012\\011\\011\\011group by m.id) as counter_table \\012\\011where c < 1; \\012\\011\\012\\011if counter > 0 then \\012\\011\\011-- skip migration if there is at least one gene without library_id\\012\\011\\011return;\\012\\011end if;\\012\\011\\012\\011\\012\\011insert into property_types\\012\\011\\011(id\\012\\011\\011,code\\012\\011\\011,description\\012\\011\\011,label\\012\\011\\011,daty_id\\012\\011\\011,pers_id_registerer\\012\\011\\011,dbin_id)\\012\\011values \\012\\011\\011(nextval('PROPERTY_TYPE_ID_SEQ')\\012\\011\\011,'GENE_SYMBOLS'\\012\\011\\011,'Gene symbols'\\012\\011\\011,'Gene symbols'\\012\\011\\011,(select id from data_types where code ='VARCHAR')\\012\\011\\011,(select id from persons where user_id ='system')\\012\\011\\011,(select id from database_instances where is_original_source = 'T')\\012\\011);\\012\\011\\011\\012\\011insert into material_type_property_types( \\012\\011  id,\\012\\011  maty_id,\\012\\011  prty_id,\\012\\011  is_mandatory,\\012\\011  pers_id_registerer,\\012\\011  ordinal\\012\\011) values(\\012\\011\\011\\011nextval('mtpt_id_seq'), \\012\\011\\011\\011(select id from material_types where code = 'GENE'),\\012\\011\\011\\011(select id from property_types where code = 'GENE_SYMBOLS'),\\012\\011\\011\\011false,\\012\\011\\011\\011(select id from persons where user_id ='system'),\\012\\011\\011\\011(select max(ordinal)+1 from material_type_property_types \\012\\011\\011\\011\\011where maty_id = (select id from material_types where code = 'GENE'))\\012\\011\\011);\\012\\012\\011--------------------------------------------------\\012\\011-- create temporary table with all gene migration information\\012\\011--------------------------------------------------\\012\\012\\011create temp table genes \\012\\011(\\012\\011\\011id tech_id,\\012\\011\\011code code,\\012\\011\\011library_id generic_value,\\012\\011\\011gene_codes generic_value,\\012\\011\\011new_id tech_id,\\012\\011\\011library_tech_id tech_id\\011\\011\\012\\011);\\012\\011\\012\\011insert into genes (id, code, library_id, library_tech_id)\\012\\011\\011(select m.id, m.code, mp.value as library_id, mp.id as library_tech_id from materials m, material_properties mp, material_type_property_types mtpt, property_types pt, material_types mt\\012\\011\\011where mp.mate_id = m.id and  mp.mtpt_id = mtpt.id and pt.id = mtpt.prty_id and pt.code = 'LIBRARY_ID' and mt.id = m.maty_id and mt.id = mtpt.maty_id and mt.code = 'GENE');\\012\\011\\012\\011update genes set new_id = map.to_id from (select g_from.id as from_id, min(g_to.id) as to_id  from genes g_from, genes g_to where g_from.library_id = g_to.library_id group by g_from.id) as map where map.from_id = id;\\011\\012\\011\\012\\011update genes set gene_codes = map.gene_codes from (select g_from.library_id as lib_id, merge_words(distinct g_to.code) as gene_codes from genes g_from, genes g_to where g_from.library_id = g_to.library_id group by g_from.library_id) as map where map.lib_id = library_id;\\011\\012\\012\\011--------------------------------------------------\\012\\011-- update gene references\\012\\011--------------------------------------------------\\012\\012\\011update EXPERIMENTS set MATE_ID_STUDY_OBJECT = genes.new_id from genes where genes.id = MATE_ID_STUDY_OBJECT and not genes.id = genes.new_id;\\012\\011update EXPERIMENT_PROPERTIES set  MATE_PROP_ID = genes.new_id from genes where genes.id = MATE_PROP_ID and not genes.id = genes.new_id;\\012\\011update MATERIAL_PROPERTIES set  MATE_PROP_ID = genes.new_id from genes where genes.id = MATE_PROP_ID and not genes.id = genes.new_id;\\012\\011update SAMPLE_PROPERTIES set  MATE_PROP_ID = genes.new_id from genes where genes.id = MATE_PROP_ID and not genes.id = genes.new_id;\\012\\011update DATA_SET_PROPERTIES set  MATE_PROP_ID = genes.new_id from genes where genes.id = MATE_PROP_ID and not genes.id = genes.new_id;\\012\\011\\012\\011delete from  material_properties where mate_id in (select id from genes where not genes.id = genes.new_id);\\012\\011delete from MATERIALS where id in (select id from genes where not genes.id = genes.new_id);\\012\\012\\011delete from genes where id in (select id from genes where not genes.id = genes.new_id);\\012\\012\\012\\011--------------------------------------------------\\012\\011-- replace gene code with library_id\\012\\011--------------------------------------------------\\012\\011\\012\\011update materials set code = genes.library_id from genes where materials.id = genes.id ;\\012\\011delete from material_properties where id in (select library_tech_id from genes);\\012\\011\\012\\011--------------------------------------------------\\012\\011-- create a gene symbols property for each gene\\012\\011--------------------------------------------------\\012\\011\\012\\011insert into material_properties\\012\\011\\011(id\\012\\011  , mate_id\\012\\011  , mtpt_id\\012\\011  , "value"\\012\\011  , pers_id_registerer)\\012\\011\\011(select nextval('material_property_id_seq') id\\012\\011  \\011, genes.id  mate_id\\012\\011    , (select mtpt.id\\012\\011    \\011\\011from   material_type_property_types mtpt, material_types mt, property_types pt\\012\\011    \\011\\011where  pt.code = 'GENE_SYMBOLS' and mt.code = 'GENE' and mtpt.prty_id = pt.id\\012\\011        \\011and mtpt.maty_id = mt.id) mtpt_id\\012\\011    , genes.gene_codes "value"\\012\\011    , (select id from persons where user_id = 'system') pers_id_registerer\\012\\011 \\011from genes); \\012\\012\\011--------------------------------------------------\\012\\011-- delete temporary table\\012\\011--------------------------------------------------\\012\\011\\012\\011drop table genes;\\012\\011\\012\\011delete from material_type_property_types where id = \\012\\011\\011(select mtpt.id from material_type_property_types mtpt, material_types mt, property_types pt \\012\\011\\011\\011where pt.id = mtpt.prty_id and mtpt.maty_id = mt.id \\012\\011\\011\\011and pt.code = 'LIBRARY_ID' and mt.code = 'GENE');\\012\\011\\012END;\\012$$ LANGUAGE 'plpgsql';\\012\\012select REPLACE_GENE_SYMBOL_BY_GENE_ID();\\012drop function REPLACE_GENE_SYMBOL_BY_GENE_ID();\\012DROP AGGREGATE merge_words(text);\\012drop function merge_words(text,text);\\012\\012\\012--------------------------------------------------------------------------------------\\012--------------------------------------------------------------------------------------\\012\\012UPDATE sample_types SET code = 'SIRNA_WELL' WHERE code = 'OLIGO_WELL';\\012UPDATE material_types SET code = 'SIRNA' WHERE code = 'OLIGO';\\012UPDATE property_types SET code = 'SIRNA', label = 'siRNA' WHERE code = 'OLIGO';\\012\\012\\012\\012\\012\\012\\012\\012\\012\\012\\012\\012\\012\\012\\012\\012\\012\\012\\012\\012	\N
+./sourceTest/sql/postgresql/056/schema-056.sql:    LANGUAGE plpgsql
+./sourceTest/sql/postgresql/056/schema-056.sql:    LANGUAGE plpgsql
+./sourceTest/sql/postgresql/056/schema-056.sql:    LANGUAGE plpgsql
+./sourceTest/sql/postgresql/056/schema-056.sql:    LANGUAGE plpgsql
+./sourceTest/sql/postgresql/056/schema-056.sql:    LANGUAGE plpgsql
+./sourceTest/sql/postgresql/056/schema-056.sql:    LANGUAGE plpgsql
+./sourceTest/sql/postgresql/056/schema-056.sql:    LANGUAGE plpgsql
+./sourceTest/sql/postgresql/056/schema-056.sql:    LANGUAGE plpgsql
+./sourceTest/sql/postgresql/056/schema-056.sql:    LANGUAGE plpgsql
+./sourceTest/sql/postgresql/057/.svn/text-base/017=database_version_logs.tsv.svn-base:027	D:\\User\\felmer\\dev-workspace\\openbis/source/sql/postgresql/027/function-027.sql	SUCCESS	2008-11-05 09:18:00.403	-- Creating Functions\\012\\012------------------------------------------------------------------------------------\\012--  Purpose:  Create function RENAME_SEQUENCE() that is required for renaming the sequences belonging to tables\\012------------------------------------------------------------------------------------\\012CREATE FUNCTION RENAME_SEQUENCE(OLD_NAME VARCHAR, NEW_NAME VARCHAR) RETURNS INTEGER AS $$\\012DECLARE\\012  CURR_SEQ_VAL   INTEGER;\\012BEGIN\\012  SELECT INTO CURR_SEQ_VAL NEXTVAL(OLD_NAME);\\012  EXECUTE 'CREATE SEQUENCE ' || NEW_NAME || ' START WITH ' || CURR_SEQ_VAL;\\012  EXECUTE 'DROP SEQUENCE ' || OLD_NAME;\\012  RETURN CURR_SEQ_VAL;\\012END;\\012$$ LANGUAGE 'plpgsql';\\012\\012\\012------------------------------------------------------------------------------------\\012--  Purpose:  Create trigger CONTROLLED_VOCABULARY_CHECK \\012------------------------------------------------------------------------------------\\012\\012CREATE OR REPLACE FUNCTION CONTROLLED_VOCABULARY_CHECK() RETURNS trigger AS $$\\012DECLARE\\012   v_code  CODE;\\012BEGIN\\012\\012   select code into v_code from data_types where id = NEW.daty_id;\\012\\012   -- Check if the data is of type "CONTROLLEDVOCABULARY"\\012   if v_code = 'CONTROLLEDVOCABULARY' then\\012      if NEW.covo_id IS NULL then\\012         RAISE EXCEPTION 'Insert/Update of Property Type (Code: %) failed, as its Data Type is CONTROLLEDVOCABULARY, but it is not linked to a Controlled Vocabulary.', NEW.code;\\012      end if;\\012   end if;\\012\\012   RETURN NEW;\\012\\012END;\\012$$ LANGUAGE 'plpgsql';\\012\\012CREATE TRIGGER CONTROLLED_VOCABULARY_CHECK BEFORE INSERT OR UPDATE ON PROPERTY_TYPES\\012    FOR EACH ROW EXECUTE PROCEDURE CONTROLLED_VOCABULARY_CHECK();\\012\\012\\012------------------------------------------------------------------------------------\\012--  Purpose:  Create trigger EXTERNAL_DATA_STORAGE_FORMAT_CHECK \\012------------------------------------------------------------------------------------\\012\\012CREATE OR REPLACE FUNCTION EXTERNAL_DATA_STORAGE_FORMAT_CHECK() RETURNS trigger AS $$\\012DECLARE\\012   v_covo_code  CODE;\\012   data_code CODE;\\012BEGIN\\012\\012   select code into v_covo_code from controlled_vocabularies\\012      where is_internal_namespace = true and \\012         id = (select covo_id from controlled_vocabulary_terms where id = NEW.cvte_id_stor_fmt);\\012   -- Check if the data storage format is a term of the controlled vocabulary "STORAGE_FORMAT"\\012   if v_covo_code != 'STORAGE_FORMAT' then\\012      select code into data_code from data where id = NEW.data_id; \\012      RAISE EXCEPTION 'Insert/Update of Data (Code: %) failed, as its Storage Format is %, but is required to be STORAGE_FORMAT.', data_code, v_covo_code;\\012   end if;\\012\\012   RETURN NEW;\\012\\012END;\\012$$ LANGUAGE 'plpgsql';\\012\\012CREATE TRIGGER EXTERNAL_DATA_STORAGE_FORMAT_CHECK BEFORE INSERT OR UPDATE ON EXTERNAL_DATA\\012    FOR EACH ROW EXECUTE PROCEDURE EXTERNAL_DATA_STORAGE_FORMAT_CHECK();\\012\\012------------------------------------------------------------------------------------\\012--  Purpose:  Create trigger SAMPLE_CODE_UNIQUENESS_CHECK \\012------------------------------------------------------------------------------------\\012\\012CREATE OR REPLACE FUNCTION SAMPLE_CODE_UNIQUENESS_CHECK() RETURNS trigger AS $$\\012DECLARE\\012   counter  INTEGER;\\012BEGIN\\012\\011IF (NEW.samp_id_part_of is NULL) THEN\\012\\011\\011IF (NEW.dbin_id is not NULL) THEN\\012\\011\\011\\011SELECT count(*) into counter FROM samples \\012\\011\\011\\011\\011where id != NEW.id and code = NEW.code and samp_id_part_of is NULL and dbin_id = NEW.dbin_id;\\012\\011\\011\\011IF (counter > 0) THEN\\012\\011\\011\\011\\011RAISE EXCEPTION 'Insert/Update of Sample (Code: %) failed because database instance sample with the same code already exists.', NEW.code;\\012\\011\\011\\011END IF;\\012\\011\\011ELSIF (NEW.grou_id is not NULL) THEN\\012\\011\\011\\011SELECT count(*) into counter FROM samples \\012\\011\\011\\011\\011where id != NEW.id and code = NEW.code and samp_id_part_of is NULL and grou_id = NEW.grou_id;\\012\\011\\011\\011IF (counter > 0) THEN\\012\\011\\011\\011\\011RAISE EXCEPTION 'Insert/Update of Sample (Code: %) failed because group sample with the same code already exists.', NEW.code;\\012\\011\\011\\011END IF;\\012\\011\\011END IF;\\012        ELSE\\012\\011\\011IF (NEW.dbin_id is not NULL) THEN\\012\\011\\011\\011SELECT count(*) into counter FROM samples \\012\\011\\011\\011\\011where id != NEW.id and code = NEW.code and samp_id_part_of = NEW.samp_id_part_of and dbin_id = NEW.dbin_id;\\012\\011\\011\\011IF (counter > 0) THEN\\012\\011\\011\\011\\011RAISE EXCEPTION 'Insert/Update of Sample (Code: %) failed because database instance sample with the same code and being the part of the same parent already exists.', NEW.code;\\012\\011\\011\\011END IF;\\012\\011\\011ELSIF (NEW.grou_id is not NULL) THEN\\012\\011\\011\\011SELECT count(*) into counter FROM samples \\012\\011\\011\\011\\011where id != NEW.id and code = NEW.code and samp_id_part_of = NEW.samp_id_part_of and grou_id = NEW.grou_id;\\012\\011\\011\\011IF (counter > 0) THEN\\012\\011\\011\\011\\011RAISE EXCEPTION 'Insert/Update of Sample (Code: %) failed because group sample with the same code and being the part of the same parent already exists.', NEW.code;\\012\\011\\011\\011END IF;\\012\\011\\011END IF;\\012        END IF;   \\012   RETURN NEW;\\012END;\\012$$ LANGUAGE 'plpgsql';\\012\\012CREATE TRIGGER SAMPLE_CODE_UNIQUENESS_CHECK BEFORE INSERT OR UPDATE ON SAMPLES\\012    FOR EACH ROW EXECUTE PROCEDURE SAMPLE_CODE_UNIQUENESS_CHECK();\\012	\N
+./sourceTest/sql/postgresql/057/.svn/text-base/017=database_version_logs.tsv.svn-base:028	source/sql/postgresql/migration/migration-027-028.sql	SUCCESS	2008-11-18 13:24:17.508	-- Create EXPERIMENT_ATTACHMENT_CONTENTS.\\012CREATE TABLE EXPERIMENT_ATTACHMENT_CONTENTS (ID TECH_ID NOT NULL,VALUE FILE NOT NULL);\\012CREATE SEQUENCE EXPERIMENT_ATTACHMENT_CONTENT_ID_SEQ;\\012ALTER TABLE EXPERIMENT_ATTACHMENT_CONTENTS ADD CONSTRAINT EXAC_PK PRIMARY KEY(ID);\\012\\012-- Alter EXPERIMENT_ATTACHMENTS by adding the new column which has a NULL constraint.\\012-- The NOT NULL constraint is added later on.\\012ALTER TABLE EXPERIMENT_ATTACHMENTS ADD COLUMN EXAC_ID TECH_ID;\\012\\012-- Does the VALUE migration between EXPERIMENT_ATTACHMENTS to EXPERIMENT_ATTACHMENT_CONTENTS.\\012CREATE OR REPLACE FUNCTION move_exp_att_content() RETURNS integer AS $$\\012DECLARE\\012    rec RECORD;\\012    seq BIGINT;\\012BEGIN\\012  FOR rec IN SELECT id, value FROM EXPERIMENT_ATTACHMENTS LOOP\\012  \\011seq := nextval('EXPERIMENT_ATTACHMENT_CONTENT_ID_SEQ');\\012    INSERT INTO EXPERIMENT_ATTACHMENT_CONTENTS (id, value) VALUES (seq, rec.value);\\012    UPDATE EXPERIMENT_ATTACHMENTS SET exac_id = seq WHERE id = rec.id;\\012  END LOOP;\\012  RETURN 1;\\012END;\\012$$ LANGUAGE 'plpgsql';\\012\\012-- Call the function.\\012SELECT move_exp_att_content();\\012DROP FUNCTION move_exp_att_content();\\012\\012\\012-- Finish EXPERIMENT_ATTACHMENTS changes.\\012ALTER TABLE EXPERIMENT_ATTACHMENTS ADD CONSTRAINT EXAT_CONT_FK FOREIGN KEY (EXAC_ID) REFERENCES EXPERIMENT_ATTACHMENT_CONTENTS(ID);\\012ALTER TABLE EXPERIMENT_ATTACHMENTS DROP COLUMN VALUE;\\012ALTER TABLE EXPERIMENT_ATTACHMENTS ALTER COLUMN EXAC_ID SET NOT NULL;\\012	\N
+./sourceTest/sql/postgresql/057/.svn/text-base/017=database_version_logs.tsv.svn-base:029	source/sql/postgresql/migration/migration-028-029.sql	SUCCESS	2009-03-18 10:50:20.105	-- -------\\012-- add modification_timestamp field to allow edition with Hibernate\\012-- -------\\012\\012ALTER TABLE samples\\012\\011ADD COLUMN modification_timestamp TIME_STAMP DEFAULT CURRENT_TIMESTAMP;\\012\\012ALTER TABLE experiments\\012\\011ADD COLUMN modification_timestamp TIME_STAMP DEFAULT CURRENT_TIMESTAMP;\\012\\012ALTER TABLE materials\\012\\011ADD COLUMN modification_timestamp TIME_STAMP DEFAULT CURRENT_TIMESTAMP;\\012\\012ALTER TABLE experiment_properties\\012\\011ADD COLUMN modification_timestamp TIME_STAMP DEFAULT CURRENT_TIMESTAMP;\\012\\012ALTER TABLE material_properties\\012\\011ADD COLUMN modification_timestamp TIME_STAMP DEFAULT CURRENT_TIMESTAMP;\\012\\012ALTER TABLE sample_properties\\012\\011ADD COLUMN modification_timestamp TIME_STAMP DEFAULT CURRENT_TIMESTAMP;\\012\\012-- -------\\012-- add property data type which references materials\\012-- -------\\012\\012ALTER TABLE property_types\\012\\011ADD COLUMN maty_prop_id tech_id;\\012\\012ALTER TABLE property_types\\012\\011ADD CONSTRAINT prty_maty_fk FOREIGN KEY (maty_prop_id) REFERENCES material_types(id);\\012\\012ALTER TABLE experiment_properties\\012\\011ADD COLUMN mate_prop_id tech_id;\\012\\012ALTER TABLE material_properties\\012\\011ADD COLUMN mate_prop_id tech_id;\\012\\012ALTER TABLE sample_properties\\012\\011ADD COLUMN mate_prop_id tech_id;\\012\\012ALTER TABLE experiment_properties\\012\\011ADD CONSTRAINT expr_mapr_fk FOREIGN KEY (mate_prop_id) REFERENCES materials(id);\\012\\012ALTER TABLE material_properties\\012\\011ADD CONSTRAINT mapr_mapr_fk FOREIGN KEY (mate_prop_id) REFERENCES materials(id);\\012\\012ALTER TABLE sample_properties\\012\\011ADD CONSTRAINT sapr_mapr_fk FOREIGN KEY (mate_prop_id) REFERENCES materials(id);\\012\\012insert into data_types\\012(id\\012 ,code\\012 ,description)\\012 values \\012 (nextval('DATA_TYPE_ID_SEQ')\\012 ,'MATERIAL'\\012 ,'Reference to a material'\\012);\\012\\012ALTER TABLE MATERIAL_PROPERTIES DROP CONSTRAINT MAPR_CK;\\012ALTER TABLE MATERIAL_PROPERTIES ADD CONSTRAINT MAPR_CK CHECK \\012\\011((VALUE IS NOT NULL AND CVTE_ID IS NULL AND MATE_PROP_ID IS NULL) OR \\012\\011 (VALUE IS NULL AND CVTE_ID IS NOT NULL AND MATE_PROP_ID IS NULL) OR\\012\\011 (VALUE IS NULL AND CVTE_ID IS NULL AND MATE_PROP_ID IS NOT NULL)\\012\\011);\\012\\012ALTER TABLE EXPERIMENT_PROPERTIES DROP CONSTRAINT EXPR_CK;\\012ALTER TABLE EXPERIMENT_PROPERTIES ADD CONSTRAINT EXPR_CK CHECK \\012\\011((VALUE IS NOT NULL AND CVTE_ID IS NULL AND MATE_PROP_ID IS NULL) OR \\012\\011 (VALUE IS NULL AND CVTE_ID IS NOT NULL AND MATE_PROP_ID IS NULL) OR\\012\\011 (VALUE IS NULL AND CVTE_ID IS NULL AND MATE_PROP_ID IS NOT NULL)\\012\\011);\\012\\012ALTER TABLE SAMPLE_PROPERTIES DROP CONSTRAINT SAPR_CK;\\012ALTER TABLE SAMPLE_PROPERTIES ADD CONSTRAINT SAPR_CK CHECK \\012\\011((VALUE IS NOT NULL AND CVTE_ID IS NULL AND MATE_PROP_ID IS NULL) OR \\012\\011 (VALUE IS NULL AND CVTE_ID IS NOT NULL AND MATE_PROP_ID IS NULL) OR\\012\\011 (VALUE IS NULL AND CVTE_ID IS NULL AND MATE_PROP_ID IS NOT NULL)\\012\\011);\\012\\012------------------------------------------------------------------------------------\\012--  Purpose:  Create trigger MATERIAL/SAMPLE/EXPERIMENT _PROPERTY_WITH_MATERIAL_DATA_TYPE_CHECK\\012--            It checks that if material property value is assigned to the entity,\\012--\\011\\011\\011\\011\\011\\011then the material type is equal to the one described by property type.\\012------------------------------------------------------------------------------------\\012\\012CREATE OR REPLACE FUNCTION MATERIAL_PROPERTY_WITH_MATERIAL_DATA_TYPE_CHECK() RETURNS trigger AS $$\\012DECLARE\\012   v_type_id  CODE;\\012   v_type_id_prop  CODE;\\012BEGIN\\012   if NEW.mate_prop_id IS NOT NULL then\\012\\011\\011\\011-- find material type id of the property type \\012\\011\\011\\011select pt.maty_prop_id into v_type_id_prop \\012\\011\\011\\011  from material_type_property_types etpt, property_types pt \\012\\011\\011\\011 where NEW.mtpt_id = etpt.id AND etpt.prty_id = pt.id;\\012\\011\\011\\012\\011\\011\\011if v_type_id_prop IS NOT NULL then\\012\\011\\011\\011\\011-- find material type id of the material which consists the entity's property value\\012\\011\\011\\011\\011select entity.maty_id into v_type_id \\012\\011\\011\\011\\011  from materials entity\\012\\011\\011\\011\\011 where NEW.mate_prop_id = entity.id;\\012\\011\\011\\011\\011if v_type_id != v_type_id_prop then\\012\\011\\011\\011\\011\\011RAISE EXCEPTION 'Insert/Update of property value referencing material (id: %) failed, as referenced material type is different than expected (id %, expected id: %).', \\012\\011\\011\\011\\011\\011\\011\\011 NEW.mate_prop_id, v_type_id, v_type_id_prop;\\012\\011\\011\\011\\011end if;\\012\\011\\011\\011end if;\\012   end if;\\012   RETURN NEW;\\012END;\\012$$ LANGUAGE 'plpgsql';\\012\\012CREATE TRIGGER MATERIAL_PROPERTY_WITH_MATERIAL_DATA_TYPE_CHECK BEFORE INSERT OR UPDATE ON material_properties\\012    FOR EACH ROW EXECUTE PROCEDURE MATERIAL_PROPERTY_WITH_MATERIAL_DATA_TYPE_CHECK();\\012    \\012CREATE OR REPLACE FUNCTION SAMPLE_PROPERTY_WITH_MATERIAL_DATA_TYPE_CHECK() RETURNS trigger AS $$\\012DECLARE\\012   v_type_id  CODE;\\012   v_type_id_prop  CODE;\\012BEGIN\\012   if NEW.mate_prop_id IS NOT NULL then\\012\\011\\011\\011-- find material type id of the property type \\012\\011\\011\\011select pt.maty_prop_id into v_type_id_prop \\012\\011\\011\\011  from sample_type_property_types etpt, property_types pt \\012\\011\\011\\011 where NEW.stpt_id = etpt.id AND etpt.prty_id = pt.id;\\012\\011\\011\\012\\011\\011\\011if v_type_id_prop IS NOT NULL then\\012\\011\\011\\011\\011-- find material type id of the material which consists the entity's property value\\012\\011\\011\\011\\011select entity.maty_id into v_type_id \\012\\011\\011\\011\\011  from materials entity\\012\\011\\011\\011\\011 where NEW.mate_prop_id = entity.id;\\012\\011\\011\\011\\011if v_type_id != v_type_id_prop then\\012\\011\\011\\011\\011\\011RAISE EXCEPTION 'Insert/Update of property value referencing material (id: %) failed, as referenced material type is different than expected (id %, expected id: %).', \\012\\011\\011\\011\\011\\011\\011\\011\\011\\011\\011\\011\\011 NEW.mate_prop_id, v_type_id, v_type_id_prop;\\012\\011\\011\\011\\011end if;\\012\\011\\011\\011end if;\\012   end if;\\012   RETURN NEW;\\012END;\\012$$ LANGUAGE 'plpgsql';\\012\\012CREATE TRIGGER SAMPLE_PROPERTY_WITH_MATERIAL_DATA_TYPE_CHECK BEFORE INSERT OR UPDATE ON sample_properties\\012    FOR EACH ROW EXECUTE PROCEDURE SAMPLE_PROPERTY_WITH_MATERIAL_DATA_TYPE_CHECK();\\012    \\012CREATE OR REPLACE FUNCTION EXPERIMENT_PROPERTY_WITH_MATERIAL_DATA_TYPE_CHECK() RETURNS trigger AS $$\\012DECLARE\\012   v_type_id  CODE;\\012   v_type_id_prop  CODE;\\012BEGIN\\012   if NEW.mate_prop_id IS NOT NULL then\\012\\011\\011\\011-- find material type id of the property type \\012\\011\\011\\011select pt.maty_prop_id into v_type_id_prop \\012\\011\\011\\011  from experiment_type_property_types etpt, property_types pt \\012\\011\\011\\011 where NEW.etpt_id = etpt.id AND etpt.prty_id = pt.id;\\012\\011\\011\\012\\011\\011\\011if v_type_id_prop IS NOT NULL then\\012\\011\\011\\011\\011-- find material type id of the material which consists the entity's property value\\012\\011\\011\\011\\011select entity.maty_id into v_type_id \\012\\011\\011\\011\\011  from materials entity\\012\\011\\011\\011\\011 where NEW.mate_prop_id = entity.id;\\012\\011\\011\\011\\011if v_type_id != v_type_id_prop then\\012\\011\\011\\011\\011\\011RAISE EXCEPTION 'Insert/Update of property value referencing material (id: %) failed, as referenced material type is different than expected (id %, expected id: %).', \\012\\011\\011\\011\\011\\011\\011\\011\\011\\011\\011\\011\\011 NEW.mate_prop_id, v_type_id, v_type_id_prop;\\012\\011\\011\\011\\011end if;\\012\\011\\011\\011end if;\\012   end if;\\012   RETURN NEW;\\012END;\\012$$ LANGUAGE 'plpgsql';\\012\\012CREATE TRIGGER EXPERIMENT_PROPERTY_WITH_MATERIAL_DATA_TYPE_CHECK BEFORE INSERT OR UPDATE ON experiment_properties\\012    FOR EACH ROW EXECUTE PROCEDURE EXPERIMENT_PROPERTY_WITH_MATERIAL_DATA_TYPE_CHECK();\\012       \\012-- -------\\012-- remove the reminescents of the OBSERVABLE_TYPE\\012-- -------\\012\\012ALTER TABLE data\\012\\011DROP CONSTRAINT data_obty_fk;\\012\\012ALTER TABLE data_set_types\\012\\011DROP CONSTRAINT obty_pk;\\012\\012ALTER TABLE data_set_types\\012\\011ADD CONSTRAINT dsty_pk PRIMARY KEY (id);\\012\\012ALTER TABLE data\\012\\011ADD CONSTRAINT data_dsty_fk FOREIGN KEY (dsty_id) REFERENCES data_set_types(id);\\012\\012ALTER TABLE data_set_types\\012\\011DROP CONSTRAINT obty_bk_uk;\\012\\012ALTER TABLE data_set_types\\012\\011DROP CONSTRAINT obty_dbin_fk;\\012\\012ALTER TABLE data_set_types\\012\\011ADD CONSTRAINT dsty_bk_uk UNIQUE (code, dbin_id);\\012\\012ALTER TABLE data_set_types\\012\\011ADD CONSTRAINT dsty_dbin_fk FOREIGN KEY (dbin_id) REFERENCES database_instances(id);\\012\\012DROP INDEX data_obty_fk_i;\\012\\012CREATE INDEX data_dsty_fk_i ON data(dsty_id);\\012	\N
+./sourceTest/sql/postgresql/057/.svn/text-base/017=database_version_logs.tsv.svn-base:030	source/sql/postgresql/migration/migration-029-030.sql	SUCCESS	2009-03-23 15:34:44.72	-- -------\\012-- add modification_timestamp field to allow edition with Hibernate\\012-- -------\\012ALTER TABLE data\\012\\011ADD COLUMN modification_timestamp TIME_STAMP DEFAULT CURRENT_TIMESTAMP;\\012ALTER TABLE experiment_types\\012\\011ADD COLUMN modification_timestamp TIME_STAMP DEFAULT CURRENT_TIMESTAMP;\\012ALTER TABLE sample_types\\012\\011ADD COLUMN modification_timestamp TIME_STAMP DEFAULT CURRENT_TIMESTAMP;\\012ALTER TABLE material_types\\012\\011ADD COLUMN modification_timestamp TIME_STAMP DEFAULT CURRENT_TIMESTAMP;\\012ALTER TABLE data_set_types\\012\\011ADD COLUMN modification_timestamp TIME_STAMP DEFAULT CURRENT_TIMESTAMP;\\012ALTER TABLE controlled_vocabularies\\012\\011ADD COLUMN modification_timestamp TIME_STAMP DEFAULT CURRENT_TIMESTAMP;\\012-- -------\\012-- add properties to data sets\\012-- -------\\012CREATE TABLE DATA_SET_PROPERTIES (ID TECH_ID NOT NULL,DS_ID TECH_ID NOT NULL,DSTPT_ID TECH_ID NOT NULL,VALUE GENERIC_VALUE,CVTE_ID TECH_ID, MATE_PROP_ID TECH_ID, PERS_ID_REGISTERER TECH_ID NOT NULL,REGISTRATION_TIMESTAMP TIME_STAMP_DFL NOT NULL DEFAULT CURRENT_TIMESTAMP, MODIFICATION_TIMESTAMP TIME_STAMP DEFAULT CURRENT_TIMESTAMP);\\012CREATE TABLE DATA_SET_TYPE_PROPERTY_TYPES (ID TECH_ID NOT NULL,DSTY_ID TECH_ID NOT NULL,PRTY_ID TECH_ID NOT NULL,IS_MANDATORY BOOLEAN_CHAR NOT NULL DEFAULT 'F',IS_MANAGED_INTERNALLY BOOLEAN_CHAR NOT NULL DEFAULT 'F',PERS_ID_REGISTERER TECH_ID NOT NULL,REGISTRATION_TIMESTAMP TIME_STAMP_DFL NOT NULL DEFAULT CURRENT_TIMESTAMP);\\012\\012CREATE SEQUENCE DATA_SET_PROPERTY_ID_SEQ;\\012CREATE SEQUENCE DSTPT_ID_SEQ;\\012\\012ALTER TABLE DATA_SET_TYPE_PROPERTY_TYPES ADD CONSTRAINT DSTPT_PK PRIMARY KEY(ID);\\012ALTER TABLE DATA_SET_PROPERTIES ADD CONSTRAINT DSPR_PK PRIMARY KEY(ID);\\012\\012ALTER TABLE DATA_SET_TYPE_PROPERTY_TYPES ADD CONSTRAINT DSTPT_BK_UK UNIQUE(DSTY_ID,PRTY_ID);\\012ALTER TABLE DATA_SET_PROPERTIES ADD CONSTRAINT DSPR_BK_UK UNIQUE(DS_ID,DSTPT_ID);\\012\\012\\012ALTER TABLE DATA_SET_TYPE_PROPERTY_TYPES ADD CONSTRAINT DSTPT_DSTY_FK FOREIGN KEY (DSTY_ID) REFERENCES DATA_SET_TYPES(ID);\\012ALTER TABLE DATA_SET_TYPE_PROPERTY_TYPES ADD CONSTRAINT DSTPT_PERS_FK FOREIGN KEY (PERS_ID_REGISTERER) REFERENCES PERSONS(ID);\\012ALTER TABLE DATA_SET_TYPE_PROPERTY_TYPES ADD CONSTRAINT DSTPT_PRTY_FK FOREIGN KEY (PRTY_ID) REFERENCES PROPERTY_TYPES(ID);\\012ALTER TABLE DATA_SET_PROPERTIES ADD CONSTRAINT DSPR_CVTE_FK FOREIGN KEY (CVTE_ID) REFERENCES CONTROLLED_VOCABULARY_TERMS(ID);\\012ALTER TABLE DATA_SET_PROPERTIES ADD CONSTRAINT DSPR_DSTPT_FK FOREIGN KEY (DSTPT_ID) REFERENCES DATA_SET_TYPE_PROPERTY_TYPES(ID) ON DELETE CASCADE;\\012ALTER TABLE DATA_SET_PROPERTIES ADD CONSTRAINT DSPR_DS_FK FOREIGN KEY (DS_ID) REFERENCES DATA(ID);\\012ALTER TABLE DATA_SET_PROPERTIES ADD CONSTRAINT DSPR_PERS_FK FOREIGN KEY (PERS_ID_REGISTERER) REFERENCES PERSONS(ID);\\012ALTER TABLE DATA_SET_PROPERTIES ADD CONSTRAINT DSPR_MAPR_FK FOREIGN KEY (MATE_PROP_ID) REFERENCES MATERIALS(ID);\\012\\012ALTER TABLE DATA_SET_PROPERTIES ADD CONSTRAINT DSPR_CK CHECK \\012\\011((VALUE IS NOT NULL AND CVTE_ID IS NULL AND MATE_PROP_ID IS NULL) OR \\012\\011 (VALUE IS NULL AND CVTE_ID IS NOT NULL AND MATE_PROP_ID IS NULL) OR\\012\\011 (VALUE IS NULL AND CVTE_ID IS NULL AND MATE_PROP_ID IS NOT NULL)\\012\\011);\\012\\012CREATE INDEX DSPR_CVTE_FK_I ON DATA_SET_PROPERTIES (CVTE_ID);\\012CREATE INDEX DSPR_DSTPT_FK_I ON DATA_SET_PROPERTIES (DSTPT_ID);\\012CREATE INDEX DSPR_DS_FK_I ON DATA_SET_PROPERTIES (DS_ID);\\012CREATE INDEX DSPR_PERS_FK_I ON DATA_SET_PROPERTIES (PERS_ID_REGISTERER);\\012CREATE INDEX DSTPT_DSTY_FK_I ON DATA_SET_TYPE_PROPERTY_TYPES (DSTY_ID);\\012CREATE INDEX DSTPT_PERS_FK_I ON DATA_SET_TYPE_PROPERTY_TYPES (PERS_ID_REGISTERER);\\012CREATE INDEX DSTPT_PRTY_FK_I ON DATA_SET_TYPE_PROPERTY_TYPES (PRTY_ID);\\012\\012CREATE OR REPLACE FUNCTION DATA_SET_PROPERTY_WITH_MATERIAL_DATA_TYPE_CHECK() RETURNS trigger AS $$\\012DECLARE\\012   v_type_id  CODE;\\012   v_type_id_prop  CODE;\\012BEGIN\\012   if NEW.mate_prop_id IS NOT NULL then\\012\\011\\011\\011-- find material type id of the property type \\012\\011\\011\\011select pt.maty_prop_id into v_type_id_prop \\012\\011\\011\\011  from data_set_type_property_types dstpt, property_types pt \\012\\011\\011\\011 where NEW.dstpt_id = dstpt.id AND dstpt.prty_id = pt.id;\\012\\011\\011\\012\\011\\011\\011if v_type_id_prop IS NOT NULL then\\012\\011\\011\\011\\011-- find material type id of the material which consists the entity's property value\\012\\011\\011\\011\\011select entity.maty_id into v_type_id \\012\\011\\011\\011\\011  from materials entity\\012\\011\\011\\011\\011 where NEW.mate_prop_id = entity.id;\\012\\011\\011\\011\\011if v_type_id != v_type_id_prop then\\012\\011\\011\\011\\011\\011RAISE EXCEPTION 'Insert/Update of property value referencing material (id: %) failed, as referenced material type is different than expected (id %, expected id: %).', \\012\\011\\011\\011\\011\\011\\011\\011\\011\\011\\011\\011\\011 NEW.mate_prop_id, v_type_id, v_type_id_prop;\\012\\011\\011\\011\\011end if;\\012\\011\\011\\011end if;\\012   end if;\\012   RETURN NEW;\\012END;\\012$$ LANGUAGE 'plpgsql';\\012\\012CREATE TRIGGER DATA_SET_PROPERTY_WITH_MATERIAL_DATA_TYPE_CHECK BEFORE INSERT OR UPDATE ON data_set_properties\\012    FOR EACH ROW EXECUTE PROCEDURE DATA_SET_PROPERTY_WITH_MATERIAL_DATA_TYPE_CHECK();   \\012	\N
+./sourceTest/sql/postgresql/057/.svn/text-base/017=database_version_logs.tsv.svn-base:032	source/sql/postgresql/migration/migration-031-032.sql	SUCCESS	2009-04-09 09:36:36.2	-- -------\\012-- Modify MATERIAL_BATCHES\\012-- -------\\012\\012ALTER TABLE material_batches\\012    DROP COLUMN proc_id;\\012\\012-- -------\\012-- Modify SAMPLES\\012-- -------\\012\\012ALTER TABLE samples\\012    ADD COLUMN expe_id tech_id;\\012\\012ALTER TABLE samples\\012    ADD CONSTRAINT samp_expe_fk FOREIGN KEY (expe_id) REFERENCES experiments(id);\\012\\012CREATE INDEX samp_expe_fk_i ON samples USING btree (expe_id);\\012\\012-- relink samples directly to experiments\\012\\012UPDATE samples\\012SET expe_id = (SELECT e.id FROM experiments e, procedures p, sample_inputs si \\012               WHERE si.samp_id = samples.id AND si.proc_id = p.id AND p.expe_id = e.id AND e.inva_id IS NULL);\\012\\012\\012-- -------\\012-- Modify DATA\\012-- -------\\012\\012ALTER TABLE data\\012    ADD COLUMN expe_id tech_id;\\012\\012ALTER TABLE data\\012    ADD CONSTRAINT data_expe_fk FOREIGN KEY (expe_id) REFERENCES experiments(id);\\012\\012CREATE INDEX data_expe_fk_i ON data USING btree (expe_id);\\012\\012UPDATE data\\012SET expe_id = (SELECT e.id FROM experiments e, procedures p \\012               WHERE data.proc_id_produced_by = p.id AND p.expe_id = e.id);\\012\\012ALTER TABLE data\\012    ALTER COLUMN expe_id SET NOT NULL;\\012\\012ALTER TABLE data\\012    DROP COLUMN proc_id_produced_by;\\012\\012-- -------\\012-- Drop PROCEDURES, PROCEDURE_TYPES, and SAMPLE_INPUTS\\012-- -------\\012\\012DROP TABLE sample_inputs;\\012DROP TABLE procedures;\\012DROP TABLE procedure_types;\\012\\012DROP SEQUENCE procedure_id_seq;\\012DROP SEQUENCE procedure_type_id_seq;\\012\\012-- -------\\012-- Add CODE_SEQ\\012-- -------\\012\\012CREATE SEQUENCE CODE_SEQ;\\012\\012-- -------\\012-- Add new columns to DATA_STORES\\012-- -------\\012\\012ALTER TABLE data_stores\\012    ADD COLUMN remote_url character varying(250),\\012    ADD COLUMN session_token character varying(50),\\012    ADD COLUMN modification_timestamp time_stamp DEFAULT now();\\012\\012UPDATE data_stores\\012SET remote_url = '', session_token='';\\012\\012ALTER TABLE data_stores\\012    ALTER COLUMN remote_url SET NOT NULL,\\012    ALTER COLUMN session_token SET NOT NULL;\\012\\012-- -------\\012-- Drop foreign keys onto DATA_STORES\\012-- -------\\012\\012ALTER TABLE database_instances\\012    DROP COLUMN dast_id;\\012\\012ALTER TABLE groups\\012    DROP COLUMN dast_id;\\012\\012ALTER TABLE projects\\012    DROP COLUMN dast_id;\\012\\012ALTER TABLE experiments\\012    DROP COLUMN dast_id;\\012\\012-- -------\\012-- Add foreign key from DATA onto DATA_STORES\\012-- -------\\012\\012ALTER TABLE data\\012    ADD COLUMN dast_id tech_id;\\012\\012ALTER TABLE data\\012    ADD CONSTRAINT data_dast_fk FOREIGN KEY (dast_id) REFERENCES data_stores(id);\\012\\012UPDATE data\\012SET dast_id = (select id from data_stores where code = 'STANDARD');\\012\\012ALTER TABLE data\\012    ALTER COLUMN dast_id SET NOT NULL;\\012\\012\\012------------------------------------------------------------------------------------\\012--  Purpose:  Replace trigger SAMPLE_CODE_UNIQUENESS_CHECK \\012------------------------------------------------------------------------------------\\012\\012CREATE OR REPLACE FUNCTION SAMPLE_CODE_UNIQUENESS_CHECK() RETURNS trigger AS $$\\012DECLARE\\012   counter  INTEGER;\\012BEGIN\\012    LOCK TABLE samples IN EXCLUSIVE MODE;\\012    IF (NEW.samp_id_part_of is NULL) THEN\\012        IF (NEW.dbin_id is not NULL) THEN\\012            SELECT count(*) into counter FROM samples \\012                where id != NEW.id and code = NEW.code and samp_id_part_of is NULL and dbin_id = NEW.dbin_id;\\012            IF (counter > 0) THEN\\012                RAISE EXCEPTION 'Insert/Update of Sample (Code: %) failed because database instance sample with the same code already exists.', NEW.code;\\012            END IF;\\012        ELSIF (NEW.grou_id is not NULL) THEN\\012            SELECT count(*) into counter FROM samples \\012                where id != NEW.id and code = NEW.code and samp_id_part_of is NULL and grou_id = NEW.grou_id;\\012            IF (counter > 0) THEN\\012                RAISE EXCEPTION 'Insert/Update of Sample (Code: %) failed because group sample with the same code already exists.', NEW.code;\\012            END IF;\\012        END IF;\\012        ELSE\\012        IF (NEW.dbin_id is not NULL) THEN\\012            SELECT count(*) into counter FROM samples \\012                where id != NEW.id and code = NEW.code and samp_id_part_of = NEW.samp_id_part_of and dbin_id = NEW.dbin_id;\\012            IF (counter > 0) THEN\\012                RAISE EXCEPTION 'Insert/Update of Sample (Code: %) failed because database instance sample with the same code and being the part of the same parent already exists.', NEW.code;\\012            END IF;\\012        ELSIF (NEW.grou_id is not NULL) THEN\\012            SELECT count(*) into counter FROM samples \\012                where id != NEW.id and code = NEW.code and samp_id_part_of = NEW.samp_id_part_of and grou_id = NEW.grou_id;\\012            IF (counter > 0) THEN\\012                RAISE EXCEPTION 'Insert/Update of Sample (Code: %) failed because group sample with the same code and being the part of the same parent already exists.', NEW.code;\\012            END IF;\\012        END IF;\\012        END IF;   \\012   RETURN NEW;\\012END;\\012$$ LANGUAGE 'plpgsql';\\012\\012\\012\\012	\N
+./sourceTest/sql/postgresql/057/.svn/text-base/017=database_version_logs.tsv.svn-base:034	source/sql/postgresql/migration/migration-033-034.sql	SUCCESS	2009-05-26 08:32:49.935	------------------------------------------------------------------------------------\\012-- Create sequence for generating permanent identifiers starting with nextval of existing dataset sequence.\\012------------------------------------------------------------------------------------\\012CREATE FUNCTION CREATE_SEQUENCE(EXISTING_SEQUENCE VARCHAR, NEW_SEQUENCE VARCHAR) RETURNS VOID AS $$\\012DECLARE\\012  CURR_SEQ_VAL   INTEGER;\\012BEGIN\\012  SELECT INTO CURR_SEQ_VAL NEXTVAL(EXISTING_SEQUENCE);\\012  EXECUTE 'CREATE SEQUENCE ' || NEW_SEQUENCE || ' START WITH ' || CURR_SEQ_VAL;\\012  RETURN;\\012END;\\012$$ LANGUAGE 'plpgsql';\\012\\012SELECT CREATE_SEQUENCE('DATA_ID_SEQ', 'PERM_ID_SEQ');\\012DROP FUNCTION CREATE_SEQUENCE(VARCHAR, VARCHAR);\\012\\012------------------------------------------------------------------------------------\\012-- Add perm_id columns to samples and experiments.\\012------------------------------------------------------------------------------------\\012ALTER TABLE SAMPLES ADD COLUMN PERM_ID CODE;\\012ALTER TABLE EXPERIMENTS ADD COLUMN PERM_ID CODE;\\012\\012UPDATE SAMPLES SET PERM_ID = to_char(registration_timestamp,'YYYYMMDDHHSSMS') || '-' || NEXTVAL('PERM_ID_SEQ');\\012UPDATE EXPERIMENTS SET PERM_ID = to_char(registration_timestamp,'YYYYMMDDHHSSMS') || '-' || NEXTVAL('PERM_ID_SEQ');\\012ALTER TABLE SAMPLES ALTER COLUMN PERM_ID SET NOT NULL;\\012ALTER TABLE EXPERIMENTS ALTER COLUMN PERM_ID SET NOT NULL;\\012ALTER TABLE SAMPLES ADD CONSTRAINT SAMP_PI_UK UNIQUE(PERM_ID);\\012ALTER TABLE EXPERIMENTS ADD CONSTRAINT EXPE_PI_UK UNIQUE(PERM_ID);\\012\\012\\012------------------------------------------------------------------------------------\\012-- Add column is_chosen_from_list to controlled_vocabularies.\\012------------------------------------------------------------------------------------\\012ALTER TABLE controlled_vocabularies ADD COLUMN is_chosen_from_list BOOLEAN_CHAR NOT NULL DEFAULT TRUE;\\012ALTER TABLE controlled_vocabularies ADD COLUMN source_uri CHARACTER VARYING(250);\\012------------------------------------------------------------------------------------\\012-- Modify Data table - remove arc connection between Sample and Data table, use a flag instead\\012------------------------------------------------------------------------------------\\012\\012-- add new columns\\012\\012ALTER TABLE data\\012    ADD COLUMN is_derived boolean_char;\\012ALTER TABLE data\\012    ADD COLUMN samp_id tech_id;\\012\\012-- update values in new columns\\012\\012UPDATE data\\012    SET is_derived = (samp_id_derived_from IS NOT NULL); \\012UPDATE data\\012    SET samp_id = samp_id_derived_from \\012    WHERE is_derived = 'TRUE';\\012UPDATE data\\012    SET samp_id = samp_id_acquired_from \\012    WHERE is_derived = 'FALSE';\\012\\012-- add constraints and indexes to new columns\\012\\012ALTER TABLE data\\012    ALTER COLUMN is_derived SET NOT NULL;\\012ALTER TABLE data\\012    ALTER COLUMN samp_id SET NOT NULL;   \\012ALTER TABLE data\\012    ADD CONSTRAINT data_samp_fk FOREIGN KEY (samp_id) REFERENCES samples (id);\\012CREATE INDEX data_samp_fk_i ON data USING btree (samp_id);\\012\\012-- remove old columns\\012\\012ALTER TABLE data\\012    DROP COLUMN samp_id_acquired_from;\\012ALTER TABLE data\\012    DROP COLUMN samp_id_derived_from;\\012    \\012------------------------------------------------------------------------------------\\012-- Granting SELECT privilege to group openbis_readonly\\012------------------------------------------------------------------------------------\\012\\012GRANT SELECT ON SEQUENCE attachment_content_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE attachment_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE code_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE controlled_vocabulary_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE cvte_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE data_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE data_set_property_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE data_set_relationship_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE data_set_type_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE data_store_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE data_type_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE database_instance_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE dstpt_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE etpt_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE event_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE experiment_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE experiment_property_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE experiment_type_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE file_format_type_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE group_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE invalidation_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE locator_type_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE material_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE material_property_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE material_type_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE mtpt_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE perm_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE person_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE project_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE property_type_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE role_assignment_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE sample_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE sample_property_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE sample_type_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE stpt_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE attachment_contents TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE attachments TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE controlled_vocabularies TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE controlled_vocabulary_terms TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE data TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE data_set_properties TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE data_set_relationships TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE data_set_type_property_types TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE data_set_types TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE data_stores TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE data_types TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE database_instances TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE database_version_logs TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE events TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE experiment_properties TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE experiment_type_property_types TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE experiment_types TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE experiments TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE external_data TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE file_format_types TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE groups TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE invalidations TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE locator_types TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE material_properties TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE material_type_property_types TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE material_types TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE materials TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE persons TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE projects TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE property_types TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE role_assignments TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE sample_properties TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE sample_type_property_types TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE sample_types TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE samples TO GROUP OPENBIS_READONLY;\\012\\012------------------------------------------------------------------------------------\\012-- Delete MATERIAL_BATCHES table\\012------------------------------------------------------------------------------------\\012\\012-- WARNING: Potential data lost!!!\\012-- WARNING: Potential data lost!!!\\012-- WARNING: Potential data lost!!!\\012\\012DROP TABLE SAMPLE_MATERIAL_BATCHES;\\012DROP TABLE MATERIAL_BATCHES;\\012DROP SEQUENCE MATERIAL_BATCH_ID_SEQ;\\012\\012------------------------------------------------------------------------------------\\012-- Delete MATE_ID_INHIBITOR_OF from table MATERIALS\\012------------------------------------------------------------------------------------\\012\\012-- WARNING: Potential data lost!!!\\012-- WARNING: Potential data lost!!!\\012-- WARNING: Potential data lost!!!\\012\\012ALTER TABLE MATERIALS DROP COLUMN MATE_ID_INHIBITOR_OF;\\012	\N
+./sourceTest/sql/postgresql/057/.svn/text-base/017=database_version_logs.tsv.svn-base:041	source/sql/postgresql/migration/migration-040-041.sql	SUCCESS	2009-09-14 13:48:57.539	-- Create FILTERS table\\012\\012CREATE TABLE FILTERS (ID TECH_ID NOT NULL, DBIN_ID TECH_ID NOT NULL, NAME VARCHAR(200) NOT NULL, DESCRIPTION DESCRIPTION_1000,REGISTRATION_TIMESTAMP TIME_STAMP_DFL NOT NULL DEFAULT CURRENT_TIMESTAMP, PERS_ID_REGISTERER TECH_ID NOT NULL, MODIFICATION_TIMESTAMP TIME_STAMP DEFAULT CURRENT_TIMESTAMP, EXPRESSION VARCHAR(2000) NOT NULL, IS_PUBLIC BOOLEAN NOT NULL, GRID_ID VARCHAR(200) NOT NULL);\\012CREATE SEQUENCE FILTER_ID_SEQ;\\012ALTER TABLE FILTERS ADD CONSTRAINT FILT_PK PRIMARY KEY(ID);\\012ALTER TABLE FILTERS ADD CONSTRAINT FILT_BK_UK UNIQUE(NAME, DBIN_ID, GRID_ID);\\012ALTER TABLE FILTERS ADD CONSTRAINT FILT_PERS_FK FOREIGN KEY (PERS_ID_REGISTERER) REFERENCES PERSONS(ID);\\012ALTER TABLE FILTERS ADD CONSTRAINT FILT_DBIN_FK FOREIGN KEY (DBIN_ID) REFERENCES DATABASE_INSTANCES(ID);\\012CREATE INDEX FILT_PERS_FK_I ON FILTERS (PERS_ID_REGISTERER);\\012CREATE INDEX FILT_DBIN_FK_I ON FILTERS (DBIN_ID);\\012GRANT SELECT ON SEQUENCE filter_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE filters TO GROUP OPENBIS_READONLY;\\012\\012-- Add missing foreign key to role assignments authorization group\\012ALTER TABLE ROLE_ASSIGNMENTS ADD CONSTRAINT ROAS_AG_FK_GRANTEE FOREIGN KEY (AG_ID_GRANTEE) REFERENCES AUTHORIZATION_GROUPS(ID);\\012\\012--------------------------------------------------------------------------------------------------\\012-- Modify dataset connections:\\012-- 1. connection with sample shouldn't be mandatory any more\\012-- 2. introduce an arc condition that dataset cannot be connected with a sample and a parent dataset at the same time\\012--------------------------------------------------------------------------------------------------\\012\\012-- Weaken data-sample connection constraint - allow dataset to have no connection with sample\\012ALTER TABLE data ALTER COLUMN samp_id DROP NOT NULL;\\012\\012-- Remove data-sample connection for datasets that have a parent\\012\\012UPDATE data \\012   SET samp_id = NULL \\012 WHERE id IN (SELECT DISTINCT data_id_child FROM data_set_relationships);\\012\\012-- With PostgreSQL 8.4 one can check that before migration there were no cycles in dataset relationships:\\012--\\012-- WITH RECURSIVE data_set_parents(id, parent_ids, cycle) AS (\\012--         SELECT  r.data_id_child AS id, \\012--                 ARRAY[CAST (r.data_id_parent AS bigint)] AS parent_ids, \\012--                 false AS cycle \\012--         FROM data_set_relationships r\\012--     UNION ALL\\012--         SELECT  r.data_id_child,\\012--                 CAST (r.data_id_parent AS bigint) || p.parent_ids,\\012--                 r.data_id_child = ANY(p.parent_ids)\\012--         FROM data_set_relationships r, data_set_parents p\\012--         WHERE r.data_id_parent = p.id AND NOT cycle\\012-- )\\012-- SELECT count(*) AS cycles FROM data_set_parents WHERE cycle = true;\\012\\012---------------------------------------------------------------------------------------------------\\012--  Purpose:  Create DEFERRED triggers:\\012--            * check_dataset_relationships_on_data_table_modification,\\012--            * check_dataset_relationships_on_relationships_table_modification.\\012--            They check that after all modifications of database (just before commit) \\012--            if 'data'/'data_set_relationships' tables are among modified tables \\012--            dataset is not connected with a sample and a parent dataset at the same time.\\012--            This connections are held in two different tables so simple immediate trigger \\012--            with arc check cannot be used and we need two deferred triggers.\\012----------------------------------------------------------------------------------------------------\\012\\012-- trigger for 'data' table\\012\\012CREATE OR REPLACE FUNCTION check_dataset_relationships_on_data_table_modification() RETURNS trigger AS $$\\012DECLARE\\012\\011counter\\011INTEGER;\\012BEGIN\\012\\011-- if there is a connection with a Sample there should not be any connection with a parent Data Set\\012\\011IF (NEW.samp_id IS NOT NULL) THEN\\012\\011\\011-- count number of parents\\012\\011\\011SELECT count(*) INTO counter \\012\\011\\011\\011FROM data_set_relationships \\012\\011\\011\\011WHERE data_id_child = OLD.id;\\012\\011\\011IF (counter > 0) THEN\\012\\011\\011\\011RAISE EXCEPTION 'Insert/Update of Data Set (Code: %) failed because it cannot be connected with a Sample and a parent Data Set at the same time.', OLD.code;\\012\\011\\011END IF;\\012\\011END IF;\\012  RETURN NEW;\\012END;\\012$$ LANGUAGE 'plpgsql';\\012\\012CREATE CONSTRAINT TRIGGER check_dataset_relationships_on_data_table_modification \\012  AFTER INSERT OR UPDATE ON data\\012\\011DEFERRABLE INITIALLY DEFERRED\\012\\011FOR EACH ROW \\012\\011EXECUTE PROCEDURE check_dataset_relationships_on_data_table_modification();\\012\\012-- trigger for 'data_set_relationships'\\012\\012CREATE OR REPLACE FUNCTION check_dataset_relationships_on_relationships_table_modification() RETURNS trigger AS $$\\012DECLARE\\012\\011counter\\011INTEGER;\\012\\011sample_id\\011TECH_ID;\\012\\011data_code\\011CODE;\\012BEGIN\\012\\011-- child will have a parent added so it should not be connected with any sample\\012\\011SELECT samp_id, code INTO sample_id, data_code \\012\\011\\011FROM data \\012\\011\\011WHERE id = NEW.data_id_child;\\012\\011IF (sample_id IS NOT NULL) THEN\\012\\011\\011RAISE EXCEPTION 'Insert/Update of Data Set (Code: %) failed because it cannot be connected to a Sample and to a parent Data Set at the same time.', data_code;\\012\\011END IF;\\012\\011RETURN NEW;\\012END;\\012$$ LANGUAGE 'plpgsql';\\012  \\012CREATE CONSTRAINT TRIGGER check_dataset_relationships_on_relationships_table_modification \\012  AFTER INSERT OR UPDATE ON data_set_relationships\\012\\011DEFERRABLE INITIALLY DEFERRED\\012\\011FOR EACH ROW \\012\\011EXECUTE PROCEDURE check_dataset_relationships_on_relationships_table_modification();\\012	\N
+./sourceTest/sql/postgresql/057/.svn/text-base/017=database_version_logs.tsv.svn-base:053	source/sql/postgresql/migration/migration-052-053.sql	SUCCESS	2010-06-08 15:27:55.032	-- Migration from 052 to 053\\012\\012-- Change code uniqueness check for samples of specific type.\\012-- If sample_types.is_subcode_unique flag is set to 'true', additional check is performed \\012-- on codes of samples of the type. Subcodes will have to be unique as well.\\012\\012ALTER TABLE sample_types ADD COLUMN is_subcode_unique boolean_char NOT NULL DEFAULT false;\\012\\012CREATE OR REPLACE FUNCTION SAMPLE_SUBCODE_UNIQUENESS_CHECK() RETURNS trigger AS $$\\012DECLARE\\012   counter  INTEGER;\\012   unique_subcode  BOOLEAN_CHAR;\\012BEGIN\\012  LOCK TABLE samples IN EXCLUSIVE MODE;\\012  \\012  SELECT is_subcode_unique into unique_subcode FROM sample_types WHERE id = NEW.saty_id;\\012  \\012  IF (unique_subcode) THEN\\012    IF (NEW.dbin_id is not NULL) THEN\\012\\011\\011\\011SELECT count(*) into counter FROM samples \\012\\011\\011\\011\\011where id != NEW.id and code = NEW.code and saty_id = NEW.saty_id and dbin_id = NEW.dbin_id;\\012\\011\\011\\011IF (counter > 0) THEN\\012\\011\\011\\011\\011RAISE EXCEPTION 'Insert/Update of Sample (Code: %) failed because database instance sample of the same type with the same subcode already exists.', NEW.code;\\012\\011\\011\\011END IF;\\012\\011\\011ELSIF (NEW.grou_id is not NULL) THEN\\012\\011\\011\\011SELECT count(*) into counter FROM samples \\012\\011\\011\\011\\011where id != NEW.id and code = NEW.code and saty_id = NEW.saty_id and grou_id = NEW.grou_id;\\012\\011\\011\\011IF (counter > 0) THEN\\012\\011\\011\\011\\011RAISE EXCEPTION 'Insert/Update of Sample (Code: %) failed because space sample of the same type with the same subcode already exists.', NEW.code;\\012\\011\\011\\011END IF;\\012\\011\\011END IF;\\012  END IF;\\012  \\012  RETURN NEW;\\012END;\\012$$ LANGUAGE 'plpgsql';\\012\\012CREATE TRIGGER SAMPLE_SUBCODE_UNIQUENESS_CHECK BEFORE INSERT OR UPDATE ON SAMPLES\\012    FOR EACH ROW EXECUTE PROCEDURE SAMPLE_SUBCODE_UNIQUENESS_CHECK();\\012    \\012-- Fixing error messages in old trigger\\012\\012CREATE OR REPLACE FUNCTION SAMPLE_CODE_UNIQUENESS_CHECK() RETURNS trigger AS $$\\012DECLARE\\012   counter  INTEGER;\\012BEGIN\\012  LOCK TABLE samples IN EXCLUSIVE MODE;\\012  \\012\\011  IF (NEW.samp_id_part_of is NULL) THEN\\012\\011\\011  IF (NEW.dbin_id is not NULL) THEN\\012\\011\\011\\011  SELECT count(*) into counter FROM samples \\012\\011\\011      where id != NEW.id and code = NEW.code and samp_id_part_of is NULL and dbin_id = NEW.dbin_id;\\012        IF (counter > 0) THEN\\012\\011\\011\\011\\011  RAISE EXCEPTION 'Insert/Update of Sample (Code: %) failed because database instance sample with the same code already exists.', NEW.code;\\012        END IF;\\012\\011\\011  ELSIF (NEW.grou_id is not NULL) THEN\\012\\011\\011\\011  SELECT count(*) into counter FROM samples \\012\\011\\011\\011\\011  where id != NEW.id and code = NEW.code and samp_id_part_of is NULL and grou_id = NEW.grou_id;\\012\\011\\011\\011  IF (counter > 0) THEN\\012\\011\\011\\011\\011  RAISE EXCEPTION 'Insert/Update of Sample (Code: %) failed because space sample with the same code already exists.', NEW.code;\\012\\011\\011\\011  END IF;\\012      END IF;\\012    ELSE\\012\\011\\011  IF (NEW.dbin_id is not NULL) THEN\\012\\011\\011\\011  SELECT count(*) into counter FROM samples \\012\\011\\011\\011\\011  where id != NEW.id and code = NEW.code and samp_id_part_of = NEW.samp_id_part_of and dbin_id = NEW.dbin_id;\\012\\011\\011\\011  IF (counter > 0) THEN\\012\\011\\011\\011\\011  RAISE EXCEPTION 'Insert/Update of Sample (Code: %) failed because database instance sample with the same code and being the part of the same container already exists.', NEW.code;\\012\\011\\011\\011  END IF;\\012\\011\\011  ELSIF (NEW.grou_id is not NULL) THEN\\012\\011\\011\\011  SELECT count(*) into counter FROM samples \\012\\011\\011\\011\\011  where id != NEW.id and code = NEW.code and samp_id_part_of = NEW.samp_id_part_of and grou_id = NEW.grou_id;\\012\\011\\011\\011  IF (counter > 0) THEN\\012\\011\\011\\011\\011  RAISE EXCEPTION 'Insert/Update of Sample (Code: %) failed because space sample with the same code and being the part of the same container already exists.', NEW.code;\\012\\011\\011\\011  END IF;\\012\\011\\011  END IF;\\012     END IF;   \\012  \\012  RETURN NEW;\\012END;\\012$$ LANGUAGE 'plpgsql';\\012	\N
+./sourceTest/sql/postgresql/057/.svn/text-base/017=database_version_logs.tsv.svn-base:054	source/sql/postgresql/migration/migration-053-054.sql	SUCCESS	2010-07-27 11:30:46.766	-- Migration from 053 to 054\\012\\012\\012-- Add RELATIONSHIP_TYPES table\\012CREATE TABLE relationship_types (id TECH_ID NOT NULL, code CODE NOT NULL, label COLUMN_LABEL, parent_label COLUMN_LABEL, child_label COLUMN_LABEL, description DESCRIPTION_2000, registration_timestamp TIME_STAMP_DFL NOT NULL DEFAULT CURRENT_TIMESTAMP, pers_id_registerer TECH_ID NOT NULL, is_managed_internally BOOLEAN_CHAR NOT NULL DEFAULT 'F', is_internal_namespace BOOLEAN_CHAR NOT NULL DEFAULT 'F', dbin_id TECH_ID NOT NULL);\\012\\012-- Add SAMPLE_RELATIONSHIPS table\\012CREATE TABLE sample_relationships (id TECH_ID NOT NULL, sample_id_parent TECH_ID NOT NULL, relationship_id TECH_ID NOT NULL, sample_id_child TECH_ID NOT NULL);\\012\\012-- Add/update constraints\\012ALTER TABLE relationship_types ADD CONSTRAINT rety_pk PRIMARY KEY (id);\\012ALTER TABLE relationship_types ADD CONSTRAINT rety_uk UNIQUE(code,dbin_id);\\012ALTER TABLE sample_relationships ADD CONSTRAINT sare_pk PRIMARY KEY (id);\\012ALTER TABLE sample_relationships ADD CONSTRAINT sare_bk_uk UNIQUE(sample_id_child,sample_id_parent,relationship_id);\\012ALTER TABLE sample_relationships ADD CONSTRAINT sare_data_fk_child FOREIGN KEY (sample_id_child) REFERENCES samples(id) ON DELETE CASCADE;\\012ALTER TABLE sample_relationships ADD CONSTRAINT sare_data_fk_parent FOREIGN KEY (sample_id_parent) REFERENCES samples(id) ON DELETE CASCADE;\\012ALTER TABLE sample_relationships ADD CONSTRAINT sare_data_fk_relationship FOREIGN KEY (relationship_id) REFERENCES relationship_types(id);\\012\\012-- Create index\\012CREATE INDEX sare_data_fk_i_child ON sample_relationships (sample_id_child);\\012CREATE INDEX sare_data_fk_i_parent ON sample_relationships (sample_id_parent);\\012CREATE INDEX sare_data_fk_i_relationship ON sample_relationships (relationship_id);\\012\\012-- Create sequence for RELATIONSHIP_TYPES\\012CREATE SEQUENCE RELATIONSHIP_TYPE_ID_SEQ;\\012CREATE SEQUENCE SAMPLE_RELATIONSHIP_ID_SEQ;\\012\\012-- Create initial relationships\\012insert into relationship_types\\012(id, \\012code, \\012label, \\012parent_label, \\012child_label, \\012description, \\012pers_id_registerer, \\012is_managed_internally, \\012is_internal_namespace, \\012dbin_id) \\012values\\012(\\012nextval('RELATIONSHIP_TYPE_ID_SEQ'),\\012'PARENT_CHILD',\\012'Parent - Child', \\012'Parent', \\012'Child', \\012'Parent - Child relationship', \\012(select id from persons where user_id ='system'), \\012'T', \\012'T', \\012(select id from database_instances where is_original_source = 'T')\\012);\\012\\012insert into relationship_types\\012(id, \\012code, \\012label, \\012parent_label, \\012child_label, \\012description, \\012pers_id_registerer, \\012is_managed_internally, \\012is_internal_namespace, \\012dbin_id) \\012values\\012(\\012nextval('RELATIONSHIP_TYPE_ID_SEQ'),\\012'PLATE_CONTROL_LAYOUT',\\012'Plate - Control Layout', \\012'Plate', \\012'Control Layout', \\012'Plate - Control Layout relationship', \\012(select id from persons where user_id ='system'), \\012'T', \\012'T', \\012(select id from database_instances where is_original_source = 'T')\\012); \\012\\012\\012-- Migrate sample relationships to new schema\\012INSERT INTO sample_relationships (id, sample_id_parent,sample_id_child,relationship_id) (select distinct nextval('SAMPLE_RELATIONSHIP_ID_SEQ') as id, s.SAMP_ID_GENERATED_FROM as parent_id, s.ID as child_id, rt.id as relationship_id from samples s, relationship_types rt  WHERE rt.code = 'PARENT_CHILD' and s.SAMP_ID_GENERATED_FROM is not null); \\012INSERT INTO sample_relationships (id, sample_id_parent,sample_id_child,relationship_id) (select distinct nextval('SAMPLE_RELATIONSHIP_ID_SEQ') as id, s.SAMP_ID_CONTROL_LAYOUT as parent_id, s.ID as child_id, rt.id as relationship_id from samples s, relationship_types rt  WHERE rt.code = 'PLATE_CONTROL_LAYOUT' and s.SAMP_ID_CONTROL_LAYOUT is not null);\\012\\012-- Drop old sample relations\\012ALTER TABLE SAMPLES DROP COLUMN SAMP_ID_TOP;\\012ALTER TABLE SAMPLES DROP COLUMN SAMP_ID_GENERATED_FROM;\\012ALTER TABLE SAMPLES DROP COLUMN SAMP_ID_CONTROL_LAYOUT;\\012\\012--------------------------------------------------------------------------------------\\012--------------------------------------------------------------------------------------\\012-- This is a screening specific migration. Nothing will be performed on openBIS databases \\012-- which are not screening specific.\\012-- \\012-- This migration for each existing connection between oligo well, oligo material and gene material\\012-- creates a direct connection between the well and the gene. \\012--------------------------------------------------------------------------------------\\012--------------------------------------------------------------------------------------\\012 \\012\\011\\012CREATE OR REPLACE FUNCTION CONNECT_WELLS_WITH_GENES() RETURNS void AS $$\\012DECLARE\\012\\011counter  int;\\012\\011oligo_well_exists bool;\\012BEGIN\\012\\011--------------------------------------------------\\012\\011-- create a gene property and assign it to oligo well\\012\\011--------------------------------------------------\\012\\011\\012\\011select true \\012\\011into oligo_well_exists\\012\\011from sample_types \\012\\011where code = 'OLIGO_WELL';\\012\\011\\012\\011if oligo_well_exists IS NULL then \\012\\011\\011-- skip migration if there are no oligo wells\\012\\011\\011return;\\012\\011end if;   \\012\\011\\012\\011insert into property_types(\\012\\011\\011id, \\012\\011\\011code, description, label, \\012\\011\\011daty_id,\\012\\011\\011pers_id_registerer,\\012\\011\\011dbin_id,\\012\\011\\011maty_prop_id) \\012\\011values(\\012\\011\\011\\011nextval('PROPERTY_TYPE_ID_SEQ'), \\012\\011\\011\\011'GENE','Inhibited gene','Gene',\\012\\011\\011\\011(select id from data_types where code = 'MATERIAL'), \\012\\011\\011\\011(select id from persons where user_id ='system'), \\012\\011\\011\\011(select id from database_instances where is_original_source = 'T'), \\012\\011\\011\\011(select id from material_types where code = 'GENE')\\012\\011\\011);\\012\\011\\011\\012\\011insert into sample_type_property_types( \\012\\011  id,\\012\\011  saty_id,\\012\\011  prty_id,\\012\\011  is_mandatory,\\012\\011  pers_id_registerer,\\012\\011  ordinal\\012\\011) values(\\012\\011\\011\\011nextval('stpt_id_seq'), \\012\\011\\011\\011(select id from sample_types where code = 'OLIGO_WELL'),\\012\\011\\011\\011(select id from property_types where code = 'GENE'),\\012\\011\\011\\011false,\\012\\011\\011\\011(select id from persons where user_id ='system'),\\012\\011\\011\\011(select max(ordinal)+1 from sample_type_property_types \\012\\011\\011\\011\\011where saty_id = (select id from sample_types where code = 'OLIGO_WELL'))\\012\\011\\011);\\012\\012\\011--------------------------------------------------\\012\\011-- create a gene material property for each oligo well\\012\\011--------------------------------------------------\\012\\011\\011\\012\\011select \\011count(*)\\012\\011into counter\\012\\011from\\012\\011\\011samples well, sample_types well_type, sample_properties well_props, \\012\\011\\011materials well_material, material_properties well_material_props,\\012\\011\\011materials nested_well_material\\012\\011where\\012\\011\\011well_type.code = 'OLIGO_WELL' and\\012\\011\\011-- find 'well_material' assigned to the well\\012\\011\\011well_props.samp_id = well.id and well_material.id = well_props.mate_prop_id and \\012\\011\\011-- additional joins to entity type tables\\012\\011\\011well_type.id = well.saty_id and\\012\\011\\011-- well content material property\\012\\011\\011well_material_props.mate_id = well_material.id and \\012\\011\\011-- material connected to the material in the well (e.g. gene)\\012\\011\\011well_material_props.mate_prop_id = nested_well_material.id and\\012\\011\\011nested_well_material.maty_id = (select id from material_types where code = 'GENE');\\012\\011\\012\\011if counter = 0 then \\012\\011\\011-- skip migration if there are no genes indirectly connected to oligo wells\\012\\011\\011return;\\012\\011end if;   \\012\\012\\011insert into sample_properties(id, samp_id, stpt_id, mate_prop_id, pers_id_registerer) (\\012\\011\\011select \\011nextval('sample_property_id_seq') id, \\012\\011\\011\\011well.id samp_id, \\012\\011\\011\\011(select stpt.id from sample_type_property_types stpt, property_types props where stpt.prty_id = props.id and props.code='GENE') stpt_id,\\012\\011\\011\\011nested_well_material.id mate_prop_id,\\012\\011\\011\\011(select id from persons where user_id ='system') pers_id_registerer \\012\\011\\011from\\012\\011\\011\\011samples well, sample_types well_type, sample_properties well_props, \\012\\011\\011\\011materials well_material, material_properties well_material_props,\\012\\011\\011\\011materials nested_well_material\\012\\011\\011where\\012\\011\\011\\011well_type.code = 'OLIGO_WELL' and\\012\\011\\011\\011-- find 'well_material' assigned to the well\\012\\011\\011\\011well_props.samp_id = well.id and well_material.id = well_props.mate_prop_id and \\012\\011\\011\\011-- additional joins to entity type tables\\012\\011\\011\\011well_type.id = well.saty_id and\\012\\011\\011\\011-- well content material property\\012\\011\\011\\011well_material_props.mate_id = well_material.id and \\012\\011\\011\\011-- material connected to the material in the well (e.g. gene)\\012\\011\\011\\011well_material_props.mate_prop_id = nested_well_material.id and\\012\\011\\011\\011nested_well_material.maty_id = (select id from material_types where code = 'GENE')\\012\\011);\\012\\012END;\\012$$ LANGUAGE 'plpgsql';\\012\\012select CONNECT_WELLS_WITH_GENES();\\012drop function CONNECT_WELLS_WITH_GENES();\\012\\012--------------------------------------------------------------------------------------\\012--------------------------------------------------------------------------------------\\012\\012-- drop dataset triggers\\012\\012DROP TRIGGER check_dataset_relationships_on_data_table_modification ON data;\\012DROP FUNCTION check_dataset_relationships_on_data_table_modification();\\012DROP TRIGGER check_dataset_relationships_on_relationships_table_modification ON data_set_relationships;\\012DROP FUNCTION check_dataset_relationships_on_relationships_table_modification();\\012 \\012\\012\\012\\012\\012\\012\\012\\012	\N
+./sourceTest/sql/postgresql/057/.svn/text-base/017=database_version_logs.tsv.svn-base:056	source/sql/postgresql/migration/migration-055-056.sql	SUCCESS	2010-09-10 09:06:20.278	-- Migration from 055 to 056\\012\\012--------------------------------------------------------------------------------------\\012--------------------------------------------------------------------------------------\\012-- Screening specific migration. Nothing will be performed on openBIS databases \\012-- which are not screening specific.\\012--------------------------------------------------------------------------------------\\012--------------------------------------------------------------------------------------\\012\\012CREATE OR REPLACE FUNCTION merge_words(text, text) RETURNS text AS $$\\012DECLARE\\012  BEGIN\\012    IF  character_length($1) > 0 THEN\\012      RETURN $1 || ' ' || $2;\\012    ELSE\\012      RETURN $2;\\012    END IF;\\012  END;\\012$$ LANGUAGE plpgsql;\\012\\012CREATE AGGREGATE merge_words(text)\\012(\\012  SFUNC = merge_words,\\012  STYPE = text\\012);\\012\\012\\012CREATE OR REPLACE FUNCTION REPLACE_GENE_SYMBOL_BY_GENE_ID() RETURNS void AS $$\\012DECLARE\\012\\011counter  int;\\012\\011library_id_assigned_to_gene bool;\\012BEGIN\\012\\011--------------------------------------------------\\012\\011-- create a GENE_SYMBOL property and assign it to GENE\\012\\011--------------------------------------------------\\012\\011\\012\\011select true  \\012\\011into library_id_assigned_to_gene \\012\\011from material_type_property_types mtpt, material_types mt, property_types pt  \\012\\011where mtpt.maty_id = mt.id and mtpt.prty_id = pt.id \\012\\011\\011and mt.code = 'GENE' and pt.code = 'LIBRARY_ID';\\012\\011\\012\\011if library_id_assigned_to_gene IS NULL then \\012\\011\\011-- skip migration if gene has no library_id property\\012\\011\\011return;\\012\\011end if; \\012\\011\\012\\011\\012\\011select count(*)\\012\\011into counter \\012\\011from  \\012\\011\\011(select m.id, count(mp.id) as c \\012\\011\\011\\011from materials m, material_types mt, material_properties mp, material_type_property_types mtpt, property_types pt \\012\\011\\011\\011where m.maty_id = mt.id and mp.mate_id = m.id and mp.mtpt_id = mtpt.id and mtpt.maty_id = mt.id and pt.id = mtpt.prty_id\\012\\011\\011\\011\\011and mt.code = 'GENE' and pt.code = 'LIBRARY_ID' \\012\\011\\011\\011group by m.id) as counter_table \\012\\011where c < 1; \\012\\011\\012\\011if counter > 0 then \\012\\011\\011-- skip migration if there is at least one gene without library_id\\012\\011\\011return;\\012\\011end if;\\012\\011\\012\\011\\012\\011insert into property_types\\012\\011\\011(id\\012\\011\\011,code\\012\\011\\011,description\\012\\011\\011,label\\012\\011\\011,daty_id\\012\\011\\011,pers_id_registerer\\012\\011\\011,dbin_id)\\012\\011values \\012\\011\\011(nextval('PROPERTY_TYPE_ID_SEQ')\\012\\011\\011,'GENE_SYMBOLS'\\012\\011\\011,'Gene symbols'\\012\\011\\011,'Gene symbols'\\012\\011\\011,(select id from data_types where code ='VARCHAR')\\012\\011\\011,(select id from persons where user_id ='system')\\012\\011\\011,(select id from database_instances where is_original_source = 'T')\\012\\011);\\012\\011\\011\\012\\011insert into material_type_property_types( \\012\\011  id,\\012\\011  maty_id,\\012\\011  prty_id,\\012\\011  is_mandatory,\\012\\011  pers_id_registerer,\\012\\011  ordinal\\012\\011) values(\\012\\011\\011\\011nextval('mtpt_id_seq'), \\012\\011\\011\\011(select id from material_types where code = 'GENE'),\\012\\011\\011\\011(select id from property_types where code = 'GENE_SYMBOLS'),\\012\\011\\011\\011false,\\012\\011\\011\\011(select id from persons where user_id ='system'),\\012\\011\\011\\011(select max(ordinal)+1 from material_type_property_types \\012\\011\\011\\011\\011where maty_id = (select id from material_types where code = 'GENE'))\\012\\011\\011);\\012\\012\\011--------------------------------------------------\\012\\011-- create temporary table with all gene migration information\\012\\011--------------------------------------------------\\012\\012\\011create temp table genes \\012\\011(\\012\\011\\011id tech_id,\\012\\011\\011code code,\\012\\011\\011library_id generic_value,\\012\\011\\011gene_codes generic_value,\\012\\011\\011new_id tech_id,\\012\\011\\011library_tech_id tech_id\\011\\011\\012\\011);\\012\\011\\012\\011insert into genes (id, code, library_id, library_tech_id)\\012\\011\\011(select m.id, m.code, mp.value as library_id, mp.id as library_tech_id from materials m, material_properties mp, material_type_property_types mtpt, property_types pt, material_types mt\\012\\011\\011where mp.mate_id = m.id and  mp.mtpt_id = mtpt.id and pt.id = mtpt.prty_id and pt.code = 'LIBRARY_ID' and mt.id = m.maty_id and mt.id = mtpt.maty_id and mt.code = 'GENE');\\012\\011\\012\\011update genes set new_id = map.to_id from (select g_from.id as from_id, min(g_to.id) as to_id  from genes g_from, genes g_to where g_from.library_id = g_to.library_id group by g_from.id) as map where map.from_id = id;\\011\\012\\011\\012\\011update genes set gene_codes = map.gene_codes from (select g_from.library_id as lib_id, merge_words(distinct g_to.code) as gene_codes from genes g_from, genes g_to where g_from.library_id = g_to.library_id group by g_from.library_id) as map where map.lib_id = library_id;\\011\\012\\012\\011--------------------------------------------------\\012\\011-- update gene references\\012\\011--------------------------------------------------\\012\\012\\011update EXPERIMENTS set MATE_ID_STUDY_OBJECT = genes.new_id from genes where genes.id = MATE_ID_STUDY_OBJECT and not genes.id = genes.new_id;\\012\\011update EXPERIMENT_PROPERTIES set  MATE_PROP_ID = genes.new_id from genes where genes.id = MATE_PROP_ID and not genes.id = genes.new_id;\\012\\011update MATERIAL_PROPERTIES set  MATE_PROP_ID = genes.new_id from genes where genes.id = MATE_PROP_ID and not genes.id = genes.new_id;\\012\\011update SAMPLE_PROPERTIES set  MATE_PROP_ID = genes.new_id from genes where genes.id = MATE_PROP_ID and not genes.id = genes.new_id;\\012\\011update DATA_SET_PROPERTIES set  MATE_PROP_ID = genes.new_id from genes where genes.id = MATE_PROP_ID and not genes.id = genes.new_id;\\012\\011\\012\\011delete from  material_properties where mate_id in (select id from genes where not genes.id = genes.new_id);\\012\\011delete from MATERIALS where id in (select id from genes where not genes.id = genes.new_id);\\012\\012\\011delete from genes where id in (select id from genes where not genes.id = genes.new_id);\\012\\012\\012\\011--------------------------------------------------\\012\\011-- replace gene code with library_id\\012\\011--------------------------------------------------\\012\\011\\012\\011update materials set code = genes.library_id from genes where materials.id = genes.id ;\\012\\011delete from material_properties where id in (select library_tech_id from genes);\\012\\011\\012\\011--------------------------------------------------\\012\\011-- create a gene symbols property for each gene\\012\\011--------------------------------------------------\\012\\011\\012\\011insert into material_properties\\012\\011\\011(id\\012\\011  , mate_id\\012\\011  , mtpt_id\\012\\011  , "value"\\012\\011  , pers_id_registerer)\\012\\011\\011(select nextval('material_property_id_seq') id\\012\\011  \\011, genes.id  mate_id\\012\\011    , (select mtpt.id\\012\\011    \\011\\011from   material_type_property_types mtpt, material_types mt, property_types pt\\012\\011    \\011\\011where  pt.code = 'GENE_SYMBOLS' and mt.code = 'GENE' and mtpt.prty_id = pt.id\\012\\011        \\011and mtpt.maty_id = mt.id) mtpt_id\\012\\011    , genes.gene_codes "value"\\012\\011    , (select id from persons where user_id = 'system') pers_id_registerer\\012\\011 \\011from genes); \\012\\012\\011--------------------------------------------------\\012\\011-- delete temporary table\\012\\011--------------------------------------------------\\012\\011\\012\\011drop table genes;\\012\\011\\012END;\\012$$ LANGUAGE 'plpgsql';\\012\\012select REPLACE_GENE_SYMBOL_BY_GENE_ID();\\012drop function REPLACE_GENE_SYMBOL_BY_GENE_ID();\\012DROP AGGREGATE merge_words(text);\\012drop function merge_words(text,text);\\012\\012\\012--------------------------------------------------------------------------------------\\012--------------------------------------------------------------------------------------\\012\\012UPDATE sample_types SET code = 'SIRNA_WELL' WHERE code = 'OLIGO_WELL';\\012UPDATE material_types SET code = 'SIRNA' WHERE code = 'OLIGO';\\012UPDATE property_types SET code = 'SIRNA', label = 'siRNA' WHERE code = 'OLIGO';\\012\\012\\012\\012\\012\\012\\012\\012\\012\\012\\012\\012\\012\\012\\012\\012\\012\\012\\012\\012	\N
+./sourceTest/sql/postgresql/057/.svn/text-base/schema-057.sql.svn-base:    LANGUAGE plpgsql
+./sourceTest/sql/postgresql/057/.svn/text-base/schema-057.sql.svn-base:    LANGUAGE plpgsql
+./sourceTest/sql/postgresql/057/.svn/text-base/schema-057.sql.svn-base:    LANGUAGE plpgsql
+./sourceTest/sql/postgresql/057/.svn/text-base/schema-057.sql.svn-base:    LANGUAGE plpgsql
+./sourceTest/sql/postgresql/057/.svn/text-base/schema-057.sql.svn-base:    LANGUAGE plpgsql
+./sourceTest/sql/postgresql/057/.svn/text-base/schema-057.sql.svn-base:    LANGUAGE plpgsql
+./sourceTest/sql/postgresql/057/.svn/text-base/schema-057.sql.svn-base:    LANGUAGE plpgsql
+./sourceTest/sql/postgresql/057/.svn/text-base/schema-057.sql.svn-base:    LANGUAGE plpgsql
+./sourceTest/sql/postgresql/057/.svn/text-base/schema-057.sql.svn-base:    LANGUAGE plpgsql
+./sourceTest/sql/postgresql/057/017=database_version_logs.tsv:027	D:\\User\\felmer\\dev-workspace\\openbis/source/sql/postgresql/027/function-027.sql	SUCCESS	2008-11-05 09:18:00.403	-- Creating Functions\\012\\012------------------------------------------------------------------------------------\\012--  Purpose:  Create function RENAME_SEQUENCE() that is required for renaming the sequences belonging to tables\\012------------------------------------------------------------------------------------\\012CREATE FUNCTION RENAME_SEQUENCE(OLD_NAME VARCHAR, NEW_NAME VARCHAR) RETURNS INTEGER AS $$\\012DECLARE\\012  CURR_SEQ_VAL   INTEGER;\\012BEGIN\\012  SELECT INTO CURR_SEQ_VAL NEXTVAL(OLD_NAME);\\012  EXECUTE 'CREATE SEQUENCE ' || NEW_NAME || ' START WITH ' || CURR_SEQ_VAL;\\012  EXECUTE 'DROP SEQUENCE ' || OLD_NAME;\\012  RETURN CURR_SEQ_VAL;\\012END;\\012$$ LANGUAGE 'plpgsql';\\012\\012\\012------------------------------------------------------------------------------------\\012--  Purpose:  Create trigger CONTROLLED_VOCABULARY_CHECK \\012------------------------------------------------------------------------------------\\012\\012CREATE OR REPLACE FUNCTION CONTROLLED_VOCABULARY_CHECK() RETURNS trigger AS $$\\012DECLARE\\012   v_code  CODE;\\012BEGIN\\012\\012   select code into v_code from data_types where id = NEW.daty_id;\\012\\012   -- Check if the data is of type "CONTROLLEDVOCABULARY"\\012   if v_code = 'CONTROLLEDVOCABULARY' then\\012      if NEW.covo_id IS NULL then\\012         RAISE EXCEPTION 'Insert/Update of Property Type (Code: %) failed, as its Data Type is CONTROLLEDVOCABULARY, but it is not linked to a Controlled Vocabulary.', NEW.code;\\012      end if;\\012   end if;\\012\\012   RETURN NEW;\\012\\012END;\\012$$ LANGUAGE 'plpgsql';\\012\\012CREATE TRIGGER CONTROLLED_VOCABULARY_CHECK BEFORE INSERT OR UPDATE ON PROPERTY_TYPES\\012    FOR EACH ROW EXECUTE PROCEDURE CONTROLLED_VOCABULARY_CHECK();\\012\\012\\012------------------------------------------------------------------------------------\\012--  Purpose:  Create trigger EXTERNAL_DATA_STORAGE_FORMAT_CHECK \\012------------------------------------------------------------------------------------\\012\\012CREATE OR REPLACE FUNCTION EXTERNAL_DATA_STORAGE_FORMAT_CHECK() RETURNS trigger AS $$\\012DECLARE\\012   v_covo_code  CODE;\\012   data_code CODE;\\012BEGIN\\012\\012   select code into v_covo_code from controlled_vocabularies\\012      where is_internal_namespace = true and \\012         id = (select covo_id from controlled_vocabulary_terms where id = NEW.cvte_id_stor_fmt);\\012   -- Check if the data storage format is a term of the controlled vocabulary "STORAGE_FORMAT"\\012   if v_covo_code != 'STORAGE_FORMAT' then\\012      select code into data_code from data where id = NEW.data_id; \\012      RAISE EXCEPTION 'Insert/Update of Data (Code: %) failed, as its Storage Format is %, but is required to be STORAGE_FORMAT.', data_code, v_covo_code;\\012   end if;\\012\\012   RETURN NEW;\\012\\012END;\\012$$ LANGUAGE 'plpgsql';\\012\\012CREATE TRIGGER EXTERNAL_DATA_STORAGE_FORMAT_CHECK BEFORE INSERT OR UPDATE ON EXTERNAL_DATA\\012    FOR EACH ROW EXECUTE PROCEDURE EXTERNAL_DATA_STORAGE_FORMAT_CHECK();\\012\\012------------------------------------------------------------------------------------\\012--  Purpose:  Create trigger SAMPLE_CODE_UNIQUENESS_CHECK \\012------------------------------------------------------------------------------------\\012\\012CREATE OR REPLACE FUNCTION SAMPLE_CODE_UNIQUENESS_CHECK() RETURNS trigger AS $$\\012DECLARE\\012   counter  INTEGER;\\012BEGIN\\012\\011IF (NEW.samp_id_part_of is NULL) THEN\\012\\011\\011IF (NEW.dbin_id is not NULL) THEN\\012\\011\\011\\011SELECT count(*) into counter FROM samples \\012\\011\\011\\011\\011where id != NEW.id and code = NEW.code and samp_id_part_of is NULL and dbin_id = NEW.dbin_id;\\012\\011\\011\\011IF (counter > 0) THEN\\012\\011\\011\\011\\011RAISE EXCEPTION 'Insert/Update of Sample (Code: %) failed because database instance sample with the same code already exists.', NEW.code;\\012\\011\\011\\011END IF;\\012\\011\\011ELSIF (NEW.grou_id is not NULL) THEN\\012\\011\\011\\011SELECT count(*) into counter FROM samples \\012\\011\\011\\011\\011where id != NEW.id and code = NEW.code and samp_id_part_of is NULL and grou_id = NEW.grou_id;\\012\\011\\011\\011IF (counter > 0) THEN\\012\\011\\011\\011\\011RAISE EXCEPTION 'Insert/Update of Sample (Code: %) failed because group sample with the same code already exists.', NEW.code;\\012\\011\\011\\011END IF;\\012\\011\\011END IF;\\012        ELSE\\012\\011\\011IF (NEW.dbin_id is not NULL) THEN\\012\\011\\011\\011SELECT count(*) into counter FROM samples \\012\\011\\011\\011\\011where id != NEW.id and code = NEW.code and samp_id_part_of = NEW.samp_id_part_of and dbin_id = NEW.dbin_id;\\012\\011\\011\\011IF (counter > 0) THEN\\012\\011\\011\\011\\011RAISE EXCEPTION 'Insert/Update of Sample (Code: %) failed because database instance sample with the same code and being the part of the same parent already exists.', NEW.code;\\012\\011\\011\\011END IF;\\012\\011\\011ELSIF (NEW.grou_id is not NULL) THEN\\012\\011\\011\\011SELECT count(*) into counter FROM samples \\012\\011\\011\\011\\011where id != NEW.id and code = NEW.code and samp_id_part_of = NEW.samp_id_part_of and grou_id = NEW.grou_id;\\012\\011\\011\\011IF (counter > 0) THEN\\012\\011\\011\\011\\011RAISE EXCEPTION 'Insert/Update of Sample (Code: %) failed because group sample with the same code and being the part of the same parent already exists.', NEW.code;\\012\\011\\011\\011END IF;\\012\\011\\011END IF;\\012        END IF;   \\012   RETURN NEW;\\012END;\\012$$ LANGUAGE 'plpgsql';\\012\\012CREATE TRIGGER SAMPLE_CODE_UNIQUENESS_CHECK BEFORE INSERT OR UPDATE ON SAMPLES\\012    FOR EACH ROW EXECUTE PROCEDURE SAMPLE_CODE_UNIQUENESS_CHECK();\\012	\N
+./sourceTest/sql/postgresql/057/017=database_version_logs.tsv:028	source/sql/postgresql/migration/migration-027-028.sql	SUCCESS	2008-11-18 13:24:17.508	-- Create EXPERIMENT_ATTACHMENT_CONTENTS.\\012CREATE TABLE EXPERIMENT_ATTACHMENT_CONTENTS (ID TECH_ID NOT NULL,VALUE FILE NOT NULL);\\012CREATE SEQUENCE EXPERIMENT_ATTACHMENT_CONTENT_ID_SEQ;\\012ALTER TABLE EXPERIMENT_ATTACHMENT_CONTENTS ADD CONSTRAINT EXAC_PK PRIMARY KEY(ID);\\012\\012-- Alter EXPERIMENT_ATTACHMENTS by adding the new column which has a NULL constraint.\\012-- The NOT NULL constraint is added later on.\\012ALTER TABLE EXPERIMENT_ATTACHMENTS ADD COLUMN EXAC_ID TECH_ID;\\012\\012-- Does the VALUE migration between EXPERIMENT_ATTACHMENTS to EXPERIMENT_ATTACHMENT_CONTENTS.\\012CREATE OR REPLACE FUNCTION move_exp_att_content() RETURNS integer AS $$\\012DECLARE\\012    rec RECORD;\\012    seq BIGINT;\\012BEGIN\\012  FOR rec IN SELECT id, value FROM EXPERIMENT_ATTACHMENTS LOOP\\012  \\011seq := nextval('EXPERIMENT_ATTACHMENT_CONTENT_ID_SEQ');\\012    INSERT INTO EXPERIMENT_ATTACHMENT_CONTENTS (id, value) VALUES (seq, rec.value);\\012    UPDATE EXPERIMENT_ATTACHMENTS SET exac_id = seq WHERE id = rec.id;\\012  END LOOP;\\012  RETURN 1;\\012END;\\012$$ LANGUAGE 'plpgsql';\\012\\012-- Call the function.\\012SELECT move_exp_att_content();\\012DROP FUNCTION move_exp_att_content();\\012\\012\\012-- Finish EXPERIMENT_ATTACHMENTS changes.\\012ALTER TABLE EXPERIMENT_ATTACHMENTS ADD CONSTRAINT EXAT_CONT_FK FOREIGN KEY (EXAC_ID) REFERENCES EXPERIMENT_ATTACHMENT_CONTENTS(ID);\\012ALTER TABLE EXPERIMENT_ATTACHMENTS DROP COLUMN VALUE;\\012ALTER TABLE EXPERIMENT_ATTACHMENTS ALTER COLUMN EXAC_ID SET NOT NULL;\\012	\N
+./sourceTest/sql/postgresql/057/017=database_version_logs.tsv:029	source/sql/postgresql/migration/migration-028-029.sql	SUCCESS	2009-03-18 10:50:20.105	-- -------\\012-- add modification_timestamp field to allow edition with Hibernate\\012-- -------\\012\\012ALTER TABLE samples\\012\\011ADD COLUMN modification_timestamp TIME_STAMP DEFAULT CURRENT_TIMESTAMP;\\012\\012ALTER TABLE experiments\\012\\011ADD COLUMN modification_timestamp TIME_STAMP DEFAULT CURRENT_TIMESTAMP;\\012\\012ALTER TABLE materials\\012\\011ADD COLUMN modification_timestamp TIME_STAMP DEFAULT CURRENT_TIMESTAMP;\\012\\012ALTER TABLE experiment_properties\\012\\011ADD COLUMN modification_timestamp TIME_STAMP DEFAULT CURRENT_TIMESTAMP;\\012\\012ALTER TABLE material_properties\\012\\011ADD COLUMN modification_timestamp TIME_STAMP DEFAULT CURRENT_TIMESTAMP;\\012\\012ALTER TABLE sample_properties\\012\\011ADD COLUMN modification_timestamp TIME_STAMP DEFAULT CURRENT_TIMESTAMP;\\012\\012-- -------\\012-- add property data type which references materials\\012-- -------\\012\\012ALTER TABLE property_types\\012\\011ADD COLUMN maty_prop_id tech_id;\\012\\012ALTER TABLE property_types\\012\\011ADD CONSTRAINT prty_maty_fk FOREIGN KEY (maty_prop_id) REFERENCES material_types(id);\\012\\012ALTER TABLE experiment_properties\\012\\011ADD COLUMN mate_prop_id tech_id;\\012\\012ALTER TABLE material_properties\\012\\011ADD COLUMN mate_prop_id tech_id;\\012\\012ALTER TABLE sample_properties\\012\\011ADD COLUMN mate_prop_id tech_id;\\012\\012ALTER TABLE experiment_properties\\012\\011ADD CONSTRAINT expr_mapr_fk FOREIGN KEY (mate_prop_id) REFERENCES materials(id);\\012\\012ALTER TABLE material_properties\\012\\011ADD CONSTRAINT mapr_mapr_fk FOREIGN KEY (mate_prop_id) REFERENCES materials(id);\\012\\012ALTER TABLE sample_properties\\012\\011ADD CONSTRAINT sapr_mapr_fk FOREIGN KEY (mate_prop_id) REFERENCES materials(id);\\012\\012insert into data_types\\012(id\\012 ,code\\012 ,description)\\012 values \\012 (nextval('DATA_TYPE_ID_SEQ')\\012 ,'MATERIAL'\\012 ,'Reference to a material'\\012);\\012\\012ALTER TABLE MATERIAL_PROPERTIES DROP CONSTRAINT MAPR_CK;\\012ALTER TABLE MATERIAL_PROPERTIES ADD CONSTRAINT MAPR_CK CHECK \\012\\011((VALUE IS NOT NULL AND CVTE_ID IS NULL AND MATE_PROP_ID IS NULL) OR \\012\\011 (VALUE IS NULL AND CVTE_ID IS NOT NULL AND MATE_PROP_ID IS NULL) OR\\012\\011 (VALUE IS NULL AND CVTE_ID IS NULL AND MATE_PROP_ID IS NOT NULL)\\012\\011);\\012\\012ALTER TABLE EXPERIMENT_PROPERTIES DROP CONSTRAINT EXPR_CK;\\012ALTER TABLE EXPERIMENT_PROPERTIES ADD CONSTRAINT EXPR_CK CHECK \\012\\011((VALUE IS NOT NULL AND CVTE_ID IS NULL AND MATE_PROP_ID IS NULL) OR \\012\\011 (VALUE IS NULL AND CVTE_ID IS NOT NULL AND MATE_PROP_ID IS NULL) OR\\012\\011 (VALUE IS NULL AND CVTE_ID IS NULL AND MATE_PROP_ID IS NOT NULL)\\012\\011);\\012\\012ALTER TABLE SAMPLE_PROPERTIES DROP CONSTRAINT SAPR_CK;\\012ALTER TABLE SAMPLE_PROPERTIES ADD CONSTRAINT SAPR_CK CHECK \\012\\011((VALUE IS NOT NULL AND CVTE_ID IS NULL AND MATE_PROP_ID IS NULL) OR \\012\\011 (VALUE IS NULL AND CVTE_ID IS NOT NULL AND MATE_PROP_ID IS NULL) OR\\012\\011 (VALUE IS NULL AND CVTE_ID IS NULL AND MATE_PROP_ID IS NOT NULL)\\012\\011);\\012\\012------------------------------------------------------------------------------------\\012--  Purpose:  Create trigger MATERIAL/SAMPLE/EXPERIMENT _PROPERTY_WITH_MATERIAL_DATA_TYPE_CHECK\\012--            It checks that if material property value is assigned to the entity,\\012--\\011\\011\\011\\011\\011\\011then the material type is equal to the one described by property type.\\012------------------------------------------------------------------------------------\\012\\012CREATE OR REPLACE FUNCTION MATERIAL_PROPERTY_WITH_MATERIAL_DATA_TYPE_CHECK() RETURNS trigger AS $$\\012DECLARE\\012   v_type_id  CODE;\\012   v_type_id_prop  CODE;\\012BEGIN\\012   if NEW.mate_prop_id IS NOT NULL then\\012\\011\\011\\011-- find material type id of the property type \\012\\011\\011\\011select pt.maty_prop_id into v_type_id_prop \\012\\011\\011\\011  from material_type_property_types etpt, property_types pt \\012\\011\\011\\011 where NEW.mtpt_id = etpt.id AND etpt.prty_id = pt.id;\\012\\011\\011\\012\\011\\011\\011if v_type_id_prop IS NOT NULL then\\012\\011\\011\\011\\011-- find material type id of the material which consists the entity's property value\\012\\011\\011\\011\\011select entity.maty_id into v_type_id \\012\\011\\011\\011\\011  from materials entity\\012\\011\\011\\011\\011 where NEW.mate_prop_id = entity.id;\\012\\011\\011\\011\\011if v_type_id != v_type_id_prop then\\012\\011\\011\\011\\011\\011RAISE EXCEPTION 'Insert/Update of property value referencing material (id: %) failed, as referenced material type is different than expected (id %, expected id: %).', \\012\\011\\011\\011\\011\\011\\011\\011 NEW.mate_prop_id, v_type_id, v_type_id_prop;\\012\\011\\011\\011\\011end if;\\012\\011\\011\\011end if;\\012   end if;\\012   RETURN NEW;\\012END;\\012$$ LANGUAGE 'plpgsql';\\012\\012CREATE TRIGGER MATERIAL_PROPERTY_WITH_MATERIAL_DATA_TYPE_CHECK BEFORE INSERT OR UPDATE ON material_properties\\012    FOR EACH ROW EXECUTE PROCEDURE MATERIAL_PROPERTY_WITH_MATERIAL_DATA_TYPE_CHECK();\\012    \\012CREATE OR REPLACE FUNCTION SAMPLE_PROPERTY_WITH_MATERIAL_DATA_TYPE_CHECK() RETURNS trigger AS $$\\012DECLARE\\012   v_type_id  CODE;\\012   v_type_id_prop  CODE;\\012BEGIN\\012   if NEW.mate_prop_id IS NOT NULL then\\012\\011\\011\\011-- find material type id of the property type \\012\\011\\011\\011select pt.maty_prop_id into v_type_id_prop \\012\\011\\011\\011  from sample_type_property_types etpt, property_types pt \\012\\011\\011\\011 where NEW.stpt_id = etpt.id AND etpt.prty_id = pt.id;\\012\\011\\011\\012\\011\\011\\011if v_type_id_prop IS NOT NULL then\\012\\011\\011\\011\\011-- find material type id of the material which consists the entity's property value\\012\\011\\011\\011\\011select entity.maty_id into v_type_id \\012\\011\\011\\011\\011  from materials entity\\012\\011\\011\\011\\011 where NEW.mate_prop_id = entity.id;\\012\\011\\011\\011\\011if v_type_id != v_type_id_prop then\\012\\011\\011\\011\\011\\011RAISE EXCEPTION 'Insert/Update of property value referencing material (id: %) failed, as referenced material type is different than expected (id %, expected id: %).', \\012\\011\\011\\011\\011\\011\\011\\011\\011\\011\\011\\011\\011 NEW.mate_prop_id, v_type_id, v_type_id_prop;\\012\\011\\011\\011\\011end if;\\012\\011\\011\\011end if;\\012   end if;\\012   RETURN NEW;\\012END;\\012$$ LANGUAGE 'plpgsql';\\012\\012CREATE TRIGGER SAMPLE_PROPERTY_WITH_MATERIAL_DATA_TYPE_CHECK BEFORE INSERT OR UPDATE ON sample_properties\\012    FOR EACH ROW EXECUTE PROCEDURE SAMPLE_PROPERTY_WITH_MATERIAL_DATA_TYPE_CHECK();\\012    \\012CREATE OR REPLACE FUNCTION EXPERIMENT_PROPERTY_WITH_MATERIAL_DATA_TYPE_CHECK() RETURNS trigger AS $$\\012DECLARE\\012   v_type_id  CODE;\\012   v_type_id_prop  CODE;\\012BEGIN\\012   if NEW.mate_prop_id IS NOT NULL then\\012\\011\\011\\011-- find material type id of the property type \\012\\011\\011\\011select pt.maty_prop_id into v_type_id_prop \\012\\011\\011\\011  from experiment_type_property_types etpt, property_types pt \\012\\011\\011\\011 where NEW.etpt_id = etpt.id AND etpt.prty_id = pt.id;\\012\\011\\011\\012\\011\\011\\011if v_type_id_prop IS NOT NULL then\\012\\011\\011\\011\\011-- find material type id of the material which consists the entity's property value\\012\\011\\011\\011\\011select entity.maty_id into v_type_id \\012\\011\\011\\011\\011  from materials entity\\012\\011\\011\\011\\011 where NEW.mate_prop_id = entity.id;\\012\\011\\011\\011\\011if v_type_id != v_type_id_prop then\\012\\011\\011\\011\\011\\011RAISE EXCEPTION 'Insert/Update of property value referencing material (id: %) failed, as referenced material type is different than expected (id %, expected id: %).', \\012\\011\\011\\011\\011\\011\\011\\011\\011\\011\\011\\011\\011 NEW.mate_prop_id, v_type_id, v_type_id_prop;\\012\\011\\011\\011\\011end if;\\012\\011\\011\\011end if;\\012   end if;\\012   RETURN NEW;\\012END;\\012$$ LANGUAGE 'plpgsql';\\012\\012CREATE TRIGGER EXPERIMENT_PROPERTY_WITH_MATERIAL_DATA_TYPE_CHECK BEFORE INSERT OR UPDATE ON experiment_properties\\012    FOR EACH ROW EXECUTE PROCEDURE EXPERIMENT_PROPERTY_WITH_MATERIAL_DATA_TYPE_CHECK();\\012       \\012-- -------\\012-- remove the reminescents of the OBSERVABLE_TYPE\\012-- -------\\012\\012ALTER TABLE data\\012\\011DROP CONSTRAINT data_obty_fk;\\012\\012ALTER TABLE data_set_types\\012\\011DROP CONSTRAINT obty_pk;\\012\\012ALTER TABLE data_set_types\\012\\011ADD CONSTRAINT dsty_pk PRIMARY KEY (id);\\012\\012ALTER TABLE data\\012\\011ADD CONSTRAINT data_dsty_fk FOREIGN KEY (dsty_id) REFERENCES data_set_types(id);\\012\\012ALTER TABLE data_set_types\\012\\011DROP CONSTRAINT obty_bk_uk;\\012\\012ALTER TABLE data_set_types\\012\\011DROP CONSTRAINT obty_dbin_fk;\\012\\012ALTER TABLE data_set_types\\012\\011ADD CONSTRAINT dsty_bk_uk UNIQUE (code, dbin_id);\\012\\012ALTER TABLE data_set_types\\012\\011ADD CONSTRAINT dsty_dbin_fk FOREIGN KEY (dbin_id) REFERENCES database_instances(id);\\012\\012DROP INDEX data_obty_fk_i;\\012\\012CREATE INDEX data_dsty_fk_i ON data(dsty_id);\\012	\N
+./sourceTest/sql/postgresql/057/017=database_version_logs.tsv:030	source/sql/postgresql/migration/migration-029-030.sql	SUCCESS	2009-03-23 15:34:44.72	-- -------\\012-- add modification_timestamp field to allow edition with Hibernate\\012-- -------\\012ALTER TABLE data\\012\\011ADD COLUMN modification_timestamp TIME_STAMP DEFAULT CURRENT_TIMESTAMP;\\012ALTER TABLE experiment_types\\012\\011ADD COLUMN modification_timestamp TIME_STAMP DEFAULT CURRENT_TIMESTAMP;\\012ALTER TABLE sample_types\\012\\011ADD COLUMN modification_timestamp TIME_STAMP DEFAULT CURRENT_TIMESTAMP;\\012ALTER TABLE material_types\\012\\011ADD COLUMN modification_timestamp TIME_STAMP DEFAULT CURRENT_TIMESTAMP;\\012ALTER TABLE data_set_types\\012\\011ADD COLUMN modification_timestamp TIME_STAMP DEFAULT CURRENT_TIMESTAMP;\\012ALTER TABLE controlled_vocabularies\\012\\011ADD COLUMN modification_timestamp TIME_STAMP DEFAULT CURRENT_TIMESTAMP;\\012-- -------\\012-- add properties to data sets\\012-- -------\\012CREATE TABLE DATA_SET_PROPERTIES (ID TECH_ID NOT NULL,DS_ID TECH_ID NOT NULL,DSTPT_ID TECH_ID NOT NULL,VALUE GENERIC_VALUE,CVTE_ID TECH_ID, MATE_PROP_ID TECH_ID, PERS_ID_REGISTERER TECH_ID NOT NULL,REGISTRATION_TIMESTAMP TIME_STAMP_DFL NOT NULL DEFAULT CURRENT_TIMESTAMP, MODIFICATION_TIMESTAMP TIME_STAMP DEFAULT CURRENT_TIMESTAMP);\\012CREATE TABLE DATA_SET_TYPE_PROPERTY_TYPES (ID TECH_ID NOT NULL,DSTY_ID TECH_ID NOT NULL,PRTY_ID TECH_ID NOT NULL,IS_MANDATORY BOOLEAN_CHAR NOT NULL DEFAULT 'F',IS_MANAGED_INTERNALLY BOOLEAN_CHAR NOT NULL DEFAULT 'F',PERS_ID_REGISTERER TECH_ID NOT NULL,REGISTRATION_TIMESTAMP TIME_STAMP_DFL NOT NULL DEFAULT CURRENT_TIMESTAMP);\\012\\012CREATE SEQUENCE DATA_SET_PROPERTY_ID_SEQ;\\012CREATE SEQUENCE DSTPT_ID_SEQ;\\012\\012ALTER TABLE DATA_SET_TYPE_PROPERTY_TYPES ADD CONSTRAINT DSTPT_PK PRIMARY KEY(ID);\\012ALTER TABLE DATA_SET_PROPERTIES ADD CONSTRAINT DSPR_PK PRIMARY KEY(ID);\\012\\012ALTER TABLE DATA_SET_TYPE_PROPERTY_TYPES ADD CONSTRAINT DSTPT_BK_UK UNIQUE(DSTY_ID,PRTY_ID);\\012ALTER TABLE DATA_SET_PROPERTIES ADD CONSTRAINT DSPR_BK_UK UNIQUE(DS_ID,DSTPT_ID);\\012\\012\\012ALTER TABLE DATA_SET_TYPE_PROPERTY_TYPES ADD CONSTRAINT DSTPT_DSTY_FK FOREIGN KEY (DSTY_ID) REFERENCES DATA_SET_TYPES(ID);\\012ALTER TABLE DATA_SET_TYPE_PROPERTY_TYPES ADD CONSTRAINT DSTPT_PERS_FK FOREIGN KEY (PERS_ID_REGISTERER) REFERENCES PERSONS(ID);\\012ALTER TABLE DATA_SET_TYPE_PROPERTY_TYPES ADD CONSTRAINT DSTPT_PRTY_FK FOREIGN KEY (PRTY_ID) REFERENCES PROPERTY_TYPES(ID);\\012ALTER TABLE DATA_SET_PROPERTIES ADD CONSTRAINT DSPR_CVTE_FK FOREIGN KEY (CVTE_ID) REFERENCES CONTROLLED_VOCABULARY_TERMS(ID);\\012ALTER TABLE DATA_SET_PROPERTIES ADD CONSTRAINT DSPR_DSTPT_FK FOREIGN KEY (DSTPT_ID) REFERENCES DATA_SET_TYPE_PROPERTY_TYPES(ID) ON DELETE CASCADE;\\012ALTER TABLE DATA_SET_PROPERTIES ADD CONSTRAINT DSPR_DS_FK FOREIGN KEY (DS_ID) REFERENCES DATA(ID);\\012ALTER TABLE DATA_SET_PROPERTIES ADD CONSTRAINT DSPR_PERS_FK FOREIGN KEY (PERS_ID_REGISTERER) REFERENCES PERSONS(ID);\\012ALTER TABLE DATA_SET_PROPERTIES ADD CONSTRAINT DSPR_MAPR_FK FOREIGN KEY (MATE_PROP_ID) REFERENCES MATERIALS(ID);\\012\\012ALTER TABLE DATA_SET_PROPERTIES ADD CONSTRAINT DSPR_CK CHECK \\012\\011((VALUE IS NOT NULL AND CVTE_ID IS NULL AND MATE_PROP_ID IS NULL) OR \\012\\011 (VALUE IS NULL AND CVTE_ID IS NOT NULL AND MATE_PROP_ID IS NULL) OR\\012\\011 (VALUE IS NULL AND CVTE_ID IS NULL AND MATE_PROP_ID IS NOT NULL)\\012\\011);\\012\\012CREATE INDEX DSPR_CVTE_FK_I ON DATA_SET_PROPERTIES (CVTE_ID);\\012CREATE INDEX DSPR_DSTPT_FK_I ON DATA_SET_PROPERTIES (DSTPT_ID);\\012CREATE INDEX DSPR_DS_FK_I ON DATA_SET_PROPERTIES (DS_ID);\\012CREATE INDEX DSPR_PERS_FK_I ON DATA_SET_PROPERTIES (PERS_ID_REGISTERER);\\012CREATE INDEX DSTPT_DSTY_FK_I ON DATA_SET_TYPE_PROPERTY_TYPES (DSTY_ID);\\012CREATE INDEX DSTPT_PERS_FK_I ON DATA_SET_TYPE_PROPERTY_TYPES (PERS_ID_REGISTERER);\\012CREATE INDEX DSTPT_PRTY_FK_I ON DATA_SET_TYPE_PROPERTY_TYPES (PRTY_ID);\\012\\012CREATE OR REPLACE FUNCTION DATA_SET_PROPERTY_WITH_MATERIAL_DATA_TYPE_CHECK() RETURNS trigger AS $$\\012DECLARE\\012   v_type_id  CODE;\\012   v_type_id_prop  CODE;\\012BEGIN\\012   if NEW.mate_prop_id IS NOT NULL then\\012\\011\\011\\011-- find material type id of the property type \\012\\011\\011\\011select pt.maty_prop_id into v_type_id_prop \\012\\011\\011\\011  from data_set_type_property_types dstpt, property_types pt \\012\\011\\011\\011 where NEW.dstpt_id = dstpt.id AND dstpt.prty_id = pt.id;\\012\\011\\011\\012\\011\\011\\011if v_type_id_prop IS NOT NULL then\\012\\011\\011\\011\\011-- find material type id of the material which consists the entity's property value\\012\\011\\011\\011\\011select entity.maty_id into v_type_id \\012\\011\\011\\011\\011  from materials entity\\012\\011\\011\\011\\011 where NEW.mate_prop_id = entity.id;\\012\\011\\011\\011\\011if v_type_id != v_type_id_prop then\\012\\011\\011\\011\\011\\011RAISE EXCEPTION 'Insert/Update of property value referencing material (id: %) failed, as referenced material type is different than expected (id %, expected id: %).', \\012\\011\\011\\011\\011\\011\\011\\011\\011\\011\\011\\011\\011 NEW.mate_prop_id, v_type_id, v_type_id_prop;\\012\\011\\011\\011\\011end if;\\012\\011\\011\\011end if;\\012   end if;\\012   RETURN NEW;\\012END;\\012$$ LANGUAGE 'plpgsql';\\012\\012CREATE TRIGGER DATA_SET_PROPERTY_WITH_MATERIAL_DATA_TYPE_CHECK BEFORE INSERT OR UPDATE ON data_set_properties\\012    FOR EACH ROW EXECUTE PROCEDURE DATA_SET_PROPERTY_WITH_MATERIAL_DATA_TYPE_CHECK();   \\012	\N
+./sourceTest/sql/postgresql/057/017=database_version_logs.tsv:032	source/sql/postgresql/migration/migration-031-032.sql	SUCCESS	2009-04-09 09:36:36.2	-- -------\\012-- Modify MATERIAL_BATCHES\\012-- -------\\012\\012ALTER TABLE material_batches\\012    DROP COLUMN proc_id;\\012\\012-- -------\\012-- Modify SAMPLES\\012-- -------\\012\\012ALTER TABLE samples\\012    ADD COLUMN expe_id tech_id;\\012\\012ALTER TABLE samples\\012    ADD CONSTRAINT samp_expe_fk FOREIGN KEY (expe_id) REFERENCES experiments(id);\\012\\012CREATE INDEX samp_expe_fk_i ON samples USING btree (expe_id);\\012\\012-- relink samples directly to experiments\\012\\012UPDATE samples\\012SET expe_id = (SELECT e.id FROM experiments e, procedures p, sample_inputs si \\012               WHERE si.samp_id = samples.id AND si.proc_id = p.id AND p.expe_id = e.id AND e.inva_id IS NULL);\\012\\012\\012-- -------\\012-- Modify DATA\\012-- -------\\012\\012ALTER TABLE data\\012    ADD COLUMN expe_id tech_id;\\012\\012ALTER TABLE data\\012    ADD CONSTRAINT data_expe_fk FOREIGN KEY (expe_id) REFERENCES experiments(id);\\012\\012CREATE INDEX data_expe_fk_i ON data USING btree (expe_id);\\012\\012UPDATE data\\012SET expe_id = (SELECT e.id FROM experiments e, procedures p \\012               WHERE data.proc_id_produced_by = p.id AND p.expe_id = e.id);\\012\\012ALTER TABLE data\\012    ALTER COLUMN expe_id SET NOT NULL;\\012\\012ALTER TABLE data\\012    DROP COLUMN proc_id_produced_by;\\012\\012-- -------\\012-- Drop PROCEDURES, PROCEDURE_TYPES, and SAMPLE_INPUTS\\012-- -------\\012\\012DROP TABLE sample_inputs;\\012DROP TABLE procedures;\\012DROP TABLE procedure_types;\\012\\012DROP SEQUENCE procedure_id_seq;\\012DROP SEQUENCE procedure_type_id_seq;\\012\\012-- -------\\012-- Add CODE_SEQ\\012-- -------\\012\\012CREATE SEQUENCE CODE_SEQ;\\012\\012-- -------\\012-- Add new columns to DATA_STORES\\012-- -------\\012\\012ALTER TABLE data_stores\\012    ADD COLUMN remote_url character varying(250),\\012    ADD COLUMN session_token character varying(50),\\012    ADD COLUMN modification_timestamp time_stamp DEFAULT now();\\012\\012UPDATE data_stores\\012SET remote_url = '', session_token='';\\012\\012ALTER TABLE data_stores\\012    ALTER COLUMN remote_url SET NOT NULL,\\012    ALTER COLUMN session_token SET NOT NULL;\\012\\012-- -------\\012-- Drop foreign keys onto DATA_STORES\\012-- -------\\012\\012ALTER TABLE database_instances\\012    DROP COLUMN dast_id;\\012\\012ALTER TABLE groups\\012    DROP COLUMN dast_id;\\012\\012ALTER TABLE projects\\012    DROP COLUMN dast_id;\\012\\012ALTER TABLE experiments\\012    DROP COLUMN dast_id;\\012\\012-- -------\\012-- Add foreign key from DATA onto DATA_STORES\\012-- -------\\012\\012ALTER TABLE data\\012    ADD COLUMN dast_id tech_id;\\012\\012ALTER TABLE data\\012    ADD CONSTRAINT data_dast_fk FOREIGN KEY (dast_id) REFERENCES data_stores(id);\\012\\012UPDATE data\\012SET dast_id = (select id from data_stores where code = 'STANDARD');\\012\\012ALTER TABLE data\\012    ALTER COLUMN dast_id SET NOT NULL;\\012\\012\\012------------------------------------------------------------------------------------\\012--  Purpose:  Replace trigger SAMPLE_CODE_UNIQUENESS_CHECK \\012------------------------------------------------------------------------------------\\012\\012CREATE OR REPLACE FUNCTION SAMPLE_CODE_UNIQUENESS_CHECK() RETURNS trigger AS $$\\012DECLARE\\012   counter  INTEGER;\\012BEGIN\\012    LOCK TABLE samples IN EXCLUSIVE MODE;\\012    IF (NEW.samp_id_part_of is NULL) THEN\\012        IF (NEW.dbin_id is not NULL) THEN\\012            SELECT count(*) into counter FROM samples \\012                where id != NEW.id and code = NEW.code and samp_id_part_of is NULL and dbin_id = NEW.dbin_id;\\012            IF (counter > 0) THEN\\012                RAISE EXCEPTION 'Insert/Update of Sample (Code: %) failed because database instance sample with the same code already exists.', NEW.code;\\012            END IF;\\012        ELSIF (NEW.grou_id is not NULL) THEN\\012            SELECT count(*) into counter FROM samples \\012                where id != NEW.id and code = NEW.code and samp_id_part_of is NULL and grou_id = NEW.grou_id;\\012            IF (counter > 0) THEN\\012                RAISE EXCEPTION 'Insert/Update of Sample (Code: %) failed because group sample with the same code already exists.', NEW.code;\\012            END IF;\\012        END IF;\\012        ELSE\\012        IF (NEW.dbin_id is not NULL) THEN\\012            SELECT count(*) into counter FROM samples \\012                where id != NEW.id and code = NEW.code and samp_id_part_of = NEW.samp_id_part_of and dbin_id = NEW.dbin_id;\\012            IF (counter > 0) THEN\\012                RAISE EXCEPTION 'Insert/Update of Sample (Code: %) failed because database instance sample with the same code and being the part of the same parent already exists.', NEW.code;\\012            END IF;\\012        ELSIF (NEW.grou_id is not NULL) THEN\\012            SELECT count(*) into counter FROM samples \\012                where id != NEW.id and code = NEW.code and samp_id_part_of = NEW.samp_id_part_of and grou_id = NEW.grou_id;\\012            IF (counter > 0) THEN\\012                RAISE EXCEPTION 'Insert/Update of Sample (Code: %) failed because group sample with the same code and being the part of the same parent already exists.', NEW.code;\\012            END IF;\\012        END IF;\\012        END IF;   \\012   RETURN NEW;\\012END;\\012$$ LANGUAGE 'plpgsql';\\012\\012\\012\\012	\N
+./sourceTest/sql/postgresql/057/017=database_version_logs.tsv:034	source/sql/postgresql/migration/migration-033-034.sql	SUCCESS	2009-05-26 08:32:49.935	------------------------------------------------------------------------------------\\012-- Create sequence for generating permanent identifiers starting with nextval of existing dataset sequence.\\012------------------------------------------------------------------------------------\\012CREATE FUNCTION CREATE_SEQUENCE(EXISTING_SEQUENCE VARCHAR, NEW_SEQUENCE VARCHAR) RETURNS VOID AS $$\\012DECLARE\\012  CURR_SEQ_VAL   INTEGER;\\012BEGIN\\012  SELECT INTO CURR_SEQ_VAL NEXTVAL(EXISTING_SEQUENCE);\\012  EXECUTE 'CREATE SEQUENCE ' || NEW_SEQUENCE || ' START WITH ' || CURR_SEQ_VAL;\\012  RETURN;\\012END;\\012$$ LANGUAGE 'plpgsql';\\012\\012SELECT CREATE_SEQUENCE('DATA_ID_SEQ', 'PERM_ID_SEQ');\\012DROP FUNCTION CREATE_SEQUENCE(VARCHAR, VARCHAR);\\012\\012------------------------------------------------------------------------------------\\012-- Add perm_id columns to samples and experiments.\\012------------------------------------------------------------------------------------\\012ALTER TABLE SAMPLES ADD COLUMN PERM_ID CODE;\\012ALTER TABLE EXPERIMENTS ADD COLUMN PERM_ID CODE;\\012\\012UPDATE SAMPLES SET PERM_ID = to_char(registration_timestamp,'YYYYMMDDHHSSMS') || '-' || NEXTVAL('PERM_ID_SEQ');\\012UPDATE EXPERIMENTS SET PERM_ID = to_char(registration_timestamp,'YYYYMMDDHHSSMS') || '-' || NEXTVAL('PERM_ID_SEQ');\\012ALTER TABLE SAMPLES ALTER COLUMN PERM_ID SET NOT NULL;\\012ALTER TABLE EXPERIMENTS ALTER COLUMN PERM_ID SET NOT NULL;\\012ALTER TABLE SAMPLES ADD CONSTRAINT SAMP_PI_UK UNIQUE(PERM_ID);\\012ALTER TABLE EXPERIMENTS ADD CONSTRAINT EXPE_PI_UK UNIQUE(PERM_ID);\\012\\012\\012------------------------------------------------------------------------------------\\012-- Add column is_chosen_from_list to controlled_vocabularies.\\012------------------------------------------------------------------------------------\\012ALTER TABLE controlled_vocabularies ADD COLUMN is_chosen_from_list BOOLEAN_CHAR NOT NULL DEFAULT TRUE;\\012ALTER TABLE controlled_vocabularies ADD COLUMN source_uri CHARACTER VARYING(250);\\012------------------------------------------------------------------------------------\\012-- Modify Data table - remove arc connection between Sample and Data table, use a flag instead\\012------------------------------------------------------------------------------------\\012\\012-- add new columns\\012\\012ALTER TABLE data\\012    ADD COLUMN is_derived boolean_char;\\012ALTER TABLE data\\012    ADD COLUMN samp_id tech_id;\\012\\012-- update values in new columns\\012\\012UPDATE data\\012    SET is_derived = (samp_id_derived_from IS NOT NULL); \\012UPDATE data\\012    SET samp_id = samp_id_derived_from \\012    WHERE is_derived = 'TRUE';\\012UPDATE data\\012    SET samp_id = samp_id_acquired_from \\012    WHERE is_derived = 'FALSE';\\012\\012-- add constraints and indexes to new columns\\012\\012ALTER TABLE data\\012    ALTER COLUMN is_derived SET NOT NULL;\\012ALTER TABLE data\\012    ALTER COLUMN samp_id SET NOT NULL;   \\012ALTER TABLE data\\012    ADD CONSTRAINT data_samp_fk FOREIGN KEY (samp_id) REFERENCES samples (id);\\012CREATE INDEX data_samp_fk_i ON data USING btree (samp_id);\\012\\012-- remove old columns\\012\\012ALTER TABLE data\\012    DROP COLUMN samp_id_acquired_from;\\012ALTER TABLE data\\012    DROP COLUMN samp_id_derived_from;\\012    \\012------------------------------------------------------------------------------------\\012-- Granting SELECT privilege to group openbis_readonly\\012------------------------------------------------------------------------------------\\012\\012GRANT SELECT ON SEQUENCE attachment_content_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE attachment_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE code_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE controlled_vocabulary_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE cvte_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE data_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE data_set_property_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE data_set_relationship_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE data_set_type_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE data_store_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE data_type_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE database_instance_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE dstpt_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE etpt_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE event_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE experiment_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE experiment_property_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE experiment_type_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE file_format_type_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE group_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE invalidation_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE locator_type_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE material_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE material_property_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE material_type_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE mtpt_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE perm_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE person_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE project_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE property_type_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE role_assignment_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE sample_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE sample_property_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE sample_type_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE stpt_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE attachment_contents TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE attachments TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE controlled_vocabularies TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE controlled_vocabulary_terms TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE data TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE data_set_properties TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE data_set_relationships TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE data_set_type_property_types TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE data_set_types TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE data_stores TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE data_types TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE database_instances TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE database_version_logs TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE events TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE experiment_properties TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE experiment_type_property_types TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE experiment_types TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE experiments TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE external_data TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE file_format_types TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE groups TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE invalidations TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE locator_types TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE material_properties TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE material_type_property_types TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE material_types TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE materials TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE persons TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE projects TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE property_types TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE role_assignments TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE sample_properties TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE sample_type_property_types TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE sample_types TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE samples TO GROUP OPENBIS_READONLY;\\012\\012------------------------------------------------------------------------------------\\012-- Delete MATERIAL_BATCHES table\\012------------------------------------------------------------------------------------\\012\\012-- WARNING: Potential data lost!!!\\012-- WARNING: Potential data lost!!!\\012-- WARNING: Potential data lost!!!\\012\\012DROP TABLE SAMPLE_MATERIAL_BATCHES;\\012DROP TABLE MATERIAL_BATCHES;\\012DROP SEQUENCE MATERIAL_BATCH_ID_SEQ;\\012\\012------------------------------------------------------------------------------------\\012-- Delete MATE_ID_INHIBITOR_OF from table MATERIALS\\012------------------------------------------------------------------------------------\\012\\012-- WARNING: Potential data lost!!!\\012-- WARNING: Potential data lost!!!\\012-- WARNING: Potential data lost!!!\\012\\012ALTER TABLE MATERIALS DROP COLUMN MATE_ID_INHIBITOR_OF;\\012	\N
+./sourceTest/sql/postgresql/057/017=database_version_logs.tsv:041	source/sql/postgresql/migration/migration-040-041.sql	SUCCESS	2009-09-14 13:48:57.539	-- Create FILTERS table\\012\\012CREATE TABLE FILTERS (ID TECH_ID NOT NULL, DBIN_ID TECH_ID NOT NULL, NAME VARCHAR(200) NOT NULL, DESCRIPTION DESCRIPTION_1000,REGISTRATION_TIMESTAMP TIME_STAMP_DFL NOT NULL DEFAULT CURRENT_TIMESTAMP, PERS_ID_REGISTERER TECH_ID NOT NULL, MODIFICATION_TIMESTAMP TIME_STAMP DEFAULT CURRENT_TIMESTAMP, EXPRESSION VARCHAR(2000) NOT NULL, IS_PUBLIC BOOLEAN NOT NULL, GRID_ID VARCHAR(200) NOT NULL);\\012CREATE SEQUENCE FILTER_ID_SEQ;\\012ALTER TABLE FILTERS ADD CONSTRAINT FILT_PK PRIMARY KEY(ID);\\012ALTER TABLE FILTERS ADD CONSTRAINT FILT_BK_UK UNIQUE(NAME, DBIN_ID, GRID_ID);\\012ALTER TABLE FILTERS ADD CONSTRAINT FILT_PERS_FK FOREIGN KEY (PERS_ID_REGISTERER) REFERENCES PERSONS(ID);\\012ALTER TABLE FILTERS ADD CONSTRAINT FILT_DBIN_FK FOREIGN KEY (DBIN_ID) REFERENCES DATABASE_INSTANCES(ID);\\012CREATE INDEX FILT_PERS_FK_I ON FILTERS (PERS_ID_REGISTERER);\\012CREATE INDEX FILT_DBIN_FK_I ON FILTERS (DBIN_ID);\\012GRANT SELECT ON SEQUENCE filter_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE filters TO GROUP OPENBIS_READONLY;\\012\\012-- Add missing foreign key to role assignments authorization group\\012ALTER TABLE ROLE_ASSIGNMENTS ADD CONSTRAINT ROAS_AG_FK_GRANTEE FOREIGN KEY (AG_ID_GRANTEE) REFERENCES AUTHORIZATION_GROUPS(ID);\\012\\012--------------------------------------------------------------------------------------------------\\012-- Modify dataset connections:\\012-- 1. connection with sample shouldn't be mandatory any more\\012-- 2. introduce an arc condition that dataset cannot be connected with a sample and a parent dataset at the same time\\012--------------------------------------------------------------------------------------------------\\012\\012-- Weaken data-sample connection constraint - allow dataset to have no connection with sample\\012ALTER TABLE data ALTER COLUMN samp_id DROP NOT NULL;\\012\\012-- Remove data-sample connection for datasets that have a parent\\012\\012UPDATE data \\012   SET samp_id = NULL \\012 WHERE id IN (SELECT DISTINCT data_id_child FROM data_set_relationships);\\012\\012-- With PostgreSQL 8.4 one can check that before migration there were no cycles in dataset relationships:\\012--\\012-- WITH RECURSIVE data_set_parents(id, parent_ids, cycle) AS (\\012--         SELECT  r.data_id_child AS id, \\012--                 ARRAY[CAST (r.data_id_parent AS bigint)] AS parent_ids, \\012--                 false AS cycle \\012--         FROM data_set_relationships r\\012--     UNION ALL\\012--         SELECT  r.data_id_child,\\012--                 CAST (r.data_id_parent AS bigint) || p.parent_ids,\\012--                 r.data_id_child = ANY(p.parent_ids)\\012--         FROM data_set_relationships r, data_set_parents p\\012--         WHERE r.data_id_parent = p.id AND NOT cycle\\012-- )\\012-- SELECT count(*) AS cycles FROM data_set_parents WHERE cycle = true;\\012\\012---------------------------------------------------------------------------------------------------\\012--  Purpose:  Create DEFERRED triggers:\\012--            * check_dataset_relationships_on_data_table_modification,\\012--            * check_dataset_relationships_on_relationships_table_modification.\\012--            They check that after all modifications of database (just before commit) \\012--            if 'data'/'data_set_relationships' tables are among modified tables \\012--            dataset is not connected with a sample and a parent dataset at the same time.\\012--            This connections are held in two different tables so simple immediate trigger \\012--            with arc check cannot be used and we need two deferred triggers.\\012----------------------------------------------------------------------------------------------------\\012\\012-- trigger for 'data' table\\012\\012CREATE OR REPLACE FUNCTION check_dataset_relationships_on_data_table_modification() RETURNS trigger AS $$\\012DECLARE\\012\\011counter\\011INTEGER;\\012BEGIN\\012\\011-- if there is a connection with a Sample there should not be any connection with a parent Data Set\\012\\011IF (NEW.samp_id IS NOT NULL) THEN\\012\\011\\011-- count number of parents\\012\\011\\011SELECT count(*) INTO counter \\012\\011\\011\\011FROM data_set_relationships \\012\\011\\011\\011WHERE data_id_child = OLD.id;\\012\\011\\011IF (counter > 0) THEN\\012\\011\\011\\011RAISE EXCEPTION 'Insert/Update of Data Set (Code: %) failed because it cannot be connected with a Sample and a parent Data Set at the same time.', OLD.code;\\012\\011\\011END IF;\\012\\011END IF;\\012  RETURN NEW;\\012END;\\012$$ LANGUAGE 'plpgsql';\\012\\012CREATE CONSTRAINT TRIGGER check_dataset_relationships_on_data_table_modification \\012  AFTER INSERT OR UPDATE ON data\\012\\011DEFERRABLE INITIALLY DEFERRED\\012\\011FOR EACH ROW \\012\\011EXECUTE PROCEDURE check_dataset_relationships_on_data_table_modification();\\012\\012-- trigger for 'data_set_relationships'\\012\\012CREATE OR REPLACE FUNCTION check_dataset_relationships_on_relationships_table_modification() RETURNS trigger AS $$\\012DECLARE\\012\\011counter\\011INTEGER;\\012\\011sample_id\\011TECH_ID;\\012\\011data_code\\011CODE;\\012BEGIN\\012\\011-- child will have a parent added so it should not be connected with any sample\\012\\011SELECT samp_id, code INTO sample_id, data_code \\012\\011\\011FROM data \\012\\011\\011WHERE id = NEW.data_id_child;\\012\\011IF (sample_id IS NOT NULL) THEN\\012\\011\\011RAISE EXCEPTION 'Insert/Update of Data Set (Code: %) failed because it cannot be connected to a Sample and to a parent Data Set at the same time.', data_code;\\012\\011END IF;\\012\\011RETURN NEW;\\012END;\\012$$ LANGUAGE 'plpgsql';\\012  \\012CREATE CONSTRAINT TRIGGER check_dataset_relationships_on_relationships_table_modification \\012  AFTER INSERT OR UPDATE ON data_set_relationships\\012\\011DEFERRABLE INITIALLY DEFERRED\\012\\011FOR EACH ROW \\012\\011EXECUTE PROCEDURE check_dataset_relationships_on_relationships_table_modification();\\012	\N
+./sourceTest/sql/postgresql/057/017=database_version_logs.tsv:053	source/sql/postgresql/migration/migration-052-053.sql	SUCCESS	2010-06-08 15:27:55.032	-- Migration from 052 to 053\\012\\012-- Change code uniqueness check for samples of specific type.\\012-- If sample_types.is_subcode_unique flag is set to 'true', additional check is performed \\012-- on codes of samples of the type. Subcodes will have to be unique as well.\\012\\012ALTER TABLE sample_types ADD COLUMN is_subcode_unique boolean_char NOT NULL DEFAULT false;\\012\\012CREATE OR REPLACE FUNCTION SAMPLE_SUBCODE_UNIQUENESS_CHECK() RETURNS trigger AS $$\\012DECLARE\\012   counter  INTEGER;\\012   unique_subcode  BOOLEAN_CHAR;\\012BEGIN\\012  LOCK TABLE samples IN EXCLUSIVE MODE;\\012  \\012  SELECT is_subcode_unique into unique_subcode FROM sample_types WHERE id = NEW.saty_id;\\012  \\012  IF (unique_subcode) THEN\\012    IF (NEW.dbin_id is not NULL) THEN\\012\\011\\011\\011SELECT count(*) into counter FROM samples \\012\\011\\011\\011\\011where id != NEW.id and code = NEW.code and saty_id = NEW.saty_id and dbin_id = NEW.dbin_id;\\012\\011\\011\\011IF (counter > 0) THEN\\012\\011\\011\\011\\011RAISE EXCEPTION 'Insert/Update of Sample (Code: %) failed because database instance sample of the same type with the same subcode already exists.', NEW.code;\\012\\011\\011\\011END IF;\\012\\011\\011ELSIF (NEW.grou_id is not NULL) THEN\\012\\011\\011\\011SELECT count(*) into counter FROM samples \\012\\011\\011\\011\\011where id != NEW.id and code = NEW.code and saty_id = NEW.saty_id and grou_id = NEW.grou_id;\\012\\011\\011\\011IF (counter > 0) THEN\\012\\011\\011\\011\\011RAISE EXCEPTION 'Insert/Update of Sample (Code: %) failed because space sample of the same type with the same subcode already exists.', NEW.code;\\012\\011\\011\\011END IF;\\012\\011\\011END IF;\\012  END IF;\\012  \\012  RETURN NEW;\\012END;\\012$$ LANGUAGE 'plpgsql';\\012\\012CREATE TRIGGER SAMPLE_SUBCODE_UNIQUENESS_CHECK BEFORE INSERT OR UPDATE ON SAMPLES\\012    FOR EACH ROW EXECUTE PROCEDURE SAMPLE_SUBCODE_UNIQUENESS_CHECK();\\012    \\012-- Fixing error messages in old trigger\\012\\012CREATE OR REPLACE FUNCTION SAMPLE_CODE_UNIQUENESS_CHECK() RETURNS trigger AS $$\\012DECLARE\\012   counter  INTEGER;\\012BEGIN\\012  LOCK TABLE samples IN EXCLUSIVE MODE;\\012  \\012\\011  IF (NEW.samp_id_part_of is NULL) THEN\\012\\011\\011  IF (NEW.dbin_id is not NULL) THEN\\012\\011\\011\\011  SELECT count(*) into counter FROM samples \\012\\011\\011      where id != NEW.id and code = NEW.code and samp_id_part_of is NULL and dbin_id = NEW.dbin_id;\\012        IF (counter > 0) THEN\\012\\011\\011\\011\\011  RAISE EXCEPTION 'Insert/Update of Sample (Code: %) failed because database instance sample with the same code already exists.', NEW.code;\\012        END IF;\\012\\011\\011  ELSIF (NEW.grou_id is not NULL) THEN\\012\\011\\011\\011  SELECT count(*) into counter FROM samples \\012\\011\\011\\011\\011  where id != NEW.id and code = NEW.code and samp_id_part_of is NULL and grou_id = NEW.grou_id;\\012\\011\\011\\011  IF (counter > 0) THEN\\012\\011\\011\\011\\011  RAISE EXCEPTION 'Insert/Update of Sample (Code: %) failed because space sample with the same code already exists.', NEW.code;\\012\\011\\011\\011  END IF;\\012      END IF;\\012    ELSE\\012\\011\\011  IF (NEW.dbin_id is not NULL) THEN\\012\\011\\011\\011  SELECT count(*) into counter FROM samples \\012\\011\\011\\011\\011  where id != NEW.id and code = NEW.code and samp_id_part_of = NEW.samp_id_part_of and dbin_id = NEW.dbin_id;\\012\\011\\011\\011  IF (counter > 0) THEN\\012\\011\\011\\011\\011  RAISE EXCEPTION 'Insert/Update of Sample (Code: %) failed because database instance sample with the same code and being the part of the same container already exists.', NEW.code;\\012\\011\\011\\011  END IF;\\012\\011\\011  ELSIF (NEW.grou_id is not NULL) THEN\\012\\011\\011\\011  SELECT count(*) into counter FROM samples \\012\\011\\011\\011\\011  where id != NEW.id and code = NEW.code and samp_id_part_of = NEW.samp_id_part_of and grou_id = NEW.grou_id;\\012\\011\\011\\011  IF (counter > 0) THEN\\012\\011\\011\\011\\011  RAISE EXCEPTION 'Insert/Update of Sample (Code: %) failed because space sample with the same code and being the part of the same container already exists.', NEW.code;\\012\\011\\011\\011  END IF;\\012\\011\\011  END IF;\\012     END IF;   \\012  \\012  RETURN NEW;\\012END;\\012$$ LANGUAGE 'plpgsql';\\012	\N
+./sourceTest/sql/postgresql/057/017=database_version_logs.tsv:054	source/sql/postgresql/migration/migration-053-054.sql	SUCCESS	2010-07-27 11:30:46.766	-- Migration from 053 to 054\\012\\012\\012-- Add RELATIONSHIP_TYPES table\\012CREATE TABLE relationship_types (id TECH_ID NOT NULL, code CODE NOT NULL, label COLUMN_LABEL, parent_label COLUMN_LABEL, child_label COLUMN_LABEL, description DESCRIPTION_2000, registration_timestamp TIME_STAMP_DFL NOT NULL DEFAULT CURRENT_TIMESTAMP, pers_id_registerer TECH_ID NOT NULL, is_managed_internally BOOLEAN_CHAR NOT NULL DEFAULT 'F', is_internal_namespace BOOLEAN_CHAR NOT NULL DEFAULT 'F', dbin_id TECH_ID NOT NULL);\\012\\012-- Add SAMPLE_RELATIONSHIPS table\\012CREATE TABLE sample_relationships (id TECH_ID NOT NULL, sample_id_parent TECH_ID NOT NULL, relationship_id TECH_ID NOT NULL, sample_id_child TECH_ID NOT NULL);\\012\\012-- Add/update constraints\\012ALTER TABLE relationship_types ADD CONSTRAINT rety_pk PRIMARY KEY (id);\\012ALTER TABLE relationship_types ADD CONSTRAINT rety_uk UNIQUE(code,dbin_id);\\012ALTER TABLE sample_relationships ADD CONSTRAINT sare_pk PRIMARY KEY (id);\\012ALTER TABLE sample_relationships ADD CONSTRAINT sare_bk_uk UNIQUE(sample_id_child,sample_id_parent,relationship_id);\\012ALTER TABLE sample_relationships ADD CONSTRAINT sare_data_fk_child FOREIGN KEY (sample_id_child) REFERENCES samples(id) ON DELETE CASCADE;\\012ALTER TABLE sample_relationships ADD CONSTRAINT sare_data_fk_parent FOREIGN KEY (sample_id_parent) REFERENCES samples(id) ON DELETE CASCADE;\\012ALTER TABLE sample_relationships ADD CONSTRAINT sare_data_fk_relationship FOREIGN KEY (relationship_id) REFERENCES relationship_types(id);\\012\\012-- Create index\\012CREATE INDEX sare_data_fk_i_child ON sample_relationships (sample_id_child);\\012CREATE INDEX sare_data_fk_i_parent ON sample_relationships (sample_id_parent);\\012CREATE INDEX sare_data_fk_i_relationship ON sample_relationships (relationship_id);\\012\\012-- Create sequence for RELATIONSHIP_TYPES\\012CREATE SEQUENCE RELATIONSHIP_TYPE_ID_SEQ;\\012CREATE SEQUENCE SAMPLE_RELATIONSHIP_ID_SEQ;\\012\\012-- Create initial relationships\\012insert into relationship_types\\012(id, \\012code, \\012label, \\012parent_label, \\012child_label, \\012description, \\012pers_id_registerer, \\012is_managed_internally, \\012is_internal_namespace, \\012dbin_id) \\012values\\012(\\012nextval('RELATIONSHIP_TYPE_ID_SEQ'),\\012'PARENT_CHILD',\\012'Parent - Child', \\012'Parent', \\012'Child', \\012'Parent - Child relationship', \\012(select id from persons where user_id ='system'), \\012'T', \\012'T', \\012(select id from database_instances where is_original_source = 'T')\\012);\\012\\012insert into relationship_types\\012(id, \\012code, \\012label, \\012parent_label, \\012child_label, \\012description, \\012pers_id_registerer, \\012is_managed_internally, \\012is_internal_namespace, \\012dbin_id) \\012values\\012(\\012nextval('RELATIONSHIP_TYPE_ID_SEQ'),\\012'PLATE_CONTROL_LAYOUT',\\012'Plate - Control Layout', \\012'Plate', \\012'Control Layout', \\012'Plate - Control Layout relationship', \\012(select id from persons where user_id ='system'), \\012'T', \\012'T', \\012(select id from database_instances where is_original_source = 'T')\\012); \\012\\012\\012-- Migrate sample relationships to new schema\\012INSERT INTO sample_relationships (id, sample_id_parent,sample_id_child,relationship_id) (select distinct nextval('SAMPLE_RELATIONSHIP_ID_SEQ') as id, s.SAMP_ID_GENERATED_FROM as parent_id, s.ID as child_id, rt.id as relationship_id from samples s, relationship_types rt  WHERE rt.code = 'PARENT_CHILD' and s.SAMP_ID_GENERATED_FROM is not null); \\012INSERT INTO sample_relationships (id, sample_id_parent,sample_id_child,relationship_id) (select distinct nextval('SAMPLE_RELATIONSHIP_ID_SEQ') as id, s.SAMP_ID_CONTROL_LAYOUT as parent_id, s.ID as child_id, rt.id as relationship_id from samples s, relationship_types rt  WHERE rt.code = 'PLATE_CONTROL_LAYOUT' and s.SAMP_ID_CONTROL_LAYOUT is not null);\\012\\012-- Drop old sample relations\\012ALTER TABLE SAMPLES DROP COLUMN SAMP_ID_TOP;\\012ALTER TABLE SAMPLES DROP COLUMN SAMP_ID_GENERATED_FROM;\\012ALTER TABLE SAMPLES DROP COLUMN SAMP_ID_CONTROL_LAYOUT;\\012\\012--------------------------------------------------------------------------------------\\012--------------------------------------------------------------------------------------\\012-- This is a screening specific migration. Nothing will be performed on openBIS databases \\012-- which are not screening specific.\\012-- \\012-- This migration for each existing connection between oligo well, oligo material and gene material\\012-- creates a direct connection between the well and the gene. \\012--------------------------------------------------------------------------------------\\012--------------------------------------------------------------------------------------\\012 \\012\\011\\012CREATE OR REPLACE FUNCTION CONNECT_WELLS_WITH_GENES() RETURNS void AS $$\\012DECLARE\\012\\011counter  int;\\012\\011oligo_well_exists bool;\\012BEGIN\\012\\011--------------------------------------------------\\012\\011-- create a gene property and assign it to oligo well\\012\\011--------------------------------------------------\\012\\011\\012\\011select true \\012\\011into oligo_well_exists\\012\\011from sample_types \\012\\011where code = 'OLIGO_WELL';\\012\\011\\012\\011if oligo_well_exists IS NULL then \\012\\011\\011-- skip migration if there are no oligo wells\\012\\011\\011return;\\012\\011end if;   \\012\\011\\012\\011insert into property_types(\\012\\011\\011id, \\012\\011\\011code, description, label, \\012\\011\\011daty_id,\\012\\011\\011pers_id_registerer,\\012\\011\\011dbin_id,\\012\\011\\011maty_prop_id) \\012\\011values(\\012\\011\\011\\011nextval('PROPERTY_TYPE_ID_SEQ'), \\012\\011\\011\\011'GENE','Inhibited gene','Gene',\\012\\011\\011\\011(select id from data_types where code = 'MATERIAL'), \\012\\011\\011\\011(select id from persons where user_id ='system'), \\012\\011\\011\\011(select id from database_instances where is_original_source = 'T'), \\012\\011\\011\\011(select id from material_types where code = 'GENE')\\012\\011\\011);\\012\\011\\011\\012\\011insert into sample_type_property_types( \\012\\011  id,\\012\\011  saty_id,\\012\\011  prty_id,\\012\\011  is_mandatory,\\012\\011  pers_id_registerer,\\012\\011  ordinal\\012\\011) values(\\012\\011\\011\\011nextval('stpt_id_seq'), \\012\\011\\011\\011(select id from sample_types where code = 'OLIGO_WELL'),\\012\\011\\011\\011(select id from property_types where code = 'GENE'),\\012\\011\\011\\011false,\\012\\011\\011\\011(select id from persons where user_id ='system'),\\012\\011\\011\\011(select max(ordinal)+1 from sample_type_property_types \\012\\011\\011\\011\\011where saty_id = (select id from sample_types where code = 'OLIGO_WELL'))\\012\\011\\011);\\012\\012\\011--------------------------------------------------\\012\\011-- create a gene material property for each oligo well\\012\\011--------------------------------------------------\\012\\011\\011\\012\\011select \\011count(*)\\012\\011into counter\\012\\011from\\012\\011\\011samples well, sample_types well_type, sample_properties well_props, \\012\\011\\011materials well_material, material_properties well_material_props,\\012\\011\\011materials nested_well_material\\012\\011where\\012\\011\\011well_type.code = 'OLIGO_WELL' and\\012\\011\\011-- find 'well_material' assigned to the well\\012\\011\\011well_props.samp_id = well.id and well_material.id = well_props.mate_prop_id and \\012\\011\\011-- additional joins to entity type tables\\012\\011\\011well_type.id = well.saty_id and\\012\\011\\011-- well content material property\\012\\011\\011well_material_props.mate_id = well_material.id and \\012\\011\\011-- material connected to the material in the well (e.g. gene)\\012\\011\\011well_material_props.mate_prop_id = nested_well_material.id and\\012\\011\\011nested_well_material.maty_id = (select id from material_types where code = 'GENE');\\012\\011\\012\\011if counter = 0 then \\012\\011\\011-- skip migration if there are no genes indirectly connected to oligo wells\\012\\011\\011return;\\012\\011end if;   \\012\\012\\011insert into sample_properties(id, samp_id, stpt_id, mate_prop_id, pers_id_registerer) (\\012\\011\\011select \\011nextval('sample_property_id_seq') id, \\012\\011\\011\\011well.id samp_id, \\012\\011\\011\\011(select stpt.id from sample_type_property_types stpt, property_types props where stpt.prty_id = props.id and props.code='GENE') stpt_id,\\012\\011\\011\\011nested_well_material.id mate_prop_id,\\012\\011\\011\\011(select id from persons where user_id ='system') pers_id_registerer \\012\\011\\011from\\012\\011\\011\\011samples well, sample_types well_type, sample_properties well_props, \\012\\011\\011\\011materials well_material, material_properties well_material_props,\\012\\011\\011\\011materials nested_well_material\\012\\011\\011where\\012\\011\\011\\011well_type.code = 'OLIGO_WELL' and\\012\\011\\011\\011-- find 'well_material' assigned to the well\\012\\011\\011\\011well_props.samp_id = well.id and well_material.id = well_props.mate_prop_id and \\012\\011\\011\\011-- additional joins to entity type tables\\012\\011\\011\\011well_type.id = well.saty_id and\\012\\011\\011\\011-- well content material property\\012\\011\\011\\011well_material_props.mate_id = well_material.id and \\012\\011\\011\\011-- material connected to the material in the well (e.g. gene)\\012\\011\\011\\011well_material_props.mate_prop_id = nested_well_material.id and\\012\\011\\011\\011nested_well_material.maty_id = (select id from material_types where code = 'GENE')\\012\\011);\\012\\012END;\\012$$ LANGUAGE 'plpgsql';\\012\\012select CONNECT_WELLS_WITH_GENES();\\012drop function CONNECT_WELLS_WITH_GENES();\\012\\012--------------------------------------------------------------------------------------\\012--------------------------------------------------------------------------------------\\012\\012-- drop dataset triggers\\012\\012DROP TRIGGER check_dataset_relationships_on_data_table_modification ON data;\\012DROP FUNCTION check_dataset_relationships_on_data_table_modification();\\012DROP TRIGGER check_dataset_relationships_on_relationships_table_modification ON data_set_relationships;\\012DROP FUNCTION check_dataset_relationships_on_relationships_table_modification();\\012 \\012\\012\\012\\012\\012\\012\\012\\012	\N
+./sourceTest/sql/postgresql/057/017=database_version_logs.tsv:056	source/sql/postgresql/migration/migration-055-056.sql	SUCCESS	2010-09-10 09:06:20.278	-- Migration from 055 to 056\\012\\012--------------------------------------------------------------------------------------\\012--------------------------------------------------------------------------------------\\012-- Screening specific migration. Nothing will be performed on openBIS databases \\012-- which are not screening specific.\\012--------------------------------------------------------------------------------------\\012--------------------------------------------------------------------------------------\\012\\012CREATE OR REPLACE FUNCTION merge_words(text, text) RETURNS text AS $$\\012DECLARE\\012  BEGIN\\012    IF  character_length($1) > 0 THEN\\012      RETURN $1 || ' ' || $2;\\012    ELSE\\012      RETURN $2;\\012    END IF;\\012  END;\\012$$ LANGUAGE plpgsql;\\012\\012CREATE AGGREGATE merge_words(text)\\012(\\012  SFUNC = merge_words,\\012  STYPE = text\\012);\\012\\012\\012CREATE OR REPLACE FUNCTION REPLACE_GENE_SYMBOL_BY_GENE_ID() RETURNS void AS $$\\012DECLARE\\012\\011counter  int;\\012\\011library_id_assigned_to_gene bool;\\012BEGIN\\012\\011--------------------------------------------------\\012\\011-- create a GENE_SYMBOL property and assign it to GENE\\012\\011--------------------------------------------------\\012\\011\\012\\011select true  \\012\\011into library_id_assigned_to_gene \\012\\011from material_type_property_types mtpt, material_types mt, property_types pt  \\012\\011where mtpt.maty_id = mt.id and mtpt.prty_id = pt.id \\012\\011\\011and mt.code = 'GENE' and pt.code = 'LIBRARY_ID';\\012\\011\\012\\011if library_id_assigned_to_gene IS NULL then \\012\\011\\011-- skip migration if gene has no library_id property\\012\\011\\011return;\\012\\011end if; \\012\\011\\012\\011\\012\\011select count(*)\\012\\011into counter \\012\\011from  \\012\\011\\011(select m.id, count(mp.id) as c \\012\\011\\011\\011from materials m, material_types mt, material_properties mp, material_type_property_types mtpt, property_types pt \\012\\011\\011\\011where m.maty_id = mt.id and mp.mate_id = m.id and mp.mtpt_id = mtpt.id and mtpt.maty_id = mt.id and pt.id = mtpt.prty_id\\012\\011\\011\\011\\011and mt.code = 'GENE' and pt.code = 'LIBRARY_ID' \\012\\011\\011\\011group by m.id) as counter_table \\012\\011where c < 1; \\012\\011\\012\\011if counter > 0 then \\012\\011\\011-- skip migration if there is at least one gene without library_id\\012\\011\\011return;\\012\\011end if;\\012\\011\\012\\011\\012\\011insert into property_types\\012\\011\\011(id\\012\\011\\011,code\\012\\011\\011,description\\012\\011\\011,label\\012\\011\\011,daty_id\\012\\011\\011,pers_id_registerer\\012\\011\\011,dbin_id)\\012\\011values \\012\\011\\011(nextval('PROPERTY_TYPE_ID_SEQ')\\012\\011\\011,'GENE_SYMBOLS'\\012\\011\\011,'Gene symbols'\\012\\011\\011,'Gene symbols'\\012\\011\\011,(select id from data_types where code ='VARCHAR')\\012\\011\\011,(select id from persons where user_id ='system')\\012\\011\\011,(select id from database_instances where is_original_source = 'T')\\012\\011);\\012\\011\\011\\012\\011insert into material_type_property_types( \\012\\011  id,\\012\\011  maty_id,\\012\\011  prty_id,\\012\\011  is_mandatory,\\012\\011  pers_id_registerer,\\012\\011  ordinal\\012\\011) values(\\012\\011\\011\\011nextval('mtpt_id_seq'), \\012\\011\\011\\011(select id from material_types where code = 'GENE'),\\012\\011\\011\\011(select id from property_types where code = 'GENE_SYMBOLS'),\\012\\011\\011\\011false,\\012\\011\\011\\011(select id from persons where user_id ='system'),\\012\\011\\011\\011(select max(ordinal)+1 from material_type_property_types \\012\\011\\011\\011\\011where maty_id = (select id from material_types where code = 'GENE'))\\012\\011\\011);\\012\\012\\011--------------------------------------------------\\012\\011-- create temporary table with all gene migration information\\012\\011--------------------------------------------------\\012\\012\\011create temp table genes \\012\\011(\\012\\011\\011id tech_id,\\012\\011\\011code code,\\012\\011\\011library_id generic_value,\\012\\011\\011gene_codes generic_value,\\012\\011\\011new_id tech_id,\\012\\011\\011library_tech_id tech_id\\011\\011\\012\\011);\\012\\011\\012\\011insert into genes (id, code, library_id, library_tech_id)\\012\\011\\011(select m.id, m.code, mp.value as library_id, mp.id as library_tech_id from materials m, material_properties mp, material_type_property_types mtpt, property_types pt, material_types mt\\012\\011\\011where mp.mate_id = m.id and  mp.mtpt_id = mtpt.id and pt.id = mtpt.prty_id and pt.code = 'LIBRARY_ID' and mt.id = m.maty_id and mt.id = mtpt.maty_id and mt.code = 'GENE');\\012\\011\\012\\011update genes set new_id = map.to_id from (select g_from.id as from_id, min(g_to.id) as to_id  from genes g_from, genes g_to where g_from.library_id = g_to.library_id group by g_from.id) as map where map.from_id = id;\\011\\012\\011\\012\\011update genes set gene_codes = map.gene_codes from (select g_from.library_id as lib_id, merge_words(distinct g_to.code) as gene_codes from genes g_from, genes g_to where g_from.library_id = g_to.library_id group by g_from.library_id) as map where map.lib_id = library_id;\\011\\012\\012\\011--------------------------------------------------\\012\\011-- update gene references\\012\\011--------------------------------------------------\\012\\012\\011update EXPERIMENTS set MATE_ID_STUDY_OBJECT = genes.new_id from genes where genes.id = MATE_ID_STUDY_OBJECT and not genes.id = genes.new_id;\\012\\011update EXPERIMENT_PROPERTIES set  MATE_PROP_ID = genes.new_id from genes where genes.id = MATE_PROP_ID and not genes.id = genes.new_id;\\012\\011update MATERIAL_PROPERTIES set  MATE_PROP_ID = genes.new_id from genes where genes.id = MATE_PROP_ID and not genes.id = genes.new_id;\\012\\011update SAMPLE_PROPERTIES set  MATE_PROP_ID = genes.new_id from genes where genes.id = MATE_PROP_ID and not genes.id = genes.new_id;\\012\\011update DATA_SET_PROPERTIES set  MATE_PROP_ID = genes.new_id from genes where genes.id = MATE_PROP_ID and not genes.id = genes.new_id;\\012\\011\\012\\011delete from  material_properties where mate_id in (select id from genes where not genes.id = genes.new_id);\\012\\011delete from MATERIALS where id in (select id from genes where not genes.id = genes.new_id);\\012\\012\\011delete from genes where id in (select id from genes where not genes.id = genes.new_id);\\012\\012\\012\\011--------------------------------------------------\\012\\011-- replace gene code with library_id\\012\\011--------------------------------------------------\\012\\011\\012\\011update materials set code = genes.library_id from genes where materials.id = genes.id ;\\012\\011delete from material_properties where id in (select library_tech_id from genes);\\012\\011\\012\\011--------------------------------------------------\\012\\011-- create a gene symbols property for each gene\\012\\011--------------------------------------------------\\012\\011\\012\\011insert into material_properties\\012\\011\\011(id\\012\\011  , mate_id\\012\\011  , mtpt_id\\012\\011  , "value"\\012\\011  , pers_id_registerer)\\012\\011\\011(select nextval('material_property_id_seq') id\\012\\011  \\011, genes.id  mate_id\\012\\011    , (select mtpt.id\\012\\011    \\011\\011from   material_type_property_types mtpt, material_types mt, property_types pt\\012\\011    \\011\\011where  pt.code = 'GENE_SYMBOLS' and mt.code = 'GENE' and mtpt.prty_id = pt.id\\012\\011        \\011and mtpt.maty_id = mt.id) mtpt_id\\012\\011    , genes.gene_codes "value"\\012\\011    , (select id from persons where user_id = 'system') pers_id_registerer\\012\\011 \\011from genes); \\012\\012\\011--------------------------------------------------\\012\\011-- delete temporary table\\012\\011--------------------------------------------------\\012\\011\\012\\011drop table genes;\\012\\011\\012END;\\012$$ LANGUAGE 'plpgsql';\\012\\012select REPLACE_GENE_SYMBOL_BY_GENE_ID();\\012drop function REPLACE_GENE_SYMBOL_BY_GENE_ID();\\012DROP AGGREGATE merge_words(text);\\012drop function merge_words(text,text);\\012\\012\\012--------------------------------------------------------------------------------------\\012--------------------------------------------------------------------------------------\\012\\012UPDATE sample_types SET code = 'SIRNA_WELL' WHERE code = 'OLIGO_WELL';\\012UPDATE material_types SET code = 'SIRNA' WHERE code = 'OLIGO';\\012UPDATE property_types SET code = 'SIRNA', label = 'siRNA' WHERE code = 'OLIGO';\\012\\012\\012\\012\\012\\012\\012\\012\\012\\012\\012\\012\\012\\012\\012\\012\\012\\012\\012\\012	\N
+./sourceTest/sql/postgresql/057/schema-057.sql:    LANGUAGE plpgsql
+./sourceTest/sql/postgresql/057/schema-057.sql:    LANGUAGE plpgsql
+./sourceTest/sql/postgresql/057/schema-057.sql:    LANGUAGE plpgsql
+./sourceTest/sql/postgresql/057/schema-057.sql:    LANGUAGE plpgsql
+./sourceTest/sql/postgresql/057/schema-057.sql:    LANGUAGE plpgsql
+./sourceTest/sql/postgresql/057/schema-057.sql:    LANGUAGE plpgsql
+./sourceTest/sql/postgresql/057/schema-057.sql:    LANGUAGE plpgsql
+./sourceTest/sql/postgresql/057/schema-057.sql:    LANGUAGE plpgsql
+./sourceTest/sql/postgresql/057/schema-057.sql:    LANGUAGE plpgsql
+./sourceTest/sql/postgresql/058/.svn/text-base/017=database_version_logs.tsv.svn-base:027	D:\\User\\felmer\\dev-workspace\\openbis/source/sql/postgresql/027/function-027.sql	SUCCESS	2008-11-05 09:18:00.403	-- Creating Functions\\012\\012------------------------------------------------------------------------------------\\012--  Purpose:  Create function RENAME_SEQUENCE() that is required for renaming the sequences belonging to tables\\012------------------------------------------------------------------------------------\\012CREATE FUNCTION RENAME_SEQUENCE(OLD_NAME VARCHAR, NEW_NAME VARCHAR) RETURNS INTEGER AS $$\\012DECLARE\\012  CURR_SEQ_VAL   INTEGER;\\012BEGIN\\012  SELECT INTO CURR_SEQ_VAL NEXTVAL(OLD_NAME);\\012  EXECUTE 'CREATE SEQUENCE ' || NEW_NAME || ' START WITH ' || CURR_SEQ_VAL;\\012  EXECUTE 'DROP SEQUENCE ' || OLD_NAME;\\012  RETURN CURR_SEQ_VAL;\\012END;\\012$$ LANGUAGE 'plpgsql';\\012\\012\\012------------------------------------------------------------------------------------\\012--  Purpose:  Create trigger CONTROLLED_VOCABULARY_CHECK \\012------------------------------------------------------------------------------------\\012\\012CREATE OR REPLACE FUNCTION CONTROLLED_VOCABULARY_CHECK() RETURNS trigger AS $$\\012DECLARE\\012   v_code  CODE;\\012BEGIN\\012\\012   select code into v_code from data_types where id = NEW.daty_id;\\012\\012   -- Check if the data is of type "CONTROLLEDVOCABULARY"\\012   if v_code = 'CONTROLLEDVOCABULARY' then\\012      if NEW.covo_id IS NULL then\\012         RAISE EXCEPTION 'Insert/Update of Property Type (Code: %) failed, as its Data Type is CONTROLLEDVOCABULARY, but it is not linked to a Controlled Vocabulary.', NEW.code;\\012      end if;\\012   end if;\\012\\012   RETURN NEW;\\012\\012END;\\012$$ LANGUAGE 'plpgsql';\\012\\012CREATE TRIGGER CONTROLLED_VOCABULARY_CHECK BEFORE INSERT OR UPDATE ON PROPERTY_TYPES\\012    FOR EACH ROW EXECUTE PROCEDURE CONTROLLED_VOCABULARY_CHECK();\\012\\012\\012------------------------------------------------------------------------------------\\012--  Purpose:  Create trigger EXTERNAL_DATA_STORAGE_FORMAT_CHECK \\012------------------------------------------------------------------------------------\\012\\012CREATE OR REPLACE FUNCTION EXTERNAL_DATA_STORAGE_FORMAT_CHECK() RETURNS trigger AS $$\\012DECLARE\\012   v_covo_code  CODE;\\012   data_code CODE;\\012BEGIN\\012\\012   select code into v_covo_code from controlled_vocabularies\\012      where is_internal_namespace = true and \\012         id = (select covo_id from controlled_vocabulary_terms where id = NEW.cvte_id_stor_fmt);\\012   -- Check if the data storage format is a term of the controlled vocabulary "STORAGE_FORMAT"\\012   if v_covo_code != 'STORAGE_FORMAT' then\\012      select code into data_code from data where id = NEW.data_id; \\012      RAISE EXCEPTION 'Insert/Update of Data (Code: %) failed, as its Storage Format is %, but is required to be STORAGE_FORMAT.', data_code, v_covo_code;\\012   end if;\\012\\012   RETURN NEW;\\012\\012END;\\012$$ LANGUAGE 'plpgsql';\\012\\012CREATE TRIGGER EXTERNAL_DATA_STORAGE_FORMAT_CHECK BEFORE INSERT OR UPDATE ON EXTERNAL_DATA\\012    FOR EACH ROW EXECUTE PROCEDURE EXTERNAL_DATA_STORAGE_FORMAT_CHECK();\\012\\012------------------------------------------------------------------------------------\\012--  Purpose:  Create trigger SAMPLE_CODE_UNIQUENESS_CHECK \\012------------------------------------------------------------------------------------\\012\\012CREATE OR REPLACE FUNCTION SAMPLE_CODE_UNIQUENESS_CHECK() RETURNS trigger AS $$\\012DECLARE\\012   counter  INTEGER;\\012BEGIN\\012\\011IF (NEW.samp_id_part_of is NULL) THEN\\012\\011\\011IF (NEW.dbin_id is not NULL) THEN\\012\\011\\011\\011SELECT count(*) into counter FROM samples \\012\\011\\011\\011\\011where id != NEW.id and code = NEW.code and samp_id_part_of is NULL and dbin_id = NEW.dbin_id;\\012\\011\\011\\011IF (counter > 0) THEN\\012\\011\\011\\011\\011RAISE EXCEPTION 'Insert/Update of Sample (Code: %) failed because database instance sample with the same code already exists.', NEW.code;\\012\\011\\011\\011END IF;\\012\\011\\011ELSIF (NEW.grou_id is not NULL) THEN\\012\\011\\011\\011SELECT count(*) into counter FROM samples \\012\\011\\011\\011\\011where id != NEW.id and code = NEW.code and samp_id_part_of is NULL and grou_id = NEW.grou_id;\\012\\011\\011\\011IF (counter > 0) THEN\\012\\011\\011\\011\\011RAISE EXCEPTION 'Insert/Update of Sample (Code: %) failed because group sample with the same code already exists.', NEW.code;\\012\\011\\011\\011END IF;\\012\\011\\011END IF;\\012        ELSE\\012\\011\\011IF (NEW.dbin_id is not NULL) THEN\\012\\011\\011\\011SELECT count(*) into counter FROM samples \\012\\011\\011\\011\\011where id != NEW.id and code = NEW.code and samp_id_part_of = NEW.samp_id_part_of and dbin_id = NEW.dbin_id;\\012\\011\\011\\011IF (counter > 0) THEN\\012\\011\\011\\011\\011RAISE EXCEPTION 'Insert/Update of Sample (Code: %) failed because database instance sample with the same code and being the part of the same parent already exists.', NEW.code;\\012\\011\\011\\011END IF;\\012\\011\\011ELSIF (NEW.grou_id is not NULL) THEN\\012\\011\\011\\011SELECT count(*) into counter FROM samples \\012\\011\\011\\011\\011where id != NEW.id and code = NEW.code and samp_id_part_of = NEW.samp_id_part_of and grou_id = NEW.grou_id;\\012\\011\\011\\011IF (counter > 0) THEN\\012\\011\\011\\011\\011RAISE EXCEPTION 'Insert/Update of Sample (Code: %) failed because group sample with the same code and being the part of the same parent already exists.', NEW.code;\\012\\011\\011\\011END IF;\\012\\011\\011END IF;\\012        END IF;   \\012   RETURN NEW;\\012END;\\012$$ LANGUAGE 'plpgsql';\\012\\012CREATE TRIGGER SAMPLE_CODE_UNIQUENESS_CHECK BEFORE INSERT OR UPDATE ON SAMPLES\\012    FOR EACH ROW EXECUTE PROCEDURE SAMPLE_CODE_UNIQUENESS_CHECK();\\012	\N
+./sourceTest/sql/postgresql/058/.svn/text-base/017=database_version_logs.tsv.svn-base:028	source/sql/postgresql/migration/migration-027-028.sql	SUCCESS	2008-11-18 13:24:17.508	-- Create EXPERIMENT_ATTACHMENT_CONTENTS.\\012CREATE TABLE EXPERIMENT_ATTACHMENT_CONTENTS (ID TECH_ID NOT NULL,VALUE FILE NOT NULL);\\012CREATE SEQUENCE EXPERIMENT_ATTACHMENT_CONTENT_ID_SEQ;\\012ALTER TABLE EXPERIMENT_ATTACHMENT_CONTENTS ADD CONSTRAINT EXAC_PK PRIMARY KEY(ID);\\012\\012-- Alter EXPERIMENT_ATTACHMENTS by adding the new column which has a NULL constraint.\\012-- The NOT NULL constraint is added later on.\\012ALTER TABLE EXPERIMENT_ATTACHMENTS ADD COLUMN EXAC_ID TECH_ID;\\012\\012-- Does the VALUE migration between EXPERIMENT_ATTACHMENTS to EXPERIMENT_ATTACHMENT_CONTENTS.\\012CREATE OR REPLACE FUNCTION move_exp_att_content() RETURNS integer AS $$\\012DECLARE\\012    rec RECORD;\\012    seq BIGINT;\\012BEGIN\\012  FOR rec IN SELECT id, value FROM EXPERIMENT_ATTACHMENTS LOOP\\012  \\011seq := nextval('EXPERIMENT_ATTACHMENT_CONTENT_ID_SEQ');\\012    INSERT INTO EXPERIMENT_ATTACHMENT_CONTENTS (id, value) VALUES (seq, rec.value);\\012    UPDATE EXPERIMENT_ATTACHMENTS SET exac_id = seq WHERE id = rec.id;\\012  END LOOP;\\012  RETURN 1;\\012END;\\012$$ LANGUAGE 'plpgsql';\\012\\012-- Call the function.\\012SELECT move_exp_att_content();\\012DROP FUNCTION move_exp_att_content();\\012\\012\\012-- Finish EXPERIMENT_ATTACHMENTS changes.\\012ALTER TABLE EXPERIMENT_ATTACHMENTS ADD CONSTRAINT EXAT_CONT_FK FOREIGN KEY (EXAC_ID) REFERENCES EXPERIMENT_ATTACHMENT_CONTENTS(ID);\\012ALTER TABLE EXPERIMENT_ATTACHMENTS DROP COLUMN VALUE;\\012ALTER TABLE EXPERIMENT_ATTACHMENTS ALTER COLUMN EXAC_ID SET NOT NULL;\\012	\N
+./sourceTest/sql/postgresql/058/.svn/text-base/017=database_version_logs.tsv.svn-base:029	source/sql/postgresql/migration/migration-028-029.sql	SUCCESS	2009-03-18 10:50:20.105	-- -------\\012-- add modification_timestamp field to allow edition with Hibernate\\012-- -------\\012\\012ALTER TABLE samples\\012\\011ADD COLUMN modification_timestamp TIME_STAMP DEFAULT CURRENT_TIMESTAMP;\\012\\012ALTER TABLE experiments\\012\\011ADD COLUMN modification_timestamp TIME_STAMP DEFAULT CURRENT_TIMESTAMP;\\012\\012ALTER TABLE materials\\012\\011ADD COLUMN modification_timestamp TIME_STAMP DEFAULT CURRENT_TIMESTAMP;\\012\\012ALTER TABLE experiment_properties\\012\\011ADD COLUMN modification_timestamp TIME_STAMP DEFAULT CURRENT_TIMESTAMP;\\012\\012ALTER TABLE material_properties\\012\\011ADD COLUMN modification_timestamp TIME_STAMP DEFAULT CURRENT_TIMESTAMP;\\012\\012ALTER TABLE sample_properties\\012\\011ADD COLUMN modification_timestamp TIME_STAMP DEFAULT CURRENT_TIMESTAMP;\\012\\012-- -------\\012-- add property data type which references materials\\012-- -------\\012\\012ALTER TABLE property_types\\012\\011ADD COLUMN maty_prop_id tech_id;\\012\\012ALTER TABLE property_types\\012\\011ADD CONSTRAINT prty_maty_fk FOREIGN KEY (maty_prop_id) REFERENCES material_types(id);\\012\\012ALTER TABLE experiment_properties\\012\\011ADD COLUMN mate_prop_id tech_id;\\012\\012ALTER TABLE material_properties\\012\\011ADD COLUMN mate_prop_id tech_id;\\012\\012ALTER TABLE sample_properties\\012\\011ADD COLUMN mate_prop_id tech_id;\\012\\012ALTER TABLE experiment_properties\\012\\011ADD CONSTRAINT expr_mapr_fk FOREIGN KEY (mate_prop_id) REFERENCES materials(id);\\012\\012ALTER TABLE material_properties\\012\\011ADD CONSTRAINT mapr_mapr_fk FOREIGN KEY (mate_prop_id) REFERENCES materials(id);\\012\\012ALTER TABLE sample_properties\\012\\011ADD CONSTRAINT sapr_mapr_fk FOREIGN KEY (mate_prop_id) REFERENCES materials(id);\\012\\012insert into data_types\\012(id\\012 ,code\\012 ,description)\\012 values \\012 (nextval('DATA_TYPE_ID_SEQ')\\012 ,'MATERIAL'\\012 ,'Reference to a material'\\012);\\012\\012ALTER TABLE MATERIAL_PROPERTIES DROP CONSTRAINT MAPR_CK;\\012ALTER TABLE MATERIAL_PROPERTIES ADD CONSTRAINT MAPR_CK CHECK \\012\\011((VALUE IS NOT NULL AND CVTE_ID IS NULL AND MATE_PROP_ID IS NULL) OR \\012\\011 (VALUE IS NULL AND CVTE_ID IS NOT NULL AND MATE_PROP_ID IS NULL) OR\\012\\011 (VALUE IS NULL AND CVTE_ID IS NULL AND MATE_PROP_ID IS NOT NULL)\\012\\011);\\012\\012ALTER TABLE EXPERIMENT_PROPERTIES DROP CONSTRAINT EXPR_CK;\\012ALTER TABLE EXPERIMENT_PROPERTIES ADD CONSTRAINT EXPR_CK CHECK \\012\\011((VALUE IS NOT NULL AND CVTE_ID IS NULL AND MATE_PROP_ID IS NULL) OR \\012\\011 (VALUE IS NULL AND CVTE_ID IS NOT NULL AND MATE_PROP_ID IS NULL) OR\\012\\011 (VALUE IS NULL AND CVTE_ID IS NULL AND MATE_PROP_ID IS NOT NULL)\\012\\011);\\012\\012ALTER TABLE SAMPLE_PROPERTIES DROP CONSTRAINT SAPR_CK;\\012ALTER TABLE SAMPLE_PROPERTIES ADD CONSTRAINT SAPR_CK CHECK \\012\\011((VALUE IS NOT NULL AND CVTE_ID IS NULL AND MATE_PROP_ID IS NULL) OR \\012\\011 (VALUE IS NULL AND CVTE_ID IS NOT NULL AND MATE_PROP_ID IS NULL) OR\\012\\011 (VALUE IS NULL AND CVTE_ID IS NULL AND MATE_PROP_ID IS NOT NULL)\\012\\011);\\012\\012------------------------------------------------------------------------------------\\012--  Purpose:  Create trigger MATERIAL/SAMPLE/EXPERIMENT _PROPERTY_WITH_MATERIAL_DATA_TYPE_CHECK\\012--            It checks that if material property value is assigned to the entity,\\012--\\011\\011\\011\\011\\011\\011then the material type is equal to the one described by property type.\\012------------------------------------------------------------------------------------\\012\\012CREATE OR REPLACE FUNCTION MATERIAL_PROPERTY_WITH_MATERIAL_DATA_TYPE_CHECK() RETURNS trigger AS $$\\012DECLARE\\012   v_type_id  CODE;\\012   v_type_id_prop  CODE;\\012BEGIN\\012   if NEW.mate_prop_id IS NOT NULL then\\012\\011\\011\\011-- find material type id of the property type \\012\\011\\011\\011select pt.maty_prop_id into v_type_id_prop \\012\\011\\011\\011  from material_type_property_types etpt, property_types pt \\012\\011\\011\\011 where NEW.mtpt_id = etpt.id AND etpt.prty_id = pt.id;\\012\\011\\011\\012\\011\\011\\011if v_type_id_prop IS NOT NULL then\\012\\011\\011\\011\\011-- find material type id of the material which consists the entity's property value\\012\\011\\011\\011\\011select entity.maty_id into v_type_id \\012\\011\\011\\011\\011  from materials entity\\012\\011\\011\\011\\011 where NEW.mate_prop_id = entity.id;\\012\\011\\011\\011\\011if v_type_id != v_type_id_prop then\\012\\011\\011\\011\\011\\011RAISE EXCEPTION 'Insert/Update of property value referencing material (id: %) failed, as referenced material type is different than expected (id %, expected id: %).', \\012\\011\\011\\011\\011\\011\\011\\011 NEW.mate_prop_id, v_type_id, v_type_id_prop;\\012\\011\\011\\011\\011end if;\\012\\011\\011\\011end if;\\012   end if;\\012   RETURN NEW;\\012END;\\012$$ LANGUAGE 'plpgsql';\\012\\012CREATE TRIGGER MATERIAL_PROPERTY_WITH_MATERIAL_DATA_TYPE_CHECK BEFORE INSERT OR UPDATE ON material_properties\\012    FOR EACH ROW EXECUTE PROCEDURE MATERIAL_PROPERTY_WITH_MATERIAL_DATA_TYPE_CHECK();\\012    \\012CREATE OR REPLACE FUNCTION SAMPLE_PROPERTY_WITH_MATERIAL_DATA_TYPE_CHECK() RETURNS trigger AS $$\\012DECLARE\\012   v_type_id  CODE;\\012   v_type_id_prop  CODE;\\012BEGIN\\012   if NEW.mate_prop_id IS NOT NULL then\\012\\011\\011\\011-- find material type id of the property type \\012\\011\\011\\011select pt.maty_prop_id into v_type_id_prop \\012\\011\\011\\011  from sample_type_property_types etpt, property_types pt \\012\\011\\011\\011 where NEW.stpt_id = etpt.id AND etpt.prty_id = pt.id;\\012\\011\\011\\012\\011\\011\\011if v_type_id_prop IS NOT NULL then\\012\\011\\011\\011\\011-- find material type id of the material which consists the entity's property value\\012\\011\\011\\011\\011select entity.maty_id into v_type_id \\012\\011\\011\\011\\011  from materials entity\\012\\011\\011\\011\\011 where NEW.mate_prop_id = entity.id;\\012\\011\\011\\011\\011if v_type_id != v_type_id_prop then\\012\\011\\011\\011\\011\\011RAISE EXCEPTION 'Insert/Update of property value referencing material (id: %) failed, as referenced material type is different than expected (id %, expected id: %).', \\012\\011\\011\\011\\011\\011\\011\\011\\011\\011\\011\\011\\011 NEW.mate_prop_id, v_type_id, v_type_id_prop;\\012\\011\\011\\011\\011end if;\\012\\011\\011\\011end if;\\012   end if;\\012   RETURN NEW;\\012END;\\012$$ LANGUAGE 'plpgsql';\\012\\012CREATE TRIGGER SAMPLE_PROPERTY_WITH_MATERIAL_DATA_TYPE_CHECK BEFORE INSERT OR UPDATE ON sample_properties\\012    FOR EACH ROW EXECUTE PROCEDURE SAMPLE_PROPERTY_WITH_MATERIAL_DATA_TYPE_CHECK();\\012    \\012CREATE OR REPLACE FUNCTION EXPERIMENT_PROPERTY_WITH_MATERIAL_DATA_TYPE_CHECK() RETURNS trigger AS $$\\012DECLARE\\012   v_type_id  CODE;\\012   v_type_id_prop  CODE;\\012BEGIN\\012   if NEW.mate_prop_id IS NOT NULL then\\012\\011\\011\\011-- find material type id of the property type \\012\\011\\011\\011select pt.maty_prop_id into v_type_id_prop \\012\\011\\011\\011  from experiment_type_property_types etpt, property_types pt \\012\\011\\011\\011 where NEW.etpt_id = etpt.id AND etpt.prty_id = pt.id;\\012\\011\\011\\012\\011\\011\\011if v_type_id_prop IS NOT NULL then\\012\\011\\011\\011\\011-- find material type id of the material which consists the entity's property value\\012\\011\\011\\011\\011select entity.maty_id into v_type_id \\012\\011\\011\\011\\011  from materials entity\\012\\011\\011\\011\\011 where NEW.mate_prop_id = entity.id;\\012\\011\\011\\011\\011if v_type_id != v_type_id_prop then\\012\\011\\011\\011\\011\\011RAISE EXCEPTION 'Insert/Update of property value referencing material (id: %) failed, as referenced material type is different than expected (id %, expected id: %).', \\012\\011\\011\\011\\011\\011\\011\\011\\011\\011\\011\\011\\011 NEW.mate_prop_id, v_type_id, v_type_id_prop;\\012\\011\\011\\011\\011end if;\\012\\011\\011\\011end if;\\012   end if;\\012   RETURN NEW;\\012END;\\012$$ LANGUAGE 'plpgsql';\\012\\012CREATE TRIGGER EXPERIMENT_PROPERTY_WITH_MATERIAL_DATA_TYPE_CHECK BEFORE INSERT OR UPDATE ON experiment_properties\\012    FOR EACH ROW EXECUTE PROCEDURE EXPERIMENT_PROPERTY_WITH_MATERIAL_DATA_TYPE_CHECK();\\012       \\012-- -------\\012-- remove the reminescents of the OBSERVABLE_TYPE\\012-- -------\\012\\012ALTER TABLE data\\012\\011DROP CONSTRAINT data_obty_fk;\\012\\012ALTER TABLE data_set_types\\012\\011DROP CONSTRAINT obty_pk;\\012\\012ALTER TABLE data_set_types\\012\\011ADD CONSTRAINT dsty_pk PRIMARY KEY (id);\\012\\012ALTER TABLE data\\012\\011ADD CONSTRAINT data_dsty_fk FOREIGN KEY (dsty_id) REFERENCES data_set_types(id);\\012\\012ALTER TABLE data_set_types\\012\\011DROP CONSTRAINT obty_bk_uk;\\012\\012ALTER TABLE data_set_types\\012\\011DROP CONSTRAINT obty_dbin_fk;\\012\\012ALTER TABLE data_set_types\\012\\011ADD CONSTRAINT dsty_bk_uk UNIQUE (code, dbin_id);\\012\\012ALTER TABLE data_set_types\\012\\011ADD CONSTRAINT dsty_dbin_fk FOREIGN KEY (dbin_id) REFERENCES database_instances(id);\\012\\012DROP INDEX data_obty_fk_i;\\012\\012CREATE INDEX data_dsty_fk_i ON data(dsty_id);\\012	\N
+./sourceTest/sql/postgresql/058/.svn/text-base/017=database_version_logs.tsv.svn-base:030	source/sql/postgresql/migration/migration-029-030.sql	SUCCESS	2009-03-23 15:34:44.72	-- -------\\012-- add modification_timestamp field to allow edition with Hibernate\\012-- -------\\012ALTER TABLE data\\012\\011ADD COLUMN modification_timestamp TIME_STAMP DEFAULT CURRENT_TIMESTAMP;\\012ALTER TABLE experiment_types\\012\\011ADD COLUMN modification_timestamp TIME_STAMP DEFAULT CURRENT_TIMESTAMP;\\012ALTER TABLE sample_types\\012\\011ADD COLUMN modification_timestamp TIME_STAMP DEFAULT CURRENT_TIMESTAMP;\\012ALTER TABLE material_types\\012\\011ADD COLUMN modification_timestamp TIME_STAMP DEFAULT CURRENT_TIMESTAMP;\\012ALTER TABLE data_set_types\\012\\011ADD COLUMN modification_timestamp TIME_STAMP DEFAULT CURRENT_TIMESTAMP;\\012ALTER TABLE controlled_vocabularies\\012\\011ADD COLUMN modification_timestamp TIME_STAMP DEFAULT CURRENT_TIMESTAMP;\\012-- -------\\012-- add properties to data sets\\012-- -------\\012CREATE TABLE DATA_SET_PROPERTIES (ID TECH_ID NOT NULL,DS_ID TECH_ID NOT NULL,DSTPT_ID TECH_ID NOT NULL,VALUE GENERIC_VALUE,CVTE_ID TECH_ID, MATE_PROP_ID TECH_ID, PERS_ID_REGISTERER TECH_ID NOT NULL,REGISTRATION_TIMESTAMP TIME_STAMP_DFL NOT NULL DEFAULT CURRENT_TIMESTAMP, MODIFICATION_TIMESTAMP TIME_STAMP DEFAULT CURRENT_TIMESTAMP);\\012CREATE TABLE DATA_SET_TYPE_PROPERTY_TYPES (ID TECH_ID NOT NULL,DSTY_ID TECH_ID NOT NULL,PRTY_ID TECH_ID NOT NULL,IS_MANDATORY BOOLEAN_CHAR NOT NULL DEFAULT 'F',IS_MANAGED_INTERNALLY BOOLEAN_CHAR NOT NULL DEFAULT 'F',PERS_ID_REGISTERER TECH_ID NOT NULL,REGISTRATION_TIMESTAMP TIME_STAMP_DFL NOT NULL DEFAULT CURRENT_TIMESTAMP);\\012\\012CREATE SEQUENCE DATA_SET_PROPERTY_ID_SEQ;\\012CREATE SEQUENCE DSTPT_ID_SEQ;\\012\\012ALTER TABLE DATA_SET_TYPE_PROPERTY_TYPES ADD CONSTRAINT DSTPT_PK PRIMARY KEY(ID);\\012ALTER TABLE DATA_SET_PROPERTIES ADD CONSTRAINT DSPR_PK PRIMARY KEY(ID);\\012\\012ALTER TABLE DATA_SET_TYPE_PROPERTY_TYPES ADD CONSTRAINT DSTPT_BK_UK UNIQUE(DSTY_ID,PRTY_ID);\\012ALTER TABLE DATA_SET_PROPERTIES ADD CONSTRAINT DSPR_BK_UK UNIQUE(DS_ID,DSTPT_ID);\\012\\012\\012ALTER TABLE DATA_SET_TYPE_PROPERTY_TYPES ADD CONSTRAINT DSTPT_DSTY_FK FOREIGN KEY (DSTY_ID) REFERENCES DATA_SET_TYPES(ID);\\012ALTER TABLE DATA_SET_TYPE_PROPERTY_TYPES ADD CONSTRAINT DSTPT_PERS_FK FOREIGN KEY (PERS_ID_REGISTERER) REFERENCES PERSONS(ID);\\012ALTER TABLE DATA_SET_TYPE_PROPERTY_TYPES ADD CONSTRAINT DSTPT_PRTY_FK FOREIGN KEY (PRTY_ID) REFERENCES PROPERTY_TYPES(ID);\\012ALTER TABLE DATA_SET_PROPERTIES ADD CONSTRAINT DSPR_CVTE_FK FOREIGN KEY (CVTE_ID) REFERENCES CONTROLLED_VOCABULARY_TERMS(ID);\\012ALTER TABLE DATA_SET_PROPERTIES ADD CONSTRAINT DSPR_DSTPT_FK FOREIGN KEY (DSTPT_ID) REFERENCES DATA_SET_TYPE_PROPERTY_TYPES(ID) ON DELETE CASCADE;\\012ALTER TABLE DATA_SET_PROPERTIES ADD CONSTRAINT DSPR_DS_FK FOREIGN KEY (DS_ID) REFERENCES DATA(ID);\\012ALTER TABLE DATA_SET_PROPERTIES ADD CONSTRAINT DSPR_PERS_FK FOREIGN KEY (PERS_ID_REGISTERER) REFERENCES PERSONS(ID);\\012ALTER TABLE DATA_SET_PROPERTIES ADD CONSTRAINT DSPR_MAPR_FK FOREIGN KEY (MATE_PROP_ID) REFERENCES MATERIALS(ID);\\012\\012ALTER TABLE DATA_SET_PROPERTIES ADD CONSTRAINT DSPR_CK CHECK \\012\\011((VALUE IS NOT NULL AND CVTE_ID IS NULL AND MATE_PROP_ID IS NULL) OR \\012\\011 (VALUE IS NULL AND CVTE_ID IS NOT NULL AND MATE_PROP_ID IS NULL) OR\\012\\011 (VALUE IS NULL AND CVTE_ID IS NULL AND MATE_PROP_ID IS NOT NULL)\\012\\011);\\012\\012CREATE INDEX DSPR_CVTE_FK_I ON DATA_SET_PROPERTIES (CVTE_ID);\\012CREATE INDEX DSPR_DSTPT_FK_I ON DATA_SET_PROPERTIES (DSTPT_ID);\\012CREATE INDEX DSPR_DS_FK_I ON DATA_SET_PROPERTIES (DS_ID);\\012CREATE INDEX DSPR_PERS_FK_I ON DATA_SET_PROPERTIES (PERS_ID_REGISTERER);\\012CREATE INDEX DSTPT_DSTY_FK_I ON DATA_SET_TYPE_PROPERTY_TYPES (DSTY_ID);\\012CREATE INDEX DSTPT_PERS_FK_I ON DATA_SET_TYPE_PROPERTY_TYPES (PERS_ID_REGISTERER);\\012CREATE INDEX DSTPT_PRTY_FK_I ON DATA_SET_TYPE_PROPERTY_TYPES (PRTY_ID);\\012\\012CREATE OR REPLACE FUNCTION DATA_SET_PROPERTY_WITH_MATERIAL_DATA_TYPE_CHECK() RETURNS trigger AS $$\\012DECLARE\\012   v_type_id  CODE;\\012   v_type_id_prop  CODE;\\012BEGIN\\012   if NEW.mate_prop_id IS NOT NULL then\\012\\011\\011\\011-- find material type id of the property type \\012\\011\\011\\011select pt.maty_prop_id into v_type_id_prop \\012\\011\\011\\011  from data_set_type_property_types dstpt, property_types pt \\012\\011\\011\\011 where NEW.dstpt_id = dstpt.id AND dstpt.prty_id = pt.id;\\012\\011\\011\\012\\011\\011\\011if v_type_id_prop IS NOT NULL then\\012\\011\\011\\011\\011-- find material type id of the material which consists the entity's property value\\012\\011\\011\\011\\011select entity.maty_id into v_type_id \\012\\011\\011\\011\\011  from materials entity\\012\\011\\011\\011\\011 where NEW.mate_prop_id = entity.id;\\012\\011\\011\\011\\011if v_type_id != v_type_id_prop then\\012\\011\\011\\011\\011\\011RAISE EXCEPTION 'Insert/Update of property value referencing material (id: %) failed, as referenced material type is different than expected (id %, expected id: %).', \\012\\011\\011\\011\\011\\011\\011\\011\\011\\011\\011\\011\\011 NEW.mate_prop_id, v_type_id, v_type_id_prop;\\012\\011\\011\\011\\011end if;\\012\\011\\011\\011end if;\\012   end if;\\012   RETURN NEW;\\012END;\\012$$ LANGUAGE 'plpgsql';\\012\\012CREATE TRIGGER DATA_SET_PROPERTY_WITH_MATERIAL_DATA_TYPE_CHECK BEFORE INSERT OR UPDATE ON data_set_properties\\012    FOR EACH ROW EXECUTE PROCEDURE DATA_SET_PROPERTY_WITH_MATERIAL_DATA_TYPE_CHECK();   \\012	\N
+./sourceTest/sql/postgresql/058/.svn/text-base/017=database_version_logs.tsv.svn-base:032	source/sql/postgresql/migration/migration-031-032.sql	SUCCESS	2009-04-09 09:36:36.2	-- -------\\012-- Modify MATERIAL_BATCHES\\012-- -------\\012\\012ALTER TABLE material_batches\\012    DROP COLUMN proc_id;\\012\\012-- -------\\012-- Modify SAMPLES\\012-- -------\\012\\012ALTER TABLE samples\\012    ADD COLUMN expe_id tech_id;\\012\\012ALTER TABLE samples\\012    ADD CONSTRAINT samp_expe_fk FOREIGN KEY (expe_id) REFERENCES experiments(id);\\012\\012CREATE INDEX samp_expe_fk_i ON samples USING btree (expe_id);\\012\\012-- relink samples directly to experiments\\012\\012UPDATE samples\\012SET expe_id = (SELECT e.id FROM experiments e, procedures p, sample_inputs si \\012               WHERE si.samp_id = samples.id AND si.proc_id = p.id AND p.expe_id = e.id AND e.inva_id IS NULL);\\012\\012\\012-- -------\\012-- Modify DATA\\012-- -------\\012\\012ALTER TABLE data\\012    ADD COLUMN expe_id tech_id;\\012\\012ALTER TABLE data\\012    ADD CONSTRAINT data_expe_fk FOREIGN KEY (expe_id) REFERENCES experiments(id);\\012\\012CREATE INDEX data_expe_fk_i ON data USING btree (expe_id);\\012\\012UPDATE data\\012SET expe_id = (SELECT e.id FROM experiments e, procedures p \\012               WHERE data.proc_id_produced_by = p.id AND p.expe_id = e.id);\\012\\012ALTER TABLE data\\012    ALTER COLUMN expe_id SET NOT NULL;\\012\\012ALTER TABLE data\\012    DROP COLUMN proc_id_produced_by;\\012\\012-- -------\\012-- Drop PROCEDURES, PROCEDURE_TYPES, and SAMPLE_INPUTS\\012-- -------\\012\\012DROP TABLE sample_inputs;\\012DROP TABLE procedures;\\012DROP TABLE procedure_types;\\012\\012DROP SEQUENCE procedure_id_seq;\\012DROP SEQUENCE procedure_type_id_seq;\\012\\012-- -------\\012-- Add CODE_SEQ\\012-- -------\\012\\012CREATE SEQUENCE CODE_SEQ;\\012\\012-- -------\\012-- Add new columns to DATA_STORES\\012-- -------\\012\\012ALTER TABLE data_stores\\012    ADD COLUMN remote_url character varying(250),\\012    ADD COLUMN session_token character varying(50),\\012    ADD COLUMN modification_timestamp time_stamp DEFAULT now();\\012\\012UPDATE data_stores\\012SET remote_url = '', session_token='';\\012\\012ALTER TABLE data_stores\\012    ALTER COLUMN remote_url SET NOT NULL,\\012    ALTER COLUMN session_token SET NOT NULL;\\012\\012-- -------\\012-- Drop foreign keys onto DATA_STORES\\012-- -------\\012\\012ALTER TABLE database_instances\\012    DROP COLUMN dast_id;\\012\\012ALTER TABLE groups\\012    DROP COLUMN dast_id;\\012\\012ALTER TABLE projects\\012    DROP COLUMN dast_id;\\012\\012ALTER TABLE experiments\\012    DROP COLUMN dast_id;\\012\\012-- -------\\012-- Add foreign key from DATA onto DATA_STORES\\012-- -------\\012\\012ALTER TABLE data\\012    ADD COLUMN dast_id tech_id;\\012\\012ALTER TABLE data\\012    ADD CONSTRAINT data_dast_fk FOREIGN KEY (dast_id) REFERENCES data_stores(id);\\012\\012UPDATE data\\012SET dast_id = (select id from data_stores where code = 'STANDARD');\\012\\012ALTER TABLE data\\012    ALTER COLUMN dast_id SET NOT NULL;\\012\\012\\012------------------------------------------------------------------------------------\\012--  Purpose:  Replace trigger SAMPLE_CODE_UNIQUENESS_CHECK \\012------------------------------------------------------------------------------------\\012\\012CREATE OR REPLACE FUNCTION SAMPLE_CODE_UNIQUENESS_CHECK() RETURNS trigger AS $$\\012DECLARE\\012   counter  INTEGER;\\012BEGIN\\012    LOCK TABLE samples IN EXCLUSIVE MODE;\\012    IF (NEW.samp_id_part_of is NULL) THEN\\012        IF (NEW.dbin_id is not NULL) THEN\\012            SELECT count(*) into counter FROM samples \\012                where id != NEW.id and code = NEW.code and samp_id_part_of is NULL and dbin_id = NEW.dbin_id;\\012            IF (counter > 0) THEN\\012                RAISE EXCEPTION 'Insert/Update of Sample (Code: %) failed because database instance sample with the same code already exists.', NEW.code;\\012            END IF;\\012        ELSIF (NEW.grou_id is not NULL) THEN\\012            SELECT count(*) into counter FROM samples \\012                where id != NEW.id and code = NEW.code and samp_id_part_of is NULL and grou_id = NEW.grou_id;\\012            IF (counter > 0) THEN\\012                RAISE EXCEPTION 'Insert/Update of Sample (Code: %) failed because group sample with the same code already exists.', NEW.code;\\012            END IF;\\012        END IF;\\012        ELSE\\012        IF (NEW.dbin_id is not NULL) THEN\\012            SELECT count(*) into counter FROM samples \\012                where id != NEW.id and code = NEW.code and samp_id_part_of = NEW.samp_id_part_of and dbin_id = NEW.dbin_id;\\012            IF (counter > 0) THEN\\012                RAISE EXCEPTION 'Insert/Update of Sample (Code: %) failed because database instance sample with the same code and being the part of the same parent already exists.', NEW.code;\\012            END IF;\\012        ELSIF (NEW.grou_id is not NULL) THEN\\012            SELECT count(*) into counter FROM samples \\012                where id != NEW.id and code = NEW.code and samp_id_part_of = NEW.samp_id_part_of and grou_id = NEW.grou_id;\\012            IF (counter > 0) THEN\\012                RAISE EXCEPTION 'Insert/Update of Sample (Code: %) failed because group sample with the same code and being the part of the same parent already exists.', NEW.code;\\012            END IF;\\012        END IF;\\012        END IF;   \\012   RETURN NEW;\\012END;\\012$$ LANGUAGE 'plpgsql';\\012\\012\\012\\012	\N
+./sourceTest/sql/postgresql/058/.svn/text-base/017=database_version_logs.tsv.svn-base:034	source/sql/postgresql/migration/migration-033-034.sql	SUCCESS	2009-05-26 08:32:49.935	------------------------------------------------------------------------------------\\012-- Create sequence for generating permanent identifiers starting with nextval of existing dataset sequence.\\012------------------------------------------------------------------------------------\\012CREATE FUNCTION CREATE_SEQUENCE(EXISTING_SEQUENCE VARCHAR, NEW_SEQUENCE VARCHAR) RETURNS VOID AS $$\\012DECLARE\\012  CURR_SEQ_VAL   INTEGER;\\012BEGIN\\012  SELECT INTO CURR_SEQ_VAL NEXTVAL(EXISTING_SEQUENCE);\\012  EXECUTE 'CREATE SEQUENCE ' || NEW_SEQUENCE || ' START WITH ' || CURR_SEQ_VAL;\\012  RETURN;\\012END;\\012$$ LANGUAGE 'plpgsql';\\012\\012SELECT CREATE_SEQUENCE('DATA_ID_SEQ', 'PERM_ID_SEQ');\\012DROP FUNCTION CREATE_SEQUENCE(VARCHAR, VARCHAR);\\012\\012------------------------------------------------------------------------------------\\012-- Add perm_id columns to samples and experiments.\\012------------------------------------------------------------------------------------\\012ALTER TABLE SAMPLES ADD COLUMN PERM_ID CODE;\\012ALTER TABLE EXPERIMENTS ADD COLUMN PERM_ID CODE;\\012\\012UPDATE SAMPLES SET PERM_ID = to_char(registration_timestamp,'YYYYMMDDHHSSMS') || '-' || NEXTVAL('PERM_ID_SEQ');\\012UPDATE EXPERIMENTS SET PERM_ID = to_char(registration_timestamp,'YYYYMMDDHHSSMS') || '-' || NEXTVAL('PERM_ID_SEQ');\\012ALTER TABLE SAMPLES ALTER COLUMN PERM_ID SET NOT NULL;\\012ALTER TABLE EXPERIMENTS ALTER COLUMN PERM_ID SET NOT NULL;\\012ALTER TABLE SAMPLES ADD CONSTRAINT SAMP_PI_UK UNIQUE(PERM_ID);\\012ALTER TABLE EXPERIMENTS ADD CONSTRAINT EXPE_PI_UK UNIQUE(PERM_ID);\\012\\012\\012------------------------------------------------------------------------------------\\012-- Add column is_chosen_from_list to controlled_vocabularies.\\012------------------------------------------------------------------------------------\\012ALTER TABLE controlled_vocabularies ADD COLUMN is_chosen_from_list BOOLEAN_CHAR NOT NULL DEFAULT TRUE;\\012ALTER TABLE controlled_vocabularies ADD COLUMN source_uri CHARACTER VARYING(250);\\012------------------------------------------------------------------------------------\\012-- Modify Data table - remove arc connection between Sample and Data table, use a flag instead\\012------------------------------------------------------------------------------------\\012\\012-- add new columns\\012\\012ALTER TABLE data\\012    ADD COLUMN is_derived boolean_char;\\012ALTER TABLE data\\012    ADD COLUMN samp_id tech_id;\\012\\012-- update values in new columns\\012\\012UPDATE data\\012    SET is_derived = (samp_id_derived_from IS NOT NULL); \\012UPDATE data\\012    SET samp_id = samp_id_derived_from \\012    WHERE is_derived = 'TRUE';\\012UPDATE data\\012    SET samp_id = samp_id_acquired_from \\012    WHERE is_derived = 'FALSE';\\012\\012-- add constraints and indexes to new columns\\012\\012ALTER TABLE data\\012    ALTER COLUMN is_derived SET NOT NULL;\\012ALTER TABLE data\\012    ALTER COLUMN samp_id SET NOT NULL;   \\012ALTER TABLE data\\012    ADD CONSTRAINT data_samp_fk FOREIGN KEY (samp_id) REFERENCES samples (id);\\012CREATE INDEX data_samp_fk_i ON data USING btree (samp_id);\\012\\012-- remove old columns\\012\\012ALTER TABLE data\\012    DROP COLUMN samp_id_acquired_from;\\012ALTER TABLE data\\012    DROP COLUMN samp_id_derived_from;\\012    \\012------------------------------------------------------------------------------------\\012-- Granting SELECT privilege to group openbis_readonly\\012------------------------------------------------------------------------------------\\012\\012GRANT SELECT ON SEQUENCE attachment_content_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE attachment_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE code_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE controlled_vocabulary_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE cvte_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE data_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE data_set_property_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE data_set_relationship_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE data_set_type_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE data_store_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE data_type_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE database_instance_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE dstpt_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE etpt_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE event_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE experiment_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE experiment_property_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE experiment_type_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE file_format_type_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE group_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE invalidation_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE locator_type_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE material_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE material_property_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE material_type_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE mtpt_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE perm_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE person_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE project_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE property_type_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE role_assignment_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE sample_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE sample_property_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE sample_type_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE stpt_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE attachment_contents TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE attachments TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE controlled_vocabularies TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE controlled_vocabulary_terms TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE data TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE data_set_properties TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE data_set_relationships TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE data_set_type_property_types TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE data_set_types TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE data_stores TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE data_types TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE database_instances TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE database_version_logs TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE events TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE experiment_properties TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE experiment_type_property_types TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE experiment_types TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE experiments TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE external_data TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE file_format_types TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE groups TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE invalidations TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE locator_types TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE material_properties TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE material_type_property_types TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE material_types TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE materials TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE persons TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE projects TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE property_types TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE role_assignments TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE sample_properties TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE sample_type_property_types TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE sample_types TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE samples TO GROUP OPENBIS_READONLY;\\012\\012------------------------------------------------------------------------------------\\012-- Delete MATERIAL_BATCHES table\\012------------------------------------------------------------------------------------\\012\\012-- WARNING: Potential data lost!!!\\012-- WARNING: Potential data lost!!!\\012-- WARNING: Potential data lost!!!\\012\\012DROP TABLE SAMPLE_MATERIAL_BATCHES;\\012DROP TABLE MATERIAL_BATCHES;\\012DROP SEQUENCE MATERIAL_BATCH_ID_SEQ;\\012\\012------------------------------------------------------------------------------------\\012-- Delete MATE_ID_INHIBITOR_OF from table MATERIALS\\012------------------------------------------------------------------------------------\\012\\012-- WARNING: Potential data lost!!!\\012-- WARNING: Potential data lost!!!\\012-- WARNING: Potential data lost!!!\\012\\012ALTER TABLE MATERIALS DROP COLUMN MATE_ID_INHIBITOR_OF;\\012	\N
+./sourceTest/sql/postgresql/058/.svn/text-base/017=database_version_logs.tsv.svn-base:041	source/sql/postgresql/migration/migration-040-041.sql	SUCCESS	2009-09-14 13:48:57.539	-- Create FILTERS table\\012\\012CREATE TABLE FILTERS (ID TECH_ID NOT NULL, DBIN_ID TECH_ID NOT NULL, NAME VARCHAR(200) NOT NULL, DESCRIPTION DESCRIPTION_1000,REGISTRATION_TIMESTAMP TIME_STAMP_DFL NOT NULL DEFAULT CURRENT_TIMESTAMP, PERS_ID_REGISTERER TECH_ID NOT NULL, MODIFICATION_TIMESTAMP TIME_STAMP DEFAULT CURRENT_TIMESTAMP, EXPRESSION VARCHAR(2000) NOT NULL, IS_PUBLIC BOOLEAN NOT NULL, GRID_ID VARCHAR(200) NOT NULL);\\012CREATE SEQUENCE FILTER_ID_SEQ;\\012ALTER TABLE FILTERS ADD CONSTRAINT FILT_PK PRIMARY KEY(ID);\\012ALTER TABLE FILTERS ADD CONSTRAINT FILT_BK_UK UNIQUE(NAME, DBIN_ID, GRID_ID);\\012ALTER TABLE FILTERS ADD CONSTRAINT FILT_PERS_FK FOREIGN KEY (PERS_ID_REGISTERER) REFERENCES PERSONS(ID);\\012ALTER TABLE FILTERS ADD CONSTRAINT FILT_DBIN_FK FOREIGN KEY (DBIN_ID) REFERENCES DATABASE_INSTANCES(ID);\\012CREATE INDEX FILT_PERS_FK_I ON FILTERS (PERS_ID_REGISTERER);\\012CREATE INDEX FILT_DBIN_FK_I ON FILTERS (DBIN_ID);\\012GRANT SELECT ON SEQUENCE filter_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE filters TO GROUP OPENBIS_READONLY;\\012\\012-- Add missing foreign key to role assignments authorization group\\012ALTER TABLE ROLE_ASSIGNMENTS ADD CONSTRAINT ROAS_AG_FK_GRANTEE FOREIGN KEY (AG_ID_GRANTEE) REFERENCES AUTHORIZATION_GROUPS(ID);\\012\\012--------------------------------------------------------------------------------------------------\\012-- Modify dataset connections:\\012-- 1. connection with sample shouldn't be mandatory any more\\012-- 2. introduce an arc condition that dataset cannot be connected with a sample and a parent dataset at the same time\\012--------------------------------------------------------------------------------------------------\\012\\012-- Weaken data-sample connection constraint - allow dataset to have no connection with sample\\012ALTER TABLE data ALTER COLUMN samp_id DROP NOT NULL;\\012\\012-- Remove data-sample connection for datasets that have a parent\\012\\012UPDATE data \\012   SET samp_id = NULL \\012 WHERE id IN (SELECT DISTINCT data_id_child FROM data_set_relationships);\\012\\012-- With PostgreSQL 8.4 one can check that before migration there were no cycles in dataset relationships:\\012--\\012-- WITH RECURSIVE data_set_parents(id, parent_ids, cycle) AS (\\012--         SELECT  r.data_id_child AS id, \\012--                 ARRAY[CAST (r.data_id_parent AS bigint)] AS parent_ids, \\012--                 false AS cycle \\012--         FROM data_set_relationships r\\012--     UNION ALL\\012--         SELECT  r.data_id_child,\\012--                 CAST (r.data_id_parent AS bigint) || p.parent_ids,\\012--                 r.data_id_child = ANY(p.parent_ids)\\012--         FROM data_set_relationships r, data_set_parents p\\012--         WHERE r.data_id_parent = p.id AND NOT cycle\\012-- )\\012-- SELECT count(*) AS cycles FROM data_set_parents WHERE cycle = true;\\012\\012---------------------------------------------------------------------------------------------------\\012--  Purpose:  Create DEFERRED triggers:\\012--            * check_dataset_relationships_on_data_table_modification,\\012--            * check_dataset_relationships_on_relationships_table_modification.\\012--            They check that after all modifications of database (just before commit) \\012--            if 'data'/'data_set_relationships' tables are among modified tables \\012--            dataset is not connected with a sample and a parent dataset at the same time.\\012--            This connections are held in two different tables so simple immediate trigger \\012--            with arc check cannot be used and we need two deferred triggers.\\012----------------------------------------------------------------------------------------------------\\012\\012-- trigger for 'data' table\\012\\012CREATE OR REPLACE FUNCTION check_dataset_relationships_on_data_table_modification() RETURNS trigger AS $$\\012DECLARE\\012\\011counter\\011INTEGER;\\012BEGIN\\012\\011-- if there is a connection with a Sample there should not be any connection with a parent Data Set\\012\\011IF (NEW.samp_id IS NOT NULL) THEN\\012\\011\\011-- count number of parents\\012\\011\\011SELECT count(*) INTO counter \\012\\011\\011\\011FROM data_set_relationships \\012\\011\\011\\011WHERE data_id_child = OLD.id;\\012\\011\\011IF (counter > 0) THEN\\012\\011\\011\\011RAISE EXCEPTION 'Insert/Update of Data Set (Code: %) failed because it cannot be connected with a Sample and a parent Data Set at the same time.', OLD.code;\\012\\011\\011END IF;\\012\\011END IF;\\012  RETURN NEW;\\012END;\\012$$ LANGUAGE 'plpgsql';\\012\\012CREATE CONSTRAINT TRIGGER check_dataset_relationships_on_data_table_modification \\012  AFTER INSERT OR UPDATE ON data\\012\\011DEFERRABLE INITIALLY DEFERRED\\012\\011FOR EACH ROW \\012\\011EXECUTE PROCEDURE check_dataset_relationships_on_data_table_modification();\\012\\012-- trigger for 'data_set_relationships'\\012\\012CREATE OR REPLACE FUNCTION check_dataset_relationships_on_relationships_table_modification() RETURNS trigger AS $$\\012DECLARE\\012\\011counter\\011INTEGER;\\012\\011sample_id\\011TECH_ID;\\012\\011data_code\\011CODE;\\012BEGIN\\012\\011-- child will have a parent added so it should not be connected with any sample\\012\\011SELECT samp_id, code INTO sample_id, data_code \\012\\011\\011FROM data \\012\\011\\011WHERE id = NEW.data_id_child;\\012\\011IF (sample_id IS NOT NULL) THEN\\012\\011\\011RAISE EXCEPTION 'Insert/Update of Data Set (Code: %) failed because it cannot be connected to a Sample and to a parent Data Set at the same time.', data_code;\\012\\011END IF;\\012\\011RETURN NEW;\\012END;\\012$$ LANGUAGE 'plpgsql';\\012  \\012CREATE CONSTRAINT TRIGGER check_dataset_relationships_on_relationships_table_modification \\012  AFTER INSERT OR UPDATE ON data_set_relationships\\012\\011DEFERRABLE INITIALLY DEFERRED\\012\\011FOR EACH ROW \\012\\011EXECUTE PROCEDURE check_dataset_relationships_on_relationships_table_modification();\\012	\N
+./sourceTest/sql/postgresql/058/.svn/text-base/017=database_version_logs.tsv.svn-base:053	source/sql/postgresql/migration/migration-052-053.sql	SUCCESS	2010-06-08 15:27:55.032	-- Migration from 052 to 053\\012\\012-- Change code uniqueness check for samples of specific type.\\012-- If sample_types.is_subcode_unique flag is set to 'true', additional check is performed \\012-- on codes of samples of the type. Subcodes will have to be unique as well.\\012\\012ALTER TABLE sample_types ADD COLUMN is_subcode_unique boolean_char NOT NULL DEFAULT false;\\012\\012CREATE OR REPLACE FUNCTION SAMPLE_SUBCODE_UNIQUENESS_CHECK() RETURNS trigger AS $$\\012DECLARE\\012   counter  INTEGER;\\012   unique_subcode  BOOLEAN_CHAR;\\012BEGIN\\012  LOCK TABLE samples IN EXCLUSIVE MODE;\\012  \\012  SELECT is_subcode_unique into unique_subcode FROM sample_types WHERE id = NEW.saty_id;\\012  \\012  IF (unique_subcode) THEN\\012    IF (NEW.dbin_id is not NULL) THEN\\012\\011\\011\\011SELECT count(*) into counter FROM samples \\012\\011\\011\\011\\011where id != NEW.id and code = NEW.code and saty_id = NEW.saty_id and dbin_id = NEW.dbin_id;\\012\\011\\011\\011IF (counter > 0) THEN\\012\\011\\011\\011\\011RAISE EXCEPTION 'Insert/Update of Sample (Code: %) failed because database instance sample of the same type with the same subcode already exists.', NEW.code;\\012\\011\\011\\011END IF;\\012\\011\\011ELSIF (NEW.grou_id is not NULL) THEN\\012\\011\\011\\011SELECT count(*) into counter FROM samples \\012\\011\\011\\011\\011where id != NEW.id and code = NEW.code and saty_id = NEW.saty_id and grou_id = NEW.grou_id;\\012\\011\\011\\011IF (counter > 0) THEN\\012\\011\\011\\011\\011RAISE EXCEPTION 'Insert/Update of Sample (Code: %) failed because space sample of the same type with the same subcode already exists.', NEW.code;\\012\\011\\011\\011END IF;\\012\\011\\011END IF;\\012  END IF;\\012  \\012  RETURN NEW;\\012END;\\012$$ LANGUAGE 'plpgsql';\\012\\012CREATE TRIGGER SAMPLE_SUBCODE_UNIQUENESS_CHECK BEFORE INSERT OR UPDATE ON SAMPLES\\012    FOR EACH ROW EXECUTE PROCEDURE SAMPLE_SUBCODE_UNIQUENESS_CHECK();\\012    \\012-- Fixing error messages in old trigger\\012\\012CREATE OR REPLACE FUNCTION SAMPLE_CODE_UNIQUENESS_CHECK() RETURNS trigger AS $$\\012DECLARE\\012   counter  INTEGER;\\012BEGIN\\012  LOCK TABLE samples IN EXCLUSIVE MODE;\\012  \\012\\011  IF (NEW.samp_id_part_of is NULL) THEN\\012\\011\\011  IF (NEW.dbin_id is not NULL) THEN\\012\\011\\011\\011  SELECT count(*) into counter FROM samples \\012\\011\\011      where id != NEW.id and code = NEW.code and samp_id_part_of is NULL and dbin_id = NEW.dbin_id;\\012        IF (counter > 0) THEN\\012\\011\\011\\011\\011  RAISE EXCEPTION 'Insert/Update of Sample (Code: %) failed because database instance sample with the same code already exists.', NEW.code;\\012        END IF;\\012\\011\\011  ELSIF (NEW.grou_id is not NULL) THEN\\012\\011\\011\\011  SELECT count(*) into counter FROM samples \\012\\011\\011\\011\\011  where id != NEW.id and code = NEW.code and samp_id_part_of is NULL and grou_id = NEW.grou_id;\\012\\011\\011\\011  IF (counter > 0) THEN\\012\\011\\011\\011\\011  RAISE EXCEPTION 'Insert/Update of Sample (Code: %) failed because space sample with the same code already exists.', NEW.code;\\012\\011\\011\\011  END IF;\\012      END IF;\\012    ELSE\\012\\011\\011  IF (NEW.dbin_id is not NULL) THEN\\012\\011\\011\\011  SELECT count(*) into counter FROM samples \\012\\011\\011\\011\\011  where id != NEW.id and code = NEW.code and samp_id_part_of = NEW.samp_id_part_of and dbin_id = NEW.dbin_id;\\012\\011\\011\\011  IF (counter > 0) THEN\\012\\011\\011\\011\\011  RAISE EXCEPTION 'Insert/Update of Sample (Code: %) failed because database instance sample with the same code and being the part of the same container already exists.', NEW.code;\\012\\011\\011\\011  END IF;\\012\\011\\011  ELSIF (NEW.grou_id is not NULL) THEN\\012\\011\\011\\011  SELECT count(*) into counter FROM samples \\012\\011\\011\\011\\011  where id != NEW.id and code = NEW.code and samp_id_part_of = NEW.samp_id_part_of and grou_id = NEW.grou_id;\\012\\011\\011\\011  IF (counter > 0) THEN\\012\\011\\011\\011\\011  RAISE EXCEPTION 'Insert/Update of Sample (Code: %) failed because space sample with the same code and being the part of the same container already exists.', NEW.code;\\012\\011\\011\\011  END IF;\\012\\011\\011  END IF;\\012     END IF;   \\012  \\012  RETURN NEW;\\012END;\\012$$ LANGUAGE 'plpgsql';\\012	\N
+./sourceTest/sql/postgresql/058/.svn/text-base/017=database_version_logs.tsv.svn-base:054	source/sql/postgresql/migration/migration-053-054.sql	SUCCESS	2010-07-27 11:30:46.766	-- Migration from 053 to 054\\012\\012\\012-- Add RELATIONSHIP_TYPES table\\012CREATE TABLE relationship_types (id TECH_ID NOT NULL, code CODE NOT NULL, label COLUMN_LABEL, parent_label COLUMN_LABEL, child_label COLUMN_LABEL, description DESCRIPTION_2000, registration_timestamp TIME_STAMP_DFL NOT NULL DEFAULT CURRENT_TIMESTAMP, pers_id_registerer TECH_ID NOT NULL, is_managed_internally BOOLEAN_CHAR NOT NULL DEFAULT 'F', is_internal_namespace BOOLEAN_CHAR NOT NULL DEFAULT 'F', dbin_id TECH_ID NOT NULL);\\012\\012-- Add SAMPLE_RELATIONSHIPS table\\012CREATE TABLE sample_relationships (id TECH_ID NOT NULL, sample_id_parent TECH_ID NOT NULL, relationship_id TECH_ID NOT NULL, sample_id_child TECH_ID NOT NULL);\\012\\012-- Add/update constraints\\012ALTER TABLE relationship_types ADD CONSTRAINT rety_pk PRIMARY KEY (id);\\012ALTER TABLE relationship_types ADD CONSTRAINT rety_uk UNIQUE(code,dbin_id);\\012ALTER TABLE sample_relationships ADD CONSTRAINT sare_pk PRIMARY KEY (id);\\012ALTER TABLE sample_relationships ADD CONSTRAINT sare_bk_uk UNIQUE(sample_id_child,sample_id_parent,relationship_id);\\012ALTER TABLE sample_relationships ADD CONSTRAINT sare_data_fk_child FOREIGN KEY (sample_id_child) REFERENCES samples(id) ON DELETE CASCADE;\\012ALTER TABLE sample_relationships ADD CONSTRAINT sare_data_fk_parent FOREIGN KEY (sample_id_parent) REFERENCES samples(id) ON DELETE CASCADE;\\012ALTER TABLE sample_relationships ADD CONSTRAINT sare_data_fk_relationship FOREIGN KEY (relationship_id) REFERENCES relationship_types(id);\\012\\012-- Create index\\012CREATE INDEX sare_data_fk_i_child ON sample_relationships (sample_id_child);\\012CREATE INDEX sare_data_fk_i_parent ON sample_relationships (sample_id_parent);\\012CREATE INDEX sare_data_fk_i_relationship ON sample_relationships (relationship_id);\\012\\012-- Create sequence for RELATIONSHIP_TYPES\\012CREATE SEQUENCE RELATIONSHIP_TYPE_ID_SEQ;\\012CREATE SEQUENCE SAMPLE_RELATIONSHIP_ID_SEQ;\\012\\012-- Create initial relationships\\012insert into relationship_types\\012(id, \\012code, \\012label, \\012parent_label, \\012child_label, \\012description, \\012pers_id_registerer, \\012is_managed_internally, \\012is_internal_namespace, \\012dbin_id) \\012values\\012(\\012nextval('RELATIONSHIP_TYPE_ID_SEQ'),\\012'PARENT_CHILD',\\012'Parent - Child', \\012'Parent', \\012'Child', \\012'Parent - Child relationship', \\012(select id from persons where user_id ='system'), \\012'T', \\012'T', \\012(select id from database_instances where is_original_source = 'T')\\012);\\012\\012insert into relationship_types\\012(id, \\012code, \\012label, \\012parent_label, \\012child_label, \\012description, \\012pers_id_registerer, \\012is_managed_internally, \\012is_internal_namespace, \\012dbin_id) \\012values\\012(\\012nextval('RELATIONSHIP_TYPE_ID_SEQ'),\\012'PLATE_CONTROL_LAYOUT',\\012'Plate - Control Layout', \\012'Plate', \\012'Control Layout', \\012'Plate - Control Layout relationship', \\012(select id from persons where user_id ='system'), \\012'T', \\012'T', \\012(select id from database_instances where is_original_source = 'T')\\012); \\012\\012\\012-- Migrate sample relationships to new schema\\012INSERT INTO sample_relationships (id, sample_id_parent,sample_id_child,relationship_id) (select distinct nextval('SAMPLE_RELATIONSHIP_ID_SEQ') as id, s.SAMP_ID_GENERATED_FROM as parent_id, s.ID as child_id, rt.id as relationship_id from samples s, relationship_types rt  WHERE rt.code = 'PARENT_CHILD' and s.SAMP_ID_GENERATED_FROM is not null); \\012INSERT INTO sample_relationships (id, sample_id_parent,sample_id_child,relationship_id) (select distinct nextval('SAMPLE_RELATIONSHIP_ID_SEQ') as id, s.SAMP_ID_CONTROL_LAYOUT as parent_id, s.ID as child_id, rt.id as relationship_id from samples s, relationship_types rt  WHERE rt.code = 'PLATE_CONTROL_LAYOUT' and s.SAMP_ID_CONTROL_LAYOUT is not null);\\012\\012-- Drop old sample relations\\012ALTER TABLE SAMPLES DROP COLUMN SAMP_ID_TOP;\\012ALTER TABLE SAMPLES DROP COLUMN SAMP_ID_GENERATED_FROM;\\012ALTER TABLE SAMPLES DROP COLUMN SAMP_ID_CONTROL_LAYOUT;\\012\\012--------------------------------------------------------------------------------------\\012--------------------------------------------------------------------------------------\\012-- This is a screening specific migration. Nothing will be performed on openBIS databases \\012-- which are not screening specific.\\012-- \\012-- This migration for each existing connection between oligo well, oligo material and gene material\\012-- creates a direct connection between the well and the gene. \\012--------------------------------------------------------------------------------------\\012--------------------------------------------------------------------------------------\\012 \\012\\011\\012CREATE OR REPLACE FUNCTION CONNECT_WELLS_WITH_GENES() RETURNS void AS $$\\012DECLARE\\012\\011counter  int;\\012\\011oligo_well_exists bool;\\012BEGIN\\012\\011--------------------------------------------------\\012\\011-- create a gene property and assign it to oligo well\\012\\011--------------------------------------------------\\012\\011\\012\\011select true \\012\\011into oligo_well_exists\\012\\011from sample_types \\012\\011where code = 'OLIGO_WELL';\\012\\011\\012\\011if oligo_well_exists IS NULL then \\012\\011\\011-- skip migration if there are no oligo wells\\012\\011\\011return;\\012\\011end if;   \\012\\011\\012\\011insert into property_types(\\012\\011\\011id, \\012\\011\\011code, description, label, \\012\\011\\011daty_id,\\012\\011\\011pers_id_registerer,\\012\\011\\011dbin_id,\\012\\011\\011maty_prop_id) \\012\\011values(\\012\\011\\011\\011nextval('PROPERTY_TYPE_ID_SEQ'), \\012\\011\\011\\011'GENE','Inhibited gene','Gene',\\012\\011\\011\\011(select id from data_types where code = 'MATERIAL'), \\012\\011\\011\\011(select id from persons where user_id ='system'), \\012\\011\\011\\011(select id from database_instances where is_original_source = 'T'), \\012\\011\\011\\011(select id from material_types where code = 'GENE')\\012\\011\\011);\\012\\011\\011\\012\\011insert into sample_type_property_types( \\012\\011  id,\\012\\011  saty_id,\\012\\011  prty_id,\\012\\011  is_mandatory,\\012\\011  pers_id_registerer,\\012\\011  ordinal\\012\\011) values(\\012\\011\\011\\011nextval('stpt_id_seq'), \\012\\011\\011\\011(select id from sample_types where code = 'OLIGO_WELL'),\\012\\011\\011\\011(select id from property_types where code = 'GENE'),\\012\\011\\011\\011false,\\012\\011\\011\\011(select id from persons where user_id ='system'),\\012\\011\\011\\011(select max(ordinal)+1 from sample_type_property_types \\012\\011\\011\\011\\011where saty_id = (select id from sample_types where code = 'OLIGO_WELL'))\\012\\011\\011);\\012\\012\\011--------------------------------------------------\\012\\011-- create a gene material property for each oligo well\\012\\011--------------------------------------------------\\012\\011\\011\\012\\011select \\011count(*)\\012\\011into counter\\012\\011from\\012\\011\\011samples well, sample_types well_type, sample_properties well_props, \\012\\011\\011materials well_material, material_properties well_material_props,\\012\\011\\011materials nested_well_material\\012\\011where\\012\\011\\011well_type.code = 'OLIGO_WELL' and\\012\\011\\011-- find 'well_material' assigned to the well\\012\\011\\011well_props.samp_id = well.id and well_material.id = well_props.mate_prop_id and \\012\\011\\011-- additional joins to entity type tables\\012\\011\\011well_type.id = well.saty_id and\\012\\011\\011-- well content material property\\012\\011\\011well_material_props.mate_id = well_material.id and \\012\\011\\011-- material connected to the material in the well (e.g. gene)\\012\\011\\011well_material_props.mate_prop_id = nested_well_material.id and\\012\\011\\011nested_well_material.maty_id = (select id from material_types where code = 'GENE');\\012\\011\\012\\011if counter = 0 then \\012\\011\\011-- skip migration if there are no genes indirectly connected to oligo wells\\012\\011\\011return;\\012\\011end if;   \\012\\012\\011insert into sample_properties(id, samp_id, stpt_id, mate_prop_id, pers_id_registerer) (\\012\\011\\011select \\011nextval('sample_property_id_seq') id, \\012\\011\\011\\011well.id samp_id, \\012\\011\\011\\011(select stpt.id from sample_type_property_types stpt, property_types props where stpt.prty_id = props.id and props.code='GENE') stpt_id,\\012\\011\\011\\011nested_well_material.id mate_prop_id,\\012\\011\\011\\011(select id from persons where user_id ='system') pers_id_registerer \\012\\011\\011from\\012\\011\\011\\011samples well, sample_types well_type, sample_properties well_props, \\012\\011\\011\\011materials well_material, material_properties well_material_props,\\012\\011\\011\\011materials nested_well_material\\012\\011\\011where\\012\\011\\011\\011well_type.code = 'OLIGO_WELL' and\\012\\011\\011\\011-- find 'well_material' assigned to the well\\012\\011\\011\\011well_props.samp_id = well.id and well_material.id = well_props.mate_prop_id and \\012\\011\\011\\011-- additional joins to entity type tables\\012\\011\\011\\011well_type.id = well.saty_id and\\012\\011\\011\\011-- well content material property\\012\\011\\011\\011well_material_props.mate_id = well_material.id and \\012\\011\\011\\011-- material connected to the material in the well (e.g. gene)\\012\\011\\011\\011well_material_props.mate_prop_id = nested_well_material.id and\\012\\011\\011\\011nested_well_material.maty_id = (select id from material_types where code = 'GENE')\\012\\011);\\012\\012END;\\012$$ LANGUAGE 'plpgsql';\\012\\012select CONNECT_WELLS_WITH_GENES();\\012drop function CONNECT_WELLS_WITH_GENES();\\012\\012--------------------------------------------------------------------------------------\\012--------------------------------------------------------------------------------------\\012\\012-- drop dataset triggers\\012\\012DROP TRIGGER check_dataset_relationships_on_data_table_modification ON data;\\012DROP FUNCTION check_dataset_relationships_on_data_table_modification();\\012DROP TRIGGER check_dataset_relationships_on_relationships_table_modification ON data_set_relationships;\\012DROP FUNCTION check_dataset_relationships_on_relationships_table_modification();\\012 \\012\\012\\012\\012\\012\\012\\012\\012	\N
+./sourceTest/sql/postgresql/058/.svn/text-base/017=database_version_logs.tsv.svn-base:056	source/sql/postgresql/migration/migration-055-056.sql	SUCCESS	2010-09-10 09:06:20.278	-- Migration from 055 to 056\\012\\012--------------------------------------------------------------------------------------\\012--------------------------------------------------------------------------------------\\012-- Screening specific migration. Nothing will be performed on openBIS databases \\012-- which are not screening specific.\\012--------------------------------------------------------------------------------------\\012--------------------------------------------------------------------------------------\\012\\012CREATE OR REPLACE FUNCTION merge_words(text, text) RETURNS text AS $$\\012DECLARE\\012  BEGIN\\012    IF  character_length($1) > 0 THEN\\012      RETURN $1 || ' ' || $2;\\012    ELSE\\012      RETURN $2;\\012    END IF;\\012  END;\\012$$ LANGUAGE plpgsql;\\012\\012CREATE AGGREGATE merge_words(text)\\012(\\012  SFUNC = merge_words,\\012  STYPE = text\\012);\\012\\012\\012CREATE OR REPLACE FUNCTION REPLACE_GENE_SYMBOL_BY_GENE_ID() RETURNS void AS $$\\012DECLARE\\012\\011counter  int;\\012\\011library_id_assigned_to_gene bool;\\012BEGIN\\012\\011--------------------------------------------------\\012\\011-- create a GENE_SYMBOL property and assign it to GENE\\012\\011--------------------------------------------------\\012\\011\\012\\011select true  \\012\\011into library_id_assigned_to_gene \\012\\011from material_type_property_types mtpt, material_types mt, property_types pt  \\012\\011where mtpt.maty_id = mt.id and mtpt.prty_id = pt.id \\012\\011\\011and mt.code = 'GENE' and pt.code = 'LIBRARY_ID';\\012\\011\\012\\011if library_id_assigned_to_gene IS NULL then \\012\\011\\011-- skip migration if gene has no library_id property\\012\\011\\011return;\\012\\011end if; \\012\\011\\012\\011\\012\\011select count(*)\\012\\011into counter \\012\\011from  \\012\\011\\011(select m.id, count(mp.id) as c \\012\\011\\011\\011from materials m, material_types mt, material_properties mp, material_type_property_types mtpt, property_types pt \\012\\011\\011\\011where m.maty_id = mt.id and mp.mate_id = m.id and mp.mtpt_id = mtpt.id and mtpt.maty_id = mt.id and pt.id = mtpt.prty_id\\012\\011\\011\\011\\011and mt.code = 'GENE' and pt.code = 'LIBRARY_ID' \\012\\011\\011\\011group by m.id) as counter_table \\012\\011where c < 1; \\012\\011\\012\\011if counter > 0 then \\012\\011\\011-- skip migration if there is at least one gene without library_id\\012\\011\\011return;\\012\\011end if;\\012\\011\\012\\011\\012\\011insert into property_types\\012\\011\\011(id\\012\\011\\011,code\\012\\011\\011,description\\012\\011\\011,label\\012\\011\\011,daty_id\\012\\011\\011,pers_id_registerer\\012\\011\\011,dbin_id)\\012\\011values \\012\\011\\011(nextval('PROPERTY_TYPE_ID_SEQ')\\012\\011\\011,'GENE_SYMBOLS'\\012\\011\\011,'Gene symbols'\\012\\011\\011,'Gene symbols'\\012\\011\\011,(select id from data_types where code ='VARCHAR')\\012\\011\\011,(select id from persons where user_id ='system')\\012\\011\\011,(select id from database_instances where is_original_source = 'T')\\012\\011);\\012\\011\\011\\012\\011insert into material_type_property_types( \\012\\011  id,\\012\\011  maty_id,\\012\\011  prty_id,\\012\\011  is_mandatory,\\012\\011  pers_id_registerer,\\012\\011  ordinal\\012\\011) values(\\012\\011\\011\\011nextval('mtpt_id_seq'), \\012\\011\\011\\011(select id from material_types where code = 'GENE'),\\012\\011\\011\\011(select id from property_types where code = 'GENE_SYMBOLS'),\\012\\011\\011\\011false,\\012\\011\\011\\011(select id from persons where user_id ='system'),\\012\\011\\011\\011(select max(ordinal)+1 from material_type_property_types \\012\\011\\011\\011\\011where maty_id = (select id from material_types where code = 'GENE'))\\012\\011\\011);\\012\\012\\011--------------------------------------------------\\012\\011-- create temporary table with all gene migration information\\012\\011--------------------------------------------------\\012\\012\\011create temp table genes \\012\\011(\\012\\011\\011id tech_id,\\012\\011\\011code code,\\012\\011\\011library_id generic_value,\\012\\011\\011gene_codes generic_value,\\012\\011\\011new_id tech_id,\\012\\011\\011library_tech_id tech_id\\011\\011\\012\\011);\\012\\011\\012\\011insert into genes (id, code, library_id, library_tech_id)\\012\\011\\011(select m.id, m.code, mp.value as library_id, mp.id as library_tech_id from materials m, material_properties mp, material_type_property_types mtpt, property_types pt, material_types mt\\012\\011\\011where mp.mate_id = m.id and  mp.mtpt_id = mtpt.id and pt.id = mtpt.prty_id and pt.code = 'LIBRARY_ID' and mt.id = m.maty_id and mt.id = mtpt.maty_id and mt.code = 'GENE');\\012\\011\\012\\011update genes set new_id = map.to_id from (select g_from.id as from_id, min(g_to.id) as to_id  from genes g_from, genes g_to where g_from.library_id = g_to.library_id group by g_from.id) as map where map.from_id = id;\\011\\012\\011\\012\\011update genes set gene_codes = map.gene_codes from (select g_from.library_id as lib_id, merge_words(distinct g_to.code) as gene_codes from genes g_from, genes g_to where g_from.library_id = g_to.library_id group by g_from.library_id) as map where map.lib_id = library_id;\\011\\012\\012\\011--------------------------------------------------\\012\\011-- update gene references\\012\\011--------------------------------------------------\\012\\012\\011update EXPERIMENTS set MATE_ID_STUDY_OBJECT = genes.new_id from genes where genes.id = MATE_ID_STUDY_OBJECT and not genes.id = genes.new_id;\\012\\011update EXPERIMENT_PROPERTIES set  MATE_PROP_ID = genes.new_id from genes where genes.id = MATE_PROP_ID and not genes.id = genes.new_id;\\012\\011update MATERIAL_PROPERTIES set  MATE_PROP_ID = genes.new_id from genes where genes.id = MATE_PROP_ID and not genes.id = genes.new_id;\\012\\011update SAMPLE_PROPERTIES set  MATE_PROP_ID = genes.new_id from genes where genes.id = MATE_PROP_ID and not genes.id = genes.new_id;\\012\\011update DATA_SET_PROPERTIES set  MATE_PROP_ID = genes.new_id from genes where genes.id = MATE_PROP_ID and not genes.id = genes.new_id;\\012\\011\\012\\011delete from  material_properties where mate_id in (select id from genes where not genes.id = genes.new_id);\\012\\011delete from MATERIALS where id in (select id from genes where not genes.id = genes.new_id);\\012\\012\\011delete from genes where id in (select id from genes where not genes.id = genes.new_id);\\012\\012\\012\\011--------------------------------------------------\\012\\011-- replace gene code with library_id\\012\\011--------------------------------------------------\\012\\011\\012\\011update materials set code = genes.library_id from genes where materials.id = genes.id ;\\012\\011delete from material_properties where id in (select library_tech_id from genes);\\012\\011\\012\\011--------------------------------------------------\\012\\011-- create a gene symbols property for each gene\\012\\011--------------------------------------------------\\012\\011\\012\\011insert into material_properties\\012\\011\\011(id\\012\\011  , mate_id\\012\\011  , mtpt_id\\012\\011  , "value"\\012\\011  , pers_id_registerer)\\012\\011\\011(select nextval('material_property_id_seq') id\\012\\011  \\011, genes.id  mate_id\\012\\011    , (select mtpt.id\\012\\011    \\011\\011from   material_type_property_types mtpt, material_types mt, property_types pt\\012\\011    \\011\\011where  pt.code = 'GENE_SYMBOLS' and mt.code = 'GENE' and mtpt.prty_id = pt.id\\012\\011        \\011and mtpt.maty_id = mt.id) mtpt_id\\012\\011    , genes.gene_codes "value"\\012\\011    , (select id from persons where user_id = 'system') pers_id_registerer\\012\\011 \\011from genes); \\012\\012\\011--------------------------------------------------\\012\\011-- delete temporary table\\012\\011--------------------------------------------------\\012\\011\\012\\011drop table genes;\\012\\011\\012END;\\012$$ LANGUAGE 'plpgsql';\\012\\012select REPLACE_GENE_SYMBOL_BY_GENE_ID();\\012drop function REPLACE_GENE_SYMBOL_BY_GENE_ID();\\012DROP AGGREGATE merge_words(text);\\012drop function merge_words(text,text);\\012\\012\\012--------------------------------------------------------------------------------------\\012--------------------------------------------------------------------------------------\\012\\012UPDATE sample_types SET code = 'SIRNA_WELL' WHERE code = 'OLIGO_WELL';\\012UPDATE material_types SET code = 'SIRNA' WHERE code = 'OLIGO';\\012UPDATE property_types SET code = 'SIRNA', label = 'siRNA' WHERE code = 'OLIGO';\\012\\012\\012\\012\\012\\012\\012\\012\\012\\012\\012\\012\\012\\012\\012\\012\\012\\012\\012\\012	\N
+./sourceTest/sql/postgresql/058/.svn/text-base/schema-058.sql.svn-base:    LANGUAGE plpgsql
+./sourceTest/sql/postgresql/058/.svn/text-base/schema-058.sql.svn-base:    LANGUAGE plpgsql
+./sourceTest/sql/postgresql/058/.svn/text-base/schema-058.sql.svn-base:    LANGUAGE plpgsql
+./sourceTest/sql/postgresql/058/.svn/text-base/schema-058.sql.svn-base:    LANGUAGE plpgsql
+./sourceTest/sql/postgresql/058/.svn/text-base/schema-058.sql.svn-base:    LANGUAGE plpgsql
+./sourceTest/sql/postgresql/058/.svn/text-base/schema-058.sql.svn-base:    LANGUAGE plpgsql
+./sourceTest/sql/postgresql/058/.svn/text-base/schema-058.sql.svn-base:    LANGUAGE plpgsql
+./sourceTest/sql/postgresql/058/.svn/text-base/schema-058.sql.svn-base:    LANGUAGE plpgsql
+./sourceTest/sql/postgresql/058/.svn/text-base/schema-058.sql.svn-base:    LANGUAGE plpgsql
+./sourceTest/sql/postgresql/058/017=database_version_logs.tsv:027	D:\\User\\felmer\\dev-workspace\\openbis/source/sql/postgresql/027/function-027.sql	SUCCESS	2008-11-05 09:18:00.403	-- Creating Functions\\012\\012------------------------------------------------------------------------------------\\012--  Purpose:  Create function RENAME_SEQUENCE() that is required for renaming the sequences belonging to tables\\012------------------------------------------------------------------------------------\\012CREATE FUNCTION RENAME_SEQUENCE(OLD_NAME VARCHAR, NEW_NAME VARCHAR) RETURNS INTEGER AS $$\\012DECLARE\\012  CURR_SEQ_VAL   INTEGER;\\012BEGIN\\012  SELECT INTO CURR_SEQ_VAL NEXTVAL(OLD_NAME);\\012  EXECUTE 'CREATE SEQUENCE ' || NEW_NAME || ' START WITH ' || CURR_SEQ_VAL;\\012  EXECUTE 'DROP SEQUENCE ' || OLD_NAME;\\012  RETURN CURR_SEQ_VAL;\\012END;\\012$$ LANGUAGE 'plpgsql';\\012\\012\\012------------------------------------------------------------------------------------\\012--  Purpose:  Create trigger CONTROLLED_VOCABULARY_CHECK \\012------------------------------------------------------------------------------------\\012\\012CREATE OR REPLACE FUNCTION CONTROLLED_VOCABULARY_CHECK() RETURNS trigger AS $$\\012DECLARE\\012   v_code  CODE;\\012BEGIN\\012\\012   select code into v_code from data_types where id = NEW.daty_id;\\012\\012   -- Check if the data is of type "CONTROLLEDVOCABULARY"\\012   if v_code = 'CONTROLLEDVOCABULARY' then\\012      if NEW.covo_id IS NULL then\\012         RAISE EXCEPTION 'Insert/Update of Property Type (Code: %) failed, as its Data Type is CONTROLLEDVOCABULARY, but it is not linked to a Controlled Vocabulary.', NEW.code;\\012      end if;\\012   end if;\\012\\012   RETURN NEW;\\012\\012END;\\012$$ LANGUAGE 'plpgsql';\\012\\012CREATE TRIGGER CONTROLLED_VOCABULARY_CHECK BEFORE INSERT OR UPDATE ON PROPERTY_TYPES\\012    FOR EACH ROW EXECUTE PROCEDURE CONTROLLED_VOCABULARY_CHECK();\\012\\012\\012------------------------------------------------------------------------------------\\012--  Purpose:  Create trigger EXTERNAL_DATA_STORAGE_FORMAT_CHECK \\012------------------------------------------------------------------------------------\\012\\012CREATE OR REPLACE FUNCTION EXTERNAL_DATA_STORAGE_FORMAT_CHECK() RETURNS trigger AS $$\\012DECLARE\\012   v_covo_code  CODE;\\012   data_code CODE;\\012BEGIN\\012\\012   select code into v_covo_code from controlled_vocabularies\\012      where is_internal_namespace = true and \\012         id = (select covo_id from controlled_vocabulary_terms where id = NEW.cvte_id_stor_fmt);\\012   -- Check if the data storage format is a term of the controlled vocabulary "STORAGE_FORMAT"\\012   if v_covo_code != 'STORAGE_FORMAT' then\\012      select code into data_code from data where id = NEW.data_id; \\012      RAISE EXCEPTION 'Insert/Update of Data (Code: %) failed, as its Storage Format is %, but is required to be STORAGE_FORMAT.', data_code, v_covo_code;\\012   end if;\\012\\012   RETURN NEW;\\012\\012END;\\012$$ LANGUAGE 'plpgsql';\\012\\012CREATE TRIGGER EXTERNAL_DATA_STORAGE_FORMAT_CHECK BEFORE INSERT OR UPDATE ON EXTERNAL_DATA\\012    FOR EACH ROW EXECUTE PROCEDURE EXTERNAL_DATA_STORAGE_FORMAT_CHECK();\\012\\012------------------------------------------------------------------------------------\\012--  Purpose:  Create trigger SAMPLE_CODE_UNIQUENESS_CHECK \\012------------------------------------------------------------------------------------\\012\\012CREATE OR REPLACE FUNCTION SAMPLE_CODE_UNIQUENESS_CHECK() RETURNS trigger AS $$\\012DECLARE\\012   counter  INTEGER;\\012BEGIN\\012\\011IF (NEW.samp_id_part_of is NULL) THEN\\012\\011\\011IF (NEW.dbin_id is not NULL) THEN\\012\\011\\011\\011SELECT count(*) into counter FROM samples \\012\\011\\011\\011\\011where id != NEW.id and code = NEW.code and samp_id_part_of is NULL and dbin_id = NEW.dbin_id;\\012\\011\\011\\011IF (counter > 0) THEN\\012\\011\\011\\011\\011RAISE EXCEPTION 'Insert/Update of Sample (Code: %) failed because database instance sample with the same code already exists.', NEW.code;\\012\\011\\011\\011END IF;\\012\\011\\011ELSIF (NEW.grou_id is not NULL) THEN\\012\\011\\011\\011SELECT count(*) into counter FROM samples \\012\\011\\011\\011\\011where id != NEW.id and code = NEW.code and samp_id_part_of is NULL and grou_id = NEW.grou_id;\\012\\011\\011\\011IF (counter > 0) THEN\\012\\011\\011\\011\\011RAISE EXCEPTION 'Insert/Update of Sample (Code: %) failed because group sample with the same code already exists.', NEW.code;\\012\\011\\011\\011END IF;\\012\\011\\011END IF;\\012        ELSE\\012\\011\\011IF (NEW.dbin_id is not NULL) THEN\\012\\011\\011\\011SELECT count(*) into counter FROM samples \\012\\011\\011\\011\\011where id != NEW.id and code = NEW.code and samp_id_part_of = NEW.samp_id_part_of and dbin_id = NEW.dbin_id;\\012\\011\\011\\011IF (counter > 0) THEN\\012\\011\\011\\011\\011RAISE EXCEPTION 'Insert/Update of Sample (Code: %) failed because database instance sample with the same code and being the part of the same parent already exists.', NEW.code;\\012\\011\\011\\011END IF;\\012\\011\\011ELSIF (NEW.grou_id is not NULL) THEN\\012\\011\\011\\011SELECT count(*) into counter FROM samples \\012\\011\\011\\011\\011where id != NEW.id and code = NEW.code and samp_id_part_of = NEW.samp_id_part_of and grou_id = NEW.grou_id;\\012\\011\\011\\011IF (counter > 0) THEN\\012\\011\\011\\011\\011RAISE EXCEPTION 'Insert/Update of Sample (Code: %) failed because group sample with the same code and being the part of the same parent already exists.', NEW.code;\\012\\011\\011\\011END IF;\\012\\011\\011END IF;\\012        END IF;   \\012   RETURN NEW;\\012END;\\012$$ LANGUAGE 'plpgsql';\\012\\012CREATE TRIGGER SAMPLE_CODE_UNIQUENESS_CHECK BEFORE INSERT OR UPDATE ON SAMPLES\\012    FOR EACH ROW EXECUTE PROCEDURE SAMPLE_CODE_UNIQUENESS_CHECK();\\012	\N
+./sourceTest/sql/postgresql/058/017=database_version_logs.tsv:028	source/sql/postgresql/migration/migration-027-028.sql	SUCCESS	2008-11-18 13:24:17.508	-- Create EXPERIMENT_ATTACHMENT_CONTENTS.\\012CREATE TABLE EXPERIMENT_ATTACHMENT_CONTENTS (ID TECH_ID NOT NULL,VALUE FILE NOT NULL);\\012CREATE SEQUENCE EXPERIMENT_ATTACHMENT_CONTENT_ID_SEQ;\\012ALTER TABLE EXPERIMENT_ATTACHMENT_CONTENTS ADD CONSTRAINT EXAC_PK PRIMARY KEY(ID);\\012\\012-- Alter EXPERIMENT_ATTACHMENTS by adding the new column which has a NULL constraint.\\012-- The NOT NULL constraint is added later on.\\012ALTER TABLE EXPERIMENT_ATTACHMENTS ADD COLUMN EXAC_ID TECH_ID;\\012\\012-- Does the VALUE migration between EXPERIMENT_ATTACHMENTS to EXPERIMENT_ATTACHMENT_CONTENTS.\\012CREATE OR REPLACE FUNCTION move_exp_att_content() RETURNS integer AS $$\\012DECLARE\\012    rec RECORD;\\012    seq BIGINT;\\012BEGIN\\012  FOR rec IN SELECT id, value FROM EXPERIMENT_ATTACHMENTS LOOP\\012  \\011seq := nextval('EXPERIMENT_ATTACHMENT_CONTENT_ID_SEQ');\\012    INSERT INTO EXPERIMENT_ATTACHMENT_CONTENTS (id, value) VALUES (seq, rec.value);\\012    UPDATE EXPERIMENT_ATTACHMENTS SET exac_id = seq WHERE id = rec.id;\\012  END LOOP;\\012  RETURN 1;\\012END;\\012$$ LANGUAGE 'plpgsql';\\012\\012-- Call the function.\\012SELECT move_exp_att_content();\\012DROP FUNCTION move_exp_att_content();\\012\\012\\012-- Finish EXPERIMENT_ATTACHMENTS changes.\\012ALTER TABLE EXPERIMENT_ATTACHMENTS ADD CONSTRAINT EXAT_CONT_FK FOREIGN KEY (EXAC_ID) REFERENCES EXPERIMENT_ATTACHMENT_CONTENTS(ID);\\012ALTER TABLE EXPERIMENT_ATTACHMENTS DROP COLUMN VALUE;\\012ALTER TABLE EXPERIMENT_ATTACHMENTS ALTER COLUMN EXAC_ID SET NOT NULL;\\012	\N
+./sourceTest/sql/postgresql/058/017=database_version_logs.tsv:029	source/sql/postgresql/migration/migration-028-029.sql	SUCCESS	2009-03-18 10:50:20.105	-- -------\\012-- add modification_timestamp field to allow edition with Hibernate\\012-- -------\\012\\012ALTER TABLE samples\\012\\011ADD COLUMN modification_timestamp TIME_STAMP DEFAULT CURRENT_TIMESTAMP;\\012\\012ALTER TABLE experiments\\012\\011ADD COLUMN modification_timestamp TIME_STAMP DEFAULT CURRENT_TIMESTAMP;\\012\\012ALTER TABLE materials\\012\\011ADD COLUMN modification_timestamp TIME_STAMP DEFAULT CURRENT_TIMESTAMP;\\012\\012ALTER TABLE experiment_properties\\012\\011ADD COLUMN modification_timestamp TIME_STAMP DEFAULT CURRENT_TIMESTAMP;\\012\\012ALTER TABLE material_properties\\012\\011ADD COLUMN modification_timestamp TIME_STAMP DEFAULT CURRENT_TIMESTAMP;\\012\\012ALTER TABLE sample_properties\\012\\011ADD COLUMN modification_timestamp TIME_STAMP DEFAULT CURRENT_TIMESTAMP;\\012\\012-- -------\\012-- add property data type which references materials\\012-- -------\\012\\012ALTER TABLE property_types\\012\\011ADD COLUMN maty_prop_id tech_id;\\012\\012ALTER TABLE property_types\\012\\011ADD CONSTRAINT prty_maty_fk FOREIGN KEY (maty_prop_id) REFERENCES material_types(id);\\012\\012ALTER TABLE experiment_properties\\012\\011ADD COLUMN mate_prop_id tech_id;\\012\\012ALTER TABLE material_properties\\012\\011ADD COLUMN mate_prop_id tech_id;\\012\\012ALTER TABLE sample_properties\\012\\011ADD COLUMN mate_prop_id tech_id;\\012\\012ALTER TABLE experiment_properties\\012\\011ADD CONSTRAINT expr_mapr_fk FOREIGN KEY (mate_prop_id) REFERENCES materials(id);\\012\\012ALTER TABLE material_properties\\012\\011ADD CONSTRAINT mapr_mapr_fk FOREIGN KEY (mate_prop_id) REFERENCES materials(id);\\012\\012ALTER TABLE sample_properties\\012\\011ADD CONSTRAINT sapr_mapr_fk FOREIGN KEY (mate_prop_id) REFERENCES materials(id);\\012\\012insert into data_types\\012(id\\012 ,code\\012 ,description)\\012 values \\012 (nextval('DATA_TYPE_ID_SEQ')\\012 ,'MATERIAL'\\012 ,'Reference to a material'\\012);\\012\\012ALTER TABLE MATERIAL_PROPERTIES DROP CONSTRAINT MAPR_CK;\\012ALTER TABLE MATERIAL_PROPERTIES ADD CONSTRAINT MAPR_CK CHECK \\012\\011((VALUE IS NOT NULL AND CVTE_ID IS NULL AND MATE_PROP_ID IS NULL) OR \\012\\011 (VALUE IS NULL AND CVTE_ID IS NOT NULL AND MATE_PROP_ID IS NULL) OR\\012\\011 (VALUE IS NULL AND CVTE_ID IS NULL AND MATE_PROP_ID IS NOT NULL)\\012\\011);\\012\\012ALTER TABLE EXPERIMENT_PROPERTIES DROP CONSTRAINT EXPR_CK;\\012ALTER TABLE EXPERIMENT_PROPERTIES ADD CONSTRAINT EXPR_CK CHECK \\012\\011((VALUE IS NOT NULL AND CVTE_ID IS NULL AND MATE_PROP_ID IS NULL) OR \\012\\011 (VALUE IS NULL AND CVTE_ID IS NOT NULL AND MATE_PROP_ID IS NULL) OR\\012\\011 (VALUE IS NULL AND CVTE_ID IS NULL AND MATE_PROP_ID IS NOT NULL)\\012\\011);\\012\\012ALTER TABLE SAMPLE_PROPERTIES DROP CONSTRAINT SAPR_CK;\\012ALTER TABLE SAMPLE_PROPERTIES ADD CONSTRAINT SAPR_CK CHECK \\012\\011((VALUE IS NOT NULL AND CVTE_ID IS NULL AND MATE_PROP_ID IS NULL) OR \\012\\011 (VALUE IS NULL AND CVTE_ID IS NOT NULL AND MATE_PROP_ID IS NULL) OR\\012\\011 (VALUE IS NULL AND CVTE_ID IS NULL AND MATE_PROP_ID IS NOT NULL)\\012\\011);\\012\\012------------------------------------------------------------------------------------\\012--  Purpose:  Create trigger MATERIAL/SAMPLE/EXPERIMENT _PROPERTY_WITH_MATERIAL_DATA_TYPE_CHECK\\012--            It checks that if material property value is assigned to the entity,\\012--\\011\\011\\011\\011\\011\\011then the material type is equal to the one described by property type.\\012------------------------------------------------------------------------------------\\012\\012CREATE OR REPLACE FUNCTION MATERIAL_PROPERTY_WITH_MATERIAL_DATA_TYPE_CHECK() RETURNS trigger AS $$\\012DECLARE\\012   v_type_id  CODE;\\012   v_type_id_prop  CODE;\\012BEGIN\\012   if NEW.mate_prop_id IS NOT NULL then\\012\\011\\011\\011-- find material type id of the property type \\012\\011\\011\\011select pt.maty_prop_id into v_type_id_prop \\012\\011\\011\\011  from material_type_property_types etpt, property_types pt \\012\\011\\011\\011 where NEW.mtpt_id = etpt.id AND etpt.prty_id = pt.id;\\012\\011\\011\\012\\011\\011\\011if v_type_id_prop IS NOT NULL then\\012\\011\\011\\011\\011-- find material type id of the material which consists the entity's property value\\012\\011\\011\\011\\011select entity.maty_id into v_type_id \\012\\011\\011\\011\\011  from materials entity\\012\\011\\011\\011\\011 where NEW.mate_prop_id = entity.id;\\012\\011\\011\\011\\011if v_type_id != v_type_id_prop then\\012\\011\\011\\011\\011\\011RAISE EXCEPTION 'Insert/Update of property value referencing material (id: %) failed, as referenced material type is different than expected (id %, expected id: %).', \\012\\011\\011\\011\\011\\011\\011\\011 NEW.mate_prop_id, v_type_id, v_type_id_prop;\\012\\011\\011\\011\\011end if;\\012\\011\\011\\011end if;\\012   end if;\\012   RETURN NEW;\\012END;\\012$$ LANGUAGE 'plpgsql';\\012\\012CREATE TRIGGER MATERIAL_PROPERTY_WITH_MATERIAL_DATA_TYPE_CHECK BEFORE INSERT OR UPDATE ON material_properties\\012    FOR EACH ROW EXECUTE PROCEDURE MATERIAL_PROPERTY_WITH_MATERIAL_DATA_TYPE_CHECK();\\012    \\012CREATE OR REPLACE FUNCTION SAMPLE_PROPERTY_WITH_MATERIAL_DATA_TYPE_CHECK() RETURNS trigger AS $$\\012DECLARE\\012   v_type_id  CODE;\\012   v_type_id_prop  CODE;\\012BEGIN\\012   if NEW.mate_prop_id IS NOT NULL then\\012\\011\\011\\011-- find material type id of the property type \\012\\011\\011\\011select pt.maty_prop_id into v_type_id_prop \\012\\011\\011\\011  from sample_type_property_types etpt, property_types pt \\012\\011\\011\\011 where NEW.stpt_id = etpt.id AND etpt.prty_id = pt.id;\\012\\011\\011\\012\\011\\011\\011if v_type_id_prop IS NOT NULL then\\012\\011\\011\\011\\011-- find material type id of the material which consists the entity's property value\\012\\011\\011\\011\\011select entity.maty_id into v_type_id \\012\\011\\011\\011\\011  from materials entity\\012\\011\\011\\011\\011 where NEW.mate_prop_id = entity.id;\\012\\011\\011\\011\\011if v_type_id != v_type_id_prop then\\012\\011\\011\\011\\011\\011RAISE EXCEPTION 'Insert/Update of property value referencing material (id: %) failed, as referenced material type is different than expected (id %, expected id: %).', \\012\\011\\011\\011\\011\\011\\011\\011\\011\\011\\011\\011\\011 NEW.mate_prop_id, v_type_id, v_type_id_prop;\\012\\011\\011\\011\\011end if;\\012\\011\\011\\011end if;\\012   end if;\\012   RETURN NEW;\\012END;\\012$$ LANGUAGE 'plpgsql';\\012\\012CREATE TRIGGER SAMPLE_PROPERTY_WITH_MATERIAL_DATA_TYPE_CHECK BEFORE INSERT OR UPDATE ON sample_properties\\012    FOR EACH ROW EXECUTE PROCEDURE SAMPLE_PROPERTY_WITH_MATERIAL_DATA_TYPE_CHECK();\\012    \\012CREATE OR REPLACE FUNCTION EXPERIMENT_PROPERTY_WITH_MATERIAL_DATA_TYPE_CHECK() RETURNS trigger AS $$\\012DECLARE\\012   v_type_id  CODE;\\012   v_type_id_prop  CODE;\\012BEGIN\\012   if NEW.mate_prop_id IS NOT NULL then\\012\\011\\011\\011-- find material type id of the property type \\012\\011\\011\\011select pt.maty_prop_id into v_type_id_prop \\012\\011\\011\\011  from experiment_type_property_types etpt, property_types pt \\012\\011\\011\\011 where NEW.etpt_id = etpt.id AND etpt.prty_id = pt.id;\\012\\011\\011\\012\\011\\011\\011if v_type_id_prop IS NOT NULL then\\012\\011\\011\\011\\011-- find material type id of the material which consists the entity's property value\\012\\011\\011\\011\\011select entity.maty_id into v_type_id \\012\\011\\011\\011\\011  from materials entity\\012\\011\\011\\011\\011 where NEW.mate_prop_id = entity.id;\\012\\011\\011\\011\\011if v_type_id != v_type_id_prop then\\012\\011\\011\\011\\011\\011RAISE EXCEPTION 'Insert/Update of property value referencing material (id: %) failed, as referenced material type is different than expected (id %, expected id: %).', \\012\\011\\011\\011\\011\\011\\011\\011\\011\\011\\011\\011\\011 NEW.mate_prop_id, v_type_id, v_type_id_prop;\\012\\011\\011\\011\\011end if;\\012\\011\\011\\011end if;\\012   end if;\\012   RETURN NEW;\\012END;\\012$$ LANGUAGE 'plpgsql';\\012\\012CREATE TRIGGER EXPERIMENT_PROPERTY_WITH_MATERIAL_DATA_TYPE_CHECK BEFORE INSERT OR UPDATE ON experiment_properties\\012    FOR EACH ROW EXECUTE PROCEDURE EXPERIMENT_PROPERTY_WITH_MATERIAL_DATA_TYPE_CHECK();\\012       \\012-- -------\\012-- remove the reminescents of the OBSERVABLE_TYPE\\012-- -------\\012\\012ALTER TABLE data\\012\\011DROP CONSTRAINT data_obty_fk;\\012\\012ALTER TABLE data_set_types\\012\\011DROP CONSTRAINT obty_pk;\\012\\012ALTER TABLE data_set_types\\012\\011ADD CONSTRAINT dsty_pk PRIMARY KEY (id);\\012\\012ALTER TABLE data\\012\\011ADD CONSTRAINT data_dsty_fk FOREIGN KEY (dsty_id) REFERENCES data_set_types(id);\\012\\012ALTER TABLE data_set_types\\012\\011DROP CONSTRAINT obty_bk_uk;\\012\\012ALTER TABLE data_set_types\\012\\011DROP CONSTRAINT obty_dbin_fk;\\012\\012ALTER TABLE data_set_types\\012\\011ADD CONSTRAINT dsty_bk_uk UNIQUE (code, dbin_id);\\012\\012ALTER TABLE data_set_types\\012\\011ADD CONSTRAINT dsty_dbin_fk FOREIGN KEY (dbin_id) REFERENCES database_instances(id);\\012\\012DROP INDEX data_obty_fk_i;\\012\\012CREATE INDEX data_dsty_fk_i ON data(dsty_id);\\012	\N
+./sourceTest/sql/postgresql/058/017=database_version_logs.tsv:030	source/sql/postgresql/migration/migration-029-030.sql	SUCCESS	2009-03-23 15:34:44.72	-- -------\\012-- add modification_timestamp field to allow edition with Hibernate\\012-- -------\\012ALTER TABLE data\\012\\011ADD COLUMN modification_timestamp TIME_STAMP DEFAULT CURRENT_TIMESTAMP;\\012ALTER TABLE experiment_types\\012\\011ADD COLUMN modification_timestamp TIME_STAMP DEFAULT CURRENT_TIMESTAMP;\\012ALTER TABLE sample_types\\012\\011ADD COLUMN modification_timestamp TIME_STAMP DEFAULT CURRENT_TIMESTAMP;\\012ALTER TABLE material_types\\012\\011ADD COLUMN modification_timestamp TIME_STAMP DEFAULT CURRENT_TIMESTAMP;\\012ALTER TABLE data_set_types\\012\\011ADD COLUMN modification_timestamp TIME_STAMP DEFAULT CURRENT_TIMESTAMP;\\012ALTER TABLE controlled_vocabularies\\012\\011ADD COLUMN modification_timestamp TIME_STAMP DEFAULT CURRENT_TIMESTAMP;\\012-- -------\\012-- add properties to data sets\\012-- -------\\012CREATE TABLE DATA_SET_PROPERTIES (ID TECH_ID NOT NULL,DS_ID TECH_ID NOT NULL,DSTPT_ID TECH_ID NOT NULL,VALUE GENERIC_VALUE,CVTE_ID TECH_ID, MATE_PROP_ID TECH_ID, PERS_ID_REGISTERER TECH_ID NOT NULL,REGISTRATION_TIMESTAMP TIME_STAMP_DFL NOT NULL DEFAULT CURRENT_TIMESTAMP, MODIFICATION_TIMESTAMP TIME_STAMP DEFAULT CURRENT_TIMESTAMP);\\012CREATE TABLE DATA_SET_TYPE_PROPERTY_TYPES (ID TECH_ID NOT NULL,DSTY_ID TECH_ID NOT NULL,PRTY_ID TECH_ID NOT NULL,IS_MANDATORY BOOLEAN_CHAR NOT NULL DEFAULT 'F',IS_MANAGED_INTERNALLY BOOLEAN_CHAR NOT NULL DEFAULT 'F',PERS_ID_REGISTERER TECH_ID NOT NULL,REGISTRATION_TIMESTAMP TIME_STAMP_DFL NOT NULL DEFAULT CURRENT_TIMESTAMP);\\012\\012CREATE SEQUENCE DATA_SET_PROPERTY_ID_SEQ;\\012CREATE SEQUENCE DSTPT_ID_SEQ;\\012\\012ALTER TABLE DATA_SET_TYPE_PROPERTY_TYPES ADD CONSTRAINT DSTPT_PK PRIMARY KEY(ID);\\012ALTER TABLE DATA_SET_PROPERTIES ADD CONSTRAINT DSPR_PK PRIMARY KEY(ID);\\012\\012ALTER TABLE DATA_SET_TYPE_PROPERTY_TYPES ADD CONSTRAINT DSTPT_BK_UK UNIQUE(DSTY_ID,PRTY_ID);\\012ALTER TABLE DATA_SET_PROPERTIES ADD CONSTRAINT DSPR_BK_UK UNIQUE(DS_ID,DSTPT_ID);\\012\\012\\012ALTER TABLE DATA_SET_TYPE_PROPERTY_TYPES ADD CONSTRAINT DSTPT_DSTY_FK FOREIGN KEY (DSTY_ID) REFERENCES DATA_SET_TYPES(ID);\\012ALTER TABLE DATA_SET_TYPE_PROPERTY_TYPES ADD CONSTRAINT DSTPT_PERS_FK FOREIGN KEY (PERS_ID_REGISTERER) REFERENCES PERSONS(ID);\\012ALTER TABLE DATA_SET_TYPE_PROPERTY_TYPES ADD CONSTRAINT DSTPT_PRTY_FK FOREIGN KEY (PRTY_ID) REFERENCES PROPERTY_TYPES(ID);\\012ALTER TABLE DATA_SET_PROPERTIES ADD CONSTRAINT DSPR_CVTE_FK FOREIGN KEY (CVTE_ID) REFERENCES CONTROLLED_VOCABULARY_TERMS(ID);\\012ALTER TABLE DATA_SET_PROPERTIES ADD CONSTRAINT DSPR_DSTPT_FK FOREIGN KEY (DSTPT_ID) REFERENCES DATA_SET_TYPE_PROPERTY_TYPES(ID) ON DELETE CASCADE;\\012ALTER TABLE DATA_SET_PROPERTIES ADD CONSTRAINT DSPR_DS_FK FOREIGN KEY (DS_ID) REFERENCES DATA(ID);\\012ALTER TABLE DATA_SET_PROPERTIES ADD CONSTRAINT DSPR_PERS_FK FOREIGN KEY (PERS_ID_REGISTERER) REFERENCES PERSONS(ID);\\012ALTER TABLE DATA_SET_PROPERTIES ADD CONSTRAINT DSPR_MAPR_FK FOREIGN KEY (MATE_PROP_ID) REFERENCES MATERIALS(ID);\\012\\012ALTER TABLE DATA_SET_PROPERTIES ADD CONSTRAINT DSPR_CK CHECK \\012\\011((VALUE IS NOT NULL AND CVTE_ID IS NULL AND MATE_PROP_ID IS NULL) OR \\012\\011 (VALUE IS NULL AND CVTE_ID IS NOT NULL AND MATE_PROP_ID IS NULL) OR\\012\\011 (VALUE IS NULL AND CVTE_ID IS NULL AND MATE_PROP_ID IS NOT NULL)\\012\\011);\\012\\012CREATE INDEX DSPR_CVTE_FK_I ON DATA_SET_PROPERTIES (CVTE_ID);\\012CREATE INDEX DSPR_DSTPT_FK_I ON DATA_SET_PROPERTIES (DSTPT_ID);\\012CREATE INDEX DSPR_DS_FK_I ON DATA_SET_PROPERTIES (DS_ID);\\012CREATE INDEX DSPR_PERS_FK_I ON DATA_SET_PROPERTIES (PERS_ID_REGISTERER);\\012CREATE INDEX DSTPT_DSTY_FK_I ON DATA_SET_TYPE_PROPERTY_TYPES (DSTY_ID);\\012CREATE INDEX DSTPT_PERS_FK_I ON DATA_SET_TYPE_PROPERTY_TYPES (PERS_ID_REGISTERER);\\012CREATE INDEX DSTPT_PRTY_FK_I ON DATA_SET_TYPE_PROPERTY_TYPES (PRTY_ID);\\012\\012CREATE OR REPLACE FUNCTION DATA_SET_PROPERTY_WITH_MATERIAL_DATA_TYPE_CHECK() RETURNS trigger AS $$\\012DECLARE\\012   v_type_id  CODE;\\012   v_type_id_prop  CODE;\\012BEGIN\\012   if NEW.mate_prop_id IS NOT NULL then\\012\\011\\011\\011-- find material type id of the property type \\012\\011\\011\\011select pt.maty_prop_id into v_type_id_prop \\012\\011\\011\\011  from data_set_type_property_types dstpt, property_types pt \\012\\011\\011\\011 where NEW.dstpt_id = dstpt.id AND dstpt.prty_id = pt.id;\\012\\011\\011\\012\\011\\011\\011if v_type_id_prop IS NOT NULL then\\012\\011\\011\\011\\011-- find material type id of the material which consists the entity's property value\\012\\011\\011\\011\\011select entity.maty_id into v_type_id \\012\\011\\011\\011\\011  from materials entity\\012\\011\\011\\011\\011 where NEW.mate_prop_id = entity.id;\\012\\011\\011\\011\\011if v_type_id != v_type_id_prop then\\012\\011\\011\\011\\011\\011RAISE EXCEPTION 'Insert/Update of property value referencing material (id: %) failed, as referenced material type is different than expected (id %, expected id: %).', \\012\\011\\011\\011\\011\\011\\011\\011\\011\\011\\011\\011\\011 NEW.mate_prop_id, v_type_id, v_type_id_prop;\\012\\011\\011\\011\\011end if;\\012\\011\\011\\011end if;\\012   end if;\\012   RETURN NEW;\\012END;\\012$$ LANGUAGE 'plpgsql';\\012\\012CREATE TRIGGER DATA_SET_PROPERTY_WITH_MATERIAL_DATA_TYPE_CHECK BEFORE INSERT OR UPDATE ON data_set_properties\\012    FOR EACH ROW EXECUTE PROCEDURE DATA_SET_PROPERTY_WITH_MATERIAL_DATA_TYPE_CHECK();   \\012	\N
+./sourceTest/sql/postgresql/058/017=database_version_logs.tsv:032	source/sql/postgresql/migration/migration-031-032.sql	SUCCESS	2009-04-09 09:36:36.2	-- -------\\012-- Modify MATERIAL_BATCHES\\012-- -------\\012\\012ALTER TABLE material_batches\\012    DROP COLUMN proc_id;\\012\\012-- -------\\012-- Modify SAMPLES\\012-- -------\\012\\012ALTER TABLE samples\\012    ADD COLUMN expe_id tech_id;\\012\\012ALTER TABLE samples\\012    ADD CONSTRAINT samp_expe_fk FOREIGN KEY (expe_id) REFERENCES experiments(id);\\012\\012CREATE INDEX samp_expe_fk_i ON samples USING btree (expe_id);\\012\\012-- relink samples directly to experiments\\012\\012UPDATE samples\\012SET expe_id = (SELECT e.id FROM experiments e, procedures p, sample_inputs si \\012               WHERE si.samp_id = samples.id AND si.proc_id = p.id AND p.expe_id = e.id AND e.inva_id IS NULL);\\012\\012\\012-- -------\\012-- Modify DATA\\012-- -------\\012\\012ALTER TABLE data\\012    ADD COLUMN expe_id tech_id;\\012\\012ALTER TABLE data\\012    ADD CONSTRAINT data_expe_fk FOREIGN KEY (expe_id) REFERENCES experiments(id);\\012\\012CREATE INDEX data_expe_fk_i ON data USING btree (expe_id);\\012\\012UPDATE data\\012SET expe_id = (SELECT e.id FROM experiments e, procedures p \\012               WHERE data.proc_id_produced_by = p.id AND p.expe_id = e.id);\\012\\012ALTER TABLE data\\012    ALTER COLUMN expe_id SET NOT NULL;\\012\\012ALTER TABLE data\\012    DROP COLUMN proc_id_produced_by;\\012\\012-- -------\\012-- Drop PROCEDURES, PROCEDURE_TYPES, and SAMPLE_INPUTS\\012-- -------\\012\\012DROP TABLE sample_inputs;\\012DROP TABLE procedures;\\012DROP TABLE procedure_types;\\012\\012DROP SEQUENCE procedure_id_seq;\\012DROP SEQUENCE procedure_type_id_seq;\\012\\012-- -------\\012-- Add CODE_SEQ\\012-- -------\\012\\012CREATE SEQUENCE CODE_SEQ;\\012\\012-- -------\\012-- Add new columns to DATA_STORES\\012-- -------\\012\\012ALTER TABLE data_stores\\012    ADD COLUMN remote_url character varying(250),\\012    ADD COLUMN session_token character varying(50),\\012    ADD COLUMN modification_timestamp time_stamp DEFAULT now();\\012\\012UPDATE data_stores\\012SET remote_url = '', session_token='';\\012\\012ALTER TABLE data_stores\\012    ALTER COLUMN remote_url SET NOT NULL,\\012    ALTER COLUMN session_token SET NOT NULL;\\012\\012-- -------\\012-- Drop foreign keys onto DATA_STORES\\012-- -------\\012\\012ALTER TABLE database_instances\\012    DROP COLUMN dast_id;\\012\\012ALTER TABLE groups\\012    DROP COLUMN dast_id;\\012\\012ALTER TABLE projects\\012    DROP COLUMN dast_id;\\012\\012ALTER TABLE experiments\\012    DROP COLUMN dast_id;\\012\\012-- -------\\012-- Add foreign key from DATA onto DATA_STORES\\012-- -------\\012\\012ALTER TABLE data\\012    ADD COLUMN dast_id tech_id;\\012\\012ALTER TABLE data\\012    ADD CONSTRAINT data_dast_fk FOREIGN KEY (dast_id) REFERENCES data_stores(id);\\012\\012UPDATE data\\012SET dast_id = (select id from data_stores where code = 'STANDARD');\\012\\012ALTER TABLE data\\012    ALTER COLUMN dast_id SET NOT NULL;\\012\\012\\012------------------------------------------------------------------------------------\\012--  Purpose:  Replace trigger SAMPLE_CODE_UNIQUENESS_CHECK \\012------------------------------------------------------------------------------------\\012\\012CREATE OR REPLACE FUNCTION SAMPLE_CODE_UNIQUENESS_CHECK() RETURNS trigger AS $$\\012DECLARE\\012   counter  INTEGER;\\012BEGIN\\012    LOCK TABLE samples IN EXCLUSIVE MODE;\\012    IF (NEW.samp_id_part_of is NULL) THEN\\012        IF (NEW.dbin_id is not NULL) THEN\\012            SELECT count(*) into counter FROM samples \\012                where id != NEW.id and code = NEW.code and samp_id_part_of is NULL and dbin_id = NEW.dbin_id;\\012            IF (counter > 0) THEN\\012                RAISE EXCEPTION 'Insert/Update of Sample (Code: %) failed because database instance sample with the same code already exists.', NEW.code;\\012            END IF;\\012        ELSIF (NEW.grou_id is not NULL) THEN\\012            SELECT count(*) into counter FROM samples \\012                where id != NEW.id and code = NEW.code and samp_id_part_of is NULL and grou_id = NEW.grou_id;\\012            IF (counter > 0) THEN\\012                RAISE EXCEPTION 'Insert/Update of Sample (Code: %) failed because group sample with the same code already exists.', NEW.code;\\012            END IF;\\012        END IF;\\012        ELSE\\012        IF (NEW.dbin_id is not NULL) THEN\\012            SELECT count(*) into counter FROM samples \\012                where id != NEW.id and code = NEW.code and samp_id_part_of = NEW.samp_id_part_of and dbin_id = NEW.dbin_id;\\012            IF (counter > 0) THEN\\012                RAISE EXCEPTION 'Insert/Update of Sample (Code: %) failed because database instance sample with the same code and being the part of the same parent already exists.', NEW.code;\\012            END IF;\\012        ELSIF (NEW.grou_id is not NULL) THEN\\012            SELECT count(*) into counter FROM samples \\012                where id != NEW.id and code = NEW.code and samp_id_part_of = NEW.samp_id_part_of and grou_id = NEW.grou_id;\\012            IF (counter > 0) THEN\\012                RAISE EXCEPTION 'Insert/Update of Sample (Code: %) failed because group sample with the same code and being the part of the same parent already exists.', NEW.code;\\012            END IF;\\012        END IF;\\012        END IF;   \\012   RETURN NEW;\\012END;\\012$$ LANGUAGE 'plpgsql';\\012\\012\\012\\012	\N
+./sourceTest/sql/postgresql/058/017=database_version_logs.tsv:034	source/sql/postgresql/migration/migration-033-034.sql	SUCCESS	2009-05-26 08:32:49.935	------------------------------------------------------------------------------------\\012-- Create sequence for generating permanent identifiers starting with nextval of existing dataset sequence.\\012------------------------------------------------------------------------------------\\012CREATE FUNCTION CREATE_SEQUENCE(EXISTING_SEQUENCE VARCHAR, NEW_SEQUENCE VARCHAR) RETURNS VOID AS $$\\012DECLARE\\012  CURR_SEQ_VAL   INTEGER;\\012BEGIN\\012  SELECT INTO CURR_SEQ_VAL NEXTVAL(EXISTING_SEQUENCE);\\012  EXECUTE 'CREATE SEQUENCE ' || NEW_SEQUENCE || ' START WITH ' || CURR_SEQ_VAL;\\012  RETURN;\\012END;\\012$$ LANGUAGE 'plpgsql';\\012\\012SELECT CREATE_SEQUENCE('DATA_ID_SEQ', 'PERM_ID_SEQ');\\012DROP FUNCTION CREATE_SEQUENCE(VARCHAR, VARCHAR);\\012\\012------------------------------------------------------------------------------------\\012-- Add perm_id columns to samples and experiments.\\012------------------------------------------------------------------------------------\\012ALTER TABLE SAMPLES ADD COLUMN PERM_ID CODE;\\012ALTER TABLE EXPERIMENTS ADD COLUMN PERM_ID CODE;\\012\\012UPDATE SAMPLES SET PERM_ID = to_char(registration_timestamp,'YYYYMMDDHHSSMS') || '-' || NEXTVAL('PERM_ID_SEQ');\\012UPDATE EXPERIMENTS SET PERM_ID = to_char(registration_timestamp,'YYYYMMDDHHSSMS') || '-' || NEXTVAL('PERM_ID_SEQ');\\012ALTER TABLE SAMPLES ALTER COLUMN PERM_ID SET NOT NULL;\\012ALTER TABLE EXPERIMENTS ALTER COLUMN PERM_ID SET NOT NULL;\\012ALTER TABLE SAMPLES ADD CONSTRAINT SAMP_PI_UK UNIQUE(PERM_ID);\\012ALTER TABLE EXPERIMENTS ADD CONSTRAINT EXPE_PI_UK UNIQUE(PERM_ID);\\012\\012\\012------------------------------------------------------------------------------------\\012-- Add column is_chosen_from_list to controlled_vocabularies.\\012------------------------------------------------------------------------------------\\012ALTER TABLE controlled_vocabularies ADD COLUMN is_chosen_from_list BOOLEAN_CHAR NOT NULL DEFAULT TRUE;\\012ALTER TABLE controlled_vocabularies ADD COLUMN source_uri CHARACTER VARYING(250);\\012------------------------------------------------------------------------------------\\012-- Modify Data table - remove arc connection between Sample and Data table, use a flag instead\\012------------------------------------------------------------------------------------\\012\\012-- add new columns\\012\\012ALTER TABLE data\\012    ADD COLUMN is_derived boolean_char;\\012ALTER TABLE data\\012    ADD COLUMN samp_id tech_id;\\012\\012-- update values in new columns\\012\\012UPDATE data\\012    SET is_derived = (samp_id_derived_from IS NOT NULL); \\012UPDATE data\\012    SET samp_id = samp_id_derived_from \\012    WHERE is_derived = 'TRUE';\\012UPDATE data\\012    SET samp_id = samp_id_acquired_from \\012    WHERE is_derived = 'FALSE';\\012\\012-- add constraints and indexes to new columns\\012\\012ALTER TABLE data\\012    ALTER COLUMN is_derived SET NOT NULL;\\012ALTER TABLE data\\012    ALTER COLUMN samp_id SET NOT NULL;   \\012ALTER TABLE data\\012    ADD CONSTRAINT data_samp_fk FOREIGN KEY (samp_id) REFERENCES samples (id);\\012CREATE INDEX data_samp_fk_i ON data USING btree (samp_id);\\012\\012-- remove old columns\\012\\012ALTER TABLE data\\012    DROP COLUMN samp_id_acquired_from;\\012ALTER TABLE data\\012    DROP COLUMN samp_id_derived_from;\\012    \\012------------------------------------------------------------------------------------\\012-- Granting SELECT privilege to group openbis_readonly\\012------------------------------------------------------------------------------------\\012\\012GRANT SELECT ON SEQUENCE attachment_content_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE attachment_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE code_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE controlled_vocabulary_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE cvte_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE data_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE data_set_property_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE data_set_relationship_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE data_set_type_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE data_store_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE data_type_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE database_instance_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE dstpt_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE etpt_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE event_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE experiment_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE experiment_property_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE experiment_type_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE file_format_type_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE group_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE invalidation_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE locator_type_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE material_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE material_property_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE material_type_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE mtpt_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE perm_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE person_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE project_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE property_type_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE role_assignment_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE sample_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE sample_property_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE sample_type_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE stpt_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE attachment_contents TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE attachments TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE controlled_vocabularies TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE controlled_vocabulary_terms TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE data TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE data_set_properties TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE data_set_relationships TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE data_set_type_property_types TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE data_set_types TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE data_stores TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE data_types TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE database_instances TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE database_version_logs TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE events TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE experiment_properties TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE experiment_type_property_types TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE experiment_types TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE experiments TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE external_data TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE file_format_types TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE groups TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE invalidations TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE locator_types TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE material_properties TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE material_type_property_types TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE material_types TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE materials TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE persons TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE projects TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE property_types TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE role_assignments TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE sample_properties TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE sample_type_property_types TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE sample_types TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE samples TO GROUP OPENBIS_READONLY;\\012\\012------------------------------------------------------------------------------------\\012-- Delete MATERIAL_BATCHES table\\012------------------------------------------------------------------------------------\\012\\012-- WARNING: Potential data lost!!!\\012-- WARNING: Potential data lost!!!\\012-- WARNING: Potential data lost!!!\\012\\012DROP TABLE SAMPLE_MATERIAL_BATCHES;\\012DROP TABLE MATERIAL_BATCHES;\\012DROP SEQUENCE MATERIAL_BATCH_ID_SEQ;\\012\\012------------------------------------------------------------------------------------\\012-- Delete MATE_ID_INHIBITOR_OF from table MATERIALS\\012------------------------------------------------------------------------------------\\012\\012-- WARNING: Potential data lost!!!\\012-- WARNING: Potential data lost!!!\\012-- WARNING: Potential data lost!!!\\012\\012ALTER TABLE MATERIALS DROP COLUMN MATE_ID_INHIBITOR_OF;\\012	\N
+./sourceTest/sql/postgresql/058/017=database_version_logs.tsv:041	source/sql/postgresql/migration/migration-040-041.sql	SUCCESS	2009-09-14 13:48:57.539	-- Create FILTERS table\\012\\012CREATE TABLE FILTERS (ID TECH_ID NOT NULL, DBIN_ID TECH_ID NOT NULL, NAME VARCHAR(200) NOT NULL, DESCRIPTION DESCRIPTION_1000,REGISTRATION_TIMESTAMP TIME_STAMP_DFL NOT NULL DEFAULT CURRENT_TIMESTAMP, PERS_ID_REGISTERER TECH_ID NOT NULL, MODIFICATION_TIMESTAMP TIME_STAMP DEFAULT CURRENT_TIMESTAMP, EXPRESSION VARCHAR(2000) NOT NULL, IS_PUBLIC BOOLEAN NOT NULL, GRID_ID VARCHAR(200) NOT NULL);\\012CREATE SEQUENCE FILTER_ID_SEQ;\\012ALTER TABLE FILTERS ADD CONSTRAINT FILT_PK PRIMARY KEY(ID);\\012ALTER TABLE FILTERS ADD CONSTRAINT FILT_BK_UK UNIQUE(NAME, DBIN_ID, GRID_ID);\\012ALTER TABLE FILTERS ADD CONSTRAINT FILT_PERS_FK FOREIGN KEY (PERS_ID_REGISTERER) REFERENCES PERSONS(ID);\\012ALTER TABLE FILTERS ADD CONSTRAINT FILT_DBIN_FK FOREIGN KEY (DBIN_ID) REFERENCES DATABASE_INSTANCES(ID);\\012CREATE INDEX FILT_PERS_FK_I ON FILTERS (PERS_ID_REGISTERER);\\012CREATE INDEX FILT_DBIN_FK_I ON FILTERS (DBIN_ID);\\012GRANT SELECT ON SEQUENCE filter_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE filters TO GROUP OPENBIS_READONLY;\\012\\012-- Add missing foreign key to role assignments authorization group\\012ALTER TABLE ROLE_ASSIGNMENTS ADD CONSTRAINT ROAS_AG_FK_GRANTEE FOREIGN KEY (AG_ID_GRANTEE) REFERENCES AUTHORIZATION_GROUPS(ID);\\012\\012--------------------------------------------------------------------------------------------------\\012-- Modify dataset connections:\\012-- 1. connection with sample shouldn't be mandatory any more\\012-- 2. introduce an arc condition that dataset cannot be connected with a sample and a parent dataset at the same time\\012--------------------------------------------------------------------------------------------------\\012\\012-- Weaken data-sample connection constraint - allow dataset to have no connection with sample\\012ALTER TABLE data ALTER COLUMN samp_id DROP NOT NULL;\\012\\012-- Remove data-sample connection for datasets that have a parent\\012\\012UPDATE data \\012   SET samp_id = NULL \\012 WHERE id IN (SELECT DISTINCT data_id_child FROM data_set_relationships);\\012\\012-- With PostgreSQL 8.4 one can check that before migration there were no cycles in dataset relationships:\\012--\\012-- WITH RECURSIVE data_set_parents(id, parent_ids, cycle) AS (\\012--         SELECT  r.data_id_child AS id, \\012--                 ARRAY[CAST (r.data_id_parent AS bigint)] AS parent_ids, \\012--                 false AS cycle \\012--         FROM data_set_relationships r\\012--     UNION ALL\\012--         SELECT  r.data_id_child,\\012--                 CAST (r.data_id_parent AS bigint) || p.parent_ids,\\012--                 r.data_id_child = ANY(p.parent_ids)\\012--         FROM data_set_relationships r, data_set_parents p\\012--         WHERE r.data_id_parent = p.id AND NOT cycle\\012-- )\\012-- SELECT count(*) AS cycles FROM data_set_parents WHERE cycle = true;\\012\\012---------------------------------------------------------------------------------------------------\\012--  Purpose:  Create DEFERRED triggers:\\012--            * check_dataset_relationships_on_data_table_modification,\\012--            * check_dataset_relationships_on_relationships_table_modification.\\012--            They check that after all modifications of database (just before commit) \\012--            if 'data'/'data_set_relationships' tables are among modified tables \\012--            dataset is not connected with a sample and a parent dataset at the same time.\\012--            This connections are held in two different tables so simple immediate trigger \\012--            with arc check cannot be used and we need two deferred triggers.\\012----------------------------------------------------------------------------------------------------\\012\\012-- trigger for 'data' table\\012\\012CREATE OR REPLACE FUNCTION check_dataset_relationships_on_data_table_modification() RETURNS trigger AS $$\\012DECLARE\\012\\011counter\\011INTEGER;\\012BEGIN\\012\\011-- if there is a connection with a Sample there should not be any connection with a parent Data Set\\012\\011IF (NEW.samp_id IS NOT NULL) THEN\\012\\011\\011-- count number of parents\\012\\011\\011SELECT count(*) INTO counter \\012\\011\\011\\011FROM data_set_relationships \\012\\011\\011\\011WHERE data_id_child = OLD.id;\\012\\011\\011IF (counter > 0) THEN\\012\\011\\011\\011RAISE EXCEPTION 'Insert/Update of Data Set (Code: %) failed because it cannot be connected with a Sample and a parent Data Set at the same time.', OLD.code;\\012\\011\\011END IF;\\012\\011END IF;\\012  RETURN NEW;\\012END;\\012$$ LANGUAGE 'plpgsql';\\012\\012CREATE CONSTRAINT TRIGGER check_dataset_relationships_on_data_table_modification \\012  AFTER INSERT OR UPDATE ON data\\012\\011DEFERRABLE INITIALLY DEFERRED\\012\\011FOR EACH ROW \\012\\011EXECUTE PROCEDURE check_dataset_relationships_on_data_table_modification();\\012\\012-- trigger for 'data_set_relationships'\\012\\012CREATE OR REPLACE FUNCTION check_dataset_relationships_on_relationships_table_modification() RETURNS trigger AS $$\\012DECLARE\\012\\011counter\\011INTEGER;\\012\\011sample_id\\011TECH_ID;\\012\\011data_code\\011CODE;\\012BEGIN\\012\\011-- child will have a parent added so it should not be connected with any sample\\012\\011SELECT samp_id, code INTO sample_id, data_code \\012\\011\\011FROM data \\012\\011\\011WHERE id = NEW.data_id_child;\\012\\011IF (sample_id IS NOT NULL) THEN\\012\\011\\011RAISE EXCEPTION 'Insert/Update of Data Set (Code: %) failed because it cannot be connected to a Sample and to a parent Data Set at the same time.', data_code;\\012\\011END IF;\\012\\011RETURN NEW;\\012END;\\012$$ LANGUAGE 'plpgsql';\\012  \\012CREATE CONSTRAINT TRIGGER check_dataset_relationships_on_relationships_table_modification \\012  AFTER INSERT OR UPDATE ON data_set_relationships\\012\\011DEFERRABLE INITIALLY DEFERRED\\012\\011FOR EACH ROW \\012\\011EXECUTE PROCEDURE check_dataset_relationships_on_relationships_table_modification();\\012	\N
+./sourceTest/sql/postgresql/058/017=database_version_logs.tsv:053	source/sql/postgresql/migration/migration-052-053.sql	SUCCESS	2010-06-08 15:27:55.032	-- Migration from 052 to 053\\012\\012-- Change code uniqueness check for samples of specific type.\\012-- If sample_types.is_subcode_unique flag is set to 'true', additional check is performed \\012-- on codes of samples of the type. Subcodes will have to be unique as well.\\012\\012ALTER TABLE sample_types ADD COLUMN is_subcode_unique boolean_char NOT NULL DEFAULT false;\\012\\012CREATE OR REPLACE FUNCTION SAMPLE_SUBCODE_UNIQUENESS_CHECK() RETURNS trigger AS $$\\012DECLARE\\012   counter  INTEGER;\\012   unique_subcode  BOOLEAN_CHAR;\\012BEGIN\\012  LOCK TABLE samples IN EXCLUSIVE MODE;\\012  \\012  SELECT is_subcode_unique into unique_subcode FROM sample_types WHERE id = NEW.saty_id;\\012  \\012  IF (unique_subcode) THEN\\012    IF (NEW.dbin_id is not NULL) THEN\\012\\011\\011\\011SELECT count(*) into counter FROM samples \\012\\011\\011\\011\\011where id != NEW.id and code = NEW.code and saty_id = NEW.saty_id and dbin_id = NEW.dbin_id;\\012\\011\\011\\011IF (counter > 0) THEN\\012\\011\\011\\011\\011RAISE EXCEPTION 'Insert/Update of Sample (Code: %) failed because database instance sample of the same type with the same subcode already exists.', NEW.code;\\012\\011\\011\\011END IF;\\012\\011\\011ELSIF (NEW.grou_id is not NULL) THEN\\012\\011\\011\\011SELECT count(*) into counter FROM samples \\012\\011\\011\\011\\011where id != NEW.id and code = NEW.code and saty_id = NEW.saty_id and grou_id = NEW.grou_id;\\012\\011\\011\\011IF (counter > 0) THEN\\012\\011\\011\\011\\011RAISE EXCEPTION 'Insert/Update of Sample (Code: %) failed because space sample of the same type with the same subcode already exists.', NEW.code;\\012\\011\\011\\011END IF;\\012\\011\\011END IF;\\012  END IF;\\012  \\012  RETURN NEW;\\012END;\\012$$ LANGUAGE 'plpgsql';\\012\\012CREATE TRIGGER SAMPLE_SUBCODE_UNIQUENESS_CHECK BEFORE INSERT OR UPDATE ON SAMPLES\\012    FOR EACH ROW EXECUTE PROCEDURE SAMPLE_SUBCODE_UNIQUENESS_CHECK();\\012    \\012-- Fixing error messages in old trigger\\012\\012CREATE OR REPLACE FUNCTION SAMPLE_CODE_UNIQUENESS_CHECK() RETURNS trigger AS $$\\012DECLARE\\012   counter  INTEGER;\\012BEGIN\\012  LOCK TABLE samples IN EXCLUSIVE MODE;\\012  \\012\\011  IF (NEW.samp_id_part_of is NULL) THEN\\012\\011\\011  IF (NEW.dbin_id is not NULL) THEN\\012\\011\\011\\011  SELECT count(*) into counter FROM samples \\012\\011\\011      where id != NEW.id and code = NEW.code and samp_id_part_of is NULL and dbin_id = NEW.dbin_id;\\012        IF (counter > 0) THEN\\012\\011\\011\\011\\011  RAISE EXCEPTION 'Insert/Update of Sample (Code: %) failed because database instance sample with the same code already exists.', NEW.code;\\012        END IF;\\012\\011\\011  ELSIF (NEW.grou_id is not NULL) THEN\\012\\011\\011\\011  SELECT count(*) into counter FROM samples \\012\\011\\011\\011\\011  where id != NEW.id and code = NEW.code and samp_id_part_of is NULL and grou_id = NEW.grou_id;\\012\\011\\011\\011  IF (counter > 0) THEN\\012\\011\\011\\011\\011  RAISE EXCEPTION 'Insert/Update of Sample (Code: %) failed because space sample with the same code already exists.', NEW.code;\\012\\011\\011\\011  END IF;\\012      END IF;\\012    ELSE\\012\\011\\011  IF (NEW.dbin_id is not NULL) THEN\\012\\011\\011\\011  SELECT count(*) into counter FROM samples \\012\\011\\011\\011\\011  where id != NEW.id and code = NEW.code and samp_id_part_of = NEW.samp_id_part_of and dbin_id = NEW.dbin_id;\\012\\011\\011\\011  IF (counter > 0) THEN\\012\\011\\011\\011\\011  RAISE EXCEPTION 'Insert/Update of Sample (Code: %) failed because database instance sample with the same code and being the part of the same container already exists.', NEW.code;\\012\\011\\011\\011  END IF;\\012\\011\\011  ELSIF (NEW.grou_id is not NULL) THEN\\012\\011\\011\\011  SELECT count(*) into counter FROM samples \\012\\011\\011\\011\\011  where id != NEW.id and code = NEW.code and samp_id_part_of = NEW.samp_id_part_of and grou_id = NEW.grou_id;\\012\\011\\011\\011  IF (counter > 0) THEN\\012\\011\\011\\011\\011  RAISE EXCEPTION 'Insert/Update of Sample (Code: %) failed because space sample with the same code and being the part of the same container already exists.', NEW.code;\\012\\011\\011\\011  END IF;\\012\\011\\011  END IF;\\012     END IF;   \\012  \\012  RETURN NEW;\\012END;\\012$$ LANGUAGE 'plpgsql';\\012	\N
+./sourceTest/sql/postgresql/058/017=database_version_logs.tsv:054	source/sql/postgresql/migration/migration-053-054.sql	SUCCESS	2010-07-27 11:30:46.766	-- Migration from 053 to 054\\012\\012\\012-- Add RELATIONSHIP_TYPES table\\012CREATE TABLE relationship_types (id TECH_ID NOT NULL, code CODE NOT NULL, label COLUMN_LABEL, parent_label COLUMN_LABEL, child_label COLUMN_LABEL, description DESCRIPTION_2000, registration_timestamp TIME_STAMP_DFL NOT NULL DEFAULT CURRENT_TIMESTAMP, pers_id_registerer TECH_ID NOT NULL, is_managed_internally BOOLEAN_CHAR NOT NULL DEFAULT 'F', is_internal_namespace BOOLEAN_CHAR NOT NULL DEFAULT 'F', dbin_id TECH_ID NOT NULL);\\012\\012-- Add SAMPLE_RELATIONSHIPS table\\012CREATE TABLE sample_relationships (id TECH_ID NOT NULL, sample_id_parent TECH_ID NOT NULL, relationship_id TECH_ID NOT NULL, sample_id_child TECH_ID NOT NULL);\\012\\012-- Add/update constraints\\012ALTER TABLE relationship_types ADD CONSTRAINT rety_pk PRIMARY KEY (id);\\012ALTER TABLE relationship_types ADD CONSTRAINT rety_uk UNIQUE(code,dbin_id);\\012ALTER TABLE sample_relationships ADD CONSTRAINT sare_pk PRIMARY KEY (id);\\012ALTER TABLE sample_relationships ADD CONSTRAINT sare_bk_uk UNIQUE(sample_id_child,sample_id_parent,relationship_id);\\012ALTER TABLE sample_relationships ADD CONSTRAINT sare_data_fk_child FOREIGN KEY (sample_id_child) REFERENCES samples(id) ON DELETE CASCADE;\\012ALTER TABLE sample_relationships ADD CONSTRAINT sare_data_fk_parent FOREIGN KEY (sample_id_parent) REFERENCES samples(id) ON DELETE CASCADE;\\012ALTER TABLE sample_relationships ADD CONSTRAINT sare_data_fk_relationship FOREIGN KEY (relationship_id) REFERENCES relationship_types(id);\\012\\012-- Create index\\012CREATE INDEX sare_data_fk_i_child ON sample_relationships (sample_id_child);\\012CREATE INDEX sare_data_fk_i_parent ON sample_relationships (sample_id_parent);\\012CREATE INDEX sare_data_fk_i_relationship ON sample_relationships (relationship_id);\\012\\012-- Create sequence for RELATIONSHIP_TYPES\\012CREATE SEQUENCE RELATIONSHIP_TYPE_ID_SEQ;\\012CREATE SEQUENCE SAMPLE_RELATIONSHIP_ID_SEQ;\\012\\012-- Create initial relationships\\012insert into relationship_types\\012(id, \\012code, \\012label, \\012parent_label, \\012child_label, \\012description, \\012pers_id_registerer, \\012is_managed_internally, \\012is_internal_namespace, \\012dbin_id) \\012values\\012(\\012nextval('RELATIONSHIP_TYPE_ID_SEQ'),\\012'PARENT_CHILD',\\012'Parent - Child', \\012'Parent', \\012'Child', \\012'Parent - Child relationship', \\012(select id from persons where user_id ='system'), \\012'T', \\012'T', \\012(select id from database_instances where is_original_source = 'T')\\012);\\012\\012insert into relationship_types\\012(id, \\012code, \\012label, \\012parent_label, \\012child_label, \\012description, \\012pers_id_registerer, \\012is_managed_internally, \\012is_internal_namespace, \\012dbin_id) \\012values\\012(\\012nextval('RELATIONSHIP_TYPE_ID_SEQ'),\\012'PLATE_CONTROL_LAYOUT',\\012'Plate - Control Layout', \\012'Plate', \\012'Control Layout', \\012'Plate - Control Layout relationship', \\012(select id from persons where user_id ='system'), \\012'T', \\012'T', \\012(select id from database_instances where is_original_source = 'T')\\012); \\012\\012\\012-- Migrate sample relationships to new schema\\012INSERT INTO sample_relationships (id, sample_id_parent,sample_id_child,relationship_id) (select distinct nextval('SAMPLE_RELATIONSHIP_ID_SEQ') as id, s.SAMP_ID_GENERATED_FROM as parent_id, s.ID as child_id, rt.id as relationship_id from samples s, relationship_types rt  WHERE rt.code = 'PARENT_CHILD' and s.SAMP_ID_GENERATED_FROM is not null); \\012INSERT INTO sample_relationships (id, sample_id_parent,sample_id_child,relationship_id) (select distinct nextval('SAMPLE_RELATIONSHIP_ID_SEQ') as id, s.SAMP_ID_CONTROL_LAYOUT as parent_id, s.ID as child_id, rt.id as relationship_id from samples s, relationship_types rt  WHERE rt.code = 'PLATE_CONTROL_LAYOUT' and s.SAMP_ID_CONTROL_LAYOUT is not null);\\012\\012-- Drop old sample relations\\012ALTER TABLE SAMPLES DROP COLUMN SAMP_ID_TOP;\\012ALTER TABLE SAMPLES DROP COLUMN SAMP_ID_GENERATED_FROM;\\012ALTER TABLE SAMPLES DROP COLUMN SAMP_ID_CONTROL_LAYOUT;\\012\\012--------------------------------------------------------------------------------------\\012--------------------------------------------------------------------------------------\\012-- This is a screening specific migration. Nothing will be performed on openBIS databases \\012-- which are not screening specific.\\012-- \\012-- This migration for each existing connection between oligo well, oligo material and gene material\\012-- creates a direct connection between the well and the gene. \\012--------------------------------------------------------------------------------------\\012--------------------------------------------------------------------------------------\\012 \\012\\011\\012CREATE OR REPLACE FUNCTION CONNECT_WELLS_WITH_GENES() RETURNS void AS $$\\012DECLARE\\012\\011counter  int;\\012\\011oligo_well_exists bool;\\012BEGIN\\012\\011--------------------------------------------------\\012\\011-- create a gene property and assign it to oligo well\\012\\011--------------------------------------------------\\012\\011\\012\\011select true \\012\\011into oligo_well_exists\\012\\011from sample_types \\012\\011where code = 'OLIGO_WELL';\\012\\011\\012\\011if oligo_well_exists IS NULL then \\012\\011\\011-- skip migration if there are no oligo wells\\012\\011\\011return;\\012\\011end if;   \\012\\011\\012\\011insert into property_types(\\012\\011\\011id, \\012\\011\\011code, description, label, \\012\\011\\011daty_id,\\012\\011\\011pers_id_registerer,\\012\\011\\011dbin_id,\\012\\011\\011maty_prop_id) \\012\\011values(\\012\\011\\011\\011nextval('PROPERTY_TYPE_ID_SEQ'), \\012\\011\\011\\011'GENE','Inhibited gene','Gene',\\012\\011\\011\\011(select id from data_types where code = 'MATERIAL'), \\012\\011\\011\\011(select id from persons where user_id ='system'), \\012\\011\\011\\011(select id from database_instances where is_original_source = 'T'), \\012\\011\\011\\011(select id from material_types where code = 'GENE')\\012\\011\\011);\\012\\011\\011\\012\\011insert into sample_type_property_types( \\012\\011  id,\\012\\011  saty_id,\\012\\011  prty_id,\\012\\011  is_mandatory,\\012\\011  pers_id_registerer,\\012\\011  ordinal\\012\\011) values(\\012\\011\\011\\011nextval('stpt_id_seq'), \\012\\011\\011\\011(select id from sample_types where code = 'OLIGO_WELL'),\\012\\011\\011\\011(select id from property_types where code = 'GENE'),\\012\\011\\011\\011false,\\012\\011\\011\\011(select id from persons where user_id ='system'),\\012\\011\\011\\011(select max(ordinal)+1 from sample_type_property_types \\012\\011\\011\\011\\011where saty_id = (select id from sample_types where code = 'OLIGO_WELL'))\\012\\011\\011);\\012\\012\\011--------------------------------------------------\\012\\011-- create a gene material property for each oligo well\\012\\011--------------------------------------------------\\012\\011\\011\\012\\011select \\011count(*)\\012\\011into counter\\012\\011from\\012\\011\\011samples well, sample_types well_type, sample_properties well_props, \\012\\011\\011materials well_material, material_properties well_material_props,\\012\\011\\011materials nested_well_material\\012\\011where\\012\\011\\011well_type.code = 'OLIGO_WELL' and\\012\\011\\011-- find 'well_material' assigned to the well\\012\\011\\011well_props.samp_id = well.id and well_material.id = well_props.mate_prop_id and \\012\\011\\011-- additional joins to entity type tables\\012\\011\\011well_type.id = well.saty_id and\\012\\011\\011-- well content material property\\012\\011\\011well_material_props.mate_id = well_material.id and \\012\\011\\011-- material connected to the material in the well (e.g. gene)\\012\\011\\011well_material_props.mate_prop_id = nested_well_material.id and\\012\\011\\011nested_well_material.maty_id = (select id from material_types where code = 'GENE');\\012\\011\\012\\011if counter = 0 then \\012\\011\\011-- skip migration if there are no genes indirectly connected to oligo wells\\012\\011\\011return;\\012\\011end if;   \\012\\012\\011insert into sample_properties(id, samp_id, stpt_id, mate_prop_id, pers_id_registerer) (\\012\\011\\011select \\011nextval('sample_property_id_seq') id, \\012\\011\\011\\011well.id samp_id, \\012\\011\\011\\011(select stpt.id from sample_type_property_types stpt, property_types props where stpt.prty_id = props.id and props.code='GENE') stpt_id,\\012\\011\\011\\011nested_well_material.id mate_prop_id,\\012\\011\\011\\011(select id from persons where user_id ='system') pers_id_registerer \\012\\011\\011from\\012\\011\\011\\011samples well, sample_types well_type, sample_properties well_props, \\012\\011\\011\\011materials well_material, material_properties well_material_props,\\012\\011\\011\\011materials nested_well_material\\012\\011\\011where\\012\\011\\011\\011well_type.code = 'OLIGO_WELL' and\\012\\011\\011\\011-- find 'well_material' assigned to the well\\012\\011\\011\\011well_props.samp_id = well.id and well_material.id = well_props.mate_prop_id and \\012\\011\\011\\011-- additional joins to entity type tables\\012\\011\\011\\011well_type.id = well.saty_id and\\012\\011\\011\\011-- well content material property\\012\\011\\011\\011well_material_props.mate_id = well_material.id and \\012\\011\\011\\011-- material connected to the material in the well (e.g. gene)\\012\\011\\011\\011well_material_props.mate_prop_id = nested_well_material.id and\\012\\011\\011\\011nested_well_material.maty_id = (select id from material_types where code = 'GENE')\\012\\011);\\012\\012END;\\012$$ LANGUAGE 'plpgsql';\\012\\012select CONNECT_WELLS_WITH_GENES();\\012drop function CONNECT_WELLS_WITH_GENES();\\012\\012--------------------------------------------------------------------------------------\\012--------------------------------------------------------------------------------------\\012\\012-- drop dataset triggers\\012\\012DROP TRIGGER check_dataset_relationships_on_data_table_modification ON data;\\012DROP FUNCTION check_dataset_relationships_on_data_table_modification();\\012DROP TRIGGER check_dataset_relationships_on_relationships_table_modification ON data_set_relationships;\\012DROP FUNCTION check_dataset_relationships_on_relationships_table_modification();\\012 \\012\\012\\012\\012\\012\\012\\012\\012	\N
+./sourceTest/sql/postgresql/058/017=database_version_logs.tsv:056	source/sql/postgresql/migration/migration-055-056.sql	SUCCESS	2010-09-10 09:06:20.278	-- Migration from 055 to 056\\012\\012--------------------------------------------------------------------------------------\\012--------------------------------------------------------------------------------------\\012-- Screening specific migration. Nothing will be performed on openBIS databases \\012-- which are not screening specific.\\012--------------------------------------------------------------------------------------\\012--------------------------------------------------------------------------------------\\012\\012CREATE OR REPLACE FUNCTION merge_words(text, text) RETURNS text AS $$\\012DECLARE\\012  BEGIN\\012    IF  character_length($1) > 0 THEN\\012      RETURN $1 || ' ' || $2;\\012    ELSE\\012      RETURN $2;\\012    END IF;\\012  END;\\012$$ LANGUAGE plpgsql;\\012\\012CREATE AGGREGATE merge_words(text)\\012(\\012  SFUNC = merge_words,\\012  STYPE = text\\012);\\012\\012\\012CREATE OR REPLACE FUNCTION REPLACE_GENE_SYMBOL_BY_GENE_ID() RETURNS void AS $$\\012DECLARE\\012\\011counter  int;\\012\\011library_id_assigned_to_gene bool;\\012BEGIN\\012\\011--------------------------------------------------\\012\\011-- create a GENE_SYMBOL property and assign it to GENE\\012\\011--------------------------------------------------\\012\\011\\012\\011select true  \\012\\011into library_id_assigned_to_gene \\012\\011from material_type_property_types mtpt, material_types mt, property_types pt  \\012\\011where mtpt.maty_id = mt.id and mtpt.prty_id = pt.id \\012\\011\\011and mt.code = 'GENE' and pt.code = 'LIBRARY_ID';\\012\\011\\012\\011if library_id_assigned_to_gene IS NULL then \\012\\011\\011-- skip migration if gene has no library_id property\\012\\011\\011return;\\012\\011end if; \\012\\011\\012\\011\\012\\011select count(*)\\012\\011into counter \\012\\011from  \\012\\011\\011(select m.id, count(mp.id) as c \\012\\011\\011\\011from materials m, material_types mt, material_properties mp, material_type_property_types mtpt, property_types pt \\012\\011\\011\\011where m.maty_id = mt.id and mp.mate_id = m.id and mp.mtpt_id = mtpt.id and mtpt.maty_id = mt.id and pt.id = mtpt.prty_id\\012\\011\\011\\011\\011and mt.code = 'GENE' and pt.code = 'LIBRARY_ID' \\012\\011\\011\\011group by m.id) as counter_table \\012\\011where c < 1; \\012\\011\\012\\011if counter > 0 then \\012\\011\\011-- skip migration if there is at least one gene without library_id\\012\\011\\011return;\\012\\011end if;\\012\\011\\012\\011\\012\\011insert into property_types\\012\\011\\011(id\\012\\011\\011,code\\012\\011\\011,description\\012\\011\\011,label\\012\\011\\011,daty_id\\012\\011\\011,pers_id_registerer\\012\\011\\011,dbin_id)\\012\\011values \\012\\011\\011(nextval('PROPERTY_TYPE_ID_SEQ')\\012\\011\\011,'GENE_SYMBOLS'\\012\\011\\011,'Gene symbols'\\012\\011\\011,'Gene symbols'\\012\\011\\011,(select id from data_types where code ='VARCHAR')\\012\\011\\011,(select id from persons where user_id ='system')\\012\\011\\011,(select id from database_instances where is_original_source = 'T')\\012\\011);\\012\\011\\011\\012\\011insert into material_type_property_types( \\012\\011  id,\\012\\011  maty_id,\\012\\011  prty_id,\\012\\011  is_mandatory,\\012\\011  pers_id_registerer,\\012\\011  ordinal\\012\\011) values(\\012\\011\\011\\011nextval('mtpt_id_seq'), \\012\\011\\011\\011(select id from material_types where code = 'GENE'),\\012\\011\\011\\011(select id from property_types where code = 'GENE_SYMBOLS'),\\012\\011\\011\\011false,\\012\\011\\011\\011(select id from persons where user_id ='system'),\\012\\011\\011\\011(select max(ordinal)+1 from material_type_property_types \\012\\011\\011\\011\\011where maty_id = (select id from material_types where code = 'GENE'))\\012\\011\\011);\\012\\012\\011--------------------------------------------------\\012\\011-- create temporary table with all gene migration information\\012\\011--------------------------------------------------\\012\\012\\011create temp table genes \\012\\011(\\012\\011\\011id tech_id,\\012\\011\\011code code,\\012\\011\\011library_id generic_value,\\012\\011\\011gene_codes generic_value,\\012\\011\\011new_id tech_id,\\012\\011\\011library_tech_id tech_id\\011\\011\\012\\011);\\012\\011\\012\\011insert into genes (id, code, library_id, library_tech_id)\\012\\011\\011(select m.id, m.code, mp.value as library_id, mp.id as library_tech_id from materials m, material_properties mp, material_type_property_types mtpt, property_types pt, material_types mt\\012\\011\\011where mp.mate_id = m.id and  mp.mtpt_id = mtpt.id and pt.id = mtpt.prty_id and pt.code = 'LIBRARY_ID' and mt.id = m.maty_id and mt.id = mtpt.maty_id and mt.code = 'GENE');\\012\\011\\012\\011update genes set new_id = map.to_id from (select g_from.id as from_id, min(g_to.id) as to_id  from genes g_from, genes g_to where g_from.library_id = g_to.library_id group by g_from.id) as map where map.from_id = id;\\011\\012\\011\\012\\011update genes set gene_codes = map.gene_codes from (select g_from.library_id as lib_id, merge_words(distinct g_to.code) as gene_codes from genes g_from, genes g_to where g_from.library_id = g_to.library_id group by g_from.library_id) as map where map.lib_id = library_id;\\011\\012\\012\\011--------------------------------------------------\\012\\011-- update gene references\\012\\011--------------------------------------------------\\012\\012\\011update EXPERIMENTS set MATE_ID_STUDY_OBJECT = genes.new_id from genes where genes.id = MATE_ID_STUDY_OBJECT and not genes.id = genes.new_id;\\012\\011update EXPERIMENT_PROPERTIES set  MATE_PROP_ID = genes.new_id from genes where genes.id = MATE_PROP_ID and not genes.id = genes.new_id;\\012\\011update MATERIAL_PROPERTIES set  MATE_PROP_ID = genes.new_id from genes where genes.id = MATE_PROP_ID and not genes.id = genes.new_id;\\012\\011update SAMPLE_PROPERTIES set  MATE_PROP_ID = genes.new_id from genes where genes.id = MATE_PROP_ID and not genes.id = genes.new_id;\\012\\011update DATA_SET_PROPERTIES set  MATE_PROP_ID = genes.new_id from genes where genes.id = MATE_PROP_ID and not genes.id = genes.new_id;\\012\\011\\012\\011delete from  material_properties where mate_id in (select id from genes where not genes.id = genes.new_id);\\012\\011delete from MATERIALS where id in (select id from genes where not genes.id = genes.new_id);\\012\\012\\011delete from genes where id in (select id from genes where not genes.id = genes.new_id);\\012\\012\\012\\011--------------------------------------------------\\012\\011-- replace gene code with library_id\\012\\011--------------------------------------------------\\012\\011\\012\\011update materials set code = genes.library_id from genes where materials.id = genes.id ;\\012\\011delete from material_properties where id in (select library_tech_id from genes);\\012\\011\\012\\011--------------------------------------------------\\012\\011-- create a gene symbols property for each gene\\012\\011--------------------------------------------------\\012\\011\\012\\011insert into material_properties\\012\\011\\011(id\\012\\011  , mate_id\\012\\011  , mtpt_id\\012\\011  , "value"\\012\\011  , pers_id_registerer)\\012\\011\\011(select nextval('material_property_id_seq') id\\012\\011  \\011, genes.id  mate_id\\012\\011    , (select mtpt.id\\012\\011    \\011\\011from   material_type_property_types mtpt, material_types mt, property_types pt\\012\\011    \\011\\011where  pt.code = 'GENE_SYMBOLS' and mt.code = 'GENE' and mtpt.prty_id = pt.id\\012\\011        \\011and mtpt.maty_id = mt.id) mtpt_id\\012\\011    , genes.gene_codes "value"\\012\\011    , (select id from persons where user_id = 'system') pers_id_registerer\\012\\011 \\011from genes); \\012\\012\\011--------------------------------------------------\\012\\011-- delete temporary table\\012\\011--------------------------------------------------\\012\\011\\012\\011drop table genes;\\012\\011\\012END;\\012$$ LANGUAGE 'plpgsql';\\012\\012select REPLACE_GENE_SYMBOL_BY_GENE_ID();\\012drop function REPLACE_GENE_SYMBOL_BY_GENE_ID();\\012DROP AGGREGATE merge_words(text);\\012drop function merge_words(text,text);\\012\\012\\012--------------------------------------------------------------------------------------\\012--------------------------------------------------------------------------------------\\012\\012UPDATE sample_types SET code = 'SIRNA_WELL' WHERE code = 'OLIGO_WELL';\\012UPDATE material_types SET code = 'SIRNA' WHERE code = 'OLIGO';\\012UPDATE property_types SET code = 'SIRNA', label = 'siRNA' WHERE code = 'OLIGO';\\012\\012\\012\\012\\012\\012\\012\\012\\012\\012\\012\\012\\012\\012\\012\\012\\012\\012\\012\\012	\N
+./sourceTest/sql/postgresql/058/schema-058.sql:    LANGUAGE plpgsql
+./sourceTest/sql/postgresql/058/schema-058.sql:    LANGUAGE plpgsql
+./sourceTest/sql/postgresql/058/schema-058.sql:    LANGUAGE plpgsql
+./sourceTest/sql/postgresql/058/schema-058.sql:    LANGUAGE plpgsql
+./sourceTest/sql/postgresql/058/schema-058.sql:    LANGUAGE plpgsql
+./sourceTest/sql/postgresql/058/schema-058.sql:    LANGUAGE plpgsql
+./sourceTest/sql/postgresql/058/schema-058.sql:    LANGUAGE plpgsql
+./sourceTest/sql/postgresql/058/schema-058.sql:    LANGUAGE plpgsql
+./sourceTest/sql/postgresql/058/schema-058.sql:    LANGUAGE plpgsql
+./sourceTest/sql/postgresql/059/.svn/text-base/017=database_version_logs.tsv.svn-base:027	D:\\User\\felmer\\dev-workspace\\openbis/source/sql/postgresql/027/function-027.sql	SUCCESS	2008-11-05 09:18:00.403	-- Creating Functions\\012\\012------------------------------------------------------------------------------------\\012--  Purpose:  Create function RENAME_SEQUENCE() that is required for renaming the sequences belonging to tables\\012------------------------------------------------------------------------------------\\012CREATE FUNCTION RENAME_SEQUENCE(OLD_NAME VARCHAR, NEW_NAME VARCHAR) RETURNS INTEGER AS $$\\012DECLARE\\012  CURR_SEQ_VAL   INTEGER;\\012BEGIN\\012  SELECT INTO CURR_SEQ_VAL NEXTVAL(OLD_NAME);\\012  EXECUTE 'CREATE SEQUENCE ' || NEW_NAME || ' START WITH ' || CURR_SEQ_VAL;\\012  EXECUTE 'DROP SEQUENCE ' || OLD_NAME;\\012  RETURN CURR_SEQ_VAL;\\012END;\\012$$ LANGUAGE 'plpgsql';\\012\\012\\012------------------------------------------------------------------------------------\\012--  Purpose:  Create trigger CONTROLLED_VOCABULARY_CHECK \\012------------------------------------------------------------------------------------\\012\\012CREATE OR REPLACE FUNCTION CONTROLLED_VOCABULARY_CHECK() RETURNS trigger AS $$\\012DECLARE\\012   v_code  CODE;\\012BEGIN\\012\\012   select code into v_code from data_types where id = NEW.daty_id;\\012\\012   -- Check if the data is of type "CONTROLLEDVOCABULARY"\\012   if v_code = 'CONTROLLEDVOCABULARY' then\\012      if NEW.covo_id IS NULL then\\012         RAISE EXCEPTION 'Insert/Update of Property Type (Code: %) failed, as its Data Type is CONTROLLEDVOCABULARY, but it is not linked to a Controlled Vocabulary.', NEW.code;\\012      end if;\\012   end if;\\012\\012   RETURN NEW;\\012\\012END;\\012$$ LANGUAGE 'plpgsql';\\012\\012CREATE TRIGGER CONTROLLED_VOCABULARY_CHECK BEFORE INSERT OR UPDATE ON PROPERTY_TYPES\\012    FOR EACH ROW EXECUTE PROCEDURE CONTROLLED_VOCABULARY_CHECK();\\012\\012\\012------------------------------------------------------------------------------------\\012--  Purpose:  Create trigger EXTERNAL_DATA_STORAGE_FORMAT_CHECK \\012------------------------------------------------------------------------------------\\012\\012CREATE OR REPLACE FUNCTION EXTERNAL_DATA_STORAGE_FORMAT_CHECK() RETURNS trigger AS $$\\012DECLARE\\012   v_covo_code  CODE;\\012   data_code CODE;\\012BEGIN\\012\\012   select code into v_covo_code from controlled_vocabularies\\012      where is_internal_namespace = true and \\012         id = (select covo_id from controlled_vocabulary_terms where id = NEW.cvte_id_stor_fmt);\\012   -- Check if the data storage format is a term of the controlled vocabulary "STORAGE_FORMAT"\\012   if v_covo_code != 'STORAGE_FORMAT' then\\012      select code into data_code from data where id = NEW.data_id; \\012      RAISE EXCEPTION 'Insert/Update of Data (Code: %) failed, as its Storage Format is %, but is required to be STORAGE_FORMAT.', data_code, v_covo_code;\\012   end if;\\012\\012   RETURN NEW;\\012\\012END;\\012$$ LANGUAGE 'plpgsql';\\012\\012CREATE TRIGGER EXTERNAL_DATA_STORAGE_FORMAT_CHECK BEFORE INSERT OR UPDATE ON EXTERNAL_DATA\\012    FOR EACH ROW EXECUTE PROCEDURE EXTERNAL_DATA_STORAGE_FORMAT_CHECK();\\012\\012------------------------------------------------------------------------------------\\012--  Purpose:  Create trigger SAMPLE_CODE_UNIQUENESS_CHECK \\012------------------------------------------------------------------------------------\\012\\012CREATE OR REPLACE FUNCTION SAMPLE_CODE_UNIQUENESS_CHECK() RETURNS trigger AS $$\\012DECLARE\\012   counter  INTEGER;\\012BEGIN\\012\\011IF (NEW.samp_id_part_of is NULL) THEN\\012\\011\\011IF (NEW.dbin_id is not NULL) THEN\\012\\011\\011\\011SELECT count(*) into counter FROM samples \\012\\011\\011\\011\\011where id != NEW.id and code = NEW.code and samp_id_part_of is NULL and dbin_id = NEW.dbin_id;\\012\\011\\011\\011IF (counter > 0) THEN\\012\\011\\011\\011\\011RAISE EXCEPTION 'Insert/Update of Sample (Code: %) failed because database instance sample with the same code already exists.', NEW.code;\\012\\011\\011\\011END IF;\\012\\011\\011ELSIF (NEW.grou_id is not NULL) THEN\\012\\011\\011\\011SELECT count(*) into counter FROM samples \\012\\011\\011\\011\\011where id != NEW.id and code = NEW.code and samp_id_part_of is NULL and grou_id = NEW.grou_id;\\012\\011\\011\\011IF (counter > 0) THEN\\012\\011\\011\\011\\011RAISE EXCEPTION 'Insert/Update of Sample (Code: %) failed because group sample with the same code already exists.', NEW.code;\\012\\011\\011\\011END IF;\\012\\011\\011END IF;\\012        ELSE\\012\\011\\011IF (NEW.dbin_id is not NULL) THEN\\012\\011\\011\\011SELECT count(*) into counter FROM samples \\012\\011\\011\\011\\011where id != NEW.id and code = NEW.code and samp_id_part_of = NEW.samp_id_part_of and dbin_id = NEW.dbin_id;\\012\\011\\011\\011IF (counter > 0) THEN\\012\\011\\011\\011\\011RAISE EXCEPTION 'Insert/Update of Sample (Code: %) failed because database instance sample with the same code and being the part of the same parent already exists.', NEW.code;\\012\\011\\011\\011END IF;\\012\\011\\011ELSIF (NEW.grou_id is not NULL) THEN\\012\\011\\011\\011SELECT count(*) into counter FROM samples \\012\\011\\011\\011\\011where id != NEW.id and code = NEW.code and samp_id_part_of = NEW.samp_id_part_of and grou_id = NEW.grou_id;\\012\\011\\011\\011IF (counter > 0) THEN\\012\\011\\011\\011\\011RAISE EXCEPTION 'Insert/Update of Sample (Code: %) failed because group sample with the same code and being the part of the same parent already exists.', NEW.code;\\012\\011\\011\\011END IF;\\012\\011\\011END IF;\\012        END IF;   \\012   RETURN NEW;\\012END;\\012$$ LANGUAGE 'plpgsql';\\012\\012CREATE TRIGGER SAMPLE_CODE_UNIQUENESS_CHECK BEFORE INSERT OR UPDATE ON SAMPLES\\012    FOR EACH ROW EXECUTE PROCEDURE SAMPLE_CODE_UNIQUENESS_CHECK();\\012	\N
+./sourceTest/sql/postgresql/059/.svn/text-base/017=database_version_logs.tsv.svn-base:028	source/sql/postgresql/migration/migration-027-028.sql	SUCCESS	2008-11-18 13:24:17.508	-- Create EXPERIMENT_ATTACHMENT_CONTENTS.\\012CREATE TABLE EXPERIMENT_ATTACHMENT_CONTENTS (ID TECH_ID NOT NULL,VALUE FILE NOT NULL);\\012CREATE SEQUENCE EXPERIMENT_ATTACHMENT_CONTENT_ID_SEQ;\\012ALTER TABLE EXPERIMENT_ATTACHMENT_CONTENTS ADD CONSTRAINT EXAC_PK PRIMARY KEY(ID);\\012\\012-- Alter EXPERIMENT_ATTACHMENTS by adding the new column which has a NULL constraint.\\012-- The NOT NULL constraint is added later on.\\012ALTER TABLE EXPERIMENT_ATTACHMENTS ADD COLUMN EXAC_ID TECH_ID;\\012\\012-- Does the VALUE migration between EXPERIMENT_ATTACHMENTS to EXPERIMENT_ATTACHMENT_CONTENTS.\\012CREATE OR REPLACE FUNCTION move_exp_att_content() RETURNS integer AS $$\\012DECLARE\\012    rec RECORD;\\012    seq BIGINT;\\012BEGIN\\012  FOR rec IN SELECT id, value FROM EXPERIMENT_ATTACHMENTS LOOP\\012  \\011seq := nextval('EXPERIMENT_ATTACHMENT_CONTENT_ID_SEQ');\\012    INSERT INTO EXPERIMENT_ATTACHMENT_CONTENTS (id, value) VALUES (seq, rec.value);\\012    UPDATE EXPERIMENT_ATTACHMENTS SET exac_id = seq WHERE id = rec.id;\\012  END LOOP;\\012  RETURN 1;\\012END;\\012$$ LANGUAGE 'plpgsql';\\012\\012-- Call the function.\\012SELECT move_exp_att_content();\\012DROP FUNCTION move_exp_att_content();\\012\\012\\012-- Finish EXPERIMENT_ATTACHMENTS changes.\\012ALTER TABLE EXPERIMENT_ATTACHMENTS ADD CONSTRAINT EXAT_CONT_FK FOREIGN KEY (EXAC_ID) REFERENCES EXPERIMENT_ATTACHMENT_CONTENTS(ID);\\012ALTER TABLE EXPERIMENT_ATTACHMENTS DROP COLUMN VALUE;\\012ALTER TABLE EXPERIMENT_ATTACHMENTS ALTER COLUMN EXAC_ID SET NOT NULL;\\012	\N
+./sourceTest/sql/postgresql/059/.svn/text-base/017=database_version_logs.tsv.svn-base:029	source/sql/postgresql/migration/migration-028-029.sql	SUCCESS	2009-03-18 10:50:20.105	-- -------\\012-- add modification_timestamp field to allow edition with Hibernate\\012-- -------\\012\\012ALTER TABLE samples\\012\\011ADD COLUMN modification_timestamp TIME_STAMP DEFAULT CURRENT_TIMESTAMP;\\012\\012ALTER TABLE experiments\\012\\011ADD COLUMN modification_timestamp TIME_STAMP DEFAULT CURRENT_TIMESTAMP;\\012\\012ALTER TABLE materials\\012\\011ADD COLUMN modification_timestamp TIME_STAMP DEFAULT CURRENT_TIMESTAMP;\\012\\012ALTER TABLE experiment_properties\\012\\011ADD COLUMN modification_timestamp TIME_STAMP DEFAULT CURRENT_TIMESTAMP;\\012\\012ALTER TABLE material_properties\\012\\011ADD COLUMN modification_timestamp TIME_STAMP DEFAULT CURRENT_TIMESTAMP;\\012\\012ALTER TABLE sample_properties\\012\\011ADD COLUMN modification_timestamp TIME_STAMP DEFAULT CURRENT_TIMESTAMP;\\012\\012-- -------\\012-- add property data type which references materials\\012-- -------\\012\\012ALTER TABLE property_types\\012\\011ADD COLUMN maty_prop_id tech_id;\\012\\012ALTER TABLE property_types\\012\\011ADD CONSTRAINT prty_maty_fk FOREIGN KEY (maty_prop_id) REFERENCES material_types(id);\\012\\012ALTER TABLE experiment_properties\\012\\011ADD COLUMN mate_prop_id tech_id;\\012\\012ALTER TABLE material_properties\\012\\011ADD COLUMN mate_prop_id tech_id;\\012\\012ALTER TABLE sample_properties\\012\\011ADD COLUMN mate_prop_id tech_id;\\012\\012ALTER TABLE experiment_properties\\012\\011ADD CONSTRAINT expr_mapr_fk FOREIGN KEY (mate_prop_id) REFERENCES materials(id);\\012\\012ALTER TABLE material_properties\\012\\011ADD CONSTRAINT mapr_mapr_fk FOREIGN KEY (mate_prop_id) REFERENCES materials(id);\\012\\012ALTER TABLE sample_properties\\012\\011ADD CONSTRAINT sapr_mapr_fk FOREIGN KEY (mate_prop_id) REFERENCES materials(id);\\012\\012insert into data_types\\012(id\\012 ,code\\012 ,description)\\012 values \\012 (nextval('DATA_TYPE_ID_SEQ')\\012 ,'MATERIAL'\\012 ,'Reference to a material'\\012);\\012\\012ALTER TABLE MATERIAL_PROPERTIES DROP CONSTRAINT MAPR_CK;\\012ALTER TABLE MATERIAL_PROPERTIES ADD CONSTRAINT MAPR_CK CHECK \\012\\011((VALUE IS NOT NULL AND CVTE_ID IS NULL AND MATE_PROP_ID IS NULL) OR \\012\\011 (VALUE IS NULL AND CVTE_ID IS NOT NULL AND MATE_PROP_ID IS NULL) OR\\012\\011 (VALUE IS NULL AND CVTE_ID IS NULL AND MATE_PROP_ID IS NOT NULL)\\012\\011);\\012\\012ALTER TABLE EXPERIMENT_PROPERTIES DROP CONSTRAINT EXPR_CK;\\012ALTER TABLE EXPERIMENT_PROPERTIES ADD CONSTRAINT EXPR_CK CHECK \\012\\011((VALUE IS NOT NULL AND CVTE_ID IS NULL AND MATE_PROP_ID IS NULL) OR \\012\\011 (VALUE IS NULL AND CVTE_ID IS NOT NULL AND MATE_PROP_ID IS NULL) OR\\012\\011 (VALUE IS NULL AND CVTE_ID IS NULL AND MATE_PROP_ID IS NOT NULL)\\012\\011);\\012\\012ALTER TABLE SAMPLE_PROPERTIES DROP CONSTRAINT SAPR_CK;\\012ALTER TABLE SAMPLE_PROPERTIES ADD CONSTRAINT SAPR_CK CHECK \\012\\011((VALUE IS NOT NULL AND CVTE_ID IS NULL AND MATE_PROP_ID IS NULL) OR \\012\\011 (VALUE IS NULL AND CVTE_ID IS NOT NULL AND MATE_PROP_ID IS NULL) OR\\012\\011 (VALUE IS NULL AND CVTE_ID IS NULL AND MATE_PROP_ID IS NOT NULL)\\012\\011);\\012\\012------------------------------------------------------------------------------------\\012--  Purpose:  Create trigger MATERIAL/SAMPLE/EXPERIMENT _PROPERTY_WITH_MATERIAL_DATA_TYPE_CHECK\\012--            It checks that if material property value is assigned to the entity,\\012--\\011\\011\\011\\011\\011\\011then the material type is equal to the one described by property type.\\012------------------------------------------------------------------------------------\\012\\012CREATE OR REPLACE FUNCTION MATERIAL_PROPERTY_WITH_MATERIAL_DATA_TYPE_CHECK() RETURNS trigger AS $$\\012DECLARE\\012   v_type_id  CODE;\\012   v_type_id_prop  CODE;\\012BEGIN\\012   if NEW.mate_prop_id IS NOT NULL then\\012\\011\\011\\011-- find material type id of the property type \\012\\011\\011\\011select pt.maty_prop_id into v_type_id_prop \\012\\011\\011\\011  from material_type_property_types etpt, property_types pt \\012\\011\\011\\011 where NEW.mtpt_id = etpt.id AND etpt.prty_id = pt.id;\\012\\011\\011\\012\\011\\011\\011if v_type_id_prop IS NOT NULL then\\012\\011\\011\\011\\011-- find material type id of the material which consists the entity's property value\\012\\011\\011\\011\\011select entity.maty_id into v_type_id \\012\\011\\011\\011\\011  from materials entity\\012\\011\\011\\011\\011 where NEW.mate_prop_id = entity.id;\\012\\011\\011\\011\\011if v_type_id != v_type_id_prop then\\012\\011\\011\\011\\011\\011RAISE EXCEPTION 'Insert/Update of property value referencing material (id: %) failed, as referenced material type is different than expected (id %, expected id: %).', \\012\\011\\011\\011\\011\\011\\011\\011 NEW.mate_prop_id, v_type_id, v_type_id_prop;\\012\\011\\011\\011\\011end if;\\012\\011\\011\\011end if;\\012   end if;\\012   RETURN NEW;\\012END;\\012$$ LANGUAGE 'plpgsql';\\012\\012CREATE TRIGGER MATERIAL_PROPERTY_WITH_MATERIAL_DATA_TYPE_CHECK BEFORE INSERT OR UPDATE ON material_properties\\012    FOR EACH ROW EXECUTE PROCEDURE MATERIAL_PROPERTY_WITH_MATERIAL_DATA_TYPE_CHECK();\\012    \\012CREATE OR REPLACE FUNCTION SAMPLE_PROPERTY_WITH_MATERIAL_DATA_TYPE_CHECK() RETURNS trigger AS $$\\012DECLARE\\012   v_type_id  CODE;\\012   v_type_id_prop  CODE;\\012BEGIN\\012   if NEW.mate_prop_id IS NOT NULL then\\012\\011\\011\\011-- find material type id of the property type \\012\\011\\011\\011select pt.maty_prop_id into v_type_id_prop \\012\\011\\011\\011  from sample_type_property_types etpt, property_types pt \\012\\011\\011\\011 where NEW.stpt_id = etpt.id AND etpt.prty_id = pt.id;\\012\\011\\011\\012\\011\\011\\011if v_type_id_prop IS NOT NULL then\\012\\011\\011\\011\\011-- find material type id of the material which consists the entity's property value\\012\\011\\011\\011\\011select entity.maty_id into v_type_id \\012\\011\\011\\011\\011  from materials entity\\012\\011\\011\\011\\011 where NEW.mate_prop_id = entity.id;\\012\\011\\011\\011\\011if v_type_id != v_type_id_prop then\\012\\011\\011\\011\\011\\011RAISE EXCEPTION 'Insert/Update of property value referencing material (id: %) failed, as referenced material type is different than expected (id %, expected id: %).', \\012\\011\\011\\011\\011\\011\\011\\011\\011\\011\\011\\011\\011 NEW.mate_prop_id, v_type_id, v_type_id_prop;\\012\\011\\011\\011\\011end if;\\012\\011\\011\\011end if;\\012   end if;\\012   RETURN NEW;\\012END;\\012$$ LANGUAGE 'plpgsql';\\012\\012CREATE TRIGGER SAMPLE_PROPERTY_WITH_MATERIAL_DATA_TYPE_CHECK BEFORE INSERT OR UPDATE ON sample_properties\\012    FOR EACH ROW EXECUTE PROCEDURE SAMPLE_PROPERTY_WITH_MATERIAL_DATA_TYPE_CHECK();\\012    \\012CREATE OR REPLACE FUNCTION EXPERIMENT_PROPERTY_WITH_MATERIAL_DATA_TYPE_CHECK() RETURNS trigger AS $$\\012DECLARE\\012   v_type_id  CODE;\\012   v_type_id_prop  CODE;\\012BEGIN\\012   if NEW.mate_prop_id IS NOT NULL then\\012\\011\\011\\011-- find material type id of the property type \\012\\011\\011\\011select pt.maty_prop_id into v_type_id_prop \\012\\011\\011\\011  from experiment_type_property_types etpt, property_types pt \\012\\011\\011\\011 where NEW.etpt_id = etpt.id AND etpt.prty_id = pt.id;\\012\\011\\011\\012\\011\\011\\011if v_type_id_prop IS NOT NULL then\\012\\011\\011\\011\\011-- find material type id of the material which consists the entity's property value\\012\\011\\011\\011\\011select entity.maty_id into v_type_id \\012\\011\\011\\011\\011  from materials entity\\012\\011\\011\\011\\011 where NEW.mate_prop_id = entity.id;\\012\\011\\011\\011\\011if v_type_id != v_type_id_prop then\\012\\011\\011\\011\\011\\011RAISE EXCEPTION 'Insert/Update of property value referencing material (id: %) failed, as referenced material type is different than expected (id %, expected id: %).', \\012\\011\\011\\011\\011\\011\\011\\011\\011\\011\\011\\011\\011 NEW.mate_prop_id, v_type_id, v_type_id_prop;\\012\\011\\011\\011\\011end if;\\012\\011\\011\\011end if;\\012   end if;\\012   RETURN NEW;\\012END;\\012$$ LANGUAGE 'plpgsql';\\012\\012CREATE TRIGGER EXPERIMENT_PROPERTY_WITH_MATERIAL_DATA_TYPE_CHECK BEFORE INSERT OR UPDATE ON experiment_properties\\012    FOR EACH ROW EXECUTE PROCEDURE EXPERIMENT_PROPERTY_WITH_MATERIAL_DATA_TYPE_CHECK();\\012       \\012-- -------\\012-- remove the reminescents of the OBSERVABLE_TYPE\\012-- -------\\012\\012ALTER TABLE data\\012\\011DROP CONSTRAINT data_obty_fk;\\012\\012ALTER TABLE data_set_types\\012\\011DROP CONSTRAINT obty_pk;\\012\\012ALTER TABLE data_set_types\\012\\011ADD CONSTRAINT dsty_pk PRIMARY KEY (id);\\012\\012ALTER TABLE data\\012\\011ADD CONSTRAINT data_dsty_fk FOREIGN KEY (dsty_id) REFERENCES data_set_types(id);\\012\\012ALTER TABLE data_set_types\\012\\011DROP CONSTRAINT obty_bk_uk;\\012\\012ALTER TABLE data_set_types\\012\\011DROP CONSTRAINT obty_dbin_fk;\\012\\012ALTER TABLE data_set_types\\012\\011ADD CONSTRAINT dsty_bk_uk UNIQUE (code, dbin_id);\\012\\012ALTER TABLE data_set_types\\012\\011ADD CONSTRAINT dsty_dbin_fk FOREIGN KEY (dbin_id) REFERENCES database_instances(id);\\012\\012DROP INDEX data_obty_fk_i;\\012\\012CREATE INDEX data_dsty_fk_i ON data(dsty_id);\\012	\N
+./sourceTest/sql/postgresql/059/.svn/text-base/017=database_version_logs.tsv.svn-base:030	source/sql/postgresql/migration/migration-029-030.sql	SUCCESS	2009-03-23 15:34:44.72	-- -------\\012-- add modification_timestamp field to allow edition with Hibernate\\012-- -------\\012ALTER TABLE data\\012\\011ADD COLUMN modification_timestamp TIME_STAMP DEFAULT CURRENT_TIMESTAMP;\\012ALTER TABLE experiment_types\\012\\011ADD COLUMN modification_timestamp TIME_STAMP DEFAULT CURRENT_TIMESTAMP;\\012ALTER TABLE sample_types\\012\\011ADD COLUMN modification_timestamp TIME_STAMP DEFAULT CURRENT_TIMESTAMP;\\012ALTER TABLE material_types\\012\\011ADD COLUMN modification_timestamp TIME_STAMP DEFAULT CURRENT_TIMESTAMP;\\012ALTER TABLE data_set_types\\012\\011ADD COLUMN modification_timestamp TIME_STAMP DEFAULT CURRENT_TIMESTAMP;\\012ALTER TABLE controlled_vocabularies\\012\\011ADD COLUMN modification_timestamp TIME_STAMP DEFAULT CURRENT_TIMESTAMP;\\012-- -------\\012-- add properties to data sets\\012-- -------\\012CREATE TABLE DATA_SET_PROPERTIES (ID TECH_ID NOT NULL,DS_ID TECH_ID NOT NULL,DSTPT_ID TECH_ID NOT NULL,VALUE GENERIC_VALUE,CVTE_ID TECH_ID, MATE_PROP_ID TECH_ID, PERS_ID_REGISTERER TECH_ID NOT NULL,REGISTRATION_TIMESTAMP TIME_STAMP_DFL NOT NULL DEFAULT CURRENT_TIMESTAMP, MODIFICATION_TIMESTAMP TIME_STAMP DEFAULT CURRENT_TIMESTAMP);\\012CREATE TABLE DATA_SET_TYPE_PROPERTY_TYPES (ID TECH_ID NOT NULL,DSTY_ID TECH_ID NOT NULL,PRTY_ID TECH_ID NOT NULL,IS_MANDATORY BOOLEAN_CHAR NOT NULL DEFAULT 'F',IS_MANAGED_INTERNALLY BOOLEAN_CHAR NOT NULL DEFAULT 'F',PERS_ID_REGISTERER TECH_ID NOT NULL,REGISTRATION_TIMESTAMP TIME_STAMP_DFL NOT NULL DEFAULT CURRENT_TIMESTAMP);\\012\\012CREATE SEQUENCE DATA_SET_PROPERTY_ID_SEQ;\\012CREATE SEQUENCE DSTPT_ID_SEQ;\\012\\012ALTER TABLE DATA_SET_TYPE_PROPERTY_TYPES ADD CONSTRAINT DSTPT_PK PRIMARY KEY(ID);\\012ALTER TABLE DATA_SET_PROPERTIES ADD CONSTRAINT DSPR_PK PRIMARY KEY(ID);\\012\\012ALTER TABLE DATA_SET_TYPE_PROPERTY_TYPES ADD CONSTRAINT DSTPT_BK_UK UNIQUE(DSTY_ID,PRTY_ID);\\012ALTER TABLE DATA_SET_PROPERTIES ADD CONSTRAINT DSPR_BK_UK UNIQUE(DS_ID,DSTPT_ID);\\012\\012\\012ALTER TABLE DATA_SET_TYPE_PROPERTY_TYPES ADD CONSTRAINT DSTPT_DSTY_FK FOREIGN KEY (DSTY_ID) REFERENCES DATA_SET_TYPES(ID);\\012ALTER TABLE DATA_SET_TYPE_PROPERTY_TYPES ADD CONSTRAINT DSTPT_PERS_FK FOREIGN KEY (PERS_ID_REGISTERER) REFERENCES PERSONS(ID);\\012ALTER TABLE DATA_SET_TYPE_PROPERTY_TYPES ADD CONSTRAINT DSTPT_PRTY_FK FOREIGN KEY (PRTY_ID) REFERENCES PROPERTY_TYPES(ID);\\012ALTER TABLE DATA_SET_PROPERTIES ADD CONSTRAINT DSPR_CVTE_FK FOREIGN KEY (CVTE_ID) REFERENCES CONTROLLED_VOCABULARY_TERMS(ID);\\012ALTER TABLE DATA_SET_PROPERTIES ADD CONSTRAINT DSPR_DSTPT_FK FOREIGN KEY (DSTPT_ID) REFERENCES DATA_SET_TYPE_PROPERTY_TYPES(ID) ON DELETE CASCADE;\\012ALTER TABLE DATA_SET_PROPERTIES ADD CONSTRAINT DSPR_DS_FK FOREIGN KEY (DS_ID) REFERENCES DATA(ID);\\012ALTER TABLE DATA_SET_PROPERTIES ADD CONSTRAINT DSPR_PERS_FK FOREIGN KEY (PERS_ID_REGISTERER) REFERENCES PERSONS(ID);\\012ALTER TABLE DATA_SET_PROPERTIES ADD CONSTRAINT DSPR_MAPR_FK FOREIGN KEY (MATE_PROP_ID) REFERENCES MATERIALS(ID);\\012\\012ALTER TABLE DATA_SET_PROPERTIES ADD CONSTRAINT DSPR_CK CHECK \\012\\011((VALUE IS NOT NULL AND CVTE_ID IS NULL AND MATE_PROP_ID IS NULL) OR \\012\\011 (VALUE IS NULL AND CVTE_ID IS NOT NULL AND MATE_PROP_ID IS NULL) OR\\012\\011 (VALUE IS NULL AND CVTE_ID IS NULL AND MATE_PROP_ID IS NOT NULL)\\012\\011);\\012\\012CREATE INDEX DSPR_CVTE_FK_I ON DATA_SET_PROPERTIES (CVTE_ID);\\012CREATE INDEX DSPR_DSTPT_FK_I ON DATA_SET_PROPERTIES (DSTPT_ID);\\012CREATE INDEX DSPR_DS_FK_I ON DATA_SET_PROPERTIES (DS_ID);\\012CREATE INDEX DSPR_PERS_FK_I ON DATA_SET_PROPERTIES (PERS_ID_REGISTERER);\\012CREATE INDEX DSTPT_DSTY_FK_I ON DATA_SET_TYPE_PROPERTY_TYPES (DSTY_ID);\\012CREATE INDEX DSTPT_PERS_FK_I ON DATA_SET_TYPE_PROPERTY_TYPES (PERS_ID_REGISTERER);\\012CREATE INDEX DSTPT_PRTY_FK_I ON DATA_SET_TYPE_PROPERTY_TYPES (PRTY_ID);\\012\\012CREATE OR REPLACE FUNCTION DATA_SET_PROPERTY_WITH_MATERIAL_DATA_TYPE_CHECK() RETURNS trigger AS $$\\012DECLARE\\012   v_type_id  CODE;\\012   v_type_id_prop  CODE;\\012BEGIN\\012   if NEW.mate_prop_id IS NOT NULL then\\012\\011\\011\\011-- find material type id of the property type \\012\\011\\011\\011select pt.maty_prop_id into v_type_id_prop \\012\\011\\011\\011  from data_set_type_property_types dstpt, property_types pt \\012\\011\\011\\011 where NEW.dstpt_id = dstpt.id AND dstpt.prty_id = pt.id;\\012\\011\\011\\012\\011\\011\\011if v_type_id_prop IS NOT NULL then\\012\\011\\011\\011\\011-- find material type id of the material which consists the entity's property value\\012\\011\\011\\011\\011select entity.maty_id into v_type_id \\012\\011\\011\\011\\011  from materials entity\\012\\011\\011\\011\\011 where NEW.mate_prop_id = entity.id;\\012\\011\\011\\011\\011if v_type_id != v_type_id_prop then\\012\\011\\011\\011\\011\\011RAISE EXCEPTION 'Insert/Update of property value referencing material (id: %) failed, as referenced material type is different than expected (id %, expected id: %).', \\012\\011\\011\\011\\011\\011\\011\\011\\011\\011\\011\\011\\011 NEW.mate_prop_id, v_type_id, v_type_id_prop;\\012\\011\\011\\011\\011end if;\\012\\011\\011\\011end if;\\012   end if;\\012   RETURN NEW;\\012END;\\012$$ LANGUAGE 'plpgsql';\\012\\012CREATE TRIGGER DATA_SET_PROPERTY_WITH_MATERIAL_DATA_TYPE_CHECK BEFORE INSERT OR UPDATE ON data_set_properties\\012    FOR EACH ROW EXECUTE PROCEDURE DATA_SET_PROPERTY_WITH_MATERIAL_DATA_TYPE_CHECK();   \\012	\N
+./sourceTest/sql/postgresql/059/.svn/text-base/017=database_version_logs.tsv.svn-base:032	source/sql/postgresql/migration/migration-031-032.sql	SUCCESS	2009-04-09 09:36:36.2	-- -------\\012-- Modify MATERIAL_BATCHES\\012-- -------\\012\\012ALTER TABLE material_batches\\012    DROP COLUMN proc_id;\\012\\012-- -------\\012-- Modify SAMPLES\\012-- -------\\012\\012ALTER TABLE samples\\012    ADD COLUMN expe_id tech_id;\\012\\012ALTER TABLE samples\\012    ADD CONSTRAINT samp_expe_fk FOREIGN KEY (expe_id) REFERENCES experiments(id);\\012\\012CREATE INDEX samp_expe_fk_i ON samples USING btree (expe_id);\\012\\012-- relink samples directly to experiments\\012\\012UPDATE samples\\012SET expe_id = (SELECT e.id FROM experiments e, procedures p, sample_inputs si \\012               WHERE si.samp_id = samples.id AND si.proc_id = p.id AND p.expe_id = e.id AND e.inva_id IS NULL);\\012\\012\\012-- -------\\012-- Modify DATA\\012-- -------\\012\\012ALTER TABLE data\\012    ADD COLUMN expe_id tech_id;\\012\\012ALTER TABLE data\\012    ADD CONSTRAINT data_expe_fk FOREIGN KEY (expe_id) REFERENCES experiments(id);\\012\\012CREATE INDEX data_expe_fk_i ON data USING btree (expe_id);\\012\\012UPDATE data\\012SET expe_id = (SELECT e.id FROM experiments e, procedures p \\012               WHERE data.proc_id_produced_by = p.id AND p.expe_id = e.id);\\012\\012ALTER TABLE data\\012    ALTER COLUMN expe_id SET NOT NULL;\\012\\012ALTER TABLE data\\012    DROP COLUMN proc_id_produced_by;\\012\\012-- -------\\012-- Drop PROCEDURES, PROCEDURE_TYPES, and SAMPLE_INPUTS\\012-- -------\\012\\012DROP TABLE sample_inputs;\\012DROP TABLE procedures;\\012DROP TABLE procedure_types;\\012\\012DROP SEQUENCE procedure_id_seq;\\012DROP SEQUENCE procedure_type_id_seq;\\012\\012-- -------\\012-- Add CODE_SEQ\\012-- -------\\012\\012CREATE SEQUENCE CODE_SEQ;\\012\\012-- -------\\012-- Add new columns to DATA_STORES\\012-- -------\\012\\012ALTER TABLE data_stores\\012    ADD COLUMN remote_url character varying(250),\\012    ADD COLUMN session_token character varying(50),\\012    ADD COLUMN modification_timestamp time_stamp DEFAULT now();\\012\\012UPDATE data_stores\\012SET remote_url = '', session_token='';\\012\\012ALTER TABLE data_stores\\012    ALTER COLUMN remote_url SET NOT NULL,\\012    ALTER COLUMN session_token SET NOT NULL;\\012\\012-- -------\\012-- Drop foreign keys onto DATA_STORES\\012-- -------\\012\\012ALTER TABLE database_instances\\012    DROP COLUMN dast_id;\\012\\012ALTER TABLE groups\\012    DROP COLUMN dast_id;\\012\\012ALTER TABLE projects\\012    DROP COLUMN dast_id;\\012\\012ALTER TABLE experiments\\012    DROP COLUMN dast_id;\\012\\012-- -------\\012-- Add foreign key from DATA onto DATA_STORES\\012-- -------\\012\\012ALTER TABLE data\\012    ADD COLUMN dast_id tech_id;\\012\\012ALTER TABLE data\\012    ADD CONSTRAINT data_dast_fk FOREIGN KEY (dast_id) REFERENCES data_stores(id);\\012\\012UPDATE data\\012SET dast_id = (select id from data_stores where code = 'STANDARD');\\012\\012ALTER TABLE data\\012    ALTER COLUMN dast_id SET NOT NULL;\\012\\012\\012------------------------------------------------------------------------------------\\012--  Purpose:  Replace trigger SAMPLE_CODE_UNIQUENESS_CHECK \\012------------------------------------------------------------------------------------\\012\\012CREATE OR REPLACE FUNCTION SAMPLE_CODE_UNIQUENESS_CHECK() RETURNS trigger AS $$\\012DECLARE\\012   counter  INTEGER;\\012BEGIN\\012    LOCK TABLE samples IN EXCLUSIVE MODE;\\012    IF (NEW.samp_id_part_of is NULL) THEN\\012        IF (NEW.dbin_id is not NULL) THEN\\012            SELECT count(*) into counter FROM samples \\012                where id != NEW.id and code = NEW.code and samp_id_part_of is NULL and dbin_id = NEW.dbin_id;\\012            IF (counter > 0) THEN\\012                RAISE EXCEPTION 'Insert/Update of Sample (Code: %) failed because database instance sample with the same code already exists.', NEW.code;\\012            END IF;\\012        ELSIF (NEW.grou_id is not NULL) THEN\\012            SELECT count(*) into counter FROM samples \\012                where id != NEW.id and code = NEW.code and samp_id_part_of is NULL and grou_id = NEW.grou_id;\\012            IF (counter > 0) THEN\\012                RAISE EXCEPTION 'Insert/Update of Sample (Code: %) failed because group sample with the same code already exists.', NEW.code;\\012            END IF;\\012        END IF;\\012        ELSE\\012        IF (NEW.dbin_id is not NULL) THEN\\012            SELECT count(*) into counter FROM samples \\012                where id != NEW.id and code = NEW.code and samp_id_part_of = NEW.samp_id_part_of and dbin_id = NEW.dbin_id;\\012            IF (counter > 0) THEN\\012                RAISE EXCEPTION 'Insert/Update of Sample (Code: %) failed because database instance sample with the same code and being the part of the same parent already exists.', NEW.code;\\012            END IF;\\012        ELSIF (NEW.grou_id is not NULL) THEN\\012            SELECT count(*) into counter FROM samples \\012                where id != NEW.id and code = NEW.code and samp_id_part_of = NEW.samp_id_part_of and grou_id = NEW.grou_id;\\012            IF (counter > 0) THEN\\012                RAISE EXCEPTION 'Insert/Update of Sample (Code: %) failed because group sample with the same code and being the part of the same parent already exists.', NEW.code;\\012            END IF;\\012        END IF;\\012        END IF;   \\012   RETURN NEW;\\012END;\\012$$ LANGUAGE 'plpgsql';\\012\\012\\012\\012	\N
+./sourceTest/sql/postgresql/059/.svn/text-base/017=database_version_logs.tsv.svn-base:034	source/sql/postgresql/migration/migration-033-034.sql	SUCCESS	2009-05-26 08:32:49.935	------------------------------------------------------------------------------------\\012-- Create sequence for generating permanent identifiers starting with nextval of existing dataset sequence.\\012------------------------------------------------------------------------------------\\012CREATE FUNCTION CREATE_SEQUENCE(EXISTING_SEQUENCE VARCHAR, NEW_SEQUENCE VARCHAR) RETURNS VOID AS $$\\012DECLARE\\012  CURR_SEQ_VAL   INTEGER;\\012BEGIN\\012  SELECT INTO CURR_SEQ_VAL NEXTVAL(EXISTING_SEQUENCE);\\012  EXECUTE 'CREATE SEQUENCE ' || NEW_SEQUENCE || ' START WITH ' || CURR_SEQ_VAL;\\012  RETURN;\\012END;\\012$$ LANGUAGE 'plpgsql';\\012\\012SELECT CREATE_SEQUENCE('DATA_ID_SEQ', 'PERM_ID_SEQ');\\012DROP FUNCTION CREATE_SEQUENCE(VARCHAR, VARCHAR);\\012\\012------------------------------------------------------------------------------------\\012-- Add perm_id columns to samples and experiments.\\012------------------------------------------------------------------------------------\\012ALTER TABLE SAMPLES ADD COLUMN PERM_ID CODE;\\012ALTER TABLE EXPERIMENTS ADD COLUMN PERM_ID CODE;\\012\\012UPDATE SAMPLES SET PERM_ID = to_char(registration_timestamp,'YYYYMMDDHHSSMS') || '-' || NEXTVAL('PERM_ID_SEQ');\\012UPDATE EXPERIMENTS SET PERM_ID = to_char(registration_timestamp,'YYYYMMDDHHSSMS') || '-' || NEXTVAL('PERM_ID_SEQ');\\012ALTER TABLE SAMPLES ALTER COLUMN PERM_ID SET NOT NULL;\\012ALTER TABLE EXPERIMENTS ALTER COLUMN PERM_ID SET NOT NULL;\\012ALTER TABLE SAMPLES ADD CONSTRAINT SAMP_PI_UK UNIQUE(PERM_ID);\\012ALTER TABLE EXPERIMENTS ADD CONSTRAINT EXPE_PI_UK UNIQUE(PERM_ID);\\012\\012\\012------------------------------------------------------------------------------------\\012-- Add column is_chosen_from_list to controlled_vocabularies.\\012------------------------------------------------------------------------------------\\012ALTER TABLE controlled_vocabularies ADD COLUMN is_chosen_from_list BOOLEAN_CHAR NOT NULL DEFAULT TRUE;\\012ALTER TABLE controlled_vocabularies ADD COLUMN source_uri CHARACTER VARYING(250);\\012------------------------------------------------------------------------------------\\012-- Modify Data table - remove arc connection between Sample and Data table, use a flag instead\\012------------------------------------------------------------------------------------\\012\\012-- add new columns\\012\\012ALTER TABLE data\\012    ADD COLUMN is_derived boolean_char;\\012ALTER TABLE data\\012    ADD COLUMN samp_id tech_id;\\012\\012-- update values in new columns\\012\\012UPDATE data\\012    SET is_derived = (samp_id_derived_from IS NOT NULL); \\012UPDATE data\\012    SET samp_id = samp_id_derived_from \\012    WHERE is_derived = 'TRUE';\\012UPDATE data\\012    SET samp_id = samp_id_acquired_from \\012    WHERE is_derived = 'FALSE';\\012\\012-- add constraints and indexes to new columns\\012\\012ALTER TABLE data\\012    ALTER COLUMN is_derived SET NOT NULL;\\012ALTER TABLE data\\012    ALTER COLUMN samp_id SET NOT NULL;   \\012ALTER TABLE data\\012    ADD CONSTRAINT data_samp_fk FOREIGN KEY (samp_id) REFERENCES samples (id);\\012CREATE INDEX data_samp_fk_i ON data USING btree (samp_id);\\012\\012-- remove old columns\\012\\012ALTER TABLE data\\012    DROP COLUMN samp_id_acquired_from;\\012ALTER TABLE data\\012    DROP COLUMN samp_id_derived_from;\\012    \\012------------------------------------------------------------------------------------\\012-- Granting SELECT privilege to group openbis_readonly\\012------------------------------------------------------------------------------------\\012\\012GRANT SELECT ON SEQUENCE attachment_content_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE attachment_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE code_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE controlled_vocabulary_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE cvte_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE data_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE data_set_property_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE data_set_relationship_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE data_set_type_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE data_store_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE data_type_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE database_instance_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE dstpt_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE etpt_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE event_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE experiment_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE experiment_property_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE experiment_type_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE file_format_type_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE group_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE invalidation_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE locator_type_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE material_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE material_property_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE material_type_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE mtpt_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE perm_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE person_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE project_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE property_type_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE role_assignment_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE sample_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE sample_property_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE sample_type_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE stpt_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE attachment_contents TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE attachments TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE controlled_vocabularies TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE controlled_vocabulary_terms TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE data TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE data_set_properties TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE data_set_relationships TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE data_set_type_property_types TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE data_set_types TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE data_stores TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE data_types TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE database_instances TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE database_version_logs TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE events TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE experiment_properties TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE experiment_type_property_types TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE experiment_types TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE experiments TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE external_data TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE file_format_types TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE groups TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE invalidations TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE locator_types TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE material_properties TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE material_type_property_types TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE material_types TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE materials TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE persons TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE projects TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE property_types TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE role_assignments TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE sample_properties TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE sample_type_property_types TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE sample_types TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE samples TO GROUP OPENBIS_READONLY;\\012\\012------------------------------------------------------------------------------------\\012-- Delete MATERIAL_BATCHES table\\012------------------------------------------------------------------------------------\\012\\012-- WARNING: Potential data lost!!!\\012-- WARNING: Potential data lost!!!\\012-- WARNING: Potential data lost!!!\\012\\012DROP TABLE SAMPLE_MATERIAL_BATCHES;\\012DROP TABLE MATERIAL_BATCHES;\\012DROP SEQUENCE MATERIAL_BATCH_ID_SEQ;\\012\\012------------------------------------------------------------------------------------\\012-- Delete MATE_ID_INHIBITOR_OF from table MATERIALS\\012------------------------------------------------------------------------------------\\012\\012-- WARNING: Potential data lost!!!\\012-- WARNING: Potential data lost!!!\\012-- WARNING: Potential data lost!!!\\012\\012ALTER TABLE MATERIALS DROP COLUMN MATE_ID_INHIBITOR_OF;\\012	\N
+./sourceTest/sql/postgresql/059/.svn/text-base/017=database_version_logs.tsv.svn-base:041	source/sql/postgresql/migration/migration-040-041.sql	SUCCESS	2009-09-14 13:48:57.539	-- Create FILTERS table\\012\\012CREATE TABLE FILTERS (ID TECH_ID NOT NULL, DBIN_ID TECH_ID NOT NULL, NAME VARCHAR(200) NOT NULL, DESCRIPTION DESCRIPTION_1000,REGISTRATION_TIMESTAMP TIME_STAMP_DFL NOT NULL DEFAULT CURRENT_TIMESTAMP, PERS_ID_REGISTERER TECH_ID NOT NULL, MODIFICATION_TIMESTAMP TIME_STAMP DEFAULT CURRENT_TIMESTAMP, EXPRESSION VARCHAR(2000) NOT NULL, IS_PUBLIC BOOLEAN NOT NULL, GRID_ID VARCHAR(200) NOT NULL);\\012CREATE SEQUENCE FILTER_ID_SEQ;\\012ALTER TABLE FILTERS ADD CONSTRAINT FILT_PK PRIMARY KEY(ID);\\012ALTER TABLE FILTERS ADD CONSTRAINT FILT_BK_UK UNIQUE(NAME, DBIN_ID, GRID_ID);\\012ALTER TABLE FILTERS ADD CONSTRAINT FILT_PERS_FK FOREIGN KEY (PERS_ID_REGISTERER) REFERENCES PERSONS(ID);\\012ALTER TABLE FILTERS ADD CONSTRAINT FILT_DBIN_FK FOREIGN KEY (DBIN_ID) REFERENCES DATABASE_INSTANCES(ID);\\012CREATE INDEX FILT_PERS_FK_I ON FILTERS (PERS_ID_REGISTERER);\\012CREATE INDEX FILT_DBIN_FK_I ON FILTERS (DBIN_ID);\\012GRANT SELECT ON SEQUENCE filter_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE filters TO GROUP OPENBIS_READONLY;\\012\\012-- Add missing foreign key to role assignments authorization group\\012ALTER TABLE ROLE_ASSIGNMENTS ADD CONSTRAINT ROAS_AG_FK_GRANTEE FOREIGN KEY (AG_ID_GRANTEE) REFERENCES AUTHORIZATION_GROUPS(ID);\\012\\012--------------------------------------------------------------------------------------------------\\012-- Modify dataset connections:\\012-- 1. connection with sample shouldn't be mandatory any more\\012-- 2. introduce an arc condition that dataset cannot be connected with a sample and a parent dataset at the same time\\012--------------------------------------------------------------------------------------------------\\012\\012-- Weaken data-sample connection constraint - allow dataset to have no connection with sample\\012ALTER TABLE data ALTER COLUMN samp_id DROP NOT NULL;\\012\\012-- Remove data-sample connection for datasets that have a parent\\012\\012UPDATE data \\012   SET samp_id = NULL \\012 WHERE id IN (SELECT DISTINCT data_id_child FROM data_set_relationships);\\012\\012-- With PostgreSQL 8.4 one can check that before migration there were no cycles in dataset relationships:\\012--\\012-- WITH RECURSIVE data_set_parents(id, parent_ids, cycle) AS (\\012--         SELECT  r.data_id_child AS id, \\012--                 ARRAY[CAST (r.data_id_parent AS bigint)] AS parent_ids, \\012--                 false AS cycle \\012--         FROM data_set_relationships r\\012--     UNION ALL\\012--         SELECT  r.data_id_child,\\012--                 CAST (r.data_id_parent AS bigint) || p.parent_ids,\\012--                 r.data_id_child = ANY(p.parent_ids)\\012--         FROM data_set_relationships r, data_set_parents p\\012--         WHERE r.data_id_parent = p.id AND NOT cycle\\012-- )\\012-- SELECT count(*) AS cycles FROM data_set_parents WHERE cycle = true;\\012\\012---------------------------------------------------------------------------------------------------\\012--  Purpose:  Create DEFERRED triggers:\\012--            * check_dataset_relationships_on_data_table_modification,\\012--            * check_dataset_relationships_on_relationships_table_modification.\\012--            They check that after all modifications of database (just before commit) \\012--            if 'data'/'data_set_relationships' tables are among modified tables \\012--            dataset is not connected with a sample and a parent dataset at the same time.\\012--            This connections are held in two different tables so simple immediate trigger \\012--            with arc check cannot be used and we need two deferred triggers.\\012----------------------------------------------------------------------------------------------------\\012\\012-- trigger for 'data' table\\012\\012CREATE OR REPLACE FUNCTION check_dataset_relationships_on_data_table_modification() RETURNS trigger AS $$\\012DECLARE\\012\\011counter\\011INTEGER;\\012BEGIN\\012\\011-- if there is a connection with a Sample there should not be any connection with a parent Data Set\\012\\011IF (NEW.samp_id IS NOT NULL) THEN\\012\\011\\011-- count number of parents\\012\\011\\011SELECT count(*) INTO counter \\012\\011\\011\\011FROM data_set_relationships \\012\\011\\011\\011WHERE data_id_child = OLD.id;\\012\\011\\011IF (counter > 0) THEN\\012\\011\\011\\011RAISE EXCEPTION 'Insert/Update of Data Set (Code: %) failed because it cannot be connected with a Sample and a parent Data Set at the same time.', OLD.code;\\012\\011\\011END IF;\\012\\011END IF;\\012  RETURN NEW;\\012END;\\012$$ LANGUAGE 'plpgsql';\\012\\012CREATE CONSTRAINT TRIGGER check_dataset_relationships_on_data_table_modification \\012  AFTER INSERT OR UPDATE ON data\\012\\011DEFERRABLE INITIALLY DEFERRED\\012\\011FOR EACH ROW \\012\\011EXECUTE PROCEDURE check_dataset_relationships_on_data_table_modification();\\012\\012-- trigger for 'data_set_relationships'\\012\\012CREATE OR REPLACE FUNCTION check_dataset_relationships_on_relationships_table_modification() RETURNS trigger AS $$\\012DECLARE\\012\\011counter\\011INTEGER;\\012\\011sample_id\\011TECH_ID;\\012\\011data_code\\011CODE;\\012BEGIN\\012\\011-- child will have a parent added so it should not be connected with any sample\\012\\011SELECT samp_id, code INTO sample_id, data_code \\012\\011\\011FROM data \\012\\011\\011WHERE id = NEW.data_id_child;\\012\\011IF (sample_id IS NOT NULL) THEN\\012\\011\\011RAISE EXCEPTION 'Insert/Update of Data Set (Code: %) failed because it cannot be connected to a Sample and to a parent Data Set at the same time.', data_code;\\012\\011END IF;\\012\\011RETURN NEW;\\012END;\\012$$ LANGUAGE 'plpgsql';\\012  \\012CREATE CONSTRAINT TRIGGER check_dataset_relationships_on_relationships_table_modification \\012  AFTER INSERT OR UPDATE ON data_set_relationships\\012\\011DEFERRABLE INITIALLY DEFERRED\\012\\011FOR EACH ROW \\012\\011EXECUTE PROCEDURE check_dataset_relationships_on_relationships_table_modification();\\012	\N
+./sourceTest/sql/postgresql/059/.svn/text-base/017=database_version_logs.tsv.svn-base:053	source/sql/postgresql/migration/migration-052-053.sql	SUCCESS	2010-06-08 15:27:55.032	-- Migration from 052 to 053\\012\\012-- Change code uniqueness check for samples of specific type.\\012-- If sample_types.is_subcode_unique flag is set to 'true', additional check is performed \\012-- on codes of samples of the type. Subcodes will have to be unique as well.\\012\\012ALTER TABLE sample_types ADD COLUMN is_subcode_unique boolean_char NOT NULL DEFAULT false;\\012\\012CREATE OR REPLACE FUNCTION SAMPLE_SUBCODE_UNIQUENESS_CHECK() RETURNS trigger AS $$\\012DECLARE\\012   counter  INTEGER;\\012   unique_subcode  BOOLEAN_CHAR;\\012BEGIN\\012  LOCK TABLE samples IN EXCLUSIVE MODE;\\012  \\012  SELECT is_subcode_unique into unique_subcode FROM sample_types WHERE id = NEW.saty_id;\\012  \\012  IF (unique_subcode) THEN\\012    IF (NEW.dbin_id is not NULL) THEN\\012\\011\\011\\011SELECT count(*) into counter FROM samples \\012\\011\\011\\011\\011where id != NEW.id and code = NEW.code and saty_id = NEW.saty_id and dbin_id = NEW.dbin_id;\\012\\011\\011\\011IF (counter > 0) THEN\\012\\011\\011\\011\\011RAISE EXCEPTION 'Insert/Update of Sample (Code: %) failed because database instance sample of the same type with the same subcode already exists.', NEW.code;\\012\\011\\011\\011END IF;\\012\\011\\011ELSIF (NEW.grou_id is not NULL) THEN\\012\\011\\011\\011SELECT count(*) into counter FROM samples \\012\\011\\011\\011\\011where id != NEW.id and code = NEW.code and saty_id = NEW.saty_id and grou_id = NEW.grou_id;\\012\\011\\011\\011IF (counter > 0) THEN\\012\\011\\011\\011\\011RAISE EXCEPTION 'Insert/Update of Sample (Code: %) failed because space sample of the same type with the same subcode already exists.', NEW.code;\\012\\011\\011\\011END IF;\\012\\011\\011END IF;\\012  END IF;\\012  \\012  RETURN NEW;\\012END;\\012$$ LANGUAGE 'plpgsql';\\012\\012CREATE TRIGGER SAMPLE_SUBCODE_UNIQUENESS_CHECK BEFORE INSERT OR UPDATE ON SAMPLES\\012    FOR EACH ROW EXECUTE PROCEDURE SAMPLE_SUBCODE_UNIQUENESS_CHECK();\\012    \\012-- Fixing error messages in old trigger\\012\\012CREATE OR REPLACE FUNCTION SAMPLE_CODE_UNIQUENESS_CHECK() RETURNS trigger AS $$\\012DECLARE\\012   counter  INTEGER;\\012BEGIN\\012  LOCK TABLE samples IN EXCLUSIVE MODE;\\012  \\012\\011  IF (NEW.samp_id_part_of is NULL) THEN\\012\\011\\011  IF (NEW.dbin_id is not NULL) THEN\\012\\011\\011\\011  SELECT count(*) into counter FROM samples \\012\\011\\011      where id != NEW.id and code = NEW.code and samp_id_part_of is NULL and dbin_id = NEW.dbin_id;\\012        IF (counter > 0) THEN\\012\\011\\011\\011\\011  RAISE EXCEPTION 'Insert/Update of Sample (Code: %) failed because database instance sample with the same code already exists.', NEW.code;\\012        END IF;\\012\\011\\011  ELSIF (NEW.grou_id is not NULL) THEN\\012\\011\\011\\011  SELECT count(*) into counter FROM samples \\012\\011\\011\\011\\011  where id != NEW.id and code = NEW.code and samp_id_part_of is NULL and grou_id = NEW.grou_id;\\012\\011\\011\\011  IF (counter > 0) THEN\\012\\011\\011\\011\\011  RAISE EXCEPTION 'Insert/Update of Sample (Code: %) failed because space sample with the same code already exists.', NEW.code;\\012\\011\\011\\011  END IF;\\012      END IF;\\012    ELSE\\012\\011\\011  IF (NEW.dbin_id is not NULL) THEN\\012\\011\\011\\011  SELECT count(*) into counter FROM samples \\012\\011\\011\\011\\011  where id != NEW.id and code = NEW.code and samp_id_part_of = NEW.samp_id_part_of and dbin_id = NEW.dbin_id;\\012\\011\\011\\011  IF (counter > 0) THEN\\012\\011\\011\\011\\011  RAISE EXCEPTION 'Insert/Update of Sample (Code: %) failed because database instance sample with the same code and being the part of the same container already exists.', NEW.code;\\012\\011\\011\\011  END IF;\\012\\011\\011  ELSIF (NEW.grou_id is not NULL) THEN\\012\\011\\011\\011  SELECT count(*) into counter FROM samples \\012\\011\\011\\011\\011  where id != NEW.id and code = NEW.code and samp_id_part_of = NEW.samp_id_part_of and grou_id = NEW.grou_id;\\012\\011\\011\\011  IF (counter > 0) THEN\\012\\011\\011\\011\\011  RAISE EXCEPTION 'Insert/Update of Sample (Code: %) failed because space sample with the same code and being the part of the same container already exists.', NEW.code;\\012\\011\\011\\011  END IF;\\012\\011\\011  END IF;\\012     END IF;   \\012  \\012  RETURN NEW;\\012END;\\012$$ LANGUAGE 'plpgsql';\\012	\N
+./sourceTest/sql/postgresql/059/.svn/text-base/017=database_version_logs.tsv.svn-base:054	source/sql/postgresql/migration/migration-053-054.sql	SUCCESS	2010-07-27 11:30:46.766	-- Migration from 053 to 054\\012\\012\\012-- Add RELATIONSHIP_TYPES table\\012CREATE TABLE relationship_types (id TECH_ID NOT NULL, code CODE NOT NULL, label COLUMN_LABEL, parent_label COLUMN_LABEL, child_label COLUMN_LABEL, description DESCRIPTION_2000, registration_timestamp TIME_STAMP_DFL NOT NULL DEFAULT CURRENT_TIMESTAMP, pers_id_registerer TECH_ID NOT NULL, is_managed_internally BOOLEAN_CHAR NOT NULL DEFAULT 'F', is_internal_namespace BOOLEAN_CHAR NOT NULL DEFAULT 'F', dbin_id TECH_ID NOT NULL);\\012\\012-- Add SAMPLE_RELATIONSHIPS table\\012CREATE TABLE sample_relationships (id TECH_ID NOT NULL, sample_id_parent TECH_ID NOT NULL, relationship_id TECH_ID NOT NULL, sample_id_child TECH_ID NOT NULL);\\012\\012-- Add/update constraints\\012ALTER TABLE relationship_types ADD CONSTRAINT rety_pk PRIMARY KEY (id);\\012ALTER TABLE relationship_types ADD CONSTRAINT rety_uk UNIQUE(code,dbin_id);\\012ALTER TABLE sample_relationships ADD CONSTRAINT sare_pk PRIMARY KEY (id);\\012ALTER TABLE sample_relationships ADD CONSTRAINT sare_bk_uk UNIQUE(sample_id_child,sample_id_parent,relationship_id);\\012ALTER TABLE sample_relationships ADD CONSTRAINT sare_data_fk_child FOREIGN KEY (sample_id_child) REFERENCES samples(id) ON DELETE CASCADE;\\012ALTER TABLE sample_relationships ADD CONSTRAINT sare_data_fk_parent FOREIGN KEY (sample_id_parent) REFERENCES samples(id) ON DELETE CASCADE;\\012ALTER TABLE sample_relationships ADD CONSTRAINT sare_data_fk_relationship FOREIGN KEY (relationship_id) REFERENCES relationship_types(id);\\012\\012-- Create index\\012CREATE INDEX sare_data_fk_i_child ON sample_relationships (sample_id_child);\\012CREATE INDEX sare_data_fk_i_parent ON sample_relationships (sample_id_parent);\\012CREATE INDEX sare_data_fk_i_relationship ON sample_relationships (relationship_id);\\012\\012-- Create sequence for RELATIONSHIP_TYPES\\012CREATE SEQUENCE RELATIONSHIP_TYPE_ID_SEQ;\\012CREATE SEQUENCE SAMPLE_RELATIONSHIP_ID_SEQ;\\012\\012-- Create initial relationships\\012insert into relationship_types\\012(id, \\012code, \\012label, \\012parent_label, \\012child_label, \\012description, \\012pers_id_registerer, \\012is_managed_internally, \\012is_internal_namespace, \\012dbin_id) \\012values\\012(\\012nextval('RELATIONSHIP_TYPE_ID_SEQ'),\\012'PARENT_CHILD',\\012'Parent - Child', \\012'Parent', \\012'Child', \\012'Parent - Child relationship', \\012(select id from persons where user_id ='system'), \\012'T', \\012'T', \\012(select id from database_instances where is_original_source = 'T')\\012);\\012\\012insert into relationship_types\\012(id, \\012code, \\012label, \\012parent_label, \\012child_label, \\012description, \\012pers_id_registerer, \\012is_managed_internally, \\012is_internal_namespace, \\012dbin_id) \\012values\\012(\\012nextval('RELATIONSHIP_TYPE_ID_SEQ'),\\012'PLATE_CONTROL_LAYOUT',\\012'Plate - Control Layout', \\012'Plate', \\012'Control Layout', \\012'Plate - Control Layout relationship', \\012(select id from persons where user_id ='system'), \\012'T', \\012'T', \\012(select id from database_instances where is_original_source = 'T')\\012); \\012\\012\\012-- Migrate sample relationships to new schema\\012INSERT INTO sample_relationships (id, sample_id_parent,sample_id_child,relationship_id) (select distinct nextval('SAMPLE_RELATIONSHIP_ID_SEQ') as id, s.SAMP_ID_GENERATED_FROM as parent_id, s.ID as child_id, rt.id as relationship_id from samples s, relationship_types rt  WHERE rt.code = 'PARENT_CHILD' and s.SAMP_ID_GENERATED_FROM is not null); \\012INSERT INTO sample_relationships (id, sample_id_parent,sample_id_child,relationship_id) (select distinct nextval('SAMPLE_RELATIONSHIP_ID_SEQ') as id, s.SAMP_ID_CONTROL_LAYOUT as parent_id, s.ID as child_id, rt.id as relationship_id from samples s, relationship_types rt  WHERE rt.code = 'PLATE_CONTROL_LAYOUT' and s.SAMP_ID_CONTROL_LAYOUT is not null);\\012\\012-- Drop old sample relations\\012ALTER TABLE SAMPLES DROP COLUMN SAMP_ID_TOP;\\012ALTER TABLE SAMPLES DROP COLUMN SAMP_ID_GENERATED_FROM;\\012ALTER TABLE SAMPLES DROP COLUMN SAMP_ID_CONTROL_LAYOUT;\\012\\012--------------------------------------------------------------------------------------\\012--------------------------------------------------------------------------------------\\012-- This is a screening specific migration. Nothing will be performed on openBIS databases \\012-- which are not screening specific.\\012-- \\012-- This migration for each existing connection between oligo well, oligo material and gene material\\012-- creates a direct connection between the well and the gene. \\012--------------------------------------------------------------------------------------\\012--------------------------------------------------------------------------------------\\012 \\012\\011\\012CREATE OR REPLACE FUNCTION CONNECT_WELLS_WITH_GENES() RETURNS void AS $$\\012DECLARE\\012\\011counter  int;\\012\\011oligo_well_exists bool;\\012BEGIN\\012\\011--------------------------------------------------\\012\\011-- create a gene property and assign it to oligo well\\012\\011--------------------------------------------------\\012\\011\\012\\011select true \\012\\011into oligo_well_exists\\012\\011from sample_types \\012\\011where code = 'OLIGO_WELL';\\012\\011\\012\\011if oligo_well_exists IS NULL then \\012\\011\\011-- skip migration if there are no oligo wells\\012\\011\\011return;\\012\\011end if;   \\012\\011\\012\\011insert into property_types(\\012\\011\\011id, \\012\\011\\011code, description, label, \\012\\011\\011daty_id,\\012\\011\\011pers_id_registerer,\\012\\011\\011dbin_id,\\012\\011\\011maty_prop_id) \\012\\011values(\\012\\011\\011\\011nextval('PROPERTY_TYPE_ID_SEQ'), \\012\\011\\011\\011'GENE','Inhibited gene','Gene',\\012\\011\\011\\011(select id from data_types where code = 'MATERIAL'), \\012\\011\\011\\011(select id from persons where user_id ='system'), \\012\\011\\011\\011(select id from database_instances where is_original_source = 'T'), \\012\\011\\011\\011(select id from material_types where code = 'GENE')\\012\\011\\011);\\012\\011\\011\\012\\011insert into sample_type_property_types( \\012\\011  id,\\012\\011  saty_id,\\012\\011  prty_id,\\012\\011  is_mandatory,\\012\\011  pers_id_registerer,\\012\\011  ordinal\\012\\011) values(\\012\\011\\011\\011nextval('stpt_id_seq'), \\012\\011\\011\\011(select id from sample_types where code = 'OLIGO_WELL'),\\012\\011\\011\\011(select id from property_types where code = 'GENE'),\\012\\011\\011\\011false,\\012\\011\\011\\011(select id from persons where user_id ='system'),\\012\\011\\011\\011(select max(ordinal)+1 from sample_type_property_types \\012\\011\\011\\011\\011where saty_id = (select id from sample_types where code = 'OLIGO_WELL'))\\012\\011\\011);\\012\\012\\011--------------------------------------------------\\012\\011-- create a gene material property for each oligo well\\012\\011--------------------------------------------------\\012\\011\\011\\012\\011select \\011count(*)\\012\\011into counter\\012\\011from\\012\\011\\011samples well, sample_types well_type, sample_properties well_props, \\012\\011\\011materials well_material, material_properties well_material_props,\\012\\011\\011materials nested_well_material\\012\\011where\\012\\011\\011well_type.code = 'OLIGO_WELL' and\\012\\011\\011-- find 'well_material' assigned to the well\\012\\011\\011well_props.samp_id = well.id and well_material.id = well_props.mate_prop_id and \\012\\011\\011-- additional joins to entity type tables\\012\\011\\011well_type.id = well.saty_id and\\012\\011\\011-- well content material property\\012\\011\\011well_material_props.mate_id = well_material.id and \\012\\011\\011-- material connected to the material in the well (e.g. gene)\\012\\011\\011well_material_props.mate_prop_id = nested_well_material.id and\\012\\011\\011nested_well_material.maty_id = (select id from material_types where code = 'GENE');\\012\\011\\012\\011if counter = 0 then \\012\\011\\011-- skip migration if there are no genes indirectly connected to oligo wells\\012\\011\\011return;\\012\\011end if;   \\012\\012\\011insert into sample_properties(id, samp_id, stpt_id, mate_prop_id, pers_id_registerer) (\\012\\011\\011select \\011nextval('sample_property_id_seq') id, \\012\\011\\011\\011well.id samp_id, \\012\\011\\011\\011(select stpt.id from sample_type_property_types stpt, property_types props where stpt.prty_id = props.id and props.code='GENE') stpt_id,\\012\\011\\011\\011nested_well_material.id mate_prop_id,\\012\\011\\011\\011(select id from persons where user_id ='system') pers_id_registerer \\012\\011\\011from\\012\\011\\011\\011samples well, sample_types well_type, sample_properties well_props, \\012\\011\\011\\011materials well_material, material_properties well_material_props,\\012\\011\\011\\011materials nested_well_material\\012\\011\\011where\\012\\011\\011\\011well_type.code = 'OLIGO_WELL' and\\012\\011\\011\\011-- find 'well_material' assigned to the well\\012\\011\\011\\011well_props.samp_id = well.id and well_material.id = well_props.mate_prop_id and \\012\\011\\011\\011-- additional joins to entity type tables\\012\\011\\011\\011well_type.id = well.saty_id and\\012\\011\\011\\011-- well content material property\\012\\011\\011\\011well_material_props.mate_id = well_material.id and \\012\\011\\011\\011-- material connected to the material in the well (e.g. gene)\\012\\011\\011\\011well_material_props.mate_prop_id = nested_well_material.id and\\012\\011\\011\\011nested_well_material.maty_id = (select id from material_types where code = 'GENE')\\012\\011);\\012\\012END;\\012$$ LANGUAGE 'plpgsql';\\012\\012select CONNECT_WELLS_WITH_GENES();\\012drop function CONNECT_WELLS_WITH_GENES();\\012\\012--------------------------------------------------------------------------------------\\012--------------------------------------------------------------------------------------\\012\\012-- drop dataset triggers\\012\\012DROP TRIGGER check_dataset_relationships_on_data_table_modification ON data;\\012DROP FUNCTION check_dataset_relationships_on_data_table_modification();\\012DROP TRIGGER check_dataset_relationships_on_relationships_table_modification ON data_set_relationships;\\012DROP FUNCTION check_dataset_relationships_on_relationships_table_modification();\\012 \\012\\012\\012\\012\\012\\012\\012\\012	\N
+./sourceTest/sql/postgresql/059/.svn/text-base/017=database_version_logs.tsv.svn-base:056	source/sql/postgresql/migration/migration-055-056.sql	SUCCESS	2010-09-10 09:06:20.278	-- Migration from 055 to 056\\012\\012--------------------------------------------------------------------------------------\\012--------------------------------------------------------------------------------------\\012-- Screening specific migration. Nothing will be performed on openBIS databases \\012-- which are not screening specific.\\012--------------------------------------------------------------------------------------\\012--------------------------------------------------------------------------------------\\012\\012CREATE OR REPLACE FUNCTION merge_words(text, text) RETURNS text AS $$\\012DECLARE\\012  BEGIN\\012    IF  character_length($1) > 0 THEN\\012      RETURN $1 || ' ' || $2;\\012    ELSE\\012      RETURN $2;\\012    END IF;\\012  END;\\012$$ LANGUAGE plpgsql;\\012\\012CREATE AGGREGATE merge_words(text)\\012(\\012  SFUNC = merge_words,\\012  STYPE = text\\012);\\012\\012\\012CREATE OR REPLACE FUNCTION REPLACE_GENE_SYMBOL_BY_GENE_ID() RETURNS void AS $$\\012DECLARE\\012\\011counter  int;\\012\\011library_id_assigned_to_gene bool;\\012BEGIN\\012\\011--------------------------------------------------\\012\\011-- create a GENE_SYMBOL property and assign it to GENE\\012\\011--------------------------------------------------\\012\\011\\012\\011select true  \\012\\011into library_id_assigned_to_gene \\012\\011from material_type_property_types mtpt, material_types mt, property_types pt  \\012\\011where mtpt.maty_id = mt.id and mtpt.prty_id = pt.id \\012\\011\\011and mt.code = 'GENE' and pt.code = 'LIBRARY_ID';\\012\\011\\012\\011if library_id_assigned_to_gene IS NULL then \\012\\011\\011-- skip migration if gene has no library_id property\\012\\011\\011return;\\012\\011end if; \\012\\011\\012\\011\\012\\011select count(*)\\012\\011into counter \\012\\011from  \\012\\011\\011(select m.id, count(mp.id) as c \\012\\011\\011\\011from materials m, material_types mt, material_properties mp, material_type_property_types mtpt, property_types pt \\012\\011\\011\\011where m.maty_id = mt.id and mp.mate_id = m.id and mp.mtpt_id = mtpt.id and mtpt.maty_id = mt.id and pt.id = mtpt.prty_id\\012\\011\\011\\011\\011and mt.code = 'GENE' and pt.code = 'LIBRARY_ID' \\012\\011\\011\\011group by m.id) as counter_table \\012\\011where c < 1; \\012\\011\\012\\011if counter > 0 then \\012\\011\\011-- skip migration if there is at least one gene without library_id\\012\\011\\011return;\\012\\011end if;\\012\\011\\012\\011\\012\\011insert into property_types\\012\\011\\011(id\\012\\011\\011,code\\012\\011\\011,description\\012\\011\\011,label\\012\\011\\011,daty_id\\012\\011\\011,pers_id_registerer\\012\\011\\011,dbin_id)\\012\\011values \\012\\011\\011(nextval('PROPERTY_TYPE_ID_SEQ')\\012\\011\\011,'GENE_SYMBOLS'\\012\\011\\011,'Gene symbols'\\012\\011\\011,'Gene symbols'\\012\\011\\011,(select id from data_types where code ='VARCHAR')\\012\\011\\011,(select id from persons where user_id ='system')\\012\\011\\011,(select id from database_instances where is_original_source = 'T')\\012\\011);\\012\\011\\011\\012\\011insert into material_type_property_types( \\012\\011  id,\\012\\011  maty_id,\\012\\011  prty_id,\\012\\011  is_mandatory,\\012\\011  pers_id_registerer,\\012\\011  ordinal\\012\\011) values(\\012\\011\\011\\011nextval('mtpt_id_seq'), \\012\\011\\011\\011(select id from material_types where code = 'GENE'),\\012\\011\\011\\011(select id from property_types where code = 'GENE_SYMBOLS'),\\012\\011\\011\\011false,\\012\\011\\011\\011(select id from persons where user_id ='system'),\\012\\011\\011\\011(select max(ordinal)+1 from material_type_property_types \\012\\011\\011\\011\\011where maty_id = (select id from material_types where code = 'GENE'))\\012\\011\\011);\\012\\012\\011--------------------------------------------------\\012\\011-- create temporary table with all gene migration information\\012\\011--------------------------------------------------\\012\\012\\011create temp table genes \\012\\011(\\012\\011\\011id tech_id,\\012\\011\\011code code,\\012\\011\\011library_id generic_value,\\012\\011\\011gene_codes generic_value,\\012\\011\\011new_id tech_id,\\012\\011\\011library_tech_id tech_id\\011\\011\\012\\011);\\012\\011\\012\\011insert into genes (id, code, library_id, library_tech_id)\\012\\011\\011(select m.id, m.code, mp.value as library_id, mp.id as library_tech_id from materials m, material_properties mp, material_type_property_types mtpt, property_types pt, material_types mt\\012\\011\\011where mp.mate_id = m.id and  mp.mtpt_id = mtpt.id and pt.id = mtpt.prty_id and pt.code = 'LIBRARY_ID' and mt.id = m.maty_id and mt.id = mtpt.maty_id and mt.code = 'GENE');\\012\\011\\012\\011update genes set new_id = map.to_id from (select g_from.id as from_id, min(g_to.id) as to_id  from genes g_from, genes g_to where g_from.library_id = g_to.library_id group by g_from.id) as map where map.from_id = id;\\011\\012\\011\\012\\011update genes set gene_codes = map.gene_codes from (select g_from.library_id as lib_id, merge_words(distinct g_to.code) as gene_codes from genes g_from, genes g_to where g_from.library_id = g_to.library_id group by g_from.library_id) as map where map.lib_id = library_id;\\011\\012\\012\\011--------------------------------------------------\\012\\011-- update gene references\\012\\011--------------------------------------------------\\012\\012\\011update EXPERIMENTS set MATE_ID_STUDY_OBJECT = genes.new_id from genes where genes.id = MATE_ID_STUDY_OBJECT and not genes.id = genes.new_id;\\012\\011update EXPERIMENT_PROPERTIES set  MATE_PROP_ID = genes.new_id from genes where genes.id = MATE_PROP_ID and not genes.id = genes.new_id;\\012\\011update MATERIAL_PROPERTIES set  MATE_PROP_ID = genes.new_id from genes where genes.id = MATE_PROP_ID and not genes.id = genes.new_id;\\012\\011update SAMPLE_PROPERTIES set  MATE_PROP_ID = genes.new_id from genes where genes.id = MATE_PROP_ID and not genes.id = genes.new_id;\\012\\011update DATA_SET_PROPERTIES set  MATE_PROP_ID = genes.new_id from genes where genes.id = MATE_PROP_ID and not genes.id = genes.new_id;\\012\\011\\012\\011delete from  material_properties where mate_id in (select id from genes where not genes.id = genes.new_id);\\012\\011delete from MATERIALS where id in (select id from genes where not genes.id = genes.new_id);\\012\\012\\011delete from genes where id in (select id from genes where not genes.id = genes.new_id);\\012\\012\\012\\011--------------------------------------------------\\012\\011-- replace gene code with library_id\\012\\011--------------------------------------------------\\012\\011\\012\\011update materials set code = genes.library_id from genes where materials.id = genes.id ;\\012\\011delete from material_properties where id in (select library_tech_id from genes);\\012\\011\\012\\011--------------------------------------------------\\012\\011-- create a gene symbols property for each gene\\012\\011--------------------------------------------------\\012\\011\\012\\011insert into material_properties\\012\\011\\011(id\\012\\011  , mate_id\\012\\011  , mtpt_id\\012\\011  , "value"\\012\\011  , pers_id_registerer)\\012\\011\\011(select nextval('material_property_id_seq') id\\012\\011  \\011, genes.id  mate_id\\012\\011    , (select mtpt.id\\012\\011    \\011\\011from   material_type_property_types mtpt, material_types mt, property_types pt\\012\\011    \\011\\011where  pt.code = 'GENE_SYMBOLS' and mt.code = 'GENE' and mtpt.prty_id = pt.id\\012\\011        \\011and mtpt.maty_id = mt.id) mtpt_id\\012\\011    , genes.gene_codes "value"\\012\\011    , (select id from persons where user_id = 'system') pers_id_registerer\\012\\011 \\011from genes); \\012\\012\\011--------------------------------------------------\\012\\011-- delete temporary table\\012\\011--------------------------------------------------\\012\\011\\012\\011drop table genes;\\012\\011\\012END;\\012$$ LANGUAGE 'plpgsql';\\012\\012select REPLACE_GENE_SYMBOL_BY_GENE_ID();\\012drop function REPLACE_GENE_SYMBOL_BY_GENE_ID();\\012DROP AGGREGATE merge_words(text);\\012drop function merge_words(text,text);\\012\\012\\012--------------------------------------------------------------------------------------\\012--------------------------------------------------------------------------------------\\012\\012UPDATE sample_types SET code = 'SIRNA_WELL' WHERE code = 'OLIGO_WELL';\\012UPDATE material_types SET code = 'SIRNA' WHERE code = 'OLIGO';\\012UPDATE property_types SET code = 'SIRNA', label = 'siRNA' WHERE code = 'OLIGO';\\012\\012\\012\\012\\012\\012\\012\\012\\012\\012\\012\\012\\012\\012\\012\\012\\012\\012\\012\\012	\N
+./sourceTest/sql/postgresql/059/.svn/text-base/017=database_version_logs.tsv.svn-base:059	source/sql/postgresql/migration/migration-058-059.sql	SUCCESS	2010-09-29 13:37:07.231	-- Migration from 058 to 059\\012\\012-- Add ENTITY_TYPE_CODE column to QUERIES\\012ALTER TABLE queries ADD COLUMN entity_type_code CODE;\\012\\012------------------------------------------------------------------------------------\\012--  Purpose:  Create trigger that checks if entity_type_code specified in a query\\012--            matches a code of an entity of type specified in query_type.\\012------------------------------------------------------------------------------------\\012\\012CREATE OR REPLACE FUNCTION query_entity_type_code_check() RETURNS trigger AS $$\\012DECLARE\\012   counter  INTEGER;\\012BEGIN\\012   if (NEW.entity_type_code IS NOT NULL) then\\012     if (NEW.query_type = 'GENERIC') then\\012       RAISE EXCEPTION 'Insert/Update of query (Name: %) failed, as entity_type has to be null for GENERIC queries.', NEW.name;\\012     elsif (NEW.query_type = 'EXPERIMENT') then\\012       SELECT count(*) INTO counter FROM experiment_types WHERE code = NEW.entity_type_code;\\012\\011\\011 elsif (NEW.query_type = 'DATA_SET') then\\012       SELECT count(*) INTO counter FROM data_set_types WHERE code = NEW.entity_type_code;\\012\\011\\011 elsif (NEW.query_type = 'MATERIAL') then\\012       SELECT count(*) INTO counter FROM material_types WHERE code = NEW.entity_type_code;\\012\\011\\011 elsif (NEW.query_type = 'SAMPLE') then\\012       SELECT count(*) INTO counter FROM sample_types WHERE code = NEW.entity_type_code;\\012\\011\\011 end if;\\012\\011\\011 if (counter = 0) then\\012\\011\\011\\011 RAISE EXCEPTION 'Insert/Update of query (Name: %) failed because % type (Code: %) does not exist.', NEW.name, NEW.query_type, NEW.entity_type_code;\\012\\011\\011 end if;\\011\\011\\011\\012   end if;\\012   RETURN NEW;\\012END;\\012$$ LANGUAGE 'plpgsql';\\012\\012CREATE TRIGGER query_entity_type_code_check BEFORE INSERT OR UPDATE ON queries\\012    FOR EACH ROW EXECUTE PROCEDURE query_entity_type_code_check();\\012	\N
+./sourceTest/sql/postgresql/059/.svn/text-base/schema-059.sql.svn-base:    LANGUAGE plpgsql
+./sourceTest/sql/postgresql/059/.svn/text-base/schema-059.sql.svn-base:    LANGUAGE plpgsql
+./sourceTest/sql/postgresql/059/.svn/text-base/schema-059.sql.svn-base:    LANGUAGE plpgsql
+./sourceTest/sql/postgresql/059/.svn/text-base/schema-059.sql.svn-base:    LANGUAGE plpgsql
+./sourceTest/sql/postgresql/059/.svn/text-base/schema-059.sql.svn-base:    LANGUAGE plpgsql
+./sourceTest/sql/postgresql/059/.svn/text-base/schema-059.sql.svn-base:    LANGUAGE plpgsql
+./sourceTest/sql/postgresql/059/.svn/text-base/schema-059.sql.svn-base:    LANGUAGE plpgsql
+./sourceTest/sql/postgresql/059/.svn/text-base/schema-059.sql.svn-base:    LANGUAGE plpgsql
+./sourceTest/sql/postgresql/059/.svn/text-base/schema-059.sql.svn-base:    LANGUAGE plpgsql
+./sourceTest/sql/postgresql/059/.svn/text-base/schema-059.sql.svn-base:    LANGUAGE plpgsql
+./sourceTest/sql/postgresql/059/017=database_version_logs.tsv:027	D:\\User\\felmer\\dev-workspace\\openbis/source/sql/postgresql/027/function-027.sql	SUCCESS	2008-11-05 09:18:00.403	-- Creating Functions\\012\\012------------------------------------------------------------------------------------\\012--  Purpose:  Create function RENAME_SEQUENCE() that is required for renaming the sequences belonging to tables\\012------------------------------------------------------------------------------------\\012CREATE FUNCTION RENAME_SEQUENCE(OLD_NAME VARCHAR, NEW_NAME VARCHAR) RETURNS INTEGER AS $$\\012DECLARE\\012  CURR_SEQ_VAL   INTEGER;\\012BEGIN\\012  SELECT INTO CURR_SEQ_VAL NEXTVAL(OLD_NAME);\\012  EXECUTE 'CREATE SEQUENCE ' || NEW_NAME || ' START WITH ' || CURR_SEQ_VAL;\\012  EXECUTE 'DROP SEQUENCE ' || OLD_NAME;\\012  RETURN CURR_SEQ_VAL;\\012END;\\012$$ LANGUAGE 'plpgsql';\\012\\012\\012------------------------------------------------------------------------------------\\012--  Purpose:  Create trigger CONTROLLED_VOCABULARY_CHECK \\012------------------------------------------------------------------------------------\\012\\012CREATE OR REPLACE FUNCTION CONTROLLED_VOCABULARY_CHECK() RETURNS trigger AS $$\\012DECLARE\\012   v_code  CODE;\\012BEGIN\\012\\012   select code into v_code from data_types where id = NEW.daty_id;\\012\\012   -- Check if the data is of type "CONTROLLEDVOCABULARY"\\012   if v_code = 'CONTROLLEDVOCABULARY' then\\012      if NEW.covo_id IS NULL then\\012         RAISE EXCEPTION 'Insert/Update of Property Type (Code: %) failed, as its Data Type is CONTROLLEDVOCABULARY, but it is not linked to a Controlled Vocabulary.', NEW.code;\\012      end if;\\012   end if;\\012\\012   RETURN NEW;\\012\\012END;\\012$$ LANGUAGE 'plpgsql';\\012\\012CREATE TRIGGER CONTROLLED_VOCABULARY_CHECK BEFORE INSERT OR UPDATE ON PROPERTY_TYPES\\012    FOR EACH ROW EXECUTE PROCEDURE CONTROLLED_VOCABULARY_CHECK();\\012\\012\\012------------------------------------------------------------------------------------\\012--  Purpose:  Create trigger EXTERNAL_DATA_STORAGE_FORMAT_CHECK \\012------------------------------------------------------------------------------------\\012\\012CREATE OR REPLACE FUNCTION EXTERNAL_DATA_STORAGE_FORMAT_CHECK() RETURNS trigger AS $$\\012DECLARE\\012   v_covo_code  CODE;\\012   data_code CODE;\\012BEGIN\\012\\012   select code into v_covo_code from controlled_vocabularies\\012      where is_internal_namespace = true and \\012         id = (select covo_id from controlled_vocabulary_terms where id = NEW.cvte_id_stor_fmt);\\012   -- Check if the data storage format is a term of the controlled vocabulary "STORAGE_FORMAT"\\012   if v_covo_code != 'STORAGE_FORMAT' then\\012      select code into data_code from data where id = NEW.data_id; \\012      RAISE EXCEPTION 'Insert/Update of Data (Code: %) failed, as its Storage Format is %, but is required to be STORAGE_FORMAT.', data_code, v_covo_code;\\012   end if;\\012\\012   RETURN NEW;\\012\\012END;\\012$$ LANGUAGE 'plpgsql';\\012\\012CREATE TRIGGER EXTERNAL_DATA_STORAGE_FORMAT_CHECK BEFORE INSERT OR UPDATE ON EXTERNAL_DATA\\012    FOR EACH ROW EXECUTE PROCEDURE EXTERNAL_DATA_STORAGE_FORMAT_CHECK();\\012\\012------------------------------------------------------------------------------------\\012--  Purpose:  Create trigger SAMPLE_CODE_UNIQUENESS_CHECK \\012------------------------------------------------------------------------------------\\012\\012CREATE OR REPLACE FUNCTION SAMPLE_CODE_UNIQUENESS_CHECK() RETURNS trigger AS $$\\012DECLARE\\012   counter  INTEGER;\\012BEGIN\\012\\011IF (NEW.samp_id_part_of is NULL) THEN\\012\\011\\011IF (NEW.dbin_id is not NULL) THEN\\012\\011\\011\\011SELECT count(*) into counter FROM samples \\012\\011\\011\\011\\011where id != NEW.id and code = NEW.code and samp_id_part_of is NULL and dbin_id = NEW.dbin_id;\\012\\011\\011\\011IF (counter > 0) THEN\\012\\011\\011\\011\\011RAISE EXCEPTION 'Insert/Update of Sample (Code: %) failed because database instance sample with the same code already exists.', NEW.code;\\012\\011\\011\\011END IF;\\012\\011\\011ELSIF (NEW.grou_id is not NULL) THEN\\012\\011\\011\\011SELECT count(*) into counter FROM samples \\012\\011\\011\\011\\011where id != NEW.id and code = NEW.code and samp_id_part_of is NULL and grou_id = NEW.grou_id;\\012\\011\\011\\011IF (counter > 0) THEN\\012\\011\\011\\011\\011RAISE EXCEPTION 'Insert/Update of Sample (Code: %) failed because group sample with the same code already exists.', NEW.code;\\012\\011\\011\\011END IF;\\012\\011\\011END IF;\\012        ELSE\\012\\011\\011IF (NEW.dbin_id is not NULL) THEN\\012\\011\\011\\011SELECT count(*) into counter FROM samples \\012\\011\\011\\011\\011where id != NEW.id and code = NEW.code and samp_id_part_of = NEW.samp_id_part_of and dbin_id = NEW.dbin_id;\\012\\011\\011\\011IF (counter > 0) THEN\\012\\011\\011\\011\\011RAISE EXCEPTION 'Insert/Update of Sample (Code: %) failed because database instance sample with the same code and being the part of the same parent already exists.', NEW.code;\\012\\011\\011\\011END IF;\\012\\011\\011ELSIF (NEW.grou_id is not NULL) THEN\\012\\011\\011\\011SELECT count(*) into counter FROM samples \\012\\011\\011\\011\\011where id != NEW.id and code = NEW.code and samp_id_part_of = NEW.samp_id_part_of and grou_id = NEW.grou_id;\\012\\011\\011\\011IF (counter > 0) THEN\\012\\011\\011\\011\\011RAISE EXCEPTION 'Insert/Update of Sample (Code: %) failed because group sample with the same code and being the part of the same parent already exists.', NEW.code;\\012\\011\\011\\011END IF;\\012\\011\\011END IF;\\012        END IF;   \\012   RETURN NEW;\\012END;\\012$$ LANGUAGE 'plpgsql';\\012\\012CREATE TRIGGER SAMPLE_CODE_UNIQUENESS_CHECK BEFORE INSERT OR UPDATE ON SAMPLES\\012    FOR EACH ROW EXECUTE PROCEDURE SAMPLE_CODE_UNIQUENESS_CHECK();\\012	\N
+./sourceTest/sql/postgresql/059/017=database_version_logs.tsv:028	source/sql/postgresql/migration/migration-027-028.sql	SUCCESS	2008-11-18 13:24:17.508	-- Create EXPERIMENT_ATTACHMENT_CONTENTS.\\012CREATE TABLE EXPERIMENT_ATTACHMENT_CONTENTS (ID TECH_ID NOT NULL,VALUE FILE NOT NULL);\\012CREATE SEQUENCE EXPERIMENT_ATTACHMENT_CONTENT_ID_SEQ;\\012ALTER TABLE EXPERIMENT_ATTACHMENT_CONTENTS ADD CONSTRAINT EXAC_PK PRIMARY KEY(ID);\\012\\012-- Alter EXPERIMENT_ATTACHMENTS by adding the new column which has a NULL constraint.\\012-- The NOT NULL constraint is added later on.\\012ALTER TABLE EXPERIMENT_ATTACHMENTS ADD COLUMN EXAC_ID TECH_ID;\\012\\012-- Does the VALUE migration between EXPERIMENT_ATTACHMENTS to EXPERIMENT_ATTACHMENT_CONTENTS.\\012CREATE OR REPLACE FUNCTION move_exp_att_content() RETURNS integer AS $$\\012DECLARE\\012    rec RECORD;\\012    seq BIGINT;\\012BEGIN\\012  FOR rec IN SELECT id, value FROM EXPERIMENT_ATTACHMENTS LOOP\\012  \\011seq := nextval('EXPERIMENT_ATTACHMENT_CONTENT_ID_SEQ');\\012    INSERT INTO EXPERIMENT_ATTACHMENT_CONTENTS (id, value) VALUES (seq, rec.value);\\012    UPDATE EXPERIMENT_ATTACHMENTS SET exac_id = seq WHERE id = rec.id;\\012  END LOOP;\\012  RETURN 1;\\012END;\\012$$ LANGUAGE 'plpgsql';\\012\\012-- Call the function.\\012SELECT move_exp_att_content();\\012DROP FUNCTION move_exp_att_content();\\012\\012\\012-- Finish EXPERIMENT_ATTACHMENTS changes.\\012ALTER TABLE EXPERIMENT_ATTACHMENTS ADD CONSTRAINT EXAT_CONT_FK FOREIGN KEY (EXAC_ID) REFERENCES EXPERIMENT_ATTACHMENT_CONTENTS(ID);\\012ALTER TABLE EXPERIMENT_ATTACHMENTS DROP COLUMN VALUE;\\012ALTER TABLE EXPERIMENT_ATTACHMENTS ALTER COLUMN EXAC_ID SET NOT NULL;\\012	\N
+./sourceTest/sql/postgresql/059/017=database_version_logs.tsv:029	source/sql/postgresql/migration/migration-028-029.sql	SUCCESS	2009-03-18 10:50:20.105	-- -------\\012-- add modification_timestamp field to allow edition with Hibernate\\012-- -------\\012\\012ALTER TABLE samples\\012\\011ADD COLUMN modification_timestamp TIME_STAMP DEFAULT CURRENT_TIMESTAMP;\\012\\012ALTER TABLE experiments\\012\\011ADD COLUMN modification_timestamp TIME_STAMP DEFAULT CURRENT_TIMESTAMP;\\012\\012ALTER TABLE materials\\012\\011ADD COLUMN modification_timestamp TIME_STAMP DEFAULT CURRENT_TIMESTAMP;\\012\\012ALTER TABLE experiment_properties\\012\\011ADD COLUMN modification_timestamp TIME_STAMP DEFAULT CURRENT_TIMESTAMP;\\012\\012ALTER TABLE material_properties\\012\\011ADD COLUMN modification_timestamp TIME_STAMP DEFAULT CURRENT_TIMESTAMP;\\012\\012ALTER TABLE sample_properties\\012\\011ADD COLUMN modification_timestamp TIME_STAMP DEFAULT CURRENT_TIMESTAMP;\\012\\012-- -------\\012-- add property data type which references materials\\012-- -------\\012\\012ALTER TABLE property_types\\012\\011ADD COLUMN maty_prop_id tech_id;\\012\\012ALTER TABLE property_types\\012\\011ADD CONSTRAINT prty_maty_fk FOREIGN KEY (maty_prop_id) REFERENCES material_types(id);\\012\\012ALTER TABLE experiment_properties\\012\\011ADD COLUMN mate_prop_id tech_id;\\012\\012ALTER TABLE material_properties\\012\\011ADD COLUMN mate_prop_id tech_id;\\012\\012ALTER TABLE sample_properties\\012\\011ADD COLUMN mate_prop_id tech_id;\\012\\012ALTER TABLE experiment_properties\\012\\011ADD CONSTRAINT expr_mapr_fk FOREIGN KEY (mate_prop_id) REFERENCES materials(id);\\012\\012ALTER TABLE material_properties\\012\\011ADD CONSTRAINT mapr_mapr_fk FOREIGN KEY (mate_prop_id) REFERENCES materials(id);\\012\\012ALTER TABLE sample_properties\\012\\011ADD CONSTRAINT sapr_mapr_fk FOREIGN KEY (mate_prop_id) REFERENCES materials(id);\\012\\012insert into data_types\\012(id\\012 ,code\\012 ,description)\\012 values \\012 (nextval('DATA_TYPE_ID_SEQ')\\012 ,'MATERIAL'\\012 ,'Reference to a material'\\012);\\012\\012ALTER TABLE MATERIAL_PROPERTIES DROP CONSTRAINT MAPR_CK;\\012ALTER TABLE MATERIAL_PROPERTIES ADD CONSTRAINT MAPR_CK CHECK \\012\\011((VALUE IS NOT NULL AND CVTE_ID IS NULL AND MATE_PROP_ID IS NULL) OR \\012\\011 (VALUE IS NULL AND CVTE_ID IS NOT NULL AND MATE_PROP_ID IS NULL) OR\\012\\011 (VALUE IS NULL AND CVTE_ID IS NULL AND MATE_PROP_ID IS NOT NULL)\\012\\011);\\012\\012ALTER TABLE EXPERIMENT_PROPERTIES DROP CONSTRAINT EXPR_CK;\\012ALTER TABLE EXPERIMENT_PROPERTIES ADD CONSTRAINT EXPR_CK CHECK \\012\\011((VALUE IS NOT NULL AND CVTE_ID IS NULL AND MATE_PROP_ID IS NULL) OR \\012\\011 (VALUE IS NULL AND CVTE_ID IS NOT NULL AND MATE_PROP_ID IS NULL) OR\\012\\011 (VALUE IS NULL AND CVTE_ID IS NULL AND MATE_PROP_ID IS NOT NULL)\\012\\011);\\012\\012ALTER TABLE SAMPLE_PROPERTIES DROP CONSTRAINT SAPR_CK;\\012ALTER TABLE SAMPLE_PROPERTIES ADD CONSTRAINT SAPR_CK CHECK \\012\\011((VALUE IS NOT NULL AND CVTE_ID IS NULL AND MATE_PROP_ID IS NULL) OR \\012\\011 (VALUE IS NULL AND CVTE_ID IS NOT NULL AND MATE_PROP_ID IS NULL) OR\\012\\011 (VALUE IS NULL AND CVTE_ID IS NULL AND MATE_PROP_ID IS NOT NULL)\\012\\011);\\012\\012------------------------------------------------------------------------------------\\012--  Purpose:  Create trigger MATERIAL/SAMPLE/EXPERIMENT _PROPERTY_WITH_MATERIAL_DATA_TYPE_CHECK\\012--            It checks that if material property value is assigned to the entity,\\012--\\011\\011\\011\\011\\011\\011then the material type is equal to the one described by property type.\\012------------------------------------------------------------------------------------\\012\\012CREATE OR REPLACE FUNCTION MATERIAL_PROPERTY_WITH_MATERIAL_DATA_TYPE_CHECK() RETURNS trigger AS $$\\012DECLARE\\012   v_type_id  CODE;\\012   v_type_id_prop  CODE;\\012BEGIN\\012   if NEW.mate_prop_id IS NOT NULL then\\012\\011\\011\\011-- find material type id of the property type \\012\\011\\011\\011select pt.maty_prop_id into v_type_id_prop \\012\\011\\011\\011  from material_type_property_types etpt, property_types pt \\012\\011\\011\\011 where NEW.mtpt_id = etpt.id AND etpt.prty_id = pt.id;\\012\\011\\011\\012\\011\\011\\011if v_type_id_prop IS NOT NULL then\\012\\011\\011\\011\\011-- find material type id of the material which consists the entity's property value\\012\\011\\011\\011\\011select entity.maty_id into v_type_id \\012\\011\\011\\011\\011  from materials entity\\012\\011\\011\\011\\011 where NEW.mate_prop_id = entity.id;\\012\\011\\011\\011\\011if v_type_id != v_type_id_prop then\\012\\011\\011\\011\\011\\011RAISE EXCEPTION 'Insert/Update of property value referencing material (id: %) failed, as referenced material type is different than expected (id %, expected id: %).', \\012\\011\\011\\011\\011\\011\\011\\011 NEW.mate_prop_id, v_type_id, v_type_id_prop;\\012\\011\\011\\011\\011end if;\\012\\011\\011\\011end if;\\012   end if;\\012   RETURN NEW;\\012END;\\012$$ LANGUAGE 'plpgsql';\\012\\012CREATE TRIGGER MATERIAL_PROPERTY_WITH_MATERIAL_DATA_TYPE_CHECK BEFORE INSERT OR UPDATE ON material_properties\\012    FOR EACH ROW EXECUTE PROCEDURE MATERIAL_PROPERTY_WITH_MATERIAL_DATA_TYPE_CHECK();\\012    \\012CREATE OR REPLACE FUNCTION SAMPLE_PROPERTY_WITH_MATERIAL_DATA_TYPE_CHECK() RETURNS trigger AS $$\\012DECLARE\\012   v_type_id  CODE;\\012   v_type_id_prop  CODE;\\012BEGIN\\012   if NEW.mate_prop_id IS NOT NULL then\\012\\011\\011\\011-- find material type id of the property type \\012\\011\\011\\011select pt.maty_prop_id into v_type_id_prop \\012\\011\\011\\011  from sample_type_property_types etpt, property_types pt \\012\\011\\011\\011 where NEW.stpt_id = etpt.id AND etpt.prty_id = pt.id;\\012\\011\\011\\012\\011\\011\\011if v_type_id_prop IS NOT NULL then\\012\\011\\011\\011\\011-- find material type id of the material which consists the entity's property value\\012\\011\\011\\011\\011select entity.maty_id into v_type_id \\012\\011\\011\\011\\011  from materials entity\\012\\011\\011\\011\\011 where NEW.mate_prop_id = entity.id;\\012\\011\\011\\011\\011if v_type_id != v_type_id_prop then\\012\\011\\011\\011\\011\\011RAISE EXCEPTION 'Insert/Update of property value referencing material (id: %) failed, as referenced material type is different than expected (id %, expected id: %).', \\012\\011\\011\\011\\011\\011\\011\\011\\011\\011\\011\\011\\011 NEW.mate_prop_id, v_type_id, v_type_id_prop;\\012\\011\\011\\011\\011end if;\\012\\011\\011\\011end if;\\012   end if;\\012   RETURN NEW;\\012END;\\012$$ LANGUAGE 'plpgsql';\\012\\012CREATE TRIGGER SAMPLE_PROPERTY_WITH_MATERIAL_DATA_TYPE_CHECK BEFORE INSERT OR UPDATE ON sample_properties\\012    FOR EACH ROW EXECUTE PROCEDURE SAMPLE_PROPERTY_WITH_MATERIAL_DATA_TYPE_CHECK();\\012    \\012CREATE OR REPLACE FUNCTION EXPERIMENT_PROPERTY_WITH_MATERIAL_DATA_TYPE_CHECK() RETURNS trigger AS $$\\012DECLARE\\012   v_type_id  CODE;\\012   v_type_id_prop  CODE;\\012BEGIN\\012   if NEW.mate_prop_id IS NOT NULL then\\012\\011\\011\\011-- find material type id of the property type \\012\\011\\011\\011select pt.maty_prop_id into v_type_id_prop \\012\\011\\011\\011  from experiment_type_property_types etpt, property_types pt \\012\\011\\011\\011 where NEW.etpt_id = etpt.id AND etpt.prty_id = pt.id;\\012\\011\\011\\012\\011\\011\\011if v_type_id_prop IS NOT NULL then\\012\\011\\011\\011\\011-- find material type id of the material which consists the entity's property value\\012\\011\\011\\011\\011select entity.maty_id into v_type_id \\012\\011\\011\\011\\011  from materials entity\\012\\011\\011\\011\\011 where NEW.mate_prop_id = entity.id;\\012\\011\\011\\011\\011if v_type_id != v_type_id_prop then\\012\\011\\011\\011\\011\\011RAISE EXCEPTION 'Insert/Update of property value referencing material (id: %) failed, as referenced material type is different than expected (id %, expected id: %).', \\012\\011\\011\\011\\011\\011\\011\\011\\011\\011\\011\\011\\011 NEW.mate_prop_id, v_type_id, v_type_id_prop;\\012\\011\\011\\011\\011end if;\\012\\011\\011\\011end if;\\012   end if;\\012   RETURN NEW;\\012END;\\012$$ LANGUAGE 'plpgsql';\\012\\012CREATE TRIGGER EXPERIMENT_PROPERTY_WITH_MATERIAL_DATA_TYPE_CHECK BEFORE INSERT OR UPDATE ON experiment_properties\\012    FOR EACH ROW EXECUTE PROCEDURE EXPERIMENT_PROPERTY_WITH_MATERIAL_DATA_TYPE_CHECK();\\012       \\012-- -------\\012-- remove the reminescents of the OBSERVABLE_TYPE\\012-- -------\\012\\012ALTER TABLE data\\012\\011DROP CONSTRAINT data_obty_fk;\\012\\012ALTER TABLE data_set_types\\012\\011DROP CONSTRAINT obty_pk;\\012\\012ALTER TABLE data_set_types\\012\\011ADD CONSTRAINT dsty_pk PRIMARY KEY (id);\\012\\012ALTER TABLE data\\012\\011ADD CONSTRAINT data_dsty_fk FOREIGN KEY (dsty_id) REFERENCES data_set_types(id);\\012\\012ALTER TABLE data_set_types\\012\\011DROP CONSTRAINT obty_bk_uk;\\012\\012ALTER TABLE data_set_types\\012\\011DROP CONSTRAINT obty_dbin_fk;\\012\\012ALTER TABLE data_set_types\\012\\011ADD CONSTRAINT dsty_bk_uk UNIQUE (code, dbin_id);\\012\\012ALTER TABLE data_set_types\\012\\011ADD CONSTRAINT dsty_dbin_fk FOREIGN KEY (dbin_id) REFERENCES database_instances(id);\\012\\012DROP INDEX data_obty_fk_i;\\012\\012CREATE INDEX data_dsty_fk_i ON data(dsty_id);\\012	\N
+./sourceTest/sql/postgresql/059/017=database_version_logs.tsv:030	source/sql/postgresql/migration/migration-029-030.sql	SUCCESS	2009-03-23 15:34:44.72	-- -------\\012-- add modification_timestamp field to allow edition with Hibernate\\012-- -------\\012ALTER TABLE data\\012\\011ADD COLUMN modification_timestamp TIME_STAMP DEFAULT CURRENT_TIMESTAMP;\\012ALTER TABLE experiment_types\\012\\011ADD COLUMN modification_timestamp TIME_STAMP DEFAULT CURRENT_TIMESTAMP;\\012ALTER TABLE sample_types\\012\\011ADD COLUMN modification_timestamp TIME_STAMP DEFAULT CURRENT_TIMESTAMP;\\012ALTER TABLE material_types\\012\\011ADD COLUMN modification_timestamp TIME_STAMP DEFAULT CURRENT_TIMESTAMP;\\012ALTER TABLE data_set_types\\012\\011ADD COLUMN modification_timestamp TIME_STAMP DEFAULT CURRENT_TIMESTAMP;\\012ALTER TABLE controlled_vocabularies\\012\\011ADD COLUMN modification_timestamp TIME_STAMP DEFAULT CURRENT_TIMESTAMP;\\012-- -------\\012-- add properties to data sets\\012-- -------\\012CREATE TABLE DATA_SET_PROPERTIES (ID TECH_ID NOT NULL,DS_ID TECH_ID NOT NULL,DSTPT_ID TECH_ID NOT NULL,VALUE GENERIC_VALUE,CVTE_ID TECH_ID, MATE_PROP_ID TECH_ID, PERS_ID_REGISTERER TECH_ID NOT NULL,REGISTRATION_TIMESTAMP TIME_STAMP_DFL NOT NULL DEFAULT CURRENT_TIMESTAMP, MODIFICATION_TIMESTAMP TIME_STAMP DEFAULT CURRENT_TIMESTAMP);\\012CREATE TABLE DATA_SET_TYPE_PROPERTY_TYPES (ID TECH_ID NOT NULL,DSTY_ID TECH_ID NOT NULL,PRTY_ID TECH_ID NOT NULL,IS_MANDATORY BOOLEAN_CHAR NOT NULL DEFAULT 'F',IS_MANAGED_INTERNALLY BOOLEAN_CHAR NOT NULL DEFAULT 'F',PERS_ID_REGISTERER TECH_ID NOT NULL,REGISTRATION_TIMESTAMP TIME_STAMP_DFL NOT NULL DEFAULT CURRENT_TIMESTAMP);\\012\\012CREATE SEQUENCE DATA_SET_PROPERTY_ID_SEQ;\\012CREATE SEQUENCE DSTPT_ID_SEQ;\\012\\012ALTER TABLE DATA_SET_TYPE_PROPERTY_TYPES ADD CONSTRAINT DSTPT_PK PRIMARY KEY(ID);\\012ALTER TABLE DATA_SET_PROPERTIES ADD CONSTRAINT DSPR_PK PRIMARY KEY(ID);\\012\\012ALTER TABLE DATA_SET_TYPE_PROPERTY_TYPES ADD CONSTRAINT DSTPT_BK_UK UNIQUE(DSTY_ID,PRTY_ID);\\012ALTER TABLE DATA_SET_PROPERTIES ADD CONSTRAINT DSPR_BK_UK UNIQUE(DS_ID,DSTPT_ID);\\012\\012\\012ALTER TABLE DATA_SET_TYPE_PROPERTY_TYPES ADD CONSTRAINT DSTPT_DSTY_FK FOREIGN KEY (DSTY_ID) REFERENCES DATA_SET_TYPES(ID);\\012ALTER TABLE DATA_SET_TYPE_PROPERTY_TYPES ADD CONSTRAINT DSTPT_PERS_FK FOREIGN KEY (PERS_ID_REGISTERER) REFERENCES PERSONS(ID);\\012ALTER TABLE DATA_SET_TYPE_PROPERTY_TYPES ADD CONSTRAINT DSTPT_PRTY_FK FOREIGN KEY (PRTY_ID) REFERENCES PROPERTY_TYPES(ID);\\012ALTER TABLE DATA_SET_PROPERTIES ADD CONSTRAINT DSPR_CVTE_FK FOREIGN KEY (CVTE_ID) REFERENCES CONTROLLED_VOCABULARY_TERMS(ID);\\012ALTER TABLE DATA_SET_PROPERTIES ADD CONSTRAINT DSPR_DSTPT_FK FOREIGN KEY (DSTPT_ID) REFERENCES DATA_SET_TYPE_PROPERTY_TYPES(ID) ON DELETE CASCADE;\\012ALTER TABLE DATA_SET_PROPERTIES ADD CONSTRAINT DSPR_DS_FK FOREIGN KEY (DS_ID) REFERENCES DATA(ID);\\012ALTER TABLE DATA_SET_PROPERTIES ADD CONSTRAINT DSPR_PERS_FK FOREIGN KEY (PERS_ID_REGISTERER) REFERENCES PERSONS(ID);\\012ALTER TABLE DATA_SET_PROPERTIES ADD CONSTRAINT DSPR_MAPR_FK FOREIGN KEY (MATE_PROP_ID) REFERENCES MATERIALS(ID);\\012\\012ALTER TABLE DATA_SET_PROPERTIES ADD CONSTRAINT DSPR_CK CHECK \\012\\011((VALUE IS NOT NULL AND CVTE_ID IS NULL AND MATE_PROP_ID IS NULL) OR \\012\\011 (VALUE IS NULL AND CVTE_ID IS NOT NULL AND MATE_PROP_ID IS NULL) OR\\012\\011 (VALUE IS NULL AND CVTE_ID IS NULL AND MATE_PROP_ID IS NOT NULL)\\012\\011);\\012\\012CREATE INDEX DSPR_CVTE_FK_I ON DATA_SET_PROPERTIES (CVTE_ID);\\012CREATE INDEX DSPR_DSTPT_FK_I ON DATA_SET_PROPERTIES (DSTPT_ID);\\012CREATE INDEX DSPR_DS_FK_I ON DATA_SET_PROPERTIES (DS_ID);\\012CREATE INDEX DSPR_PERS_FK_I ON DATA_SET_PROPERTIES (PERS_ID_REGISTERER);\\012CREATE INDEX DSTPT_DSTY_FK_I ON DATA_SET_TYPE_PROPERTY_TYPES (DSTY_ID);\\012CREATE INDEX DSTPT_PERS_FK_I ON DATA_SET_TYPE_PROPERTY_TYPES (PERS_ID_REGISTERER);\\012CREATE INDEX DSTPT_PRTY_FK_I ON DATA_SET_TYPE_PROPERTY_TYPES (PRTY_ID);\\012\\012CREATE OR REPLACE FUNCTION DATA_SET_PROPERTY_WITH_MATERIAL_DATA_TYPE_CHECK() RETURNS trigger AS $$\\012DECLARE\\012   v_type_id  CODE;\\012   v_type_id_prop  CODE;\\012BEGIN\\012   if NEW.mate_prop_id IS NOT NULL then\\012\\011\\011\\011-- find material type id of the property type \\012\\011\\011\\011select pt.maty_prop_id into v_type_id_prop \\012\\011\\011\\011  from data_set_type_property_types dstpt, property_types pt \\012\\011\\011\\011 where NEW.dstpt_id = dstpt.id AND dstpt.prty_id = pt.id;\\012\\011\\011\\012\\011\\011\\011if v_type_id_prop IS NOT NULL then\\012\\011\\011\\011\\011-- find material type id of the material which consists the entity's property value\\012\\011\\011\\011\\011select entity.maty_id into v_type_id \\012\\011\\011\\011\\011  from materials entity\\012\\011\\011\\011\\011 where NEW.mate_prop_id = entity.id;\\012\\011\\011\\011\\011if v_type_id != v_type_id_prop then\\012\\011\\011\\011\\011\\011RAISE EXCEPTION 'Insert/Update of property value referencing material (id: %) failed, as referenced material type is different than expected (id %, expected id: %).', \\012\\011\\011\\011\\011\\011\\011\\011\\011\\011\\011\\011\\011 NEW.mate_prop_id, v_type_id, v_type_id_prop;\\012\\011\\011\\011\\011end if;\\012\\011\\011\\011end if;\\012   end if;\\012   RETURN NEW;\\012END;\\012$$ LANGUAGE 'plpgsql';\\012\\012CREATE TRIGGER DATA_SET_PROPERTY_WITH_MATERIAL_DATA_TYPE_CHECK BEFORE INSERT OR UPDATE ON data_set_properties\\012    FOR EACH ROW EXECUTE PROCEDURE DATA_SET_PROPERTY_WITH_MATERIAL_DATA_TYPE_CHECK();   \\012	\N
+./sourceTest/sql/postgresql/059/017=database_version_logs.tsv:032	source/sql/postgresql/migration/migration-031-032.sql	SUCCESS	2009-04-09 09:36:36.2	-- -------\\012-- Modify MATERIAL_BATCHES\\012-- -------\\012\\012ALTER TABLE material_batches\\012    DROP COLUMN proc_id;\\012\\012-- -------\\012-- Modify SAMPLES\\012-- -------\\012\\012ALTER TABLE samples\\012    ADD COLUMN expe_id tech_id;\\012\\012ALTER TABLE samples\\012    ADD CONSTRAINT samp_expe_fk FOREIGN KEY (expe_id) REFERENCES experiments(id);\\012\\012CREATE INDEX samp_expe_fk_i ON samples USING btree (expe_id);\\012\\012-- relink samples directly to experiments\\012\\012UPDATE samples\\012SET expe_id = (SELECT e.id FROM experiments e, procedures p, sample_inputs si \\012               WHERE si.samp_id = samples.id AND si.proc_id = p.id AND p.expe_id = e.id AND e.inva_id IS NULL);\\012\\012\\012-- -------\\012-- Modify DATA\\012-- -------\\012\\012ALTER TABLE data\\012    ADD COLUMN expe_id tech_id;\\012\\012ALTER TABLE data\\012    ADD CONSTRAINT data_expe_fk FOREIGN KEY (expe_id) REFERENCES experiments(id);\\012\\012CREATE INDEX data_expe_fk_i ON data USING btree (expe_id);\\012\\012UPDATE data\\012SET expe_id = (SELECT e.id FROM experiments e, procedures p \\012               WHERE data.proc_id_produced_by = p.id AND p.expe_id = e.id);\\012\\012ALTER TABLE data\\012    ALTER COLUMN expe_id SET NOT NULL;\\012\\012ALTER TABLE data\\012    DROP COLUMN proc_id_produced_by;\\012\\012-- -------\\012-- Drop PROCEDURES, PROCEDURE_TYPES, and SAMPLE_INPUTS\\012-- -------\\012\\012DROP TABLE sample_inputs;\\012DROP TABLE procedures;\\012DROP TABLE procedure_types;\\012\\012DROP SEQUENCE procedure_id_seq;\\012DROP SEQUENCE procedure_type_id_seq;\\012\\012-- -------\\012-- Add CODE_SEQ\\012-- -------\\012\\012CREATE SEQUENCE CODE_SEQ;\\012\\012-- -------\\012-- Add new columns to DATA_STORES\\012-- -------\\012\\012ALTER TABLE data_stores\\012    ADD COLUMN remote_url character varying(250),\\012    ADD COLUMN session_token character varying(50),\\012    ADD COLUMN modification_timestamp time_stamp DEFAULT now();\\012\\012UPDATE data_stores\\012SET remote_url = '', session_token='';\\012\\012ALTER TABLE data_stores\\012    ALTER COLUMN remote_url SET NOT NULL,\\012    ALTER COLUMN session_token SET NOT NULL;\\012\\012-- -------\\012-- Drop foreign keys onto DATA_STORES\\012-- -------\\012\\012ALTER TABLE database_instances\\012    DROP COLUMN dast_id;\\012\\012ALTER TABLE groups\\012    DROP COLUMN dast_id;\\012\\012ALTER TABLE projects\\012    DROP COLUMN dast_id;\\012\\012ALTER TABLE experiments\\012    DROP COLUMN dast_id;\\012\\012-- -------\\012-- Add foreign key from DATA onto DATA_STORES\\012-- -------\\012\\012ALTER TABLE data\\012    ADD COLUMN dast_id tech_id;\\012\\012ALTER TABLE data\\012    ADD CONSTRAINT data_dast_fk FOREIGN KEY (dast_id) REFERENCES data_stores(id);\\012\\012UPDATE data\\012SET dast_id = (select id from data_stores where code = 'STANDARD');\\012\\012ALTER TABLE data\\012    ALTER COLUMN dast_id SET NOT NULL;\\012\\012\\012------------------------------------------------------------------------------------\\012--  Purpose:  Replace trigger SAMPLE_CODE_UNIQUENESS_CHECK \\012------------------------------------------------------------------------------------\\012\\012CREATE OR REPLACE FUNCTION SAMPLE_CODE_UNIQUENESS_CHECK() RETURNS trigger AS $$\\012DECLARE\\012   counter  INTEGER;\\012BEGIN\\012    LOCK TABLE samples IN EXCLUSIVE MODE;\\012    IF (NEW.samp_id_part_of is NULL) THEN\\012        IF (NEW.dbin_id is not NULL) THEN\\012            SELECT count(*) into counter FROM samples \\012                where id != NEW.id and code = NEW.code and samp_id_part_of is NULL and dbin_id = NEW.dbin_id;\\012            IF (counter > 0) THEN\\012                RAISE EXCEPTION 'Insert/Update of Sample (Code: %) failed because database instance sample with the same code already exists.', NEW.code;\\012            END IF;\\012        ELSIF (NEW.grou_id is not NULL) THEN\\012            SELECT count(*) into counter FROM samples \\012                where id != NEW.id and code = NEW.code and samp_id_part_of is NULL and grou_id = NEW.grou_id;\\012            IF (counter > 0) THEN\\012                RAISE EXCEPTION 'Insert/Update of Sample (Code: %) failed because group sample with the same code already exists.', NEW.code;\\012            END IF;\\012        END IF;\\012        ELSE\\012        IF (NEW.dbin_id is not NULL) THEN\\012            SELECT count(*) into counter FROM samples \\012                where id != NEW.id and code = NEW.code and samp_id_part_of = NEW.samp_id_part_of and dbin_id = NEW.dbin_id;\\012            IF (counter > 0) THEN\\012                RAISE EXCEPTION 'Insert/Update of Sample (Code: %) failed because database instance sample with the same code and being the part of the same parent already exists.', NEW.code;\\012            END IF;\\012        ELSIF (NEW.grou_id is not NULL) THEN\\012            SELECT count(*) into counter FROM samples \\012                where id != NEW.id and code = NEW.code and samp_id_part_of = NEW.samp_id_part_of and grou_id = NEW.grou_id;\\012            IF (counter > 0) THEN\\012                RAISE EXCEPTION 'Insert/Update of Sample (Code: %) failed because group sample with the same code and being the part of the same parent already exists.', NEW.code;\\012            END IF;\\012        END IF;\\012        END IF;   \\012   RETURN NEW;\\012END;\\012$$ LANGUAGE 'plpgsql';\\012\\012\\012\\012	\N
+./sourceTest/sql/postgresql/059/017=database_version_logs.tsv:034	source/sql/postgresql/migration/migration-033-034.sql	SUCCESS	2009-05-26 08:32:49.935	------------------------------------------------------------------------------------\\012-- Create sequence for generating permanent identifiers starting with nextval of existing dataset sequence.\\012------------------------------------------------------------------------------------\\012CREATE FUNCTION CREATE_SEQUENCE(EXISTING_SEQUENCE VARCHAR, NEW_SEQUENCE VARCHAR) RETURNS VOID AS $$\\012DECLARE\\012  CURR_SEQ_VAL   INTEGER;\\012BEGIN\\012  SELECT INTO CURR_SEQ_VAL NEXTVAL(EXISTING_SEQUENCE);\\012  EXECUTE 'CREATE SEQUENCE ' || NEW_SEQUENCE || ' START WITH ' || CURR_SEQ_VAL;\\012  RETURN;\\012END;\\012$$ LANGUAGE 'plpgsql';\\012\\012SELECT CREATE_SEQUENCE('DATA_ID_SEQ', 'PERM_ID_SEQ');\\012DROP FUNCTION CREATE_SEQUENCE(VARCHAR, VARCHAR);\\012\\012------------------------------------------------------------------------------------\\012-- Add perm_id columns to samples and experiments.\\012------------------------------------------------------------------------------------\\012ALTER TABLE SAMPLES ADD COLUMN PERM_ID CODE;\\012ALTER TABLE EXPERIMENTS ADD COLUMN PERM_ID CODE;\\012\\012UPDATE SAMPLES SET PERM_ID = to_char(registration_timestamp,'YYYYMMDDHHSSMS') || '-' || NEXTVAL('PERM_ID_SEQ');\\012UPDATE EXPERIMENTS SET PERM_ID = to_char(registration_timestamp,'YYYYMMDDHHSSMS') || '-' || NEXTVAL('PERM_ID_SEQ');\\012ALTER TABLE SAMPLES ALTER COLUMN PERM_ID SET NOT NULL;\\012ALTER TABLE EXPERIMENTS ALTER COLUMN PERM_ID SET NOT NULL;\\012ALTER TABLE SAMPLES ADD CONSTRAINT SAMP_PI_UK UNIQUE(PERM_ID);\\012ALTER TABLE EXPERIMENTS ADD CONSTRAINT EXPE_PI_UK UNIQUE(PERM_ID);\\012\\012\\012------------------------------------------------------------------------------------\\012-- Add column is_chosen_from_list to controlled_vocabularies.\\012------------------------------------------------------------------------------------\\012ALTER TABLE controlled_vocabularies ADD COLUMN is_chosen_from_list BOOLEAN_CHAR NOT NULL DEFAULT TRUE;\\012ALTER TABLE controlled_vocabularies ADD COLUMN source_uri CHARACTER VARYING(250);\\012------------------------------------------------------------------------------------\\012-- Modify Data table - remove arc connection between Sample and Data table, use a flag instead\\012------------------------------------------------------------------------------------\\012\\012-- add new columns\\012\\012ALTER TABLE data\\012    ADD COLUMN is_derived boolean_char;\\012ALTER TABLE data\\012    ADD COLUMN samp_id tech_id;\\012\\012-- update values in new columns\\012\\012UPDATE data\\012    SET is_derived = (samp_id_derived_from IS NOT NULL); \\012UPDATE data\\012    SET samp_id = samp_id_derived_from \\012    WHERE is_derived = 'TRUE';\\012UPDATE data\\012    SET samp_id = samp_id_acquired_from \\012    WHERE is_derived = 'FALSE';\\012\\012-- add constraints and indexes to new columns\\012\\012ALTER TABLE data\\012    ALTER COLUMN is_derived SET NOT NULL;\\012ALTER TABLE data\\012    ALTER COLUMN samp_id SET NOT NULL;   \\012ALTER TABLE data\\012    ADD CONSTRAINT data_samp_fk FOREIGN KEY (samp_id) REFERENCES samples (id);\\012CREATE INDEX data_samp_fk_i ON data USING btree (samp_id);\\012\\012-- remove old columns\\012\\012ALTER TABLE data\\012    DROP COLUMN samp_id_acquired_from;\\012ALTER TABLE data\\012    DROP COLUMN samp_id_derived_from;\\012    \\012------------------------------------------------------------------------------------\\012-- Granting SELECT privilege to group openbis_readonly\\012------------------------------------------------------------------------------------\\012\\012GRANT SELECT ON SEQUENCE attachment_content_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE attachment_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE code_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE controlled_vocabulary_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE cvte_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE data_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE data_set_property_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE data_set_relationship_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE data_set_type_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE data_store_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE data_type_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE database_instance_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE dstpt_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE etpt_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE event_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE experiment_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE experiment_property_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE experiment_type_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE file_format_type_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE group_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE invalidation_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE locator_type_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE material_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE material_property_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE material_type_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE mtpt_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE perm_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE person_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE project_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE property_type_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE role_assignment_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE sample_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE sample_property_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE sample_type_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE stpt_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE attachment_contents TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE attachments TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE controlled_vocabularies TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE controlled_vocabulary_terms TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE data TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE data_set_properties TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE data_set_relationships TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE data_set_type_property_types TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE data_set_types TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE data_stores TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE data_types TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE database_instances TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE database_version_logs TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE events TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE experiment_properties TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE experiment_type_property_types TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE experiment_types TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE experiments TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE external_data TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE file_format_types TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE groups TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE invalidations TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE locator_types TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE material_properties TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE material_type_property_types TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE material_types TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE materials TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE persons TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE projects TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE property_types TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE role_assignments TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE sample_properties TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE sample_type_property_types TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE sample_types TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE samples TO GROUP OPENBIS_READONLY;\\012\\012------------------------------------------------------------------------------------\\012-- Delete MATERIAL_BATCHES table\\012------------------------------------------------------------------------------------\\012\\012-- WARNING: Potential data lost!!!\\012-- WARNING: Potential data lost!!!\\012-- WARNING: Potential data lost!!!\\012\\012DROP TABLE SAMPLE_MATERIAL_BATCHES;\\012DROP TABLE MATERIAL_BATCHES;\\012DROP SEQUENCE MATERIAL_BATCH_ID_SEQ;\\012\\012------------------------------------------------------------------------------------\\012-- Delete MATE_ID_INHIBITOR_OF from table MATERIALS\\012------------------------------------------------------------------------------------\\012\\012-- WARNING: Potential data lost!!!\\012-- WARNING: Potential data lost!!!\\012-- WARNING: Potential data lost!!!\\012\\012ALTER TABLE MATERIALS DROP COLUMN MATE_ID_INHIBITOR_OF;\\012	\N
+./sourceTest/sql/postgresql/059/017=database_version_logs.tsv:041	source/sql/postgresql/migration/migration-040-041.sql	SUCCESS	2009-09-14 13:48:57.539	-- Create FILTERS table\\012\\012CREATE TABLE FILTERS (ID TECH_ID NOT NULL, DBIN_ID TECH_ID NOT NULL, NAME VARCHAR(200) NOT NULL, DESCRIPTION DESCRIPTION_1000,REGISTRATION_TIMESTAMP TIME_STAMP_DFL NOT NULL DEFAULT CURRENT_TIMESTAMP, PERS_ID_REGISTERER TECH_ID NOT NULL, MODIFICATION_TIMESTAMP TIME_STAMP DEFAULT CURRENT_TIMESTAMP, EXPRESSION VARCHAR(2000) NOT NULL, IS_PUBLIC BOOLEAN NOT NULL, GRID_ID VARCHAR(200) NOT NULL);\\012CREATE SEQUENCE FILTER_ID_SEQ;\\012ALTER TABLE FILTERS ADD CONSTRAINT FILT_PK PRIMARY KEY(ID);\\012ALTER TABLE FILTERS ADD CONSTRAINT FILT_BK_UK UNIQUE(NAME, DBIN_ID, GRID_ID);\\012ALTER TABLE FILTERS ADD CONSTRAINT FILT_PERS_FK FOREIGN KEY (PERS_ID_REGISTERER) REFERENCES PERSONS(ID);\\012ALTER TABLE FILTERS ADD CONSTRAINT FILT_DBIN_FK FOREIGN KEY (DBIN_ID) REFERENCES DATABASE_INSTANCES(ID);\\012CREATE INDEX FILT_PERS_FK_I ON FILTERS (PERS_ID_REGISTERER);\\012CREATE INDEX FILT_DBIN_FK_I ON FILTERS (DBIN_ID);\\012GRANT SELECT ON SEQUENCE filter_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE filters TO GROUP OPENBIS_READONLY;\\012\\012-- Add missing foreign key to role assignments authorization group\\012ALTER TABLE ROLE_ASSIGNMENTS ADD CONSTRAINT ROAS_AG_FK_GRANTEE FOREIGN KEY (AG_ID_GRANTEE) REFERENCES AUTHORIZATION_GROUPS(ID);\\012\\012--------------------------------------------------------------------------------------------------\\012-- Modify dataset connections:\\012-- 1. connection with sample shouldn't be mandatory any more\\012-- 2. introduce an arc condition that dataset cannot be connected with a sample and a parent dataset at the same time\\012--------------------------------------------------------------------------------------------------\\012\\012-- Weaken data-sample connection constraint - allow dataset to have no connection with sample\\012ALTER TABLE data ALTER COLUMN samp_id DROP NOT NULL;\\012\\012-- Remove data-sample connection for datasets that have a parent\\012\\012UPDATE data \\012   SET samp_id = NULL \\012 WHERE id IN (SELECT DISTINCT data_id_child FROM data_set_relationships);\\012\\012-- With PostgreSQL 8.4 one can check that before migration there were no cycles in dataset relationships:\\012--\\012-- WITH RECURSIVE data_set_parents(id, parent_ids, cycle) AS (\\012--         SELECT  r.data_id_child AS id, \\012--                 ARRAY[CAST (r.data_id_parent AS bigint)] AS parent_ids, \\012--                 false AS cycle \\012--         FROM data_set_relationships r\\012--     UNION ALL\\012--         SELECT  r.data_id_child,\\012--                 CAST (r.data_id_parent AS bigint) || p.parent_ids,\\012--                 r.data_id_child = ANY(p.parent_ids)\\012--         FROM data_set_relationships r, data_set_parents p\\012--         WHERE r.data_id_parent = p.id AND NOT cycle\\012-- )\\012-- SELECT count(*) AS cycles FROM data_set_parents WHERE cycle = true;\\012\\012---------------------------------------------------------------------------------------------------\\012--  Purpose:  Create DEFERRED triggers:\\012--            * check_dataset_relationships_on_data_table_modification,\\012--            * check_dataset_relationships_on_relationships_table_modification.\\012--            They check that after all modifications of database (just before commit) \\012--            if 'data'/'data_set_relationships' tables are among modified tables \\012--            dataset is not connected with a sample and a parent dataset at the same time.\\012--            This connections are held in two different tables so simple immediate trigger \\012--            with arc check cannot be used and we need two deferred triggers.\\012----------------------------------------------------------------------------------------------------\\012\\012-- trigger for 'data' table\\012\\012CREATE OR REPLACE FUNCTION check_dataset_relationships_on_data_table_modification() RETURNS trigger AS $$\\012DECLARE\\012\\011counter\\011INTEGER;\\012BEGIN\\012\\011-- if there is a connection with a Sample there should not be any connection with a parent Data Set\\012\\011IF (NEW.samp_id IS NOT NULL) THEN\\012\\011\\011-- count number of parents\\012\\011\\011SELECT count(*) INTO counter \\012\\011\\011\\011FROM data_set_relationships \\012\\011\\011\\011WHERE data_id_child = OLD.id;\\012\\011\\011IF (counter > 0) THEN\\012\\011\\011\\011RAISE EXCEPTION 'Insert/Update of Data Set (Code: %) failed because it cannot be connected with a Sample and a parent Data Set at the same time.', OLD.code;\\012\\011\\011END IF;\\012\\011END IF;\\012  RETURN NEW;\\012END;\\012$$ LANGUAGE 'plpgsql';\\012\\012CREATE CONSTRAINT TRIGGER check_dataset_relationships_on_data_table_modification \\012  AFTER INSERT OR UPDATE ON data\\012\\011DEFERRABLE INITIALLY DEFERRED\\012\\011FOR EACH ROW \\012\\011EXECUTE PROCEDURE check_dataset_relationships_on_data_table_modification();\\012\\012-- trigger for 'data_set_relationships'\\012\\012CREATE OR REPLACE FUNCTION check_dataset_relationships_on_relationships_table_modification() RETURNS trigger AS $$\\012DECLARE\\012\\011counter\\011INTEGER;\\012\\011sample_id\\011TECH_ID;\\012\\011data_code\\011CODE;\\012BEGIN\\012\\011-- child will have a parent added so it should not be connected with any sample\\012\\011SELECT samp_id, code INTO sample_id, data_code \\012\\011\\011FROM data \\012\\011\\011WHERE id = NEW.data_id_child;\\012\\011IF (sample_id IS NOT NULL) THEN\\012\\011\\011RAISE EXCEPTION 'Insert/Update of Data Set (Code: %) failed because it cannot be connected to a Sample and to a parent Data Set at the same time.', data_code;\\012\\011END IF;\\012\\011RETURN NEW;\\012END;\\012$$ LANGUAGE 'plpgsql';\\012  \\012CREATE CONSTRAINT TRIGGER check_dataset_relationships_on_relationships_table_modification \\012  AFTER INSERT OR UPDATE ON data_set_relationships\\012\\011DEFERRABLE INITIALLY DEFERRED\\012\\011FOR EACH ROW \\012\\011EXECUTE PROCEDURE check_dataset_relationships_on_relationships_table_modification();\\012	\N
+./sourceTest/sql/postgresql/059/017=database_version_logs.tsv:053	source/sql/postgresql/migration/migration-052-053.sql	SUCCESS	2010-06-08 15:27:55.032	-- Migration from 052 to 053\\012\\012-- Change code uniqueness check for samples of specific type.\\012-- If sample_types.is_subcode_unique flag is set to 'true', additional check is performed \\012-- on codes of samples of the type. Subcodes will have to be unique as well.\\012\\012ALTER TABLE sample_types ADD COLUMN is_subcode_unique boolean_char NOT NULL DEFAULT false;\\012\\012CREATE OR REPLACE FUNCTION SAMPLE_SUBCODE_UNIQUENESS_CHECK() RETURNS trigger AS $$\\012DECLARE\\012   counter  INTEGER;\\012   unique_subcode  BOOLEAN_CHAR;\\012BEGIN\\012  LOCK TABLE samples IN EXCLUSIVE MODE;\\012  \\012  SELECT is_subcode_unique into unique_subcode FROM sample_types WHERE id = NEW.saty_id;\\012  \\012  IF (unique_subcode) THEN\\012    IF (NEW.dbin_id is not NULL) THEN\\012\\011\\011\\011SELECT count(*) into counter FROM samples \\012\\011\\011\\011\\011where id != NEW.id and code = NEW.code and saty_id = NEW.saty_id and dbin_id = NEW.dbin_id;\\012\\011\\011\\011IF (counter > 0) THEN\\012\\011\\011\\011\\011RAISE EXCEPTION 'Insert/Update of Sample (Code: %) failed because database instance sample of the same type with the same subcode already exists.', NEW.code;\\012\\011\\011\\011END IF;\\012\\011\\011ELSIF (NEW.grou_id is not NULL) THEN\\012\\011\\011\\011SELECT count(*) into counter FROM samples \\012\\011\\011\\011\\011where id != NEW.id and code = NEW.code and saty_id = NEW.saty_id and grou_id = NEW.grou_id;\\012\\011\\011\\011IF (counter > 0) THEN\\012\\011\\011\\011\\011RAISE EXCEPTION 'Insert/Update of Sample (Code: %) failed because space sample of the same type with the same subcode already exists.', NEW.code;\\012\\011\\011\\011END IF;\\012\\011\\011END IF;\\012  END IF;\\012  \\012  RETURN NEW;\\012END;\\012$$ LANGUAGE 'plpgsql';\\012\\012CREATE TRIGGER SAMPLE_SUBCODE_UNIQUENESS_CHECK BEFORE INSERT OR UPDATE ON SAMPLES\\012    FOR EACH ROW EXECUTE PROCEDURE SAMPLE_SUBCODE_UNIQUENESS_CHECK();\\012    \\012-- Fixing error messages in old trigger\\012\\012CREATE OR REPLACE FUNCTION SAMPLE_CODE_UNIQUENESS_CHECK() RETURNS trigger AS $$\\012DECLARE\\012   counter  INTEGER;\\012BEGIN\\012  LOCK TABLE samples IN EXCLUSIVE MODE;\\012  \\012\\011  IF (NEW.samp_id_part_of is NULL) THEN\\012\\011\\011  IF (NEW.dbin_id is not NULL) THEN\\012\\011\\011\\011  SELECT count(*) into counter FROM samples \\012\\011\\011      where id != NEW.id and code = NEW.code and samp_id_part_of is NULL and dbin_id = NEW.dbin_id;\\012        IF (counter > 0) THEN\\012\\011\\011\\011\\011  RAISE EXCEPTION 'Insert/Update of Sample (Code: %) failed because database instance sample with the same code already exists.', NEW.code;\\012        END IF;\\012\\011\\011  ELSIF (NEW.grou_id is not NULL) THEN\\012\\011\\011\\011  SELECT count(*) into counter FROM samples \\012\\011\\011\\011\\011  where id != NEW.id and code = NEW.code and samp_id_part_of is NULL and grou_id = NEW.grou_id;\\012\\011\\011\\011  IF (counter > 0) THEN\\012\\011\\011\\011\\011  RAISE EXCEPTION 'Insert/Update of Sample (Code: %) failed because space sample with the same code already exists.', NEW.code;\\012\\011\\011\\011  END IF;\\012      END IF;\\012    ELSE\\012\\011\\011  IF (NEW.dbin_id is not NULL) THEN\\012\\011\\011\\011  SELECT count(*) into counter FROM samples \\012\\011\\011\\011\\011  where id != NEW.id and code = NEW.code and samp_id_part_of = NEW.samp_id_part_of and dbin_id = NEW.dbin_id;\\012\\011\\011\\011  IF (counter > 0) THEN\\012\\011\\011\\011\\011  RAISE EXCEPTION 'Insert/Update of Sample (Code: %) failed because database instance sample with the same code and being the part of the same container already exists.', NEW.code;\\012\\011\\011\\011  END IF;\\012\\011\\011  ELSIF (NEW.grou_id is not NULL) THEN\\012\\011\\011\\011  SELECT count(*) into counter FROM samples \\012\\011\\011\\011\\011  where id != NEW.id and code = NEW.code and samp_id_part_of = NEW.samp_id_part_of and grou_id = NEW.grou_id;\\012\\011\\011\\011  IF (counter > 0) THEN\\012\\011\\011\\011\\011  RAISE EXCEPTION 'Insert/Update of Sample (Code: %) failed because space sample with the same code and being the part of the same container already exists.', NEW.code;\\012\\011\\011\\011  END IF;\\012\\011\\011  END IF;\\012     END IF;   \\012  \\012  RETURN NEW;\\012END;\\012$$ LANGUAGE 'plpgsql';\\012	\N
+./sourceTest/sql/postgresql/059/017=database_version_logs.tsv:054	source/sql/postgresql/migration/migration-053-054.sql	SUCCESS	2010-07-27 11:30:46.766	-- Migration from 053 to 054\\012\\012\\012-- Add RELATIONSHIP_TYPES table\\012CREATE TABLE relationship_types (id TECH_ID NOT NULL, code CODE NOT NULL, label COLUMN_LABEL, parent_label COLUMN_LABEL, child_label COLUMN_LABEL, description DESCRIPTION_2000, registration_timestamp TIME_STAMP_DFL NOT NULL DEFAULT CURRENT_TIMESTAMP, pers_id_registerer TECH_ID NOT NULL, is_managed_internally BOOLEAN_CHAR NOT NULL DEFAULT 'F', is_internal_namespace BOOLEAN_CHAR NOT NULL DEFAULT 'F', dbin_id TECH_ID NOT NULL);\\012\\012-- Add SAMPLE_RELATIONSHIPS table\\012CREATE TABLE sample_relationships (id TECH_ID NOT NULL, sample_id_parent TECH_ID NOT NULL, relationship_id TECH_ID NOT NULL, sample_id_child TECH_ID NOT NULL);\\012\\012-- Add/update constraints\\012ALTER TABLE relationship_types ADD CONSTRAINT rety_pk PRIMARY KEY (id);\\012ALTER TABLE relationship_types ADD CONSTRAINT rety_uk UNIQUE(code,dbin_id);\\012ALTER TABLE sample_relationships ADD CONSTRAINT sare_pk PRIMARY KEY (id);\\012ALTER TABLE sample_relationships ADD CONSTRAINT sare_bk_uk UNIQUE(sample_id_child,sample_id_parent,relationship_id);\\012ALTER TABLE sample_relationships ADD CONSTRAINT sare_data_fk_child FOREIGN KEY (sample_id_child) REFERENCES samples(id) ON DELETE CASCADE;\\012ALTER TABLE sample_relationships ADD CONSTRAINT sare_data_fk_parent FOREIGN KEY (sample_id_parent) REFERENCES samples(id) ON DELETE CASCADE;\\012ALTER TABLE sample_relationships ADD CONSTRAINT sare_data_fk_relationship FOREIGN KEY (relationship_id) REFERENCES relationship_types(id);\\012\\012-- Create index\\012CREATE INDEX sare_data_fk_i_child ON sample_relationships (sample_id_child);\\012CREATE INDEX sare_data_fk_i_parent ON sample_relationships (sample_id_parent);\\012CREATE INDEX sare_data_fk_i_relationship ON sample_relationships (relationship_id);\\012\\012-- Create sequence for RELATIONSHIP_TYPES\\012CREATE SEQUENCE RELATIONSHIP_TYPE_ID_SEQ;\\012CREATE SEQUENCE SAMPLE_RELATIONSHIP_ID_SEQ;\\012\\012-- Create initial relationships\\012insert into relationship_types\\012(id, \\012code, \\012label, \\012parent_label, \\012child_label, \\012description, \\012pers_id_registerer, \\012is_managed_internally, \\012is_internal_namespace, \\012dbin_id) \\012values\\012(\\012nextval('RELATIONSHIP_TYPE_ID_SEQ'),\\012'PARENT_CHILD',\\012'Parent - Child', \\012'Parent', \\012'Child', \\012'Parent - Child relationship', \\012(select id from persons where user_id ='system'), \\012'T', \\012'T', \\012(select id from database_instances where is_original_source = 'T')\\012);\\012\\012insert into relationship_types\\012(id, \\012code, \\012label, \\012parent_label, \\012child_label, \\012description, \\012pers_id_registerer, \\012is_managed_internally, \\012is_internal_namespace, \\012dbin_id) \\012values\\012(\\012nextval('RELATIONSHIP_TYPE_ID_SEQ'),\\012'PLATE_CONTROL_LAYOUT',\\012'Plate - Control Layout', \\012'Plate', \\012'Control Layout', \\012'Plate - Control Layout relationship', \\012(select id from persons where user_id ='system'), \\012'T', \\012'T', \\012(select id from database_instances where is_original_source = 'T')\\012); \\012\\012\\012-- Migrate sample relationships to new schema\\012INSERT INTO sample_relationships (id, sample_id_parent,sample_id_child,relationship_id) (select distinct nextval('SAMPLE_RELATIONSHIP_ID_SEQ') as id, s.SAMP_ID_GENERATED_FROM as parent_id, s.ID as child_id, rt.id as relationship_id from samples s, relationship_types rt  WHERE rt.code = 'PARENT_CHILD' and s.SAMP_ID_GENERATED_FROM is not null); \\012INSERT INTO sample_relationships (id, sample_id_parent,sample_id_child,relationship_id) (select distinct nextval('SAMPLE_RELATIONSHIP_ID_SEQ') as id, s.SAMP_ID_CONTROL_LAYOUT as parent_id, s.ID as child_id, rt.id as relationship_id from samples s, relationship_types rt  WHERE rt.code = 'PLATE_CONTROL_LAYOUT' and s.SAMP_ID_CONTROL_LAYOUT is not null);\\012\\012-- Drop old sample relations\\012ALTER TABLE SAMPLES DROP COLUMN SAMP_ID_TOP;\\012ALTER TABLE SAMPLES DROP COLUMN SAMP_ID_GENERATED_FROM;\\012ALTER TABLE SAMPLES DROP COLUMN SAMP_ID_CONTROL_LAYOUT;\\012\\012--------------------------------------------------------------------------------------\\012--------------------------------------------------------------------------------------\\012-- This is a screening specific migration. Nothing will be performed on openBIS databases \\012-- which are not screening specific.\\012-- \\012-- This migration for each existing connection between oligo well, oligo material and gene material\\012-- creates a direct connection between the well and the gene. \\012--------------------------------------------------------------------------------------\\012--------------------------------------------------------------------------------------\\012 \\012\\011\\012CREATE OR REPLACE FUNCTION CONNECT_WELLS_WITH_GENES() RETURNS void AS $$\\012DECLARE\\012\\011counter  int;\\012\\011oligo_well_exists bool;\\012BEGIN\\012\\011--------------------------------------------------\\012\\011-- create a gene property and assign it to oligo well\\012\\011--------------------------------------------------\\012\\011\\012\\011select true \\012\\011into oligo_well_exists\\012\\011from sample_types \\012\\011where code = 'OLIGO_WELL';\\012\\011\\012\\011if oligo_well_exists IS NULL then \\012\\011\\011-- skip migration if there are no oligo wells\\012\\011\\011return;\\012\\011end if;   \\012\\011\\012\\011insert into property_types(\\012\\011\\011id, \\012\\011\\011code, description, label, \\012\\011\\011daty_id,\\012\\011\\011pers_id_registerer,\\012\\011\\011dbin_id,\\012\\011\\011maty_prop_id) \\012\\011values(\\012\\011\\011\\011nextval('PROPERTY_TYPE_ID_SEQ'), \\012\\011\\011\\011'GENE','Inhibited gene','Gene',\\012\\011\\011\\011(select id from data_types where code = 'MATERIAL'), \\012\\011\\011\\011(select id from persons where user_id ='system'), \\012\\011\\011\\011(select id from database_instances where is_original_source = 'T'), \\012\\011\\011\\011(select id from material_types where code = 'GENE')\\012\\011\\011);\\012\\011\\011\\012\\011insert into sample_type_property_types( \\012\\011  id,\\012\\011  saty_id,\\012\\011  prty_id,\\012\\011  is_mandatory,\\012\\011  pers_id_registerer,\\012\\011  ordinal\\012\\011) values(\\012\\011\\011\\011nextval('stpt_id_seq'), \\012\\011\\011\\011(select id from sample_types where code = 'OLIGO_WELL'),\\012\\011\\011\\011(select id from property_types where code = 'GENE'),\\012\\011\\011\\011false,\\012\\011\\011\\011(select id from persons where user_id ='system'),\\012\\011\\011\\011(select max(ordinal)+1 from sample_type_property_types \\012\\011\\011\\011\\011where saty_id = (select id from sample_types where code = 'OLIGO_WELL'))\\012\\011\\011);\\012\\012\\011--------------------------------------------------\\012\\011-- create a gene material property for each oligo well\\012\\011--------------------------------------------------\\012\\011\\011\\012\\011select \\011count(*)\\012\\011into counter\\012\\011from\\012\\011\\011samples well, sample_types well_type, sample_properties well_props, \\012\\011\\011materials well_material, material_properties well_material_props,\\012\\011\\011materials nested_well_material\\012\\011where\\012\\011\\011well_type.code = 'OLIGO_WELL' and\\012\\011\\011-- find 'well_material' assigned to the well\\012\\011\\011well_props.samp_id = well.id and well_material.id = well_props.mate_prop_id and \\012\\011\\011-- additional joins to entity type tables\\012\\011\\011well_type.id = well.saty_id and\\012\\011\\011-- well content material property\\012\\011\\011well_material_props.mate_id = well_material.id and \\012\\011\\011-- material connected to the material in the well (e.g. gene)\\012\\011\\011well_material_props.mate_prop_id = nested_well_material.id and\\012\\011\\011nested_well_material.maty_id = (select id from material_types where code = 'GENE');\\012\\011\\012\\011if counter = 0 then \\012\\011\\011-- skip migration if there are no genes indirectly connected to oligo wells\\012\\011\\011return;\\012\\011end if;   \\012\\012\\011insert into sample_properties(id, samp_id, stpt_id, mate_prop_id, pers_id_registerer) (\\012\\011\\011select \\011nextval('sample_property_id_seq') id, \\012\\011\\011\\011well.id samp_id, \\012\\011\\011\\011(select stpt.id from sample_type_property_types stpt, property_types props where stpt.prty_id = props.id and props.code='GENE') stpt_id,\\012\\011\\011\\011nested_well_material.id mate_prop_id,\\012\\011\\011\\011(select id from persons where user_id ='system') pers_id_registerer \\012\\011\\011from\\012\\011\\011\\011samples well, sample_types well_type, sample_properties well_props, \\012\\011\\011\\011materials well_material, material_properties well_material_props,\\012\\011\\011\\011materials nested_well_material\\012\\011\\011where\\012\\011\\011\\011well_type.code = 'OLIGO_WELL' and\\012\\011\\011\\011-- find 'well_material' assigned to the well\\012\\011\\011\\011well_props.samp_id = well.id and well_material.id = well_props.mate_prop_id and \\012\\011\\011\\011-- additional joins to entity type tables\\012\\011\\011\\011well_type.id = well.saty_id and\\012\\011\\011\\011-- well content material property\\012\\011\\011\\011well_material_props.mate_id = well_material.id and \\012\\011\\011\\011-- material connected to the material in the well (e.g. gene)\\012\\011\\011\\011well_material_props.mate_prop_id = nested_well_material.id and\\012\\011\\011\\011nested_well_material.maty_id = (select id from material_types where code = 'GENE')\\012\\011);\\012\\012END;\\012$$ LANGUAGE 'plpgsql';\\012\\012select CONNECT_WELLS_WITH_GENES();\\012drop function CONNECT_WELLS_WITH_GENES();\\012\\012--------------------------------------------------------------------------------------\\012--------------------------------------------------------------------------------------\\012\\012-- drop dataset triggers\\012\\012DROP TRIGGER check_dataset_relationships_on_data_table_modification ON data;\\012DROP FUNCTION check_dataset_relationships_on_data_table_modification();\\012DROP TRIGGER check_dataset_relationships_on_relationships_table_modification ON data_set_relationships;\\012DROP FUNCTION check_dataset_relationships_on_relationships_table_modification();\\012 \\012\\012\\012\\012\\012\\012\\012\\012	\N
+./sourceTest/sql/postgresql/059/017=database_version_logs.tsv:056	source/sql/postgresql/migration/migration-055-056.sql	SUCCESS	2010-09-10 09:06:20.278	-- Migration from 055 to 056\\012\\012--------------------------------------------------------------------------------------\\012--------------------------------------------------------------------------------------\\012-- Screening specific migration. Nothing will be performed on openBIS databases \\012-- which are not screening specific.\\012--------------------------------------------------------------------------------------\\012--------------------------------------------------------------------------------------\\012\\012CREATE OR REPLACE FUNCTION merge_words(text, text) RETURNS text AS $$\\012DECLARE\\012  BEGIN\\012    IF  character_length($1) > 0 THEN\\012      RETURN $1 || ' ' || $2;\\012    ELSE\\012      RETURN $2;\\012    END IF;\\012  END;\\012$$ LANGUAGE plpgsql;\\012\\012CREATE AGGREGATE merge_words(text)\\012(\\012  SFUNC = merge_words,\\012  STYPE = text\\012);\\012\\012\\012CREATE OR REPLACE FUNCTION REPLACE_GENE_SYMBOL_BY_GENE_ID() RETURNS void AS $$\\012DECLARE\\012\\011counter  int;\\012\\011library_id_assigned_to_gene bool;\\012BEGIN\\012\\011--------------------------------------------------\\012\\011-- create a GENE_SYMBOL property and assign it to GENE\\012\\011--------------------------------------------------\\012\\011\\012\\011select true  \\012\\011into library_id_assigned_to_gene \\012\\011from material_type_property_types mtpt, material_types mt, property_types pt  \\012\\011where mtpt.maty_id = mt.id and mtpt.prty_id = pt.id \\012\\011\\011and mt.code = 'GENE' and pt.code = 'LIBRARY_ID';\\012\\011\\012\\011if library_id_assigned_to_gene IS NULL then \\012\\011\\011-- skip migration if gene has no library_id property\\012\\011\\011return;\\012\\011end if; \\012\\011\\012\\011\\012\\011select count(*)\\012\\011into counter \\012\\011from  \\012\\011\\011(select m.id, count(mp.id) as c \\012\\011\\011\\011from materials m, material_types mt, material_properties mp, material_type_property_types mtpt, property_types pt \\012\\011\\011\\011where m.maty_id = mt.id and mp.mate_id = m.id and mp.mtpt_id = mtpt.id and mtpt.maty_id = mt.id and pt.id = mtpt.prty_id\\012\\011\\011\\011\\011and mt.code = 'GENE' and pt.code = 'LIBRARY_ID' \\012\\011\\011\\011group by m.id) as counter_table \\012\\011where c < 1; \\012\\011\\012\\011if counter > 0 then \\012\\011\\011-- skip migration if there is at least one gene without library_id\\012\\011\\011return;\\012\\011end if;\\012\\011\\012\\011\\012\\011insert into property_types\\012\\011\\011(id\\012\\011\\011,code\\012\\011\\011,description\\012\\011\\011,label\\012\\011\\011,daty_id\\012\\011\\011,pers_id_registerer\\012\\011\\011,dbin_id)\\012\\011values \\012\\011\\011(nextval('PROPERTY_TYPE_ID_SEQ')\\012\\011\\011,'GENE_SYMBOLS'\\012\\011\\011,'Gene symbols'\\012\\011\\011,'Gene symbols'\\012\\011\\011,(select id from data_types where code ='VARCHAR')\\012\\011\\011,(select id from persons where user_id ='system')\\012\\011\\011,(select id from database_instances where is_original_source = 'T')\\012\\011);\\012\\011\\011\\012\\011insert into material_type_property_types( \\012\\011  id,\\012\\011  maty_id,\\012\\011  prty_id,\\012\\011  is_mandatory,\\012\\011  pers_id_registerer,\\012\\011  ordinal\\012\\011) values(\\012\\011\\011\\011nextval('mtpt_id_seq'), \\012\\011\\011\\011(select id from material_types where code = 'GENE'),\\012\\011\\011\\011(select id from property_types where code = 'GENE_SYMBOLS'),\\012\\011\\011\\011false,\\012\\011\\011\\011(select id from persons where user_id ='system'),\\012\\011\\011\\011(select max(ordinal)+1 from material_type_property_types \\012\\011\\011\\011\\011where maty_id = (select id from material_types where code = 'GENE'))\\012\\011\\011);\\012\\012\\011--------------------------------------------------\\012\\011-- create temporary table with all gene migration information\\012\\011--------------------------------------------------\\012\\012\\011create temp table genes \\012\\011(\\012\\011\\011id tech_id,\\012\\011\\011code code,\\012\\011\\011library_id generic_value,\\012\\011\\011gene_codes generic_value,\\012\\011\\011new_id tech_id,\\012\\011\\011library_tech_id tech_id\\011\\011\\012\\011);\\012\\011\\012\\011insert into genes (id, code, library_id, library_tech_id)\\012\\011\\011(select m.id, m.code, mp.value as library_id, mp.id as library_tech_id from materials m, material_properties mp, material_type_property_types mtpt, property_types pt, material_types mt\\012\\011\\011where mp.mate_id = m.id and  mp.mtpt_id = mtpt.id and pt.id = mtpt.prty_id and pt.code = 'LIBRARY_ID' and mt.id = m.maty_id and mt.id = mtpt.maty_id and mt.code = 'GENE');\\012\\011\\012\\011update genes set new_id = map.to_id from (select g_from.id as from_id, min(g_to.id) as to_id  from genes g_from, genes g_to where g_from.library_id = g_to.library_id group by g_from.id) as map where map.from_id = id;\\011\\012\\011\\012\\011update genes set gene_codes = map.gene_codes from (select g_from.library_id as lib_id, merge_words(distinct g_to.code) as gene_codes from genes g_from, genes g_to where g_from.library_id = g_to.library_id group by g_from.library_id) as map where map.lib_id = library_id;\\011\\012\\012\\011--------------------------------------------------\\012\\011-- update gene references\\012\\011--------------------------------------------------\\012\\012\\011update EXPERIMENTS set MATE_ID_STUDY_OBJECT = genes.new_id from genes where genes.id = MATE_ID_STUDY_OBJECT and not genes.id = genes.new_id;\\012\\011update EXPERIMENT_PROPERTIES set  MATE_PROP_ID = genes.new_id from genes where genes.id = MATE_PROP_ID and not genes.id = genes.new_id;\\012\\011update MATERIAL_PROPERTIES set  MATE_PROP_ID = genes.new_id from genes where genes.id = MATE_PROP_ID and not genes.id = genes.new_id;\\012\\011update SAMPLE_PROPERTIES set  MATE_PROP_ID = genes.new_id from genes where genes.id = MATE_PROP_ID and not genes.id = genes.new_id;\\012\\011update DATA_SET_PROPERTIES set  MATE_PROP_ID = genes.new_id from genes where genes.id = MATE_PROP_ID and not genes.id = genes.new_id;\\012\\011\\012\\011delete from  material_properties where mate_id in (select id from genes where not genes.id = genes.new_id);\\012\\011delete from MATERIALS where id in (select id from genes where not genes.id = genes.new_id);\\012\\012\\011delete from genes where id in (select id from genes where not genes.id = genes.new_id);\\012\\012\\012\\011--------------------------------------------------\\012\\011-- replace gene code with library_id\\012\\011--------------------------------------------------\\012\\011\\012\\011update materials set code = genes.library_id from genes where materials.id = genes.id ;\\012\\011delete from material_properties where id in (select library_tech_id from genes);\\012\\011\\012\\011--------------------------------------------------\\012\\011-- create a gene symbols property for each gene\\012\\011--------------------------------------------------\\012\\011\\012\\011insert into material_properties\\012\\011\\011(id\\012\\011  , mate_id\\012\\011  , mtpt_id\\012\\011  , "value"\\012\\011  , pers_id_registerer)\\012\\011\\011(select nextval('material_property_id_seq') id\\012\\011  \\011, genes.id  mate_id\\012\\011    , (select mtpt.id\\012\\011    \\011\\011from   material_type_property_types mtpt, material_types mt, property_types pt\\012\\011    \\011\\011where  pt.code = 'GENE_SYMBOLS' and mt.code = 'GENE' and mtpt.prty_id = pt.id\\012\\011        \\011and mtpt.maty_id = mt.id) mtpt_id\\012\\011    , genes.gene_codes "value"\\012\\011    , (select id from persons where user_id = 'system') pers_id_registerer\\012\\011 \\011from genes); \\012\\012\\011--------------------------------------------------\\012\\011-- delete temporary table\\012\\011--------------------------------------------------\\012\\011\\012\\011drop table genes;\\012\\011\\012END;\\012$$ LANGUAGE 'plpgsql';\\012\\012select REPLACE_GENE_SYMBOL_BY_GENE_ID();\\012drop function REPLACE_GENE_SYMBOL_BY_GENE_ID();\\012DROP AGGREGATE merge_words(text);\\012drop function merge_words(text,text);\\012\\012\\012--------------------------------------------------------------------------------------\\012--------------------------------------------------------------------------------------\\012\\012UPDATE sample_types SET code = 'SIRNA_WELL' WHERE code = 'OLIGO_WELL';\\012UPDATE material_types SET code = 'SIRNA' WHERE code = 'OLIGO';\\012UPDATE property_types SET code = 'SIRNA', label = 'siRNA' WHERE code = 'OLIGO';\\012\\012\\012\\012\\012\\012\\012\\012\\012\\012\\012\\012\\012\\012\\012\\012\\012\\012\\012\\012	\N
+./sourceTest/sql/postgresql/059/017=database_version_logs.tsv:059	source/sql/postgresql/migration/migration-058-059.sql	SUCCESS	2010-09-29 13:37:07.231	-- Migration from 058 to 059\\012\\012-- Add ENTITY_TYPE_CODE column to QUERIES\\012ALTER TABLE queries ADD COLUMN entity_type_code CODE;\\012\\012------------------------------------------------------------------------------------\\012--  Purpose:  Create trigger that checks if entity_type_code specified in a query\\012--            matches a code of an entity of type specified in query_type.\\012------------------------------------------------------------------------------------\\012\\012CREATE OR REPLACE FUNCTION query_entity_type_code_check() RETURNS trigger AS $$\\012DECLARE\\012   counter  INTEGER;\\012BEGIN\\012   if (NEW.entity_type_code IS NOT NULL) then\\012     if (NEW.query_type = 'GENERIC') then\\012       RAISE EXCEPTION 'Insert/Update of query (Name: %) failed, as entity_type has to be null for GENERIC queries.', NEW.name;\\012     elsif (NEW.query_type = 'EXPERIMENT') then\\012       SELECT count(*) INTO counter FROM experiment_types WHERE code = NEW.entity_type_code;\\012\\011\\011 elsif (NEW.query_type = 'DATA_SET') then\\012       SELECT count(*) INTO counter FROM data_set_types WHERE code = NEW.entity_type_code;\\012\\011\\011 elsif (NEW.query_type = 'MATERIAL') then\\012       SELECT count(*) INTO counter FROM material_types WHERE code = NEW.entity_type_code;\\012\\011\\011 elsif (NEW.query_type = 'SAMPLE') then\\012       SELECT count(*) INTO counter FROM sample_types WHERE code = NEW.entity_type_code;\\012\\011\\011 end if;\\012\\011\\011 if (counter = 0) then\\012\\011\\011\\011 RAISE EXCEPTION 'Insert/Update of query (Name: %) failed because % type (Code: %) does not exist.', NEW.name, NEW.query_type, NEW.entity_type_code;\\012\\011\\011 end if;\\011\\011\\011\\012   end if;\\012   RETURN NEW;\\012END;\\012$$ LANGUAGE 'plpgsql';\\012\\012CREATE TRIGGER query_entity_type_code_check BEFORE INSERT OR UPDATE ON queries\\012    FOR EACH ROW EXECUTE PROCEDURE query_entity_type_code_check();\\012	\N
+./sourceTest/sql/postgresql/059/schema-059.sql:    LANGUAGE plpgsql
+./sourceTest/sql/postgresql/059/schema-059.sql:    LANGUAGE plpgsql
+./sourceTest/sql/postgresql/059/schema-059.sql:    LANGUAGE plpgsql
+./sourceTest/sql/postgresql/059/schema-059.sql:    LANGUAGE plpgsql
+./sourceTest/sql/postgresql/059/schema-059.sql:    LANGUAGE plpgsql
+./sourceTest/sql/postgresql/059/schema-059.sql:    LANGUAGE plpgsql
+./sourceTest/sql/postgresql/059/schema-059.sql:    LANGUAGE plpgsql
+./sourceTest/sql/postgresql/059/schema-059.sql:    LANGUAGE plpgsql
+./sourceTest/sql/postgresql/059/schema-059.sql:    LANGUAGE plpgsql
+./sourceTest/sql/postgresql/059/schema-059.sql:    LANGUAGE plpgsql
+./sourceTest/sql/postgresql/060/.svn/text-base/017=database_version_logs.tsv.svn-base:027	D:\\User\\felmer\\dev-workspace\\openbis/source/sql/postgresql/027/function-027.sql	SUCCESS	2008-11-05 09:18:00.403	-- Creating Functions\\012\\012------------------------------------------------------------------------------------\\012--  Purpose:  Create function RENAME_SEQUENCE() that is required for renaming the sequences belonging to tables\\012------------------------------------------------------------------------------------\\012CREATE FUNCTION RENAME_SEQUENCE(OLD_NAME VARCHAR, NEW_NAME VARCHAR) RETURNS INTEGER AS $$\\012DECLARE\\012  CURR_SEQ_VAL   INTEGER;\\012BEGIN\\012  SELECT INTO CURR_SEQ_VAL NEXTVAL(OLD_NAME);\\012  EXECUTE 'CREATE SEQUENCE ' || NEW_NAME || ' START WITH ' || CURR_SEQ_VAL;\\012  EXECUTE 'DROP SEQUENCE ' || OLD_NAME;\\012  RETURN CURR_SEQ_VAL;\\012END;\\012$$ LANGUAGE 'plpgsql';\\012\\012\\012------------------------------------------------------------------------------------\\012--  Purpose:  Create trigger CONTROLLED_VOCABULARY_CHECK \\012------------------------------------------------------------------------------------\\012\\012CREATE OR REPLACE FUNCTION CONTROLLED_VOCABULARY_CHECK() RETURNS trigger AS $$\\012DECLARE\\012   v_code  CODE;\\012BEGIN\\012\\012   select code into v_code from data_types where id = NEW.daty_id;\\012\\012   -- Check if the data is of type "CONTROLLEDVOCABULARY"\\012   if v_code = 'CONTROLLEDVOCABULARY' then\\012      if NEW.covo_id IS NULL then\\012         RAISE EXCEPTION 'Insert/Update of Property Type (Code: %) failed, as its Data Type is CONTROLLEDVOCABULARY, but it is not linked to a Controlled Vocabulary.', NEW.code;\\012      end if;\\012   end if;\\012\\012   RETURN NEW;\\012\\012END;\\012$$ LANGUAGE 'plpgsql';\\012\\012CREATE TRIGGER CONTROLLED_VOCABULARY_CHECK BEFORE INSERT OR UPDATE ON PROPERTY_TYPES\\012    FOR EACH ROW EXECUTE PROCEDURE CONTROLLED_VOCABULARY_CHECK();\\012\\012\\012------------------------------------------------------------------------------------\\012--  Purpose:  Create trigger EXTERNAL_DATA_STORAGE_FORMAT_CHECK \\012------------------------------------------------------------------------------------\\012\\012CREATE OR REPLACE FUNCTION EXTERNAL_DATA_STORAGE_FORMAT_CHECK() RETURNS trigger AS $$\\012DECLARE\\012   v_covo_code  CODE;\\012   data_code CODE;\\012BEGIN\\012\\012   select code into v_covo_code from controlled_vocabularies\\012      where is_internal_namespace = true and \\012         id = (select covo_id from controlled_vocabulary_terms where id = NEW.cvte_id_stor_fmt);\\012   -- Check if the data storage format is a term of the controlled vocabulary "STORAGE_FORMAT"\\012   if v_covo_code != 'STORAGE_FORMAT' then\\012      select code into data_code from data where id = NEW.data_id; \\012      RAISE EXCEPTION 'Insert/Update of Data (Code: %) failed, as its Storage Format is %, but is required to be STORAGE_FORMAT.', data_code, v_covo_code;\\012   end if;\\012\\012   RETURN NEW;\\012\\012END;\\012$$ LANGUAGE 'plpgsql';\\012\\012CREATE TRIGGER EXTERNAL_DATA_STORAGE_FORMAT_CHECK BEFORE INSERT OR UPDATE ON EXTERNAL_DATA\\012    FOR EACH ROW EXECUTE PROCEDURE EXTERNAL_DATA_STORAGE_FORMAT_CHECK();\\012\\012------------------------------------------------------------------------------------\\012--  Purpose:  Create trigger SAMPLE_CODE_UNIQUENESS_CHECK \\012------------------------------------------------------------------------------------\\012\\012CREATE OR REPLACE FUNCTION SAMPLE_CODE_UNIQUENESS_CHECK() RETURNS trigger AS $$\\012DECLARE\\012   counter  INTEGER;\\012BEGIN\\012\\011IF (NEW.samp_id_part_of is NULL) THEN\\012\\011\\011IF (NEW.dbin_id is not NULL) THEN\\012\\011\\011\\011SELECT count(*) into counter FROM samples \\012\\011\\011\\011\\011where id != NEW.id and code = NEW.code and samp_id_part_of is NULL and dbin_id = NEW.dbin_id;\\012\\011\\011\\011IF (counter > 0) THEN\\012\\011\\011\\011\\011RAISE EXCEPTION 'Insert/Update of Sample (Code: %) failed because database instance sample with the same code already exists.', NEW.code;\\012\\011\\011\\011END IF;\\012\\011\\011ELSIF (NEW.grou_id is not NULL) THEN\\012\\011\\011\\011SELECT count(*) into counter FROM samples \\012\\011\\011\\011\\011where id != NEW.id and code = NEW.code and samp_id_part_of is NULL and grou_id = NEW.grou_id;\\012\\011\\011\\011IF (counter > 0) THEN\\012\\011\\011\\011\\011RAISE EXCEPTION 'Insert/Update of Sample (Code: %) failed because group sample with the same code already exists.', NEW.code;\\012\\011\\011\\011END IF;\\012\\011\\011END IF;\\012        ELSE\\012\\011\\011IF (NEW.dbin_id is not NULL) THEN\\012\\011\\011\\011SELECT count(*) into counter FROM samples \\012\\011\\011\\011\\011where id != NEW.id and code = NEW.code and samp_id_part_of = NEW.samp_id_part_of and dbin_id = NEW.dbin_id;\\012\\011\\011\\011IF (counter > 0) THEN\\012\\011\\011\\011\\011RAISE EXCEPTION 'Insert/Update of Sample (Code: %) failed because database instance sample with the same code and being the part of the same parent already exists.', NEW.code;\\012\\011\\011\\011END IF;\\012\\011\\011ELSIF (NEW.grou_id is not NULL) THEN\\012\\011\\011\\011SELECT count(*) into counter FROM samples \\012\\011\\011\\011\\011where id != NEW.id and code = NEW.code and samp_id_part_of = NEW.samp_id_part_of and grou_id = NEW.grou_id;\\012\\011\\011\\011IF (counter > 0) THEN\\012\\011\\011\\011\\011RAISE EXCEPTION 'Insert/Update of Sample (Code: %) failed because group sample with the same code and being the part of the same parent already exists.', NEW.code;\\012\\011\\011\\011END IF;\\012\\011\\011END IF;\\012        END IF;   \\012   RETURN NEW;\\012END;\\012$$ LANGUAGE 'plpgsql';\\012\\012CREATE TRIGGER SAMPLE_CODE_UNIQUENESS_CHECK BEFORE INSERT OR UPDATE ON SAMPLES\\012    FOR EACH ROW EXECUTE PROCEDURE SAMPLE_CODE_UNIQUENESS_CHECK();\\012	\N
+./sourceTest/sql/postgresql/060/.svn/text-base/017=database_version_logs.tsv.svn-base:028	source/sql/postgresql/migration/migration-027-028.sql	SUCCESS	2008-11-18 13:24:17.508	-- Create EXPERIMENT_ATTACHMENT_CONTENTS.\\012CREATE TABLE EXPERIMENT_ATTACHMENT_CONTENTS (ID TECH_ID NOT NULL,VALUE FILE NOT NULL);\\012CREATE SEQUENCE EXPERIMENT_ATTACHMENT_CONTENT_ID_SEQ;\\012ALTER TABLE EXPERIMENT_ATTACHMENT_CONTENTS ADD CONSTRAINT EXAC_PK PRIMARY KEY(ID);\\012\\012-- Alter EXPERIMENT_ATTACHMENTS by adding the new column which has a NULL constraint.\\012-- The NOT NULL constraint is added later on.\\012ALTER TABLE EXPERIMENT_ATTACHMENTS ADD COLUMN EXAC_ID TECH_ID;\\012\\012-- Does the VALUE migration between EXPERIMENT_ATTACHMENTS to EXPERIMENT_ATTACHMENT_CONTENTS.\\012CREATE OR REPLACE FUNCTION move_exp_att_content() RETURNS integer AS $$\\012DECLARE\\012    rec RECORD;\\012    seq BIGINT;\\012BEGIN\\012  FOR rec IN SELECT id, value FROM EXPERIMENT_ATTACHMENTS LOOP\\012  \\011seq := nextval('EXPERIMENT_ATTACHMENT_CONTENT_ID_SEQ');\\012    INSERT INTO EXPERIMENT_ATTACHMENT_CONTENTS (id, value) VALUES (seq, rec.value);\\012    UPDATE EXPERIMENT_ATTACHMENTS SET exac_id = seq WHERE id = rec.id;\\012  END LOOP;\\012  RETURN 1;\\012END;\\012$$ LANGUAGE 'plpgsql';\\012\\012-- Call the function.\\012SELECT move_exp_att_content();\\012DROP FUNCTION move_exp_att_content();\\012\\012\\012-- Finish EXPERIMENT_ATTACHMENTS changes.\\012ALTER TABLE EXPERIMENT_ATTACHMENTS ADD CONSTRAINT EXAT_CONT_FK FOREIGN KEY (EXAC_ID) REFERENCES EXPERIMENT_ATTACHMENT_CONTENTS(ID);\\012ALTER TABLE EXPERIMENT_ATTACHMENTS DROP COLUMN VALUE;\\012ALTER TABLE EXPERIMENT_ATTACHMENTS ALTER COLUMN EXAC_ID SET NOT NULL;\\012	\N
+./sourceTest/sql/postgresql/060/.svn/text-base/017=database_version_logs.tsv.svn-base:029	source/sql/postgresql/migration/migration-028-029.sql	SUCCESS	2009-03-18 10:50:20.105	-- -------\\012-- add modification_timestamp field to allow edition with Hibernate\\012-- -------\\012\\012ALTER TABLE samples\\012\\011ADD COLUMN modification_timestamp TIME_STAMP DEFAULT CURRENT_TIMESTAMP;\\012\\012ALTER TABLE experiments\\012\\011ADD COLUMN modification_timestamp TIME_STAMP DEFAULT CURRENT_TIMESTAMP;\\012\\012ALTER TABLE materials\\012\\011ADD COLUMN modification_timestamp TIME_STAMP DEFAULT CURRENT_TIMESTAMP;\\012\\012ALTER TABLE experiment_properties\\012\\011ADD COLUMN modification_timestamp TIME_STAMP DEFAULT CURRENT_TIMESTAMP;\\012\\012ALTER TABLE material_properties\\012\\011ADD COLUMN modification_timestamp TIME_STAMP DEFAULT CURRENT_TIMESTAMP;\\012\\012ALTER TABLE sample_properties\\012\\011ADD COLUMN modification_timestamp TIME_STAMP DEFAULT CURRENT_TIMESTAMP;\\012\\012-- -------\\012-- add property data type which references materials\\012-- -------\\012\\012ALTER TABLE property_types\\012\\011ADD COLUMN maty_prop_id tech_id;\\012\\012ALTER TABLE property_types\\012\\011ADD CONSTRAINT prty_maty_fk FOREIGN KEY (maty_prop_id) REFERENCES material_types(id);\\012\\012ALTER TABLE experiment_properties\\012\\011ADD COLUMN mate_prop_id tech_id;\\012\\012ALTER TABLE material_properties\\012\\011ADD COLUMN mate_prop_id tech_id;\\012\\012ALTER TABLE sample_properties\\012\\011ADD COLUMN mate_prop_id tech_id;\\012\\012ALTER TABLE experiment_properties\\012\\011ADD CONSTRAINT expr_mapr_fk FOREIGN KEY (mate_prop_id) REFERENCES materials(id);\\012\\012ALTER TABLE material_properties\\012\\011ADD CONSTRAINT mapr_mapr_fk FOREIGN KEY (mate_prop_id) REFERENCES materials(id);\\012\\012ALTER TABLE sample_properties\\012\\011ADD CONSTRAINT sapr_mapr_fk FOREIGN KEY (mate_prop_id) REFERENCES materials(id);\\012\\012insert into data_types\\012(id\\012 ,code\\012 ,description)\\012 values \\012 (nextval('DATA_TYPE_ID_SEQ')\\012 ,'MATERIAL'\\012 ,'Reference to a material'\\012);\\012\\012ALTER TABLE MATERIAL_PROPERTIES DROP CONSTRAINT MAPR_CK;\\012ALTER TABLE MATERIAL_PROPERTIES ADD CONSTRAINT MAPR_CK CHECK \\012\\011((VALUE IS NOT NULL AND CVTE_ID IS NULL AND MATE_PROP_ID IS NULL) OR \\012\\011 (VALUE IS NULL AND CVTE_ID IS NOT NULL AND MATE_PROP_ID IS NULL) OR\\012\\011 (VALUE IS NULL AND CVTE_ID IS NULL AND MATE_PROP_ID IS NOT NULL)\\012\\011);\\012\\012ALTER TABLE EXPERIMENT_PROPERTIES DROP CONSTRAINT EXPR_CK;\\012ALTER TABLE EXPERIMENT_PROPERTIES ADD CONSTRAINT EXPR_CK CHECK \\012\\011((VALUE IS NOT NULL AND CVTE_ID IS NULL AND MATE_PROP_ID IS NULL) OR \\012\\011 (VALUE IS NULL AND CVTE_ID IS NOT NULL AND MATE_PROP_ID IS NULL) OR\\012\\011 (VALUE IS NULL AND CVTE_ID IS NULL AND MATE_PROP_ID IS NOT NULL)\\012\\011);\\012\\012ALTER TABLE SAMPLE_PROPERTIES DROP CONSTRAINT SAPR_CK;\\012ALTER TABLE SAMPLE_PROPERTIES ADD CONSTRAINT SAPR_CK CHECK \\012\\011((VALUE IS NOT NULL AND CVTE_ID IS NULL AND MATE_PROP_ID IS NULL) OR \\012\\011 (VALUE IS NULL AND CVTE_ID IS NOT NULL AND MATE_PROP_ID IS NULL) OR\\012\\011 (VALUE IS NULL AND CVTE_ID IS NULL AND MATE_PROP_ID IS NOT NULL)\\012\\011);\\012\\012------------------------------------------------------------------------------------\\012--  Purpose:  Create trigger MATERIAL/SAMPLE/EXPERIMENT _PROPERTY_WITH_MATERIAL_DATA_TYPE_CHECK\\012--            It checks that if material property value is assigned to the entity,\\012--\\011\\011\\011\\011\\011\\011then the material type is equal to the one described by property type.\\012------------------------------------------------------------------------------------\\012\\012CREATE OR REPLACE FUNCTION MATERIAL_PROPERTY_WITH_MATERIAL_DATA_TYPE_CHECK() RETURNS trigger AS $$\\012DECLARE\\012   v_type_id  CODE;\\012   v_type_id_prop  CODE;\\012BEGIN\\012   if NEW.mate_prop_id IS NOT NULL then\\012\\011\\011\\011-- find material type id of the property type \\012\\011\\011\\011select pt.maty_prop_id into v_type_id_prop \\012\\011\\011\\011  from material_type_property_types etpt, property_types pt \\012\\011\\011\\011 where NEW.mtpt_id = etpt.id AND etpt.prty_id = pt.id;\\012\\011\\011\\012\\011\\011\\011if v_type_id_prop IS NOT NULL then\\012\\011\\011\\011\\011-- find material type id of the material which consists the entity's property value\\012\\011\\011\\011\\011select entity.maty_id into v_type_id \\012\\011\\011\\011\\011  from materials entity\\012\\011\\011\\011\\011 where NEW.mate_prop_id = entity.id;\\012\\011\\011\\011\\011if v_type_id != v_type_id_prop then\\012\\011\\011\\011\\011\\011RAISE EXCEPTION 'Insert/Update of property value referencing material (id: %) failed, as referenced material type is different than expected (id %, expected id: %).', \\012\\011\\011\\011\\011\\011\\011\\011 NEW.mate_prop_id, v_type_id, v_type_id_prop;\\012\\011\\011\\011\\011end if;\\012\\011\\011\\011end if;\\012   end if;\\012   RETURN NEW;\\012END;\\012$$ LANGUAGE 'plpgsql';\\012\\012CREATE TRIGGER MATERIAL_PROPERTY_WITH_MATERIAL_DATA_TYPE_CHECK BEFORE INSERT OR UPDATE ON material_properties\\012    FOR EACH ROW EXECUTE PROCEDURE MATERIAL_PROPERTY_WITH_MATERIAL_DATA_TYPE_CHECK();\\012    \\012CREATE OR REPLACE FUNCTION SAMPLE_PROPERTY_WITH_MATERIAL_DATA_TYPE_CHECK() RETURNS trigger AS $$\\012DECLARE\\012   v_type_id  CODE;\\012   v_type_id_prop  CODE;\\012BEGIN\\012   if NEW.mate_prop_id IS NOT NULL then\\012\\011\\011\\011-- find material type id of the property type \\012\\011\\011\\011select pt.maty_prop_id into v_type_id_prop \\012\\011\\011\\011  from sample_type_property_types etpt, property_types pt \\012\\011\\011\\011 where NEW.stpt_id = etpt.id AND etpt.prty_id = pt.id;\\012\\011\\011\\012\\011\\011\\011if v_type_id_prop IS NOT NULL then\\012\\011\\011\\011\\011-- find material type id of the material which consists the entity's property value\\012\\011\\011\\011\\011select entity.maty_id into v_type_id \\012\\011\\011\\011\\011  from materials entity\\012\\011\\011\\011\\011 where NEW.mate_prop_id = entity.id;\\012\\011\\011\\011\\011if v_type_id != v_type_id_prop then\\012\\011\\011\\011\\011\\011RAISE EXCEPTION 'Insert/Update of property value referencing material (id: %) failed, as referenced material type is different than expected (id %, expected id: %).', \\012\\011\\011\\011\\011\\011\\011\\011\\011\\011\\011\\011\\011 NEW.mate_prop_id, v_type_id, v_type_id_prop;\\012\\011\\011\\011\\011end if;\\012\\011\\011\\011end if;\\012   end if;\\012   RETURN NEW;\\012END;\\012$$ LANGUAGE 'plpgsql';\\012\\012CREATE TRIGGER SAMPLE_PROPERTY_WITH_MATERIAL_DATA_TYPE_CHECK BEFORE INSERT OR UPDATE ON sample_properties\\012    FOR EACH ROW EXECUTE PROCEDURE SAMPLE_PROPERTY_WITH_MATERIAL_DATA_TYPE_CHECK();\\012    \\012CREATE OR REPLACE FUNCTION EXPERIMENT_PROPERTY_WITH_MATERIAL_DATA_TYPE_CHECK() RETURNS trigger AS $$\\012DECLARE\\012   v_type_id  CODE;\\012   v_type_id_prop  CODE;\\012BEGIN\\012   if NEW.mate_prop_id IS NOT NULL then\\012\\011\\011\\011-- find material type id of the property type \\012\\011\\011\\011select pt.maty_prop_id into v_type_id_prop \\012\\011\\011\\011  from experiment_type_property_types etpt, property_types pt \\012\\011\\011\\011 where NEW.etpt_id = etpt.id AND etpt.prty_id = pt.id;\\012\\011\\011\\012\\011\\011\\011if v_type_id_prop IS NOT NULL then\\012\\011\\011\\011\\011-- find material type id of the material which consists the entity's property value\\012\\011\\011\\011\\011select entity.maty_id into v_type_id \\012\\011\\011\\011\\011  from materials entity\\012\\011\\011\\011\\011 where NEW.mate_prop_id = entity.id;\\012\\011\\011\\011\\011if v_type_id != v_type_id_prop then\\012\\011\\011\\011\\011\\011RAISE EXCEPTION 'Insert/Update of property value referencing material (id: %) failed, as referenced material type is different than expected (id %, expected id: %).', \\012\\011\\011\\011\\011\\011\\011\\011\\011\\011\\011\\011\\011 NEW.mate_prop_id, v_type_id, v_type_id_prop;\\012\\011\\011\\011\\011end if;\\012\\011\\011\\011end if;\\012   end if;\\012   RETURN NEW;\\012END;\\012$$ LANGUAGE 'plpgsql';\\012\\012CREATE TRIGGER EXPERIMENT_PROPERTY_WITH_MATERIAL_DATA_TYPE_CHECK BEFORE INSERT OR UPDATE ON experiment_properties\\012    FOR EACH ROW EXECUTE PROCEDURE EXPERIMENT_PROPERTY_WITH_MATERIAL_DATA_TYPE_CHECK();\\012       \\012-- -------\\012-- remove the reminescents of the OBSERVABLE_TYPE\\012-- -------\\012\\012ALTER TABLE data\\012\\011DROP CONSTRAINT data_obty_fk;\\012\\012ALTER TABLE data_set_types\\012\\011DROP CONSTRAINT obty_pk;\\012\\012ALTER TABLE data_set_types\\012\\011ADD CONSTRAINT dsty_pk PRIMARY KEY (id);\\012\\012ALTER TABLE data\\012\\011ADD CONSTRAINT data_dsty_fk FOREIGN KEY (dsty_id) REFERENCES data_set_types(id);\\012\\012ALTER TABLE data_set_types\\012\\011DROP CONSTRAINT obty_bk_uk;\\012\\012ALTER TABLE data_set_types\\012\\011DROP CONSTRAINT obty_dbin_fk;\\012\\012ALTER TABLE data_set_types\\012\\011ADD CONSTRAINT dsty_bk_uk UNIQUE (code, dbin_id);\\012\\012ALTER TABLE data_set_types\\012\\011ADD CONSTRAINT dsty_dbin_fk FOREIGN KEY (dbin_id) REFERENCES database_instances(id);\\012\\012DROP INDEX data_obty_fk_i;\\012\\012CREATE INDEX data_dsty_fk_i ON data(dsty_id);\\012	\N
+./sourceTest/sql/postgresql/060/.svn/text-base/017=database_version_logs.tsv.svn-base:030	source/sql/postgresql/migration/migration-029-030.sql	SUCCESS	2009-03-23 15:34:44.72	-- -------\\012-- add modification_timestamp field to allow edition with Hibernate\\012-- -------\\012ALTER TABLE data\\012\\011ADD COLUMN modification_timestamp TIME_STAMP DEFAULT CURRENT_TIMESTAMP;\\012ALTER TABLE experiment_types\\012\\011ADD COLUMN modification_timestamp TIME_STAMP DEFAULT CURRENT_TIMESTAMP;\\012ALTER TABLE sample_types\\012\\011ADD COLUMN modification_timestamp TIME_STAMP DEFAULT CURRENT_TIMESTAMP;\\012ALTER TABLE material_types\\012\\011ADD COLUMN modification_timestamp TIME_STAMP DEFAULT CURRENT_TIMESTAMP;\\012ALTER TABLE data_set_types\\012\\011ADD COLUMN modification_timestamp TIME_STAMP DEFAULT CURRENT_TIMESTAMP;\\012ALTER TABLE controlled_vocabularies\\012\\011ADD COLUMN modification_timestamp TIME_STAMP DEFAULT CURRENT_TIMESTAMP;\\012-- -------\\012-- add properties to data sets\\012-- -------\\012CREATE TABLE DATA_SET_PROPERTIES (ID TECH_ID NOT NULL,DS_ID TECH_ID NOT NULL,DSTPT_ID TECH_ID NOT NULL,VALUE GENERIC_VALUE,CVTE_ID TECH_ID, MATE_PROP_ID TECH_ID, PERS_ID_REGISTERER TECH_ID NOT NULL,REGISTRATION_TIMESTAMP TIME_STAMP_DFL NOT NULL DEFAULT CURRENT_TIMESTAMP, MODIFICATION_TIMESTAMP TIME_STAMP DEFAULT CURRENT_TIMESTAMP);\\012CREATE TABLE DATA_SET_TYPE_PROPERTY_TYPES (ID TECH_ID NOT NULL,DSTY_ID TECH_ID NOT NULL,PRTY_ID TECH_ID NOT NULL,IS_MANDATORY BOOLEAN_CHAR NOT NULL DEFAULT 'F',IS_MANAGED_INTERNALLY BOOLEAN_CHAR NOT NULL DEFAULT 'F',PERS_ID_REGISTERER TECH_ID NOT NULL,REGISTRATION_TIMESTAMP TIME_STAMP_DFL NOT NULL DEFAULT CURRENT_TIMESTAMP);\\012\\012CREATE SEQUENCE DATA_SET_PROPERTY_ID_SEQ;\\012CREATE SEQUENCE DSTPT_ID_SEQ;\\012\\012ALTER TABLE DATA_SET_TYPE_PROPERTY_TYPES ADD CONSTRAINT DSTPT_PK PRIMARY KEY(ID);\\012ALTER TABLE DATA_SET_PROPERTIES ADD CONSTRAINT DSPR_PK PRIMARY KEY(ID);\\012\\012ALTER TABLE DATA_SET_TYPE_PROPERTY_TYPES ADD CONSTRAINT DSTPT_BK_UK UNIQUE(DSTY_ID,PRTY_ID);\\012ALTER TABLE DATA_SET_PROPERTIES ADD CONSTRAINT DSPR_BK_UK UNIQUE(DS_ID,DSTPT_ID);\\012\\012\\012ALTER TABLE DATA_SET_TYPE_PROPERTY_TYPES ADD CONSTRAINT DSTPT_DSTY_FK FOREIGN KEY (DSTY_ID) REFERENCES DATA_SET_TYPES(ID);\\012ALTER TABLE DATA_SET_TYPE_PROPERTY_TYPES ADD CONSTRAINT DSTPT_PERS_FK FOREIGN KEY (PERS_ID_REGISTERER) REFERENCES PERSONS(ID);\\012ALTER TABLE DATA_SET_TYPE_PROPERTY_TYPES ADD CONSTRAINT DSTPT_PRTY_FK FOREIGN KEY (PRTY_ID) REFERENCES PROPERTY_TYPES(ID);\\012ALTER TABLE DATA_SET_PROPERTIES ADD CONSTRAINT DSPR_CVTE_FK FOREIGN KEY (CVTE_ID) REFERENCES CONTROLLED_VOCABULARY_TERMS(ID);\\012ALTER TABLE DATA_SET_PROPERTIES ADD CONSTRAINT DSPR_DSTPT_FK FOREIGN KEY (DSTPT_ID) REFERENCES DATA_SET_TYPE_PROPERTY_TYPES(ID) ON DELETE CASCADE;\\012ALTER TABLE DATA_SET_PROPERTIES ADD CONSTRAINT DSPR_DS_FK FOREIGN KEY (DS_ID) REFERENCES DATA(ID);\\012ALTER TABLE DATA_SET_PROPERTIES ADD CONSTRAINT DSPR_PERS_FK FOREIGN KEY (PERS_ID_REGISTERER) REFERENCES PERSONS(ID);\\012ALTER TABLE DATA_SET_PROPERTIES ADD CONSTRAINT DSPR_MAPR_FK FOREIGN KEY (MATE_PROP_ID) REFERENCES MATERIALS(ID);\\012\\012ALTER TABLE DATA_SET_PROPERTIES ADD CONSTRAINT DSPR_CK CHECK \\012\\011((VALUE IS NOT NULL AND CVTE_ID IS NULL AND MATE_PROP_ID IS NULL) OR \\012\\011 (VALUE IS NULL AND CVTE_ID IS NOT NULL AND MATE_PROP_ID IS NULL) OR\\012\\011 (VALUE IS NULL AND CVTE_ID IS NULL AND MATE_PROP_ID IS NOT NULL)\\012\\011);\\012\\012CREATE INDEX DSPR_CVTE_FK_I ON DATA_SET_PROPERTIES (CVTE_ID);\\012CREATE INDEX DSPR_DSTPT_FK_I ON DATA_SET_PROPERTIES (DSTPT_ID);\\012CREATE INDEX DSPR_DS_FK_I ON DATA_SET_PROPERTIES (DS_ID);\\012CREATE INDEX DSPR_PERS_FK_I ON DATA_SET_PROPERTIES (PERS_ID_REGISTERER);\\012CREATE INDEX DSTPT_DSTY_FK_I ON DATA_SET_TYPE_PROPERTY_TYPES (DSTY_ID);\\012CREATE INDEX DSTPT_PERS_FK_I ON DATA_SET_TYPE_PROPERTY_TYPES (PERS_ID_REGISTERER);\\012CREATE INDEX DSTPT_PRTY_FK_I ON DATA_SET_TYPE_PROPERTY_TYPES (PRTY_ID);\\012\\012CREATE OR REPLACE FUNCTION DATA_SET_PROPERTY_WITH_MATERIAL_DATA_TYPE_CHECK() RETURNS trigger AS $$\\012DECLARE\\012   v_type_id  CODE;\\012   v_type_id_prop  CODE;\\012BEGIN\\012   if NEW.mate_prop_id IS NOT NULL then\\012\\011\\011\\011-- find material type id of the property type \\012\\011\\011\\011select pt.maty_prop_id into v_type_id_prop \\012\\011\\011\\011  from data_set_type_property_types dstpt, property_types pt \\012\\011\\011\\011 where NEW.dstpt_id = dstpt.id AND dstpt.prty_id = pt.id;\\012\\011\\011\\012\\011\\011\\011if v_type_id_prop IS NOT NULL then\\012\\011\\011\\011\\011-- find material type id of the material which consists the entity's property value\\012\\011\\011\\011\\011select entity.maty_id into v_type_id \\012\\011\\011\\011\\011  from materials entity\\012\\011\\011\\011\\011 where NEW.mate_prop_id = entity.id;\\012\\011\\011\\011\\011if v_type_id != v_type_id_prop then\\012\\011\\011\\011\\011\\011RAISE EXCEPTION 'Insert/Update of property value referencing material (id: %) failed, as referenced material type is different than expected (id %, expected id: %).', \\012\\011\\011\\011\\011\\011\\011\\011\\011\\011\\011\\011\\011 NEW.mate_prop_id, v_type_id, v_type_id_prop;\\012\\011\\011\\011\\011end if;\\012\\011\\011\\011end if;\\012   end if;\\012   RETURN NEW;\\012END;\\012$$ LANGUAGE 'plpgsql';\\012\\012CREATE TRIGGER DATA_SET_PROPERTY_WITH_MATERIAL_DATA_TYPE_CHECK BEFORE INSERT OR UPDATE ON data_set_properties\\012    FOR EACH ROW EXECUTE PROCEDURE DATA_SET_PROPERTY_WITH_MATERIAL_DATA_TYPE_CHECK();   \\012	\N
+./sourceTest/sql/postgresql/060/.svn/text-base/017=database_version_logs.tsv.svn-base:032	source/sql/postgresql/migration/migration-031-032.sql	SUCCESS	2009-04-09 09:36:36.2	-- -------\\012-- Modify MATERIAL_BATCHES\\012-- -------\\012\\012ALTER TABLE material_batches\\012    DROP COLUMN proc_id;\\012\\012-- -------\\012-- Modify SAMPLES\\012-- -------\\012\\012ALTER TABLE samples\\012    ADD COLUMN expe_id tech_id;\\012\\012ALTER TABLE samples\\012    ADD CONSTRAINT samp_expe_fk FOREIGN KEY (expe_id) REFERENCES experiments(id);\\012\\012CREATE INDEX samp_expe_fk_i ON samples USING btree (expe_id);\\012\\012-- relink samples directly to experiments\\012\\012UPDATE samples\\012SET expe_id = (SELECT e.id FROM experiments e, procedures p, sample_inputs si \\012               WHERE si.samp_id = samples.id AND si.proc_id = p.id AND p.expe_id = e.id AND e.inva_id IS NULL);\\012\\012\\012-- -------\\012-- Modify DATA\\012-- -------\\012\\012ALTER TABLE data\\012    ADD COLUMN expe_id tech_id;\\012\\012ALTER TABLE data\\012    ADD CONSTRAINT data_expe_fk FOREIGN KEY (expe_id) REFERENCES experiments(id);\\012\\012CREATE INDEX data_expe_fk_i ON data USING btree (expe_id);\\012\\012UPDATE data\\012SET expe_id = (SELECT e.id FROM experiments e, procedures p \\012               WHERE data.proc_id_produced_by = p.id AND p.expe_id = e.id);\\012\\012ALTER TABLE data\\012    ALTER COLUMN expe_id SET NOT NULL;\\012\\012ALTER TABLE data\\012    DROP COLUMN proc_id_produced_by;\\012\\012-- -------\\012-- Drop PROCEDURES, PROCEDURE_TYPES, and SAMPLE_INPUTS\\012-- -------\\012\\012DROP TABLE sample_inputs;\\012DROP TABLE procedures;\\012DROP TABLE procedure_types;\\012\\012DROP SEQUENCE procedure_id_seq;\\012DROP SEQUENCE procedure_type_id_seq;\\012\\012-- -------\\012-- Add CODE_SEQ\\012-- -------\\012\\012CREATE SEQUENCE CODE_SEQ;\\012\\012-- -------\\012-- Add new columns to DATA_STORES\\012-- -------\\012\\012ALTER TABLE data_stores\\012    ADD COLUMN remote_url character varying(250),\\012    ADD COLUMN session_token character varying(50),\\012    ADD COLUMN modification_timestamp time_stamp DEFAULT now();\\012\\012UPDATE data_stores\\012SET remote_url = '', session_token='';\\012\\012ALTER TABLE data_stores\\012    ALTER COLUMN remote_url SET NOT NULL,\\012    ALTER COLUMN session_token SET NOT NULL;\\012\\012-- -------\\012-- Drop foreign keys onto DATA_STORES\\012-- -------\\012\\012ALTER TABLE database_instances\\012    DROP COLUMN dast_id;\\012\\012ALTER TABLE groups\\012    DROP COLUMN dast_id;\\012\\012ALTER TABLE projects\\012    DROP COLUMN dast_id;\\012\\012ALTER TABLE experiments\\012    DROP COLUMN dast_id;\\012\\012-- -------\\012-- Add foreign key from DATA onto DATA_STORES\\012-- -------\\012\\012ALTER TABLE data\\012    ADD COLUMN dast_id tech_id;\\012\\012ALTER TABLE data\\012    ADD CONSTRAINT data_dast_fk FOREIGN KEY (dast_id) REFERENCES data_stores(id);\\012\\012UPDATE data\\012SET dast_id = (select id from data_stores where code = 'STANDARD');\\012\\012ALTER TABLE data\\012    ALTER COLUMN dast_id SET NOT NULL;\\012\\012\\012------------------------------------------------------------------------------------\\012--  Purpose:  Replace trigger SAMPLE_CODE_UNIQUENESS_CHECK \\012------------------------------------------------------------------------------------\\012\\012CREATE OR REPLACE FUNCTION SAMPLE_CODE_UNIQUENESS_CHECK() RETURNS trigger AS $$\\012DECLARE\\012   counter  INTEGER;\\012BEGIN\\012    LOCK TABLE samples IN EXCLUSIVE MODE;\\012    IF (NEW.samp_id_part_of is NULL) THEN\\012        IF (NEW.dbin_id is not NULL) THEN\\012            SELECT count(*) into counter FROM samples \\012                where id != NEW.id and code = NEW.code and samp_id_part_of is NULL and dbin_id = NEW.dbin_id;\\012            IF (counter > 0) THEN\\012                RAISE EXCEPTION 'Insert/Update of Sample (Code: %) failed because database instance sample with the same code already exists.', NEW.code;\\012            END IF;\\012        ELSIF (NEW.grou_id is not NULL) THEN\\012            SELECT count(*) into counter FROM samples \\012                where id != NEW.id and code = NEW.code and samp_id_part_of is NULL and grou_id = NEW.grou_id;\\012            IF (counter > 0) THEN\\012                RAISE EXCEPTION 'Insert/Update of Sample (Code: %) failed because group sample with the same code already exists.', NEW.code;\\012            END IF;\\012        END IF;\\012        ELSE\\012        IF (NEW.dbin_id is not NULL) THEN\\012            SELECT count(*) into counter FROM samples \\012                where id != NEW.id and code = NEW.code and samp_id_part_of = NEW.samp_id_part_of and dbin_id = NEW.dbin_id;\\012            IF (counter > 0) THEN\\012                RAISE EXCEPTION 'Insert/Update of Sample (Code: %) failed because database instance sample with the same code and being the part of the same parent already exists.', NEW.code;\\012            END IF;\\012        ELSIF (NEW.grou_id is not NULL) THEN\\012            SELECT count(*) into counter FROM samples \\012                where id != NEW.id and code = NEW.code and samp_id_part_of = NEW.samp_id_part_of and grou_id = NEW.grou_id;\\012            IF (counter > 0) THEN\\012                RAISE EXCEPTION 'Insert/Update of Sample (Code: %) failed because group sample with the same code and being the part of the same parent already exists.', NEW.code;\\012            END IF;\\012        END IF;\\012        END IF;   \\012   RETURN NEW;\\012END;\\012$$ LANGUAGE 'plpgsql';\\012\\012\\012\\012	\N
+./sourceTest/sql/postgresql/060/.svn/text-base/017=database_version_logs.tsv.svn-base:034	source/sql/postgresql/migration/migration-033-034.sql	SUCCESS	2009-05-26 08:32:49.935	------------------------------------------------------------------------------------\\012-- Create sequence for generating permanent identifiers starting with nextval of existing dataset sequence.\\012------------------------------------------------------------------------------------\\012CREATE FUNCTION CREATE_SEQUENCE(EXISTING_SEQUENCE VARCHAR, NEW_SEQUENCE VARCHAR) RETURNS VOID AS $$\\012DECLARE\\012  CURR_SEQ_VAL   INTEGER;\\012BEGIN\\012  SELECT INTO CURR_SEQ_VAL NEXTVAL(EXISTING_SEQUENCE);\\012  EXECUTE 'CREATE SEQUENCE ' || NEW_SEQUENCE || ' START WITH ' || CURR_SEQ_VAL;\\012  RETURN;\\012END;\\012$$ LANGUAGE 'plpgsql';\\012\\012SELECT CREATE_SEQUENCE('DATA_ID_SEQ', 'PERM_ID_SEQ');\\012DROP FUNCTION CREATE_SEQUENCE(VARCHAR, VARCHAR);\\012\\012------------------------------------------------------------------------------------\\012-- Add perm_id columns to samples and experiments.\\012------------------------------------------------------------------------------------\\012ALTER TABLE SAMPLES ADD COLUMN PERM_ID CODE;\\012ALTER TABLE EXPERIMENTS ADD COLUMN PERM_ID CODE;\\012\\012UPDATE SAMPLES SET PERM_ID = to_char(registration_timestamp,'YYYYMMDDHHSSMS') || '-' || NEXTVAL('PERM_ID_SEQ');\\012UPDATE EXPERIMENTS SET PERM_ID = to_char(registration_timestamp,'YYYYMMDDHHSSMS') || '-' || NEXTVAL('PERM_ID_SEQ');\\012ALTER TABLE SAMPLES ALTER COLUMN PERM_ID SET NOT NULL;\\012ALTER TABLE EXPERIMENTS ALTER COLUMN PERM_ID SET NOT NULL;\\012ALTER TABLE SAMPLES ADD CONSTRAINT SAMP_PI_UK UNIQUE(PERM_ID);\\012ALTER TABLE EXPERIMENTS ADD CONSTRAINT EXPE_PI_UK UNIQUE(PERM_ID);\\012\\012\\012------------------------------------------------------------------------------------\\012-- Add column is_chosen_from_list to controlled_vocabularies.\\012------------------------------------------------------------------------------------\\012ALTER TABLE controlled_vocabularies ADD COLUMN is_chosen_from_list BOOLEAN_CHAR NOT NULL DEFAULT TRUE;\\012ALTER TABLE controlled_vocabularies ADD COLUMN source_uri CHARACTER VARYING(250);\\012------------------------------------------------------------------------------------\\012-- Modify Data table - remove arc connection between Sample and Data table, use a flag instead\\012------------------------------------------------------------------------------------\\012\\012-- add new columns\\012\\012ALTER TABLE data\\012    ADD COLUMN is_derived boolean_char;\\012ALTER TABLE data\\012    ADD COLUMN samp_id tech_id;\\012\\012-- update values in new columns\\012\\012UPDATE data\\012    SET is_derived = (samp_id_derived_from IS NOT NULL); \\012UPDATE data\\012    SET samp_id = samp_id_derived_from \\012    WHERE is_derived = 'TRUE';\\012UPDATE data\\012    SET samp_id = samp_id_acquired_from \\012    WHERE is_derived = 'FALSE';\\012\\012-- add constraints and indexes to new columns\\012\\012ALTER TABLE data\\012    ALTER COLUMN is_derived SET NOT NULL;\\012ALTER TABLE data\\012    ALTER COLUMN samp_id SET NOT NULL;   \\012ALTER TABLE data\\012    ADD CONSTRAINT data_samp_fk FOREIGN KEY (samp_id) REFERENCES samples (id);\\012CREATE INDEX data_samp_fk_i ON data USING btree (samp_id);\\012\\012-- remove old columns\\012\\012ALTER TABLE data\\012    DROP COLUMN samp_id_acquired_from;\\012ALTER TABLE data\\012    DROP COLUMN samp_id_derived_from;\\012    \\012------------------------------------------------------------------------------------\\012-- Granting SELECT privilege to group openbis_readonly\\012------------------------------------------------------------------------------------\\012\\012GRANT SELECT ON SEQUENCE attachment_content_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE attachment_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE code_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE controlled_vocabulary_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE cvte_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE data_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE data_set_property_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE data_set_relationship_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE data_set_type_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE data_store_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE data_type_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE database_instance_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE dstpt_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE etpt_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE event_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE experiment_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE experiment_property_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE experiment_type_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE file_format_type_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE group_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE invalidation_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE locator_type_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE material_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE material_property_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE material_type_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE mtpt_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE perm_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE person_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE project_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE property_type_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE role_assignment_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE sample_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE sample_property_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE sample_type_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE stpt_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE attachment_contents TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE attachments TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE controlled_vocabularies TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE controlled_vocabulary_terms TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE data TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE data_set_properties TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE data_set_relationships TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE data_set_type_property_types TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE data_set_types TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE data_stores TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE data_types TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE database_instances TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE database_version_logs TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE events TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE experiment_properties TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE experiment_type_property_types TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE experiment_types TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE experiments TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE external_data TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE file_format_types TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE groups TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE invalidations TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE locator_types TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE material_properties TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE material_type_property_types TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE material_types TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE materials TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE persons TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE projects TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE property_types TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE role_assignments TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE sample_properties TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE sample_type_property_types TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE sample_types TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE samples TO GROUP OPENBIS_READONLY;\\012\\012------------------------------------------------------------------------------------\\012-- Delete MATERIAL_BATCHES table\\012------------------------------------------------------------------------------------\\012\\012-- WARNING: Potential data lost!!!\\012-- WARNING: Potential data lost!!!\\012-- WARNING: Potential data lost!!!\\012\\012DROP TABLE SAMPLE_MATERIAL_BATCHES;\\012DROP TABLE MATERIAL_BATCHES;\\012DROP SEQUENCE MATERIAL_BATCH_ID_SEQ;\\012\\012------------------------------------------------------------------------------------\\012-- Delete MATE_ID_INHIBITOR_OF from table MATERIALS\\012------------------------------------------------------------------------------------\\012\\012-- WARNING: Potential data lost!!!\\012-- WARNING: Potential data lost!!!\\012-- WARNING: Potential data lost!!!\\012\\012ALTER TABLE MATERIALS DROP COLUMN MATE_ID_INHIBITOR_OF;\\012	\N
+./sourceTest/sql/postgresql/060/.svn/text-base/017=database_version_logs.tsv.svn-base:041	source/sql/postgresql/migration/migration-040-041.sql	SUCCESS	2009-09-14 13:48:57.539	-- Create FILTERS table\\012\\012CREATE TABLE FILTERS (ID TECH_ID NOT NULL, DBIN_ID TECH_ID NOT NULL, NAME VARCHAR(200) NOT NULL, DESCRIPTION DESCRIPTION_1000,REGISTRATION_TIMESTAMP TIME_STAMP_DFL NOT NULL DEFAULT CURRENT_TIMESTAMP, PERS_ID_REGISTERER TECH_ID NOT NULL, MODIFICATION_TIMESTAMP TIME_STAMP DEFAULT CURRENT_TIMESTAMP, EXPRESSION VARCHAR(2000) NOT NULL, IS_PUBLIC BOOLEAN NOT NULL, GRID_ID VARCHAR(200) NOT NULL);\\012CREATE SEQUENCE FILTER_ID_SEQ;\\012ALTER TABLE FILTERS ADD CONSTRAINT FILT_PK PRIMARY KEY(ID);\\012ALTER TABLE FILTERS ADD CONSTRAINT FILT_BK_UK UNIQUE(NAME, DBIN_ID, GRID_ID);\\012ALTER TABLE FILTERS ADD CONSTRAINT FILT_PERS_FK FOREIGN KEY (PERS_ID_REGISTERER) REFERENCES PERSONS(ID);\\012ALTER TABLE FILTERS ADD CONSTRAINT FILT_DBIN_FK FOREIGN KEY (DBIN_ID) REFERENCES DATABASE_INSTANCES(ID);\\012CREATE INDEX FILT_PERS_FK_I ON FILTERS (PERS_ID_REGISTERER);\\012CREATE INDEX FILT_DBIN_FK_I ON FILTERS (DBIN_ID);\\012GRANT SELECT ON SEQUENCE filter_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE filters TO GROUP OPENBIS_READONLY;\\012\\012-- Add missing foreign key to role assignments authorization group\\012ALTER TABLE ROLE_ASSIGNMENTS ADD CONSTRAINT ROAS_AG_FK_GRANTEE FOREIGN KEY (AG_ID_GRANTEE) REFERENCES AUTHORIZATION_GROUPS(ID);\\012\\012--------------------------------------------------------------------------------------------------\\012-- Modify dataset connections:\\012-- 1. connection with sample shouldn't be mandatory any more\\012-- 2. introduce an arc condition that dataset cannot be connected with a sample and a parent dataset at the same time\\012--------------------------------------------------------------------------------------------------\\012\\012-- Weaken data-sample connection constraint - allow dataset to have no connection with sample\\012ALTER TABLE data ALTER COLUMN samp_id DROP NOT NULL;\\012\\012-- Remove data-sample connection for datasets that have a parent\\012\\012UPDATE data \\012   SET samp_id = NULL \\012 WHERE id IN (SELECT DISTINCT data_id_child FROM data_set_relationships);\\012\\012-- With PostgreSQL 8.4 one can check that before migration there were no cycles in dataset relationships:\\012--\\012-- WITH RECURSIVE data_set_parents(id, parent_ids, cycle) AS (\\012--         SELECT  r.data_id_child AS id, \\012--                 ARRAY[CAST (r.data_id_parent AS bigint)] AS parent_ids, \\012--                 false AS cycle \\012--         FROM data_set_relationships r\\012--     UNION ALL\\012--         SELECT  r.data_id_child,\\012--                 CAST (r.data_id_parent AS bigint) || p.parent_ids,\\012--                 r.data_id_child = ANY(p.parent_ids)\\012--         FROM data_set_relationships r, data_set_parents p\\012--         WHERE r.data_id_parent = p.id AND NOT cycle\\012-- )\\012-- SELECT count(*) AS cycles FROM data_set_parents WHERE cycle = true;\\012\\012---------------------------------------------------------------------------------------------------\\012--  Purpose:  Create DEFERRED triggers:\\012--            * check_dataset_relationships_on_data_table_modification,\\012--            * check_dataset_relationships_on_relationships_table_modification.\\012--            They check that after all modifications of database (just before commit) \\012--            if 'data'/'data_set_relationships' tables are among modified tables \\012--            dataset is not connected with a sample and a parent dataset at the same time.\\012--            This connections are held in two different tables so simple immediate trigger \\012--            with arc check cannot be used and we need two deferred triggers.\\012----------------------------------------------------------------------------------------------------\\012\\012-- trigger for 'data' table\\012\\012CREATE OR REPLACE FUNCTION check_dataset_relationships_on_data_table_modification() RETURNS trigger AS $$\\012DECLARE\\012\\011counter\\011INTEGER;\\012BEGIN\\012\\011-- if there is a connection with a Sample there should not be any connection with a parent Data Set\\012\\011IF (NEW.samp_id IS NOT NULL) THEN\\012\\011\\011-- count number of parents\\012\\011\\011SELECT count(*) INTO counter \\012\\011\\011\\011FROM data_set_relationships \\012\\011\\011\\011WHERE data_id_child = OLD.id;\\012\\011\\011IF (counter > 0) THEN\\012\\011\\011\\011RAISE EXCEPTION 'Insert/Update of Data Set (Code: %) failed because it cannot be connected with a Sample and a parent Data Set at the same time.', OLD.code;\\012\\011\\011END IF;\\012\\011END IF;\\012  RETURN NEW;\\012END;\\012$$ LANGUAGE 'plpgsql';\\012\\012CREATE CONSTRAINT TRIGGER check_dataset_relationships_on_data_table_modification \\012  AFTER INSERT OR UPDATE ON data\\012\\011DEFERRABLE INITIALLY DEFERRED\\012\\011FOR EACH ROW \\012\\011EXECUTE PROCEDURE check_dataset_relationships_on_data_table_modification();\\012\\012-- trigger for 'data_set_relationships'\\012\\012CREATE OR REPLACE FUNCTION check_dataset_relationships_on_relationships_table_modification() RETURNS trigger AS $$\\012DECLARE\\012\\011counter\\011INTEGER;\\012\\011sample_id\\011TECH_ID;\\012\\011data_code\\011CODE;\\012BEGIN\\012\\011-- child will have a parent added so it should not be connected with any sample\\012\\011SELECT samp_id, code INTO sample_id, data_code \\012\\011\\011FROM data \\012\\011\\011WHERE id = NEW.data_id_child;\\012\\011IF (sample_id IS NOT NULL) THEN\\012\\011\\011RAISE EXCEPTION 'Insert/Update of Data Set (Code: %) failed because it cannot be connected to a Sample and to a parent Data Set at the same time.', data_code;\\012\\011END IF;\\012\\011RETURN NEW;\\012END;\\012$$ LANGUAGE 'plpgsql';\\012  \\012CREATE CONSTRAINT TRIGGER check_dataset_relationships_on_relationships_table_modification \\012  AFTER INSERT OR UPDATE ON data_set_relationships\\012\\011DEFERRABLE INITIALLY DEFERRED\\012\\011FOR EACH ROW \\012\\011EXECUTE PROCEDURE check_dataset_relationships_on_relationships_table_modification();\\012	\N
+./sourceTest/sql/postgresql/060/.svn/text-base/017=database_version_logs.tsv.svn-base:053	source/sql/postgresql/migration/migration-052-053.sql	SUCCESS	2010-06-08 15:27:55.032	-- Migration from 052 to 053\\012\\012-- Change code uniqueness check for samples of specific type.\\012-- If sample_types.is_subcode_unique flag is set to 'true', additional check is performed \\012-- on codes of samples of the type. Subcodes will have to be unique as well.\\012\\012ALTER TABLE sample_types ADD COLUMN is_subcode_unique boolean_char NOT NULL DEFAULT false;\\012\\012CREATE OR REPLACE FUNCTION SAMPLE_SUBCODE_UNIQUENESS_CHECK() RETURNS trigger AS $$\\012DECLARE\\012   counter  INTEGER;\\012   unique_subcode  BOOLEAN_CHAR;\\012BEGIN\\012  LOCK TABLE samples IN EXCLUSIVE MODE;\\012  \\012  SELECT is_subcode_unique into unique_subcode FROM sample_types WHERE id = NEW.saty_id;\\012  \\012  IF (unique_subcode) THEN\\012    IF (NEW.dbin_id is not NULL) THEN\\012\\011\\011\\011SELECT count(*) into counter FROM samples \\012\\011\\011\\011\\011where id != NEW.id and code = NEW.code and saty_id = NEW.saty_id and dbin_id = NEW.dbin_id;\\012\\011\\011\\011IF (counter > 0) THEN\\012\\011\\011\\011\\011RAISE EXCEPTION 'Insert/Update of Sample (Code: %) failed because database instance sample of the same type with the same subcode already exists.', NEW.code;\\012\\011\\011\\011END IF;\\012\\011\\011ELSIF (NEW.grou_id is not NULL) THEN\\012\\011\\011\\011SELECT count(*) into counter FROM samples \\012\\011\\011\\011\\011where id != NEW.id and code = NEW.code and saty_id = NEW.saty_id and grou_id = NEW.grou_id;\\012\\011\\011\\011IF (counter > 0) THEN\\012\\011\\011\\011\\011RAISE EXCEPTION 'Insert/Update of Sample (Code: %) failed because space sample of the same type with the same subcode already exists.', NEW.code;\\012\\011\\011\\011END IF;\\012\\011\\011END IF;\\012  END IF;\\012  \\012  RETURN NEW;\\012END;\\012$$ LANGUAGE 'plpgsql';\\012\\012CREATE TRIGGER SAMPLE_SUBCODE_UNIQUENESS_CHECK BEFORE INSERT OR UPDATE ON SAMPLES\\012    FOR EACH ROW EXECUTE PROCEDURE SAMPLE_SUBCODE_UNIQUENESS_CHECK();\\012    \\012-- Fixing error messages in old trigger\\012\\012CREATE OR REPLACE FUNCTION SAMPLE_CODE_UNIQUENESS_CHECK() RETURNS trigger AS $$\\012DECLARE\\012   counter  INTEGER;\\012BEGIN\\012  LOCK TABLE samples IN EXCLUSIVE MODE;\\012  \\012\\011  IF (NEW.samp_id_part_of is NULL) THEN\\012\\011\\011  IF (NEW.dbin_id is not NULL) THEN\\012\\011\\011\\011  SELECT count(*) into counter FROM samples \\012\\011\\011      where id != NEW.id and code = NEW.code and samp_id_part_of is NULL and dbin_id = NEW.dbin_id;\\012        IF (counter > 0) THEN\\012\\011\\011\\011\\011  RAISE EXCEPTION 'Insert/Update of Sample (Code: %) failed because database instance sample with the same code already exists.', NEW.code;\\012        END IF;\\012\\011\\011  ELSIF (NEW.grou_id is not NULL) THEN\\012\\011\\011\\011  SELECT count(*) into counter FROM samples \\012\\011\\011\\011\\011  where id != NEW.id and code = NEW.code and samp_id_part_of is NULL and grou_id = NEW.grou_id;\\012\\011\\011\\011  IF (counter > 0) THEN\\012\\011\\011\\011\\011  RAISE EXCEPTION 'Insert/Update of Sample (Code: %) failed because space sample with the same code already exists.', NEW.code;\\012\\011\\011\\011  END IF;\\012      END IF;\\012    ELSE\\012\\011\\011  IF (NEW.dbin_id is not NULL) THEN\\012\\011\\011\\011  SELECT count(*) into counter FROM samples \\012\\011\\011\\011\\011  where id != NEW.id and code = NEW.code and samp_id_part_of = NEW.samp_id_part_of and dbin_id = NEW.dbin_id;\\012\\011\\011\\011  IF (counter > 0) THEN\\012\\011\\011\\011\\011  RAISE EXCEPTION 'Insert/Update of Sample (Code: %) failed because database instance sample with the same code and being the part of the same container already exists.', NEW.code;\\012\\011\\011\\011  END IF;\\012\\011\\011  ELSIF (NEW.grou_id is not NULL) THEN\\012\\011\\011\\011  SELECT count(*) into counter FROM samples \\012\\011\\011\\011\\011  where id != NEW.id and code = NEW.code and samp_id_part_of = NEW.samp_id_part_of and grou_id = NEW.grou_id;\\012\\011\\011\\011  IF (counter > 0) THEN\\012\\011\\011\\011\\011  RAISE EXCEPTION 'Insert/Update of Sample (Code: %) failed because space sample with the same code and being the part of the same container already exists.', NEW.code;\\012\\011\\011\\011  END IF;\\012\\011\\011  END IF;\\012     END IF;   \\012  \\012  RETURN NEW;\\012END;\\012$$ LANGUAGE 'plpgsql';\\012	\N
+./sourceTest/sql/postgresql/060/.svn/text-base/017=database_version_logs.tsv.svn-base:054	source/sql/postgresql/migration/migration-053-054.sql	SUCCESS	2010-07-27 11:30:46.766	-- Migration from 053 to 054\\012\\012\\012-- Add RELATIONSHIP_TYPES table\\012CREATE TABLE relationship_types (id TECH_ID NOT NULL, code CODE NOT NULL, label COLUMN_LABEL, parent_label COLUMN_LABEL, child_label COLUMN_LABEL, description DESCRIPTION_2000, registration_timestamp TIME_STAMP_DFL NOT NULL DEFAULT CURRENT_TIMESTAMP, pers_id_registerer TECH_ID NOT NULL, is_managed_internally BOOLEAN_CHAR NOT NULL DEFAULT 'F', is_internal_namespace BOOLEAN_CHAR NOT NULL DEFAULT 'F', dbin_id TECH_ID NOT NULL);\\012\\012-- Add SAMPLE_RELATIONSHIPS table\\012CREATE TABLE sample_relationships (id TECH_ID NOT NULL, sample_id_parent TECH_ID NOT NULL, relationship_id TECH_ID NOT NULL, sample_id_child TECH_ID NOT NULL);\\012\\012-- Add/update constraints\\012ALTER TABLE relationship_types ADD CONSTRAINT rety_pk PRIMARY KEY (id);\\012ALTER TABLE relationship_types ADD CONSTRAINT rety_uk UNIQUE(code,dbin_id);\\012ALTER TABLE sample_relationships ADD CONSTRAINT sare_pk PRIMARY KEY (id);\\012ALTER TABLE sample_relationships ADD CONSTRAINT sare_bk_uk UNIQUE(sample_id_child,sample_id_parent,relationship_id);\\012ALTER TABLE sample_relationships ADD CONSTRAINT sare_data_fk_child FOREIGN KEY (sample_id_child) REFERENCES samples(id) ON DELETE CASCADE;\\012ALTER TABLE sample_relationships ADD CONSTRAINT sare_data_fk_parent FOREIGN KEY (sample_id_parent) REFERENCES samples(id) ON DELETE CASCADE;\\012ALTER TABLE sample_relationships ADD CONSTRAINT sare_data_fk_relationship FOREIGN KEY (relationship_id) REFERENCES relationship_types(id);\\012\\012-- Create index\\012CREATE INDEX sare_data_fk_i_child ON sample_relationships (sample_id_child);\\012CREATE INDEX sare_data_fk_i_parent ON sample_relationships (sample_id_parent);\\012CREATE INDEX sare_data_fk_i_relationship ON sample_relationships (relationship_id);\\012\\012-- Create sequence for RELATIONSHIP_TYPES\\012CREATE SEQUENCE RELATIONSHIP_TYPE_ID_SEQ;\\012CREATE SEQUENCE SAMPLE_RELATIONSHIP_ID_SEQ;\\012\\012-- Create initial relationships\\012insert into relationship_types\\012(id, \\012code, \\012label, \\012parent_label, \\012child_label, \\012description, \\012pers_id_registerer, \\012is_managed_internally, \\012is_internal_namespace, \\012dbin_id) \\012values\\012(\\012nextval('RELATIONSHIP_TYPE_ID_SEQ'),\\012'PARENT_CHILD',\\012'Parent - Child', \\012'Parent', \\012'Child', \\012'Parent - Child relationship', \\012(select id from persons where user_id ='system'), \\012'T', \\012'T', \\012(select id from database_instances where is_original_source = 'T')\\012);\\012\\012insert into relationship_types\\012(id, \\012code, \\012label, \\012parent_label, \\012child_label, \\012description, \\012pers_id_registerer, \\012is_managed_internally, \\012is_internal_namespace, \\012dbin_id) \\012values\\012(\\012nextval('RELATIONSHIP_TYPE_ID_SEQ'),\\012'PLATE_CONTROL_LAYOUT',\\012'Plate - Control Layout', \\012'Plate', \\012'Control Layout', \\012'Plate - Control Layout relationship', \\012(select id from persons where user_id ='system'), \\012'T', \\012'T', \\012(select id from database_instances where is_original_source = 'T')\\012); \\012\\012\\012-- Migrate sample relationships to new schema\\012INSERT INTO sample_relationships (id, sample_id_parent,sample_id_child,relationship_id) (select distinct nextval('SAMPLE_RELATIONSHIP_ID_SEQ') as id, s.SAMP_ID_GENERATED_FROM as parent_id, s.ID as child_id, rt.id as relationship_id from samples s, relationship_types rt  WHERE rt.code = 'PARENT_CHILD' and s.SAMP_ID_GENERATED_FROM is not null); \\012INSERT INTO sample_relationships (id, sample_id_parent,sample_id_child,relationship_id) (select distinct nextval('SAMPLE_RELATIONSHIP_ID_SEQ') as id, s.SAMP_ID_CONTROL_LAYOUT as parent_id, s.ID as child_id, rt.id as relationship_id from samples s, relationship_types rt  WHERE rt.code = 'PLATE_CONTROL_LAYOUT' and s.SAMP_ID_CONTROL_LAYOUT is not null);\\012\\012-- Drop old sample relations\\012ALTER TABLE SAMPLES DROP COLUMN SAMP_ID_TOP;\\012ALTER TABLE SAMPLES DROP COLUMN SAMP_ID_GENERATED_FROM;\\012ALTER TABLE SAMPLES DROP COLUMN SAMP_ID_CONTROL_LAYOUT;\\012\\012--------------------------------------------------------------------------------------\\012--------------------------------------------------------------------------------------\\012-- This is a screening specific migration. Nothing will be performed on openBIS databases \\012-- which are not screening specific.\\012-- \\012-- This migration for each existing connection between oligo well, oligo material and gene material\\012-- creates a direct connection between the well and the gene. \\012--------------------------------------------------------------------------------------\\012--------------------------------------------------------------------------------------\\012 \\012\\011\\012CREATE OR REPLACE FUNCTION CONNECT_WELLS_WITH_GENES() RETURNS void AS $$\\012DECLARE\\012\\011counter  int;\\012\\011oligo_well_exists bool;\\012BEGIN\\012\\011--------------------------------------------------\\012\\011-- create a gene property and assign it to oligo well\\012\\011--------------------------------------------------\\012\\011\\012\\011select true \\012\\011into oligo_well_exists\\012\\011from sample_types \\012\\011where code = 'OLIGO_WELL';\\012\\011\\012\\011if oligo_well_exists IS NULL then \\012\\011\\011-- skip migration if there are no oligo wells\\012\\011\\011return;\\012\\011end if;   \\012\\011\\012\\011insert into property_types(\\012\\011\\011id, \\012\\011\\011code, description, label, \\012\\011\\011daty_id,\\012\\011\\011pers_id_registerer,\\012\\011\\011dbin_id,\\012\\011\\011maty_prop_id) \\012\\011values(\\012\\011\\011\\011nextval('PROPERTY_TYPE_ID_SEQ'), \\012\\011\\011\\011'GENE','Inhibited gene','Gene',\\012\\011\\011\\011(select id from data_types where code = 'MATERIAL'), \\012\\011\\011\\011(select id from persons where user_id ='system'), \\012\\011\\011\\011(select id from database_instances where is_original_source = 'T'), \\012\\011\\011\\011(select id from material_types where code = 'GENE')\\012\\011\\011);\\012\\011\\011\\012\\011insert into sample_type_property_types( \\012\\011  id,\\012\\011  saty_id,\\012\\011  prty_id,\\012\\011  is_mandatory,\\012\\011  pers_id_registerer,\\012\\011  ordinal\\012\\011) values(\\012\\011\\011\\011nextval('stpt_id_seq'), \\012\\011\\011\\011(select id from sample_types where code = 'OLIGO_WELL'),\\012\\011\\011\\011(select id from property_types where code = 'GENE'),\\012\\011\\011\\011false,\\012\\011\\011\\011(select id from persons where user_id ='system'),\\012\\011\\011\\011(select max(ordinal)+1 from sample_type_property_types \\012\\011\\011\\011\\011where saty_id = (select id from sample_types where code = 'OLIGO_WELL'))\\012\\011\\011);\\012\\012\\011--------------------------------------------------\\012\\011-- create a gene material property for each oligo well\\012\\011--------------------------------------------------\\012\\011\\011\\012\\011select \\011count(*)\\012\\011into counter\\012\\011from\\012\\011\\011samples well, sample_types well_type, sample_properties well_props, \\012\\011\\011materials well_material, material_properties well_material_props,\\012\\011\\011materials nested_well_material\\012\\011where\\012\\011\\011well_type.code = 'OLIGO_WELL' and\\012\\011\\011-- find 'well_material' assigned to the well\\012\\011\\011well_props.samp_id = well.id and well_material.id = well_props.mate_prop_id and \\012\\011\\011-- additional joins to entity type tables\\012\\011\\011well_type.id = well.saty_id and\\012\\011\\011-- well content material property\\012\\011\\011well_material_props.mate_id = well_material.id and \\012\\011\\011-- material connected to the material in the well (e.g. gene)\\012\\011\\011well_material_props.mate_prop_id = nested_well_material.id and\\012\\011\\011nested_well_material.maty_id = (select id from material_types where code = 'GENE');\\012\\011\\012\\011if counter = 0 then \\012\\011\\011-- skip migration if there are no genes indirectly connected to oligo wells\\012\\011\\011return;\\012\\011end if;   \\012\\012\\011insert into sample_properties(id, samp_id, stpt_id, mate_prop_id, pers_id_registerer) (\\012\\011\\011select \\011nextval('sample_property_id_seq') id, \\012\\011\\011\\011well.id samp_id, \\012\\011\\011\\011(select stpt.id from sample_type_property_types stpt, property_types props where stpt.prty_id = props.id and props.code='GENE') stpt_id,\\012\\011\\011\\011nested_well_material.id mate_prop_id,\\012\\011\\011\\011(select id from persons where user_id ='system') pers_id_registerer \\012\\011\\011from\\012\\011\\011\\011samples well, sample_types well_type, sample_properties well_props, \\012\\011\\011\\011materials well_material, material_properties well_material_props,\\012\\011\\011\\011materials nested_well_material\\012\\011\\011where\\012\\011\\011\\011well_type.code = 'OLIGO_WELL' and\\012\\011\\011\\011-- find 'well_material' assigned to the well\\012\\011\\011\\011well_props.samp_id = well.id and well_material.id = well_props.mate_prop_id and \\012\\011\\011\\011-- additional joins to entity type tables\\012\\011\\011\\011well_type.id = well.saty_id and\\012\\011\\011\\011-- well content material property\\012\\011\\011\\011well_material_props.mate_id = well_material.id and \\012\\011\\011\\011-- material connected to the material in the well (e.g. gene)\\012\\011\\011\\011well_material_props.mate_prop_id = nested_well_material.id and\\012\\011\\011\\011nested_well_material.maty_id = (select id from material_types where code = 'GENE')\\012\\011);\\012\\012END;\\012$$ LANGUAGE 'plpgsql';\\012\\012select CONNECT_WELLS_WITH_GENES();\\012drop function CONNECT_WELLS_WITH_GENES();\\012\\012--------------------------------------------------------------------------------------\\012--------------------------------------------------------------------------------------\\012\\012-- drop dataset triggers\\012\\012DROP TRIGGER check_dataset_relationships_on_data_table_modification ON data;\\012DROP FUNCTION check_dataset_relationships_on_data_table_modification();\\012DROP TRIGGER check_dataset_relationships_on_relationships_table_modification ON data_set_relationships;\\012DROP FUNCTION check_dataset_relationships_on_relationships_table_modification();\\012 \\012\\012\\012\\012\\012\\012\\012\\012	\N
+./sourceTest/sql/postgresql/060/.svn/text-base/017=database_version_logs.tsv.svn-base:056	source/sql/postgresql/migration/migration-055-056.sql	SUCCESS	2010-09-10 09:06:20.278	-- Migration from 055 to 056\\012\\012--------------------------------------------------------------------------------------\\012--------------------------------------------------------------------------------------\\012-- Screening specific migration. Nothing will be performed on openBIS databases \\012-- which are not screening specific.\\012--------------------------------------------------------------------------------------\\012--------------------------------------------------------------------------------------\\012\\012CREATE OR REPLACE FUNCTION merge_words(text, text) RETURNS text AS $$\\012DECLARE\\012  BEGIN\\012    IF  character_length($1) > 0 THEN\\012      RETURN $1 || ' ' || $2;\\012    ELSE\\012      RETURN $2;\\012    END IF;\\012  END;\\012$$ LANGUAGE plpgsql;\\012\\012CREATE AGGREGATE merge_words(text)\\012(\\012  SFUNC = merge_words,\\012  STYPE = text\\012);\\012\\012\\012CREATE OR REPLACE FUNCTION REPLACE_GENE_SYMBOL_BY_GENE_ID() RETURNS void AS $$\\012DECLARE\\012\\011counter  int;\\012\\011library_id_assigned_to_gene bool;\\012BEGIN\\012\\011--------------------------------------------------\\012\\011-- create a GENE_SYMBOL property and assign it to GENE\\012\\011--------------------------------------------------\\012\\011\\012\\011select true  \\012\\011into library_id_assigned_to_gene \\012\\011from material_type_property_types mtpt, material_types mt, property_types pt  \\012\\011where mtpt.maty_id = mt.id and mtpt.prty_id = pt.id \\012\\011\\011and mt.code = 'GENE' and pt.code = 'LIBRARY_ID';\\012\\011\\012\\011if library_id_assigned_to_gene IS NULL then \\012\\011\\011-- skip migration if gene has no library_id property\\012\\011\\011return;\\012\\011end if; \\012\\011\\012\\011\\012\\011select count(*)\\012\\011into counter \\012\\011from  \\012\\011\\011(select m.id, count(mp.id) as c \\012\\011\\011\\011from materials m, material_types mt, material_properties mp, material_type_property_types mtpt, property_types pt \\012\\011\\011\\011where m.maty_id = mt.id and mp.mate_id = m.id and mp.mtpt_id = mtpt.id and mtpt.maty_id = mt.id and pt.id = mtpt.prty_id\\012\\011\\011\\011\\011and mt.code = 'GENE' and pt.code = 'LIBRARY_ID' \\012\\011\\011\\011group by m.id) as counter_table \\012\\011where c < 1; \\012\\011\\012\\011if counter > 0 then \\012\\011\\011-- skip migration if there is at least one gene without library_id\\012\\011\\011return;\\012\\011end if;\\012\\011\\012\\011\\012\\011insert into property_types\\012\\011\\011(id\\012\\011\\011,code\\012\\011\\011,description\\012\\011\\011,label\\012\\011\\011,daty_id\\012\\011\\011,pers_id_registerer\\012\\011\\011,dbin_id)\\012\\011values \\012\\011\\011(nextval('PROPERTY_TYPE_ID_SEQ')\\012\\011\\011,'GENE_SYMBOLS'\\012\\011\\011,'Gene symbols'\\012\\011\\011,'Gene symbols'\\012\\011\\011,(select id from data_types where code ='VARCHAR')\\012\\011\\011,(select id from persons where user_id ='system')\\012\\011\\011,(select id from database_instances where is_original_source = 'T')\\012\\011);\\012\\011\\011\\012\\011insert into material_type_property_types( \\012\\011  id,\\012\\011  maty_id,\\012\\011  prty_id,\\012\\011  is_mandatory,\\012\\011  pers_id_registerer,\\012\\011  ordinal\\012\\011) values(\\012\\011\\011\\011nextval('mtpt_id_seq'), \\012\\011\\011\\011(select id from material_types where code = 'GENE'),\\012\\011\\011\\011(select id from property_types where code = 'GENE_SYMBOLS'),\\012\\011\\011\\011false,\\012\\011\\011\\011(select id from persons where user_id ='system'),\\012\\011\\011\\011(select max(ordinal)+1 from material_type_property_types \\012\\011\\011\\011\\011where maty_id = (select id from material_types where code = 'GENE'))\\012\\011\\011);\\012\\012\\011--------------------------------------------------\\012\\011-- create temporary table with all gene migration information\\012\\011--------------------------------------------------\\012\\012\\011create temp table genes \\012\\011(\\012\\011\\011id tech_id,\\012\\011\\011code code,\\012\\011\\011library_id generic_value,\\012\\011\\011gene_codes generic_value,\\012\\011\\011new_id tech_id,\\012\\011\\011library_tech_id tech_id\\011\\011\\012\\011);\\012\\011\\012\\011insert into genes (id, code, library_id, library_tech_id)\\012\\011\\011(select m.id, m.code, mp.value as library_id, mp.id as library_tech_id from materials m, material_properties mp, material_type_property_types mtpt, property_types pt, material_types mt\\012\\011\\011where mp.mate_id = m.id and  mp.mtpt_id = mtpt.id and pt.id = mtpt.prty_id and pt.code = 'LIBRARY_ID' and mt.id = m.maty_id and mt.id = mtpt.maty_id and mt.code = 'GENE');\\012\\011\\012\\011update genes set new_id = map.to_id from (select g_from.id as from_id, min(g_to.id) as to_id  from genes g_from, genes g_to where g_from.library_id = g_to.library_id group by g_from.id) as map where map.from_id = id;\\011\\012\\011\\012\\011update genes set gene_codes = map.gene_codes from (select g_from.library_id as lib_id, merge_words(distinct g_to.code) as gene_codes from genes g_from, genes g_to where g_from.library_id = g_to.library_id group by g_from.library_id) as map where map.lib_id = library_id;\\011\\012\\012\\011--------------------------------------------------\\012\\011-- update gene references\\012\\011--------------------------------------------------\\012\\012\\011update EXPERIMENTS set MATE_ID_STUDY_OBJECT = genes.new_id from genes where genes.id = MATE_ID_STUDY_OBJECT and not genes.id = genes.new_id;\\012\\011update EXPERIMENT_PROPERTIES set  MATE_PROP_ID = genes.new_id from genes where genes.id = MATE_PROP_ID and not genes.id = genes.new_id;\\012\\011update MATERIAL_PROPERTIES set  MATE_PROP_ID = genes.new_id from genes where genes.id = MATE_PROP_ID and not genes.id = genes.new_id;\\012\\011update SAMPLE_PROPERTIES set  MATE_PROP_ID = genes.new_id from genes where genes.id = MATE_PROP_ID and not genes.id = genes.new_id;\\012\\011update DATA_SET_PROPERTIES set  MATE_PROP_ID = genes.new_id from genes where genes.id = MATE_PROP_ID and not genes.id = genes.new_id;\\012\\011\\012\\011delete from  material_properties where mate_id in (select id from genes where not genes.id = genes.new_id);\\012\\011delete from MATERIALS where id in (select id from genes where not genes.id = genes.new_id);\\012\\012\\011delete from genes where id in (select id from genes where not genes.id = genes.new_id);\\012\\012\\012\\011--------------------------------------------------\\012\\011-- replace gene code with library_id\\012\\011--------------------------------------------------\\012\\011\\012\\011update materials set code = genes.library_id from genes where materials.id = genes.id ;\\012\\011delete from material_properties where id in (select library_tech_id from genes);\\012\\011\\012\\011--------------------------------------------------\\012\\011-- create a gene symbols property for each gene\\012\\011--------------------------------------------------\\012\\011\\012\\011insert into material_properties\\012\\011\\011(id\\012\\011  , mate_id\\012\\011  , mtpt_id\\012\\011  , "value"\\012\\011  , pers_id_registerer)\\012\\011\\011(select nextval('material_property_id_seq') id\\012\\011  \\011, genes.id  mate_id\\012\\011    , (select mtpt.id\\012\\011    \\011\\011from   material_type_property_types mtpt, material_types mt, property_types pt\\012\\011    \\011\\011where  pt.code = 'GENE_SYMBOLS' and mt.code = 'GENE' and mtpt.prty_id = pt.id\\012\\011        \\011and mtpt.maty_id = mt.id) mtpt_id\\012\\011    , genes.gene_codes "value"\\012\\011    , (select id from persons where user_id = 'system') pers_id_registerer\\012\\011 \\011from genes); \\012\\012\\011--------------------------------------------------\\012\\011-- delete temporary table\\012\\011--------------------------------------------------\\012\\011\\012\\011drop table genes;\\012\\011\\012END;\\012$$ LANGUAGE 'plpgsql';\\012\\012select REPLACE_GENE_SYMBOL_BY_GENE_ID();\\012drop function REPLACE_GENE_SYMBOL_BY_GENE_ID();\\012DROP AGGREGATE merge_words(text);\\012drop function merge_words(text,text);\\012\\012\\012--------------------------------------------------------------------------------------\\012--------------------------------------------------------------------------------------\\012\\012UPDATE sample_types SET code = 'SIRNA_WELL' WHERE code = 'OLIGO_WELL';\\012UPDATE material_types SET code = 'SIRNA' WHERE code = 'OLIGO';\\012UPDATE property_types SET code = 'SIRNA', label = 'siRNA' WHERE code = 'OLIGO';\\012\\012\\012\\012\\012\\012\\012\\012\\012\\012\\012\\012\\012\\012\\012\\012\\012\\012\\012\\012	\N
+./sourceTest/sql/postgresql/060/.svn/text-base/017=database_version_logs.tsv.svn-base:059	source/sql/postgresql/migration/migration-058-059.sql	SUCCESS	2010-09-29 13:37:07.231	-- Migration from 058 to 059\\012\\012-- Add ENTITY_TYPE_CODE column to QUERIES\\012ALTER TABLE queries ADD COLUMN entity_type_code CODE;\\012\\012------------------------------------------------------------------------------------\\012--  Purpose:  Create trigger that checks if entity_type_code specified in a query\\012--            matches a code of an entity of type specified in query_type.\\012------------------------------------------------------------------------------------\\012\\012CREATE OR REPLACE FUNCTION query_entity_type_code_check() RETURNS trigger AS $$\\012DECLARE\\012   counter  INTEGER;\\012BEGIN\\012   if (NEW.entity_type_code IS NOT NULL) then\\012     if (NEW.query_type = 'GENERIC') then\\012       RAISE EXCEPTION 'Insert/Update of query (Name: %) failed, as entity_type has to be null for GENERIC queries.', NEW.name;\\012     elsif (NEW.query_type = 'EXPERIMENT') then\\012       SELECT count(*) INTO counter FROM experiment_types WHERE code = NEW.entity_type_code;\\012\\011\\011 elsif (NEW.query_type = 'DATA_SET') then\\012       SELECT count(*) INTO counter FROM data_set_types WHERE code = NEW.entity_type_code;\\012\\011\\011 elsif (NEW.query_type = 'MATERIAL') then\\012       SELECT count(*) INTO counter FROM material_types WHERE code = NEW.entity_type_code;\\012\\011\\011 elsif (NEW.query_type = 'SAMPLE') then\\012       SELECT count(*) INTO counter FROM sample_types WHERE code = NEW.entity_type_code;\\012\\011\\011 end if;\\012\\011\\011 if (counter = 0) then\\012\\011\\011\\011 RAISE EXCEPTION 'Insert/Update of query (Name: %) failed because % type (Code: %) does not exist.', NEW.name, NEW.query_type, NEW.entity_type_code;\\012\\011\\011 end if;\\011\\011\\011\\012   end if;\\012   RETURN NEW;\\012END;\\012$$ LANGUAGE 'plpgsql';\\012\\012CREATE TRIGGER query_entity_type_code_check BEFORE INSERT OR UPDATE ON queries\\012    FOR EACH ROW EXECUTE PROCEDURE query_entity_type_code_check();\\012	\N
+./sourceTest/sql/postgresql/060/.svn/text-base/schema-060.sql.svn-base:    LANGUAGE plpgsql
+./sourceTest/sql/postgresql/060/.svn/text-base/schema-060.sql.svn-base:    LANGUAGE plpgsql
+./sourceTest/sql/postgresql/060/.svn/text-base/schema-060.sql.svn-base:    LANGUAGE plpgsql
+./sourceTest/sql/postgresql/060/.svn/text-base/schema-060.sql.svn-base:    LANGUAGE plpgsql
+./sourceTest/sql/postgresql/060/.svn/text-base/schema-060.sql.svn-base:    LANGUAGE plpgsql
+./sourceTest/sql/postgresql/060/.svn/text-base/schema-060.sql.svn-base:    LANGUAGE plpgsql
+./sourceTest/sql/postgresql/060/.svn/text-base/schema-060.sql.svn-base:    LANGUAGE plpgsql
+./sourceTest/sql/postgresql/060/.svn/text-base/schema-060.sql.svn-base:    LANGUAGE plpgsql
+./sourceTest/sql/postgresql/060/.svn/text-base/schema-060.sql.svn-base:    LANGUAGE plpgsql
+./sourceTest/sql/postgresql/060/017=database_version_logs.tsv:027	D:\\User\\felmer\\dev-workspace\\openbis/source/sql/postgresql/027/function-027.sql	SUCCESS	2008-11-05 09:18:00.403	-- Creating Functions\\012\\012------------------------------------------------------------------------------------\\012--  Purpose:  Create function RENAME_SEQUENCE() that is required for renaming the sequences belonging to tables\\012------------------------------------------------------------------------------------\\012CREATE FUNCTION RENAME_SEQUENCE(OLD_NAME VARCHAR, NEW_NAME VARCHAR) RETURNS INTEGER AS $$\\012DECLARE\\012  CURR_SEQ_VAL   INTEGER;\\012BEGIN\\012  SELECT INTO CURR_SEQ_VAL NEXTVAL(OLD_NAME);\\012  EXECUTE 'CREATE SEQUENCE ' || NEW_NAME || ' START WITH ' || CURR_SEQ_VAL;\\012  EXECUTE 'DROP SEQUENCE ' || OLD_NAME;\\012  RETURN CURR_SEQ_VAL;\\012END;\\012$$ LANGUAGE 'plpgsql';\\012\\012\\012------------------------------------------------------------------------------------\\012--  Purpose:  Create trigger CONTROLLED_VOCABULARY_CHECK \\012------------------------------------------------------------------------------------\\012\\012CREATE OR REPLACE FUNCTION CONTROLLED_VOCABULARY_CHECK() RETURNS trigger AS $$\\012DECLARE\\012   v_code  CODE;\\012BEGIN\\012\\012   select code into v_code from data_types where id = NEW.daty_id;\\012\\012   -- Check if the data is of type "CONTROLLEDVOCABULARY"\\012   if v_code = 'CONTROLLEDVOCABULARY' then\\012      if NEW.covo_id IS NULL then\\012         RAISE EXCEPTION 'Insert/Update of Property Type (Code: %) failed, as its Data Type is CONTROLLEDVOCABULARY, but it is not linked to a Controlled Vocabulary.', NEW.code;\\012      end if;\\012   end if;\\012\\012   RETURN NEW;\\012\\012END;\\012$$ LANGUAGE 'plpgsql';\\012\\012CREATE TRIGGER CONTROLLED_VOCABULARY_CHECK BEFORE INSERT OR UPDATE ON PROPERTY_TYPES\\012    FOR EACH ROW EXECUTE PROCEDURE CONTROLLED_VOCABULARY_CHECK();\\012\\012\\012------------------------------------------------------------------------------------\\012--  Purpose:  Create trigger EXTERNAL_DATA_STORAGE_FORMAT_CHECK \\012------------------------------------------------------------------------------------\\012\\012CREATE OR REPLACE FUNCTION EXTERNAL_DATA_STORAGE_FORMAT_CHECK() RETURNS trigger AS $$\\012DECLARE\\012   v_covo_code  CODE;\\012   data_code CODE;\\012BEGIN\\012\\012   select code into v_covo_code from controlled_vocabularies\\012      where is_internal_namespace = true and \\012         id = (select covo_id from controlled_vocabulary_terms where id = NEW.cvte_id_stor_fmt);\\012   -- Check if the data storage format is a term of the controlled vocabulary "STORAGE_FORMAT"\\012   if v_covo_code != 'STORAGE_FORMAT' then\\012      select code into data_code from data where id = NEW.data_id; \\012      RAISE EXCEPTION 'Insert/Update of Data (Code: %) failed, as its Storage Format is %, but is required to be STORAGE_FORMAT.', data_code, v_covo_code;\\012   end if;\\012\\012   RETURN NEW;\\012\\012END;\\012$$ LANGUAGE 'plpgsql';\\012\\012CREATE TRIGGER EXTERNAL_DATA_STORAGE_FORMAT_CHECK BEFORE INSERT OR UPDATE ON EXTERNAL_DATA\\012    FOR EACH ROW EXECUTE PROCEDURE EXTERNAL_DATA_STORAGE_FORMAT_CHECK();\\012\\012------------------------------------------------------------------------------------\\012--  Purpose:  Create trigger SAMPLE_CODE_UNIQUENESS_CHECK \\012------------------------------------------------------------------------------------\\012\\012CREATE OR REPLACE FUNCTION SAMPLE_CODE_UNIQUENESS_CHECK() RETURNS trigger AS $$\\012DECLARE\\012   counter  INTEGER;\\012BEGIN\\012\\011IF (NEW.samp_id_part_of is NULL) THEN\\012\\011\\011IF (NEW.dbin_id is not NULL) THEN\\012\\011\\011\\011SELECT count(*) into counter FROM samples \\012\\011\\011\\011\\011where id != NEW.id and code = NEW.code and samp_id_part_of is NULL and dbin_id = NEW.dbin_id;\\012\\011\\011\\011IF (counter > 0) THEN\\012\\011\\011\\011\\011RAISE EXCEPTION 'Insert/Update of Sample (Code: %) failed because database instance sample with the same code already exists.', NEW.code;\\012\\011\\011\\011END IF;\\012\\011\\011ELSIF (NEW.grou_id is not NULL) THEN\\012\\011\\011\\011SELECT count(*) into counter FROM samples \\012\\011\\011\\011\\011where id != NEW.id and code = NEW.code and samp_id_part_of is NULL and grou_id = NEW.grou_id;\\012\\011\\011\\011IF (counter > 0) THEN\\012\\011\\011\\011\\011RAISE EXCEPTION 'Insert/Update of Sample (Code: %) failed because group sample with the same code already exists.', NEW.code;\\012\\011\\011\\011END IF;\\012\\011\\011END IF;\\012        ELSE\\012\\011\\011IF (NEW.dbin_id is not NULL) THEN\\012\\011\\011\\011SELECT count(*) into counter FROM samples \\012\\011\\011\\011\\011where id != NEW.id and code = NEW.code and samp_id_part_of = NEW.samp_id_part_of and dbin_id = NEW.dbin_id;\\012\\011\\011\\011IF (counter > 0) THEN\\012\\011\\011\\011\\011RAISE EXCEPTION 'Insert/Update of Sample (Code: %) failed because database instance sample with the same code and being the part of the same parent already exists.', NEW.code;\\012\\011\\011\\011END IF;\\012\\011\\011ELSIF (NEW.grou_id is not NULL) THEN\\012\\011\\011\\011SELECT count(*) into counter FROM samples \\012\\011\\011\\011\\011where id != NEW.id and code = NEW.code and samp_id_part_of = NEW.samp_id_part_of and grou_id = NEW.grou_id;\\012\\011\\011\\011IF (counter > 0) THEN\\012\\011\\011\\011\\011RAISE EXCEPTION 'Insert/Update of Sample (Code: %) failed because group sample with the same code and being the part of the same parent already exists.', NEW.code;\\012\\011\\011\\011END IF;\\012\\011\\011END IF;\\012        END IF;   \\012   RETURN NEW;\\012END;\\012$$ LANGUAGE 'plpgsql';\\012\\012CREATE TRIGGER SAMPLE_CODE_UNIQUENESS_CHECK BEFORE INSERT OR UPDATE ON SAMPLES\\012    FOR EACH ROW EXECUTE PROCEDURE SAMPLE_CODE_UNIQUENESS_CHECK();\\012	\N
+./sourceTest/sql/postgresql/060/017=database_version_logs.tsv:028	source/sql/postgresql/migration/migration-027-028.sql	SUCCESS	2008-11-18 13:24:17.508	-- Create EXPERIMENT_ATTACHMENT_CONTENTS.\\012CREATE TABLE EXPERIMENT_ATTACHMENT_CONTENTS (ID TECH_ID NOT NULL,VALUE FILE NOT NULL);\\012CREATE SEQUENCE EXPERIMENT_ATTACHMENT_CONTENT_ID_SEQ;\\012ALTER TABLE EXPERIMENT_ATTACHMENT_CONTENTS ADD CONSTRAINT EXAC_PK PRIMARY KEY(ID);\\012\\012-- Alter EXPERIMENT_ATTACHMENTS by adding the new column which has a NULL constraint.\\012-- The NOT NULL constraint is added later on.\\012ALTER TABLE EXPERIMENT_ATTACHMENTS ADD COLUMN EXAC_ID TECH_ID;\\012\\012-- Does the VALUE migration between EXPERIMENT_ATTACHMENTS to EXPERIMENT_ATTACHMENT_CONTENTS.\\012CREATE OR REPLACE FUNCTION move_exp_att_content() RETURNS integer AS $$\\012DECLARE\\012    rec RECORD;\\012    seq BIGINT;\\012BEGIN\\012  FOR rec IN SELECT id, value FROM EXPERIMENT_ATTACHMENTS LOOP\\012  \\011seq := nextval('EXPERIMENT_ATTACHMENT_CONTENT_ID_SEQ');\\012    INSERT INTO EXPERIMENT_ATTACHMENT_CONTENTS (id, value) VALUES (seq, rec.value);\\012    UPDATE EXPERIMENT_ATTACHMENTS SET exac_id = seq WHERE id = rec.id;\\012  END LOOP;\\012  RETURN 1;\\012END;\\012$$ LANGUAGE 'plpgsql';\\012\\012-- Call the function.\\012SELECT move_exp_att_content();\\012DROP FUNCTION move_exp_att_content();\\012\\012\\012-- Finish EXPERIMENT_ATTACHMENTS changes.\\012ALTER TABLE EXPERIMENT_ATTACHMENTS ADD CONSTRAINT EXAT_CONT_FK FOREIGN KEY (EXAC_ID) REFERENCES EXPERIMENT_ATTACHMENT_CONTENTS(ID);\\012ALTER TABLE EXPERIMENT_ATTACHMENTS DROP COLUMN VALUE;\\012ALTER TABLE EXPERIMENT_ATTACHMENTS ALTER COLUMN EXAC_ID SET NOT NULL;\\012	\N
+./sourceTest/sql/postgresql/060/017=database_version_logs.tsv:029	source/sql/postgresql/migration/migration-028-029.sql	SUCCESS	2009-03-18 10:50:20.105	-- -------\\012-- add modification_timestamp field to allow edition with Hibernate\\012-- -------\\012\\012ALTER TABLE samples\\012\\011ADD COLUMN modification_timestamp TIME_STAMP DEFAULT CURRENT_TIMESTAMP;\\012\\012ALTER TABLE experiments\\012\\011ADD COLUMN modification_timestamp TIME_STAMP DEFAULT CURRENT_TIMESTAMP;\\012\\012ALTER TABLE materials\\012\\011ADD COLUMN modification_timestamp TIME_STAMP DEFAULT CURRENT_TIMESTAMP;\\012\\012ALTER TABLE experiment_properties\\012\\011ADD COLUMN modification_timestamp TIME_STAMP DEFAULT CURRENT_TIMESTAMP;\\012\\012ALTER TABLE material_properties\\012\\011ADD COLUMN modification_timestamp TIME_STAMP DEFAULT CURRENT_TIMESTAMP;\\012\\012ALTER TABLE sample_properties\\012\\011ADD COLUMN modification_timestamp TIME_STAMP DEFAULT CURRENT_TIMESTAMP;\\012\\012-- -------\\012-- add property data type which references materials\\012-- -------\\012\\012ALTER TABLE property_types\\012\\011ADD COLUMN maty_prop_id tech_id;\\012\\012ALTER TABLE property_types\\012\\011ADD CONSTRAINT prty_maty_fk FOREIGN KEY (maty_prop_id) REFERENCES material_types(id);\\012\\012ALTER TABLE experiment_properties\\012\\011ADD COLUMN mate_prop_id tech_id;\\012\\012ALTER TABLE material_properties\\012\\011ADD COLUMN mate_prop_id tech_id;\\012\\012ALTER TABLE sample_properties\\012\\011ADD COLUMN mate_prop_id tech_id;\\012\\012ALTER TABLE experiment_properties\\012\\011ADD CONSTRAINT expr_mapr_fk FOREIGN KEY (mate_prop_id) REFERENCES materials(id);\\012\\012ALTER TABLE material_properties\\012\\011ADD CONSTRAINT mapr_mapr_fk FOREIGN KEY (mate_prop_id) REFERENCES materials(id);\\012\\012ALTER TABLE sample_properties\\012\\011ADD CONSTRAINT sapr_mapr_fk FOREIGN KEY (mate_prop_id) REFERENCES materials(id);\\012\\012insert into data_types\\012(id\\012 ,code\\012 ,description)\\012 values \\012 (nextval('DATA_TYPE_ID_SEQ')\\012 ,'MATERIAL'\\012 ,'Reference to a material'\\012);\\012\\012ALTER TABLE MATERIAL_PROPERTIES DROP CONSTRAINT MAPR_CK;\\012ALTER TABLE MATERIAL_PROPERTIES ADD CONSTRAINT MAPR_CK CHECK \\012\\011((VALUE IS NOT NULL AND CVTE_ID IS NULL AND MATE_PROP_ID IS NULL) OR \\012\\011 (VALUE IS NULL AND CVTE_ID IS NOT NULL AND MATE_PROP_ID IS NULL) OR\\012\\011 (VALUE IS NULL AND CVTE_ID IS NULL AND MATE_PROP_ID IS NOT NULL)\\012\\011);\\012\\012ALTER TABLE EXPERIMENT_PROPERTIES DROP CONSTRAINT EXPR_CK;\\012ALTER TABLE EXPERIMENT_PROPERTIES ADD CONSTRAINT EXPR_CK CHECK \\012\\011((VALUE IS NOT NULL AND CVTE_ID IS NULL AND MATE_PROP_ID IS NULL) OR \\012\\011 (VALUE IS NULL AND CVTE_ID IS NOT NULL AND MATE_PROP_ID IS NULL) OR\\012\\011 (VALUE IS NULL AND CVTE_ID IS NULL AND MATE_PROP_ID IS NOT NULL)\\012\\011);\\012\\012ALTER TABLE SAMPLE_PROPERTIES DROP CONSTRAINT SAPR_CK;\\012ALTER TABLE SAMPLE_PROPERTIES ADD CONSTRAINT SAPR_CK CHECK \\012\\011((VALUE IS NOT NULL AND CVTE_ID IS NULL AND MATE_PROP_ID IS NULL) OR \\012\\011 (VALUE IS NULL AND CVTE_ID IS NOT NULL AND MATE_PROP_ID IS NULL) OR\\012\\011 (VALUE IS NULL AND CVTE_ID IS NULL AND MATE_PROP_ID IS NOT NULL)\\012\\011);\\012\\012------------------------------------------------------------------------------------\\012--  Purpose:  Create trigger MATERIAL/SAMPLE/EXPERIMENT _PROPERTY_WITH_MATERIAL_DATA_TYPE_CHECK\\012--            It checks that if material property value is assigned to the entity,\\012--\\011\\011\\011\\011\\011\\011then the material type is equal to the one described by property type.\\012------------------------------------------------------------------------------------\\012\\012CREATE OR REPLACE FUNCTION MATERIAL_PROPERTY_WITH_MATERIAL_DATA_TYPE_CHECK() RETURNS trigger AS $$\\012DECLARE\\012   v_type_id  CODE;\\012   v_type_id_prop  CODE;\\012BEGIN\\012   if NEW.mate_prop_id IS NOT NULL then\\012\\011\\011\\011-- find material type id of the property type \\012\\011\\011\\011select pt.maty_prop_id into v_type_id_prop \\012\\011\\011\\011  from material_type_property_types etpt, property_types pt \\012\\011\\011\\011 where NEW.mtpt_id = etpt.id AND etpt.prty_id = pt.id;\\012\\011\\011\\012\\011\\011\\011if v_type_id_prop IS NOT NULL then\\012\\011\\011\\011\\011-- find material type id of the material which consists the entity's property value\\012\\011\\011\\011\\011select entity.maty_id into v_type_id \\012\\011\\011\\011\\011  from materials entity\\012\\011\\011\\011\\011 where NEW.mate_prop_id = entity.id;\\012\\011\\011\\011\\011if v_type_id != v_type_id_prop then\\012\\011\\011\\011\\011\\011RAISE EXCEPTION 'Insert/Update of property value referencing material (id: %) failed, as referenced material type is different than expected (id %, expected id: %).', \\012\\011\\011\\011\\011\\011\\011\\011 NEW.mate_prop_id, v_type_id, v_type_id_prop;\\012\\011\\011\\011\\011end if;\\012\\011\\011\\011end if;\\012   end if;\\012   RETURN NEW;\\012END;\\012$$ LANGUAGE 'plpgsql';\\012\\012CREATE TRIGGER MATERIAL_PROPERTY_WITH_MATERIAL_DATA_TYPE_CHECK BEFORE INSERT OR UPDATE ON material_properties\\012    FOR EACH ROW EXECUTE PROCEDURE MATERIAL_PROPERTY_WITH_MATERIAL_DATA_TYPE_CHECK();\\012    \\012CREATE OR REPLACE FUNCTION SAMPLE_PROPERTY_WITH_MATERIAL_DATA_TYPE_CHECK() RETURNS trigger AS $$\\012DECLARE\\012   v_type_id  CODE;\\012   v_type_id_prop  CODE;\\012BEGIN\\012   if NEW.mate_prop_id IS NOT NULL then\\012\\011\\011\\011-- find material type id of the property type \\012\\011\\011\\011select pt.maty_prop_id into v_type_id_prop \\012\\011\\011\\011  from sample_type_property_types etpt, property_types pt \\012\\011\\011\\011 where NEW.stpt_id = etpt.id AND etpt.prty_id = pt.id;\\012\\011\\011\\012\\011\\011\\011if v_type_id_prop IS NOT NULL then\\012\\011\\011\\011\\011-- find material type id of the material which consists the entity's property value\\012\\011\\011\\011\\011select entity.maty_id into v_type_id \\012\\011\\011\\011\\011  from materials entity\\012\\011\\011\\011\\011 where NEW.mate_prop_id = entity.id;\\012\\011\\011\\011\\011if v_type_id != v_type_id_prop then\\012\\011\\011\\011\\011\\011RAISE EXCEPTION 'Insert/Update of property value referencing material (id: %) failed, as referenced material type is different than expected (id %, expected id: %).', \\012\\011\\011\\011\\011\\011\\011\\011\\011\\011\\011\\011\\011 NEW.mate_prop_id, v_type_id, v_type_id_prop;\\012\\011\\011\\011\\011end if;\\012\\011\\011\\011end if;\\012   end if;\\012   RETURN NEW;\\012END;\\012$$ LANGUAGE 'plpgsql';\\012\\012CREATE TRIGGER SAMPLE_PROPERTY_WITH_MATERIAL_DATA_TYPE_CHECK BEFORE INSERT OR UPDATE ON sample_properties\\012    FOR EACH ROW EXECUTE PROCEDURE SAMPLE_PROPERTY_WITH_MATERIAL_DATA_TYPE_CHECK();\\012    \\012CREATE OR REPLACE FUNCTION EXPERIMENT_PROPERTY_WITH_MATERIAL_DATA_TYPE_CHECK() RETURNS trigger AS $$\\012DECLARE\\012   v_type_id  CODE;\\012   v_type_id_prop  CODE;\\012BEGIN\\012   if NEW.mate_prop_id IS NOT NULL then\\012\\011\\011\\011-- find material type id of the property type \\012\\011\\011\\011select pt.maty_prop_id into v_type_id_prop \\012\\011\\011\\011  from experiment_type_property_types etpt, property_types pt \\012\\011\\011\\011 where NEW.etpt_id = etpt.id AND etpt.prty_id = pt.id;\\012\\011\\011\\012\\011\\011\\011if v_type_id_prop IS NOT NULL then\\012\\011\\011\\011\\011-- find material type id of the material which consists the entity's property value\\012\\011\\011\\011\\011select entity.maty_id into v_type_id \\012\\011\\011\\011\\011  from materials entity\\012\\011\\011\\011\\011 where NEW.mate_prop_id = entity.id;\\012\\011\\011\\011\\011if v_type_id != v_type_id_prop then\\012\\011\\011\\011\\011\\011RAISE EXCEPTION 'Insert/Update of property value referencing material (id: %) failed, as referenced material type is different than expected (id %, expected id: %).', \\012\\011\\011\\011\\011\\011\\011\\011\\011\\011\\011\\011\\011 NEW.mate_prop_id, v_type_id, v_type_id_prop;\\012\\011\\011\\011\\011end if;\\012\\011\\011\\011end if;\\012   end if;\\012   RETURN NEW;\\012END;\\012$$ LANGUAGE 'plpgsql';\\012\\012CREATE TRIGGER EXPERIMENT_PROPERTY_WITH_MATERIAL_DATA_TYPE_CHECK BEFORE INSERT OR UPDATE ON experiment_properties\\012    FOR EACH ROW EXECUTE PROCEDURE EXPERIMENT_PROPERTY_WITH_MATERIAL_DATA_TYPE_CHECK();\\012       \\012-- -------\\012-- remove the reminescents of the OBSERVABLE_TYPE\\012-- -------\\012\\012ALTER TABLE data\\012\\011DROP CONSTRAINT data_obty_fk;\\012\\012ALTER TABLE data_set_types\\012\\011DROP CONSTRAINT obty_pk;\\012\\012ALTER TABLE data_set_types\\012\\011ADD CONSTRAINT dsty_pk PRIMARY KEY (id);\\012\\012ALTER TABLE data\\012\\011ADD CONSTRAINT data_dsty_fk FOREIGN KEY (dsty_id) REFERENCES data_set_types(id);\\012\\012ALTER TABLE data_set_types\\012\\011DROP CONSTRAINT obty_bk_uk;\\012\\012ALTER TABLE data_set_types\\012\\011DROP CONSTRAINT obty_dbin_fk;\\012\\012ALTER TABLE data_set_types\\012\\011ADD CONSTRAINT dsty_bk_uk UNIQUE (code, dbin_id);\\012\\012ALTER TABLE data_set_types\\012\\011ADD CONSTRAINT dsty_dbin_fk FOREIGN KEY (dbin_id) REFERENCES database_instances(id);\\012\\012DROP INDEX data_obty_fk_i;\\012\\012CREATE INDEX data_dsty_fk_i ON data(dsty_id);\\012	\N
+./sourceTest/sql/postgresql/060/017=database_version_logs.tsv:030	source/sql/postgresql/migration/migration-029-030.sql	SUCCESS	2009-03-23 15:34:44.72	-- -------\\012-- add modification_timestamp field to allow edition with Hibernate\\012-- -------\\012ALTER TABLE data\\012\\011ADD COLUMN modification_timestamp TIME_STAMP DEFAULT CURRENT_TIMESTAMP;\\012ALTER TABLE experiment_types\\012\\011ADD COLUMN modification_timestamp TIME_STAMP DEFAULT CURRENT_TIMESTAMP;\\012ALTER TABLE sample_types\\012\\011ADD COLUMN modification_timestamp TIME_STAMP DEFAULT CURRENT_TIMESTAMP;\\012ALTER TABLE material_types\\012\\011ADD COLUMN modification_timestamp TIME_STAMP DEFAULT CURRENT_TIMESTAMP;\\012ALTER TABLE data_set_types\\012\\011ADD COLUMN modification_timestamp TIME_STAMP DEFAULT CURRENT_TIMESTAMP;\\012ALTER TABLE controlled_vocabularies\\012\\011ADD COLUMN modification_timestamp TIME_STAMP DEFAULT CURRENT_TIMESTAMP;\\012-- -------\\012-- add properties to data sets\\012-- -------\\012CREATE TABLE DATA_SET_PROPERTIES (ID TECH_ID NOT NULL,DS_ID TECH_ID NOT NULL,DSTPT_ID TECH_ID NOT NULL,VALUE GENERIC_VALUE,CVTE_ID TECH_ID, MATE_PROP_ID TECH_ID, PERS_ID_REGISTERER TECH_ID NOT NULL,REGISTRATION_TIMESTAMP TIME_STAMP_DFL NOT NULL DEFAULT CURRENT_TIMESTAMP, MODIFICATION_TIMESTAMP TIME_STAMP DEFAULT CURRENT_TIMESTAMP);\\012CREATE TABLE DATA_SET_TYPE_PROPERTY_TYPES (ID TECH_ID NOT NULL,DSTY_ID TECH_ID NOT NULL,PRTY_ID TECH_ID NOT NULL,IS_MANDATORY BOOLEAN_CHAR NOT NULL DEFAULT 'F',IS_MANAGED_INTERNALLY BOOLEAN_CHAR NOT NULL DEFAULT 'F',PERS_ID_REGISTERER TECH_ID NOT NULL,REGISTRATION_TIMESTAMP TIME_STAMP_DFL NOT NULL DEFAULT CURRENT_TIMESTAMP);\\012\\012CREATE SEQUENCE DATA_SET_PROPERTY_ID_SEQ;\\012CREATE SEQUENCE DSTPT_ID_SEQ;\\012\\012ALTER TABLE DATA_SET_TYPE_PROPERTY_TYPES ADD CONSTRAINT DSTPT_PK PRIMARY KEY(ID);\\012ALTER TABLE DATA_SET_PROPERTIES ADD CONSTRAINT DSPR_PK PRIMARY KEY(ID);\\012\\012ALTER TABLE DATA_SET_TYPE_PROPERTY_TYPES ADD CONSTRAINT DSTPT_BK_UK UNIQUE(DSTY_ID,PRTY_ID);\\012ALTER TABLE DATA_SET_PROPERTIES ADD CONSTRAINT DSPR_BK_UK UNIQUE(DS_ID,DSTPT_ID);\\012\\012\\012ALTER TABLE DATA_SET_TYPE_PROPERTY_TYPES ADD CONSTRAINT DSTPT_DSTY_FK FOREIGN KEY (DSTY_ID) REFERENCES DATA_SET_TYPES(ID);\\012ALTER TABLE DATA_SET_TYPE_PROPERTY_TYPES ADD CONSTRAINT DSTPT_PERS_FK FOREIGN KEY (PERS_ID_REGISTERER) REFERENCES PERSONS(ID);\\012ALTER TABLE DATA_SET_TYPE_PROPERTY_TYPES ADD CONSTRAINT DSTPT_PRTY_FK FOREIGN KEY (PRTY_ID) REFERENCES PROPERTY_TYPES(ID);\\012ALTER TABLE DATA_SET_PROPERTIES ADD CONSTRAINT DSPR_CVTE_FK FOREIGN KEY (CVTE_ID) REFERENCES CONTROLLED_VOCABULARY_TERMS(ID);\\012ALTER TABLE DATA_SET_PROPERTIES ADD CONSTRAINT DSPR_DSTPT_FK FOREIGN KEY (DSTPT_ID) REFERENCES DATA_SET_TYPE_PROPERTY_TYPES(ID) ON DELETE CASCADE;\\012ALTER TABLE DATA_SET_PROPERTIES ADD CONSTRAINT DSPR_DS_FK FOREIGN KEY (DS_ID) REFERENCES DATA(ID);\\012ALTER TABLE DATA_SET_PROPERTIES ADD CONSTRAINT DSPR_PERS_FK FOREIGN KEY (PERS_ID_REGISTERER) REFERENCES PERSONS(ID);\\012ALTER TABLE DATA_SET_PROPERTIES ADD CONSTRAINT DSPR_MAPR_FK FOREIGN KEY (MATE_PROP_ID) REFERENCES MATERIALS(ID);\\012\\012ALTER TABLE DATA_SET_PROPERTIES ADD CONSTRAINT DSPR_CK CHECK \\012\\011((VALUE IS NOT NULL AND CVTE_ID IS NULL AND MATE_PROP_ID IS NULL) OR \\012\\011 (VALUE IS NULL AND CVTE_ID IS NOT NULL AND MATE_PROP_ID IS NULL) OR\\012\\011 (VALUE IS NULL AND CVTE_ID IS NULL AND MATE_PROP_ID IS NOT NULL)\\012\\011);\\012\\012CREATE INDEX DSPR_CVTE_FK_I ON DATA_SET_PROPERTIES (CVTE_ID);\\012CREATE INDEX DSPR_DSTPT_FK_I ON DATA_SET_PROPERTIES (DSTPT_ID);\\012CREATE INDEX DSPR_DS_FK_I ON DATA_SET_PROPERTIES (DS_ID);\\012CREATE INDEX DSPR_PERS_FK_I ON DATA_SET_PROPERTIES (PERS_ID_REGISTERER);\\012CREATE INDEX DSTPT_DSTY_FK_I ON DATA_SET_TYPE_PROPERTY_TYPES (DSTY_ID);\\012CREATE INDEX DSTPT_PERS_FK_I ON DATA_SET_TYPE_PROPERTY_TYPES (PERS_ID_REGISTERER);\\012CREATE INDEX DSTPT_PRTY_FK_I ON DATA_SET_TYPE_PROPERTY_TYPES (PRTY_ID);\\012\\012CREATE OR REPLACE FUNCTION DATA_SET_PROPERTY_WITH_MATERIAL_DATA_TYPE_CHECK() RETURNS trigger AS $$\\012DECLARE\\012   v_type_id  CODE;\\012   v_type_id_prop  CODE;\\012BEGIN\\012   if NEW.mate_prop_id IS NOT NULL then\\012\\011\\011\\011-- find material type id of the property type \\012\\011\\011\\011select pt.maty_prop_id into v_type_id_prop \\012\\011\\011\\011  from data_set_type_property_types dstpt, property_types pt \\012\\011\\011\\011 where NEW.dstpt_id = dstpt.id AND dstpt.prty_id = pt.id;\\012\\011\\011\\012\\011\\011\\011if v_type_id_prop IS NOT NULL then\\012\\011\\011\\011\\011-- find material type id of the material which consists the entity's property value\\012\\011\\011\\011\\011select entity.maty_id into v_type_id \\012\\011\\011\\011\\011  from materials entity\\012\\011\\011\\011\\011 where NEW.mate_prop_id = entity.id;\\012\\011\\011\\011\\011if v_type_id != v_type_id_prop then\\012\\011\\011\\011\\011\\011RAISE EXCEPTION 'Insert/Update of property value referencing material (id: %) failed, as referenced material type is different than expected (id %, expected id: %).', \\012\\011\\011\\011\\011\\011\\011\\011\\011\\011\\011\\011\\011 NEW.mate_prop_id, v_type_id, v_type_id_prop;\\012\\011\\011\\011\\011end if;\\012\\011\\011\\011end if;\\012   end if;\\012   RETURN NEW;\\012END;\\012$$ LANGUAGE 'plpgsql';\\012\\012CREATE TRIGGER DATA_SET_PROPERTY_WITH_MATERIAL_DATA_TYPE_CHECK BEFORE INSERT OR UPDATE ON data_set_properties\\012    FOR EACH ROW EXECUTE PROCEDURE DATA_SET_PROPERTY_WITH_MATERIAL_DATA_TYPE_CHECK();   \\012	\N
+./sourceTest/sql/postgresql/060/017=database_version_logs.tsv:032	source/sql/postgresql/migration/migration-031-032.sql	SUCCESS	2009-04-09 09:36:36.2	-- -------\\012-- Modify MATERIAL_BATCHES\\012-- -------\\012\\012ALTER TABLE material_batches\\012    DROP COLUMN proc_id;\\012\\012-- -------\\012-- Modify SAMPLES\\012-- -------\\012\\012ALTER TABLE samples\\012    ADD COLUMN expe_id tech_id;\\012\\012ALTER TABLE samples\\012    ADD CONSTRAINT samp_expe_fk FOREIGN KEY (expe_id) REFERENCES experiments(id);\\012\\012CREATE INDEX samp_expe_fk_i ON samples USING btree (expe_id);\\012\\012-- relink samples directly to experiments\\012\\012UPDATE samples\\012SET expe_id = (SELECT e.id FROM experiments e, procedures p, sample_inputs si \\012               WHERE si.samp_id = samples.id AND si.proc_id = p.id AND p.expe_id = e.id AND e.inva_id IS NULL);\\012\\012\\012-- -------\\012-- Modify DATA\\012-- -------\\012\\012ALTER TABLE data\\012    ADD COLUMN expe_id tech_id;\\012\\012ALTER TABLE data\\012    ADD CONSTRAINT data_expe_fk FOREIGN KEY (expe_id) REFERENCES experiments(id);\\012\\012CREATE INDEX data_expe_fk_i ON data USING btree (expe_id);\\012\\012UPDATE data\\012SET expe_id = (SELECT e.id FROM experiments e, procedures p \\012               WHERE data.proc_id_produced_by = p.id AND p.expe_id = e.id);\\012\\012ALTER TABLE data\\012    ALTER COLUMN expe_id SET NOT NULL;\\012\\012ALTER TABLE data\\012    DROP COLUMN proc_id_produced_by;\\012\\012-- -------\\012-- Drop PROCEDURES, PROCEDURE_TYPES, and SAMPLE_INPUTS\\012-- -------\\012\\012DROP TABLE sample_inputs;\\012DROP TABLE procedures;\\012DROP TABLE procedure_types;\\012\\012DROP SEQUENCE procedure_id_seq;\\012DROP SEQUENCE procedure_type_id_seq;\\012\\012-- -------\\012-- Add CODE_SEQ\\012-- -------\\012\\012CREATE SEQUENCE CODE_SEQ;\\012\\012-- -------\\012-- Add new columns to DATA_STORES\\012-- -------\\012\\012ALTER TABLE data_stores\\012    ADD COLUMN remote_url character varying(250),\\012    ADD COLUMN session_token character varying(50),\\012    ADD COLUMN modification_timestamp time_stamp DEFAULT now();\\012\\012UPDATE data_stores\\012SET remote_url = '', session_token='';\\012\\012ALTER TABLE data_stores\\012    ALTER COLUMN remote_url SET NOT NULL,\\012    ALTER COLUMN session_token SET NOT NULL;\\012\\012-- -------\\012-- Drop foreign keys onto DATA_STORES\\012-- -------\\012\\012ALTER TABLE database_instances\\012    DROP COLUMN dast_id;\\012\\012ALTER TABLE groups\\012    DROP COLUMN dast_id;\\012\\012ALTER TABLE projects\\012    DROP COLUMN dast_id;\\012\\012ALTER TABLE experiments\\012    DROP COLUMN dast_id;\\012\\012-- -------\\012-- Add foreign key from DATA onto DATA_STORES\\012-- -------\\012\\012ALTER TABLE data\\012    ADD COLUMN dast_id tech_id;\\012\\012ALTER TABLE data\\012    ADD CONSTRAINT data_dast_fk FOREIGN KEY (dast_id) REFERENCES data_stores(id);\\012\\012UPDATE data\\012SET dast_id = (select id from data_stores where code = 'STANDARD');\\012\\012ALTER TABLE data\\012    ALTER COLUMN dast_id SET NOT NULL;\\012\\012\\012------------------------------------------------------------------------------------\\012--  Purpose:  Replace trigger SAMPLE_CODE_UNIQUENESS_CHECK \\012------------------------------------------------------------------------------------\\012\\012CREATE OR REPLACE FUNCTION SAMPLE_CODE_UNIQUENESS_CHECK() RETURNS trigger AS $$\\012DECLARE\\012   counter  INTEGER;\\012BEGIN\\012    LOCK TABLE samples IN EXCLUSIVE MODE;\\012    IF (NEW.samp_id_part_of is NULL) THEN\\012        IF (NEW.dbin_id is not NULL) THEN\\012            SELECT count(*) into counter FROM samples \\012                where id != NEW.id and code = NEW.code and samp_id_part_of is NULL and dbin_id = NEW.dbin_id;\\012            IF (counter > 0) THEN\\012                RAISE EXCEPTION 'Insert/Update of Sample (Code: %) failed because database instance sample with the same code already exists.', NEW.code;\\012            END IF;\\012        ELSIF (NEW.grou_id is not NULL) THEN\\012            SELECT count(*) into counter FROM samples \\012                where id != NEW.id and code = NEW.code and samp_id_part_of is NULL and grou_id = NEW.grou_id;\\012            IF (counter > 0) THEN\\012                RAISE EXCEPTION 'Insert/Update of Sample (Code: %) failed because group sample with the same code already exists.', NEW.code;\\012            END IF;\\012        END IF;\\012        ELSE\\012        IF (NEW.dbin_id is not NULL) THEN\\012            SELECT count(*) into counter FROM samples \\012                where id != NEW.id and code = NEW.code and samp_id_part_of = NEW.samp_id_part_of and dbin_id = NEW.dbin_id;\\012            IF (counter > 0) THEN\\012                RAISE EXCEPTION 'Insert/Update of Sample (Code: %) failed because database instance sample with the same code and being the part of the same parent already exists.', NEW.code;\\012            END IF;\\012        ELSIF (NEW.grou_id is not NULL) THEN\\012            SELECT count(*) into counter FROM samples \\012                where id != NEW.id and code = NEW.code and samp_id_part_of = NEW.samp_id_part_of and grou_id = NEW.grou_id;\\012            IF (counter > 0) THEN\\012                RAISE EXCEPTION 'Insert/Update of Sample (Code: %) failed because group sample with the same code and being the part of the same parent already exists.', NEW.code;\\012            END IF;\\012        END IF;\\012        END IF;   \\012   RETURN NEW;\\012END;\\012$$ LANGUAGE 'plpgsql';\\012\\012\\012\\012	\N
+./sourceTest/sql/postgresql/060/017=database_version_logs.tsv:034	source/sql/postgresql/migration/migration-033-034.sql	SUCCESS	2009-05-26 08:32:49.935	------------------------------------------------------------------------------------\\012-- Create sequence for generating permanent identifiers starting with nextval of existing dataset sequence.\\012------------------------------------------------------------------------------------\\012CREATE FUNCTION CREATE_SEQUENCE(EXISTING_SEQUENCE VARCHAR, NEW_SEQUENCE VARCHAR) RETURNS VOID AS $$\\012DECLARE\\012  CURR_SEQ_VAL   INTEGER;\\012BEGIN\\012  SELECT INTO CURR_SEQ_VAL NEXTVAL(EXISTING_SEQUENCE);\\012  EXECUTE 'CREATE SEQUENCE ' || NEW_SEQUENCE || ' START WITH ' || CURR_SEQ_VAL;\\012  RETURN;\\012END;\\012$$ LANGUAGE 'plpgsql';\\012\\012SELECT CREATE_SEQUENCE('DATA_ID_SEQ', 'PERM_ID_SEQ');\\012DROP FUNCTION CREATE_SEQUENCE(VARCHAR, VARCHAR);\\012\\012------------------------------------------------------------------------------------\\012-- Add perm_id columns to samples and experiments.\\012------------------------------------------------------------------------------------\\012ALTER TABLE SAMPLES ADD COLUMN PERM_ID CODE;\\012ALTER TABLE EXPERIMENTS ADD COLUMN PERM_ID CODE;\\012\\012UPDATE SAMPLES SET PERM_ID = to_char(registration_timestamp,'YYYYMMDDHHSSMS') || '-' || NEXTVAL('PERM_ID_SEQ');\\012UPDATE EXPERIMENTS SET PERM_ID = to_char(registration_timestamp,'YYYYMMDDHHSSMS') || '-' || NEXTVAL('PERM_ID_SEQ');\\012ALTER TABLE SAMPLES ALTER COLUMN PERM_ID SET NOT NULL;\\012ALTER TABLE EXPERIMENTS ALTER COLUMN PERM_ID SET NOT NULL;\\012ALTER TABLE SAMPLES ADD CONSTRAINT SAMP_PI_UK UNIQUE(PERM_ID);\\012ALTER TABLE EXPERIMENTS ADD CONSTRAINT EXPE_PI_UK UNIQUE(PERM_ID);\\012\\012\\012------------------------------------------------------------------------------------\\012-- Add column is_chosen_from_list to controlled_vocabularies.\\012------------------------------------------------------------------------------------\\012ALTER TABLE controlled_vocabularies ADD COLUMN is_chosen_from_list BOOLEAN_CHAR NOT NULL DEFAULT TRUE;\\012ALTER TABLE controlled_vocabularies ADD COLUMN source_uri CHARACTER VARYING(250);\\012------------------------------------------------------------------------------------\\012-- Modify Data table - remove arc connection between Sample and Data table, use a flag instead\\012------------------------------------------------------------------------------------\\012\\012-- add new columns\\012\\012ALTER TABLE data\\012    ADD COLUMN is_derived boolean_char;\\012ALTER TABLE data\\012    ADD COLUMN samp_id tech_id;\\012\\012-- update values in new columns\\012\\012UPDATE data\\012    SET is_derived = (samp_id_derived_from IS NOT NULL); \\012UPDATE data\\012    SET samp_id = samp_id_derived_from \\012    WHERE is_derived = 'TRUE';\\012UPDATE data\\012    SET samp_id = samp_id_acquired_from \\012    WHERE is_derived = 'FALSE';\\012\\012-- add constraints and indexes to new columns\\012\\012ALTER TABLE data\\012    ALTER COLUMN is_derived SET NOT NULL;\\012ALTER TABLE data\\012    ALTER COLUMN samp_id SET NOT NULL;   \\012ALTER TABLE data\\012    ADD CONSTRAINT data_samp_fk FOREIGN KEY (samp_id) REFERENCES samples (id);\\012CREATE INDEX data_samp_fk_i ON data USING btree (samp_id);\\012\\012-- remove old columns\\012\\012ALTER TABLE data\\012    DROP COLUMN samp_id_acquired_from;\\012ALTER TABLE data\\012    DROP COLUMN samp_id_derived_from;\\012    \\012------------------------------------------------------------------------------------\\012-- Granting SELECT privilege to group openbis_readonly\\012------------------------------------------------------------------------------------\\012\\012GRANT SELECT ON SEQUENCE attachment_content_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE attachment_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE code_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE controlled_vocabulary_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE cvte_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE data_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE data_set_property_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE data_set_relationship_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE data_set_type_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE data_store_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE data_type_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE database_instance_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE dstpt_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE etpt_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE event_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE experiment_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE experiment_property_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE experiment_type_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE file_format_type_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE group_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE invalidation_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE locator_type_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE material_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE material_property_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE material_type_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE mtpt_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE perm_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE person_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE project_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE property_type_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE role_assignment_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE sample_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE sample_property_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE sample_type_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE stpt_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE attachment_contents TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE attachments TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE controlled_vocabularies TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE controlled_vocabulary_terms TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE data TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE data_set_properties TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE data_set_relationships TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE data_set_type_property_types TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE data_set_types TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE data_stores TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE data_types TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE database_instances TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE database_version_logs TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE events TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE experiment_properties TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE experiment_type_property_types TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE experiment_types TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE experiments TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE external_data TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE file_format_types TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE groups TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE invalidations TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE locator_types TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE material_properties TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE material_type_property_types TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE material_types TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE materials TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE persons TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE projects TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE property_types TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE role_assignments TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE sample_properties TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE sample_type_property_types TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE sample_types TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE samples TO GROUP OPENBIS_READONLY;\\012\\012------------------------------------------------------------------------------------\\012-- Delete MATERIAL_BATCHES table\\012------------------------------------------------------------------------------------\\012\\012-- WARNING: Potential data lost!!!\\012-- WARNING: Potential data lost!!!\\012-- WARNING: Potential data lost!!!\\012\\012DROP TABLE SAMPLE_MATERIAL_BATCHES;\\012DROP TABLE MATERIAL_BATCHES;\\012DROP SEQUENCE MATERIAL_BATCH_ID_SEQ;\\012\\012------------------------------------------------------------------------------------\\012-- Delete MATE_ID_INHIBITOR_OF from table MATERIALS\\012------------------------------------------------------------------------------------\\012\\012-- WARNING: Potential data lost!!!\\012-- WARNING: Potential data lost!!!\\012-- WARNING: Potential data lost!!!\\012\\012ALTER TABLE MATERIALS DROP COLUMN MATE_ID_INHIBITOR_OF;\\012	\N
+./sourceTest/sql/postgresql/060/017=database_version_logs.tsv:041	source/sql/postgresql/migration/migration-040-041.sql	SUCCESS	2009-09-14 13:48:57.539	-- Create FILTERS table\\012\\012CREATE TABLE FILTERS (ID TECH_ID NOT NULL, DBIN_ID TECH_ID NOT NULL, NAME VARCHAR(200) NOT NULL, DESCRIPTION DESCRIPTION_1000,REGISTRATION_TIMESTAMP TIME_STAMP_DFL NOT NULL DEFAULT CURRENT_TIMESTAMP, PERS_ID_REGISTERER TECH_ID NOT NULL, MODIFICATION_TIMESTAMP TIME_STAMP DEFAULT CURRENT_TIMESTAMP, EXPRESSION VARCHAR(2000) NOT NULL, IS_PUBLIC BOOLEAN NOT NULL, GRID_ID VARCHAR(200) NOT NULL);\\012CREATE SEQUENCE FILTER_ID_SEQ;\\012ALTER TABLE FILTERS ADD CONSTRAINT FILT_PK PRIMARY KEY(ID);\\012ALTER TABLE FILTERS ADD CONSTRAINT FILT_BK_UK UNIQUE(NAME, DBIN_ID, GRID_ID);\\012ALTER TABLE FILTERS ADD CONSTRAINT FILT_PERS_FK FOREIGN KEY (PERS_ID_REGISTERER) REFERENCES PERSONS(ID);\\012ALTER TABLE FILTERS ADD CONSTRAINT FILT_DBIN_FK FOREIGN KEY (DBIN_ID) REFERENCES DATABASE_INSTANCES(ID);\\012CREATE INDEX FILT_PERS_FK_I ON FILTERS (PERS_ID_REGISTERER);\\012CREATE INDEX FILT_DBIN_FK_I ON FILTERS (DBIN_ID);\\012GRANT SELECT ON SEQUENCE filter_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE filters TO GROUP OPENBIS_READONLY;\\012\\012-- Add missing foreign key to role assignments authorization group\\012ALTER TABLE ROLE_ASSIGNMENTS ADD CONSTRAINT ROAS_AG_FK_GRANTEE FOREIGN KEY (AG_ID_GRANTEE) REFERENCES AUTHORIZATION_GROUPS(ID);\\012\\012--------------------------------------------------------------------------------------------------\\012-- Modify dataset connections:\\012-- 1. connection with sample shouldn't be mandatory any more\\012-- 2. introduce an arc condition that dataset cannot be connected with a sample and a parent dataset at the same time\\012--------------------------------------------------------------------------------------------------\\012\\012-- Weaken data-sample connection constraint - allow dataset to have no connection with sample\\012ALTER TABLE data ALTER COLUMN samp_id DROP NOT NULL;\\012\\012-- Remove data-sample connection for datasets that have a parent\\012\\012UPDATE data \\012   SET samp_id = NULL \\012 WHERE id IN (SELECT DISTINCT data_id_child FROM data_set_relationships);\\012\\012-- With PostgreSQL 8.4 one can check that before migration there were no cycles in dataset relationships:\\012--\\012-- WITH RECURSIVE data_set_parents(id, parent_ids, cycle) AS (\\012--         SELECT  r.data_id_child AS id, \\012--                 ARRAY[CAST (r.data_id_parent AS bigint)] AS parent_ids, \\012--                 false AS cycle \\012--         FROM data_set_relationships r\\012--     UNION ALL\\012--         SELECT  r.data_id_child,\\012--                 CAST (r.data_id_parent AS bigint) || p.parent_ids,\\012--                 r.data_id_child = ANY(p.parent_ids)\\012--         FROM data_set_relationships r, data_set_parents p\\012--         WHERE r.data_id_parent = p.id AND NOT cycle\\012-- )\\012-- SELECT count(*) AS cycles FROM data_set_parents WHERE cycle = true;\\012\\012---------------------------------------------------------------------------------------------------\\012--  Purpose:  Create DEFERRED triggers:\\012--            * check_dataset_relationships_on_data_table_modification,\\012--            * check_dataset_relationships_on_relationships_table_modification.\\012--            They check that after all modifications of database (just before commit) \\012--            if 'data'/'data_set_relationships' tables are among modified tables \\012--            dataset is not connected with a sample and a parent dataset at the same time.\\012--            This connections are held in two different tables so simple immediate trigger \\012--            with arc check cannot be used and we need two deferred triggers.\\012----------------------------------------------------------------------------------------------------\\012\\012-- trigger for 'data' table\\012\\012CREATE OR REPLACE FUNCTION check_dataset_relationships_on_data_table_modification() RETURNS trigger AS $$\\012DECLARE\\012\\011counter\\011INTEGER;\\012BEGIN\\012\\011-- if there is a connection with a Sample there should not be any connection with a parent Data Set\\012\\011IF (NEW.samp_id IS NOT NULL) THEN\\012\\011\\011-- count number of parents\\012\\011\\011SELECT count(*) INTO counter \\012\\011\\011\\011FROM data_set_relationships \\012\\011\\011\\011WHERE data_id_child = OLD.id;\\012\\011\\011IF (counter > 0) THEN\\012\\011\\011\\011RAISE EXCEPTION 'Insert/Update of Data Set (Code: %) failed because it cannot be connected with a Sample and a parent Data Set at the same time.', OLD.code;\\012\\011\\011END IF;\\012\\011END IF;\\012  RETURN NEW;\\012END;\\012$$ LANGUAGE 'plpgsql';\\012\\012CREATE CONSTRAINT TRIGGER check_dataset_relationships_on_data_table_modification \\012  AFTER INSERT OR UPDATE ON data\\012\\011DEFERRABLE INITIALLY DEFERRED\\012\\011FOR EACH ROW \\012\\011EXECUTE PROCEDURE check_dataset_relationships_on_data_table_modification();\\012\\012-- trigger for 'data_set_relationships'\\012\\012CREATE OR REPLACE FUNCTION check_dataset_relationships_on_relationships_table_modification() RETURNS trigger AS $$\\012DECLARE\\012\\011counter\\011INTEGER;\\012\\011sample_id\\011TECH_ID;\\012\\011data_code\\011CODE;\\012BEGIN\\012\\011-- child will have a parent added so it should not be connected with any sample\\012\\011SELECT samp_id, code INTO sample_id, data_code \\012\\011\\011FROM data \\012\\011\\011WHERE id = NEW.data_id_child;\\012\\011IF (sample_id IS NOT NULL) THEN\\012\\011\\011RAISE EXCEPTION 'Insert/Update of Data Set (Code: %) failed because it cannot be connected to a Sample and to a parent Data Set at the same time.', data_code;\\012\\011END IF;\\012\\011RETURN NEW;\\012END;\\012$$ LANGUAGE 'plpgsql';\\012  \\012CREATE CONSTRAINT TRIGGER check_dataset_relationships_on_relationships_table_modification \\012  AFTER INSERT OR UPDATE ON data_set_relationships\\012\\011DEFERRABLE INITIALLY DEFERRED\\012\\011FOR EACH ROW \\012\\011EXECUTE PROCEDURE check_dataset_relationships_on_relationships_table_modification();\\012	\N
+./sourceTest/sql/postgresql/060/017=database_version_logs.tsv:053	source/sql/postgresql/migration/migration-052-053.sql	SUCCESS	2010-06-08 15:27:55.032	-- Migration from 052 to 053\\012\\012-- Change code uniqueness check for samples of specific type.\\012-- If sample_types.is_subcode_unique flag is set to 'true', additional check is performed \\012-- on codes of samples of the type. Subcodes will have to be unique as well.\\012\\012ALTER TABLE sample_types ADD COLUMN is_subcode_unique boolean_char NOT NULL DEFAULT false;\\012\\012CREATE OR REPLACE FUNCTION SAMPLE_SUBCODE_UNIQUENESS_CHECK() RETURNS trigger AS $$\\012DECLARE\\012   counter  INTEGER;\\012   unique_subcode  BOOLEAN_CHAR;\\012BEGIN\\012  LOCK TABLE samples IN EXCLUSIVE MODE;\\012  \\012  SELECT is_subcode_unique into unique_subcode FROM sample_types WHERE id = NEW.saty_id;\\012  \\012  IF (unique_subcode) THEN\\012    IF (NEW.dbin_id is not NULL) THEN\\012\\011\\011\\011SELECT count(*) into counter FROM samples \\012\\011\\011\\011\\011where id != NEW.id and code = NEW.code and saty_id = NEW.saty_id and dbin_id = NEW.dbin_id;\\012\\011\\011\\011IF (counter > 0) THEN\\012\\011\\011\\011\\011RAISE EXCEPTION 'Insert/Update of Sample (Code: %) failed because database instance sample of the same type with the same subcode already exists.', NEW.code;\\012\\011\\011\\011END IF;\\012\\011\\011ELSIF (NEW.grou_id is not NULL) THEN\\012\\011\\011\\011SELECT count(*) into counter FROM samples \\012\\011\\011\\011\\011where id != NEW.id and code = NEW.code and saty_id = NEW.saty_id and grou_id = NEW.grou_id;\\012\\011\\011\\011IF (counter > 0) THEN\\012\\011\\011\\011\\011RAISE EXCEPTION 'Insert/Update of Sample (Code: %) failed because space sample of the same type with the same subcode already exists.', NEW.code;\\012\\011\\011\\011END IF;\\012\\011\\011END IF;\\012  END IF;\\012  \\012  RETURN NEW;\\012END;\\012$$ LANGUAGE 'plpgsql';\\012\\012CREATE TRIGGER SAMPLE_SUBCODE_UNIQUENESS_CHECK BEFORE INSERT OR UPDATE ON SAMPLES\\012    FOR EACH ROW EXECUTE PROCEDURE SAMPLE_SUBCODE_UNIQUENESS_CHECK();\\012    \\012-- Fixing error messages in old trigger\\012\\012CREATE OR REPLACE FUNCTION SAMPLE_CODE_UNIQUENESS_CHECK() RETURNS trigger AS $$\\012DECLARE\\012   counter  INTEGER;\\012BEGIN\\012  LOCK TABLE samples IN EXCLUSIVE MODE;\\012  \\012\\011  IF (NEW.samp_id_part_of is NULL) THEN\\012\\011\\011  IF (NEW.dbin_id is not NULL) THEN\\012\\011\\011\\011  SELECT count(*) into counter FROM samples \\012\\011\\011      where id != NEW.id and code = NEW.code and samp_id_part_of is NULL and dbin_id = NEW.dbin_id;\\012        IF (counter > 0) THEN\\012\\011\\011\\011\\011  RAISE EXCEPTION 'Insert/Update of Sample (Code: %) failed because database instance sample with the same code already exists.', NEW.code;\\012        END IF;\\012\\011\\011  ELSIF (NEW.grou_id is not NULL) THEN\\012\\011\\011\\011  SELECT count(*) into counter FROM samples \\012\\011\\011\\011\\011  where id != NEW.id and code = NEW.code and samp_id_part_of is NULL and grou_id = NEW.grou_id;\\012\\011\\011\\011  IF (counter > 0) THEN\\012\\011\\011\\011\\011  RAISE EXCEPTION 'Insert/Update of Sample (Code: %) failed because space sample with the same code already exists.', NEW.code;\\012\\011\\011\\011  END IF;\\012      END IF;\\012    ELSE\\012\\011\\011  IF (NEW.dbin_id is not NULL) THEN\\012\\011\\011\\011  SELECT count(*) into counter FROM samples \\012\\011\\011\\011\\011  where id != NEW.id and code = NEW.code and samp_id_part_of = NEW.samp_id_part_of and dbin_id = NEW.dbin_id;\\012\\011\\011\\011  IF (counter > 0) THEN\\012\\011\\011\\011\\011  RAISE EXCEPTION 'Insert/Update of Sample (Code: %) failed because database instance sample with the same code and being the part of the same container already exists.', NEW.code;\\012\\011\\011\\011  END IF;\\012\\011\\011  ELSIF (NEW.grou_id is not NULL) THEN\\012\\011\\011\\011  SELECT count(*) into counter FROM samples \\012\\011\\011\\011\\011  where id != NEW.id and code = NEW.code and samp_id_part_of = NEW.samp_id_part_of and grou_id = NEW.grou_id;\\012\\011\\011\\011  IF (counter > 0) THEN\\012\\011\\011\\011\\011  RAISE EXCEPTION 'Insert/Update of Sample (Code: %) failed because space sample with the same code and being the part of the same container already exists.', NEW.code;\\012\\011\\011\\011  END IF;\\012\\011\\011  END IF;\\012     END IF;   \\012  \\012  RETURN NEW;\\012END;\\012$$ LANGUAGE 'plpgsql';\\012	\N
+./sourceTest/sql/postgresql/060/017=database_version_logs.tsv:054	source/sql/postgresql/migration/migration-053-054.sql	SUCCESS	2010-07-27 11:30:46.766	-- Migration from 053 to 054\\012\\012\\012-- Add RELATIONSHIP_TYPES table\\012CREATE TABLE relationship_types (id TECH_ID NOT NULL, code CODE NOT NULL, label COLUMN_LABEL, parent_label COLUMN_LABEL, child_label COLUMN_LABEL, description DESCRIPTION_2000, registration_timestamp TIME_STAMP_DFL NOT NULL DEFAULT CURRENT_TIMESTAMP, pers_id_registerer TECH_ID NOT NULL, is_managed_internally BOOLEAN_CHAR NOT NULL DEFAULT 'F', is_internal_namespace BOOLEAN_CHAR NOT NULL DEFAULT 'F', dbin_id TECH_ID NOT NULL);\\012\\012-- Add SAMPLE_RELATIONSHIPS table\\012CREATE TABLE sample_relationships (id TECH_ID NOT NULL, sample_id_parent TECH_ID NOT NULL, relationship_id TECH_ID NOT NULL, sample_id_child TECH_ID NOT NULL);\\012\\012-- Add/update constraints\\012ALTER TABLE relationship_types ADD CONSTRAINT rety_pk PRIMARY KEY (id);\\012ALTER TABLE relationship_types ADD CONSTRAINT rety_uk UNIQUE(code,dbin_id);\\012ALTER TABLE sample_relationships ADD CONSTRAINT sare_pk PRIMARY KEY (id);\\012ALTER TABLE sample_relationships ADD CONSTRAINT sare_bk_uk UNIQUE(sample_id_child,sample_id_parent,relationship_id);\\012ALTER TABLE sample_relationships ADD CONSTRAINT sare_data_fk_child FOREIGN KEY (sample_id_child) REFERENCES samples(id) ON DELETE CASCADE;\\012ALTER TABLE sample_relationships ADD CONSTRAINT sare_data_fk_parent FOREIGN KEY (sample_id_parent) REFERENCES samples(id) ON DELETE CASCADE;\\012ALTER TABLE sample_relationships ADD CONSTRAINT sare_data_fk_relationship FOREIGN KEY (relationship_id) REFERENCES relationship_types(id);\\012\\012-- Create index\\012CREATE INDEX sare_data_fk_i_child ON sample_relationships (sample_id_child);\\012CREATE INDEX sare_data_fk_i_parent ON sample_relationships (sample_id_parent);\\012CREATE INDEX sare_data_fk_i_relationship ON sample_relationships (relationship_id);\\012\\012-- Create sequence for RELATIONSHIP_TYPES\\012CREATE SEQUENCE RELATIONSHIP_TYPE_ID_SEQ;\\012CREATE SEQUENCE SAMPLE_RELATIONSHIP_ID_SEQ;\\012\\012-- Create initial relationships\\012insert into relationship_types\\012(id, \\012code, \\012label, \\012parent_label, \\012child_label, \\012description, \\012pers_id_registerer, \\012is_managed_internally, \\012is_internal_namespace, \\012dbin_id) \\012values\\012(\\012nextval('RELATIONSHIP_TYPE_ID_SEQ'),\\012'PARENT_CHILD',\\012'Parent - Child', \\012'Parent', \\012'Child', \\012'Parent - Child relationship', \\012(select id from persons where user_id ='system'), \\012'T', \\012'T', \\012(select id from database_instances where is_original_source = 'T')\\012);\\012\\012insert into relationship_types\\012(id, \\012code, \\012label, \\012parent_label, \\012child_label, \\012description, \\012pers_id_registerer, \\012is_managed_internally, \\012is_internal_namespace, \\012dbin_id) \\012values\\012(\\012nextval('RELATIONSHIP_TYPE_ID_SEQ'),\\012'PLATE_CONTROL_LAYOUT',\\012'Plate - Control Layout', \\012'Plate', \\012'Control Layout', \\012'Plate - Control Layout relationship', \\012(select id from persons where user_id ='system'), \\012'T', \\012'T', \\012(select id from database_instances where is_original_source = 'T')\\012); \\012\\012\\012-- Migrate sample relationships to new schema\\012INSERT INTO sample_relationships (id, sample_id_parent,sample_id_child,relationship_id) (select distinct nextval('SAMPLE_RELATIONSHIP_ID_SEQ') as id, s.SAMP_ID_GENERATED_FROM as parent_id, s.ID as child_id, rt.id as relationship_id from samples s, relationship_types rt  WHERE rt.code = 'PARENT_CHILD' and s.SAMP_ID_GENERATED_FROM is not null); \\012INSERT INTO sample_relationships (id, sample_id_parent,sample_id_child,relationship_id) (select distinct nextval('SAMPLE_RELATIONSHIP_ID_SEQ') as id, s.SAMP_ID_CONTROL_LAYOUT as parent_id, s.ID as child_id, rt.id as relationship_id from samples s, relationship_types rt  WHERE rt.code = 'PLATE_CONTROL_LAYOUT' and s.SAMP_ID_CONTROL_LAYOUT is not null);\\012\\012-- Drop old sample relations\\012ALTER TABLE SAMPLES DROP COLUMN SAMP_ID_TOP;\\012ALTER TABLE SAMPLES DROP COLUMN SAMP_ID_GENERATED_FROM;\\012ALTER TABLE SAMPLES DROP COLUMN SAMP_ID_CONTROL_LAYOUT;\\012\\012--------------------------------------------------------------------------------------\\012--------------------------------------------------------------------------------------\\012-- This is a screening specific migration. Nothing will be performed on openBIS databases \\012-- which are not screening specific.\\012-- \\012-- This migration for each existing connection between oligo well, oligo material and gene material\\012-- creates a direct connection between the well and the gene. \\012--------------------------------------------------------------------------------------\\012--------------------------------------------------------------------------------------\\012 \\012\\011\\012CREATE OR REPLACE FUNCTION CONNECT_WELLS_WITH_GENES() RETURNS void AS $$\\012DECLARE\\012\\011counter  int;\\012\\011oligo_well_exists bool;\\012BEGIN\\012\\011--------------------------------------------------\\012\\011-- create a gene property and assign it to oligo well\\012\\011--------------------------------------------------\\012\\011\\012\\011select true \\012\\011into oligo_well_exists\\012\\011from sample_types \\012\\011where code = 'OLIGO_WELL';\\012\\011\\012\\011if oligo_well_exists IS NULL then \\012\\011\\011-- skip migration if there are no oligo wells\\012\\011\\011return;\\012\\011end if;   \\012\\011\\012\\011insert into property_types(\\012\\011\\011id, \\012\\011\\011code, description, label, \\012\\011\\011daty_id,\\012\\011\\011pers_id_registerer,\\012\\011\\011dbin_id,\\012\\011\\011maty_prop_id) \\012\\011values(\\012\\011\\011\\011nextval('PROPERTY_TYPE_ID_SEQ'), \\012\\011\\011\\011'GENE','Inhibited gene','Gene',\\012\\011\\011\\011(select id from data_types where code = 'MATERIAL'), \\012\\011\\011\\011(select id from persons where user_id ='system'), \\012\\011\\011\\011(select id from database_instances where is_original_source = 'T'), \\012\\011\\011\\011(select id from material_types where code = 'GENE')\\012\\011\\011);\\012\\011\\011\\012\\011insert into sample_type_property_types( \\012\\011  id,\\012\\011  saty_id,\\012\\011  prty_id,\\012\\011  is_mandatory,\\012\\011  pers_id_registerer,\\012\\011  ordinal\\012\\011) values(\\012\\011\\011\\011nextval('stpt_id_seq'), \\012\\011\\011\\011(select id from sample_types where code = 'OLIGO_WELL'),\\012\\011\\011\\011(select id from property_types where code = 'GENE'),\\012\\011\\011\\011false,\\012\\011\\011\\011(select id from persons where user_id ='system'),\\012\\011\\011\\011(select max(ordinal)+1 from sample_type_property_types \\012\\011\\011\\011\\011where saty_id = (select id from sample_types where code = 'OLIGO_WELL'))\\012\\011\\011);\\012\\012\\011--------------------------------------------------\\012\\011-- create a gene material property for each oligo well\\012\\011--------------------------------------------------\\012\\011\\011\\012\\011select \\011count(*)\\012\\011into counter\\012\\011from\\012\\011\\011samples well, sample_types well_type, sample_properties well_props, \\012\\011\\011materials well_material, material_properties well_material_props,\\012\\011\\011materials nested_well_material\\012\\011where\\012\\011\\011well_type.code = 'OLIGO_WELL' and\\012\\011\\011-- find 'well_material' assigned to the well\\012\\011\\011well_props.samp_id = well.id and well_material.id = well_props.mate_prop_id and \\012\\011\\011-- additional joins to entity type tables\\012\\011\\011well_type.id = well.saty_id and\\012\\011\\011-- well content material property\\012\\011\\011well_material_props.mate_id = well_material.id and \\012\\011\\011-- material connected to the material in the well (e.g. gene)\\012\\011\\011well_material_props.mate_prop_id = nested_well_material.id and\\012\\011\\011nested_well_material.maty_id = (select id from material_types where code = 'GENE');\\012\\011\\012\\011if counter = 0 then \\012\\011\\011-- skip migration if there are no genes indirectly connected to oligo wells\\012\\011\\011return;\\012\\011end if;   \\012\\012\\011insert into sample_properties(id, samp_id, stpt_id, mate_prop_id, pers_id_registerer) (\\012\\011\\011select \\011nextval('sample_property_id_seq') id, \\012\\011\\011\\011well.id samp_id, \\012\\011\\011\\011(select stpt.id from sample_type_property_types stpt, property_types props where stpt.prty_id = props.id and props.code='GENE') stpt_id,\\012\\011\\011\\011nested_well_material.id mate_prop_id,\\012\\011\\011\\011(select id from persons where user_id ='system') pers_id_registerer \\012\\011\\011from\\012\\011\\011\\011samples well, sample_types well_type, sample_properties well_props, \\012\\011\\011\\011materials well_material, material_properties well_material_props,\\012\\011\\011\\011materials nested_well_material\\012\\011\\011where\\012\\011\\011\\011well_type.code = 'OLIGO_WELL' and\\012\\011\\011\\011-- find 'well_material' assigned to the well\\012\\011\\011\\011well_props.samp_id = well.id and well_material.id = well_props.mate_prop_id and \\012\\011\\011\\011-- additional joins to entity type tables\\012\\011\\011\\011well_type.id = well.saty_id and\\012\\011\\011\\011-- well content material property\\012\\011\\011\\011well_material_props.mate_id = well_material.id and \\012\\011\\011\\011-- material connected to the material in the well (e.g. gene)\\012\\011\\011\\011well_material_props.mate_prop_id = nested_well_material.id and\\012\\011\\011\\011nested_well_material.maty_id = (select id from material_types where code = 'GENE')\\012\\011);\\012\\012END;\\012$$ LANGUAGE 'plpgsql';\\012\\012select CONNECT_WELLS_WITH_GENES();\\012drop function CONNECT_WELLS_WITH_GENES();\\012\\012--------------------------------------------------------------------------------------\\012--------------------------------------------------------------------------------------\\012\\012-- drop dataset triggers\\012\\012DROP TRIGGER check_dataset_relationships_on_data_table_modification ON data;\\012DROP FUNCTION check_dataset_relationships_on_data_table_modification();\\012DROP TRIGGER check_dataset_relationships_on_relationships_table_modification ON data_set_relationships;\\012DROP FUNCTION check_dataset_relationships_on_relationships_table_modification();\\012 \\012\\012\\012\\012\\012\\012\\012\\012	\N
+./sourceTest/sql/postgresql/060/017=database_version_logs.tsv:056	source/sql/postgresql/migration/migration-055-056.sql	SUCCESS	2010-09-10 09:06:20.278	-- Migration from 055 to 056\\012\\012--------------------------------------------------------------------------------------\\012--------------------------------------------------------------------------------------\\012-- Screening specific migration. Nothing will be performed on openBIS databases \\012-- which are not screening specific.\\012--------------------------------------------------------------------------------------\\012--------------------------------------------------------------------------------------\\012\\012CREATE OR REPLACE FUNCTION merge_words(text, text) RETURNS text AS $$\\012DECLARE\\012  BEGIN\\012    IF  character_length($1) > 0 THEN\\012      RETURN $1 || ' ' || $2;\\012    ELSE\\012      RETURN $2;\\012    END IF;\\012  END;\\012$$ LANGUAGE plpgsql;\\012\\012CREATE AGGREGATE merge_words(text)\\012(\\012  SFUNC = merge_words,\\012  STYPE = text\\012);\\012\\012\\012CREATE OR REPLACE FUNCTION REPLACE_GENE_SYMBOL_BY_GENE_ID() RETURNS void AS $$\\012DECLARE\\012\\011counter  int;\\012\\011library_id_assigned_to_gene bool;\\012BEGIN\\012\\011--------------------------------------------------\\012\\011-- create a GENE_SYMBOL property and assign it to GENE\\012\\011--------------------------------------------------\\012\\011\\012\\011select true  \\012\\011into library_id_assigned_to_gene \\012\\011from material_type_property_types mtpt, material_types mt, property_types pt  \\012\\011where mtpt.maty_id = mt.id and mtpt.prty_id = pt.id \\012\\011\\011and mt.code = 'GENE' and pt.code = 'LIBRARY_ID';\\012\\011\\012\\011if library_id_assigned_to_gene IS NULL then \\012\\011\\011-- skip migration if gene has no library_id property\\012\\011\\011return;\\012\\011end if; \\012\\011\\012\\011\\012\\011select count(*)\\012\\011into counter \\012\\011from  \\012\\011\\011(select m.id, count(mp.id) as c \\012\\011\\011\\011from materials m, material_types mt, material_properties mp, material_type_property_types mtpt, property_types pt \\012\\011\\011\\011where m.maty_id = mt.id and mp.mate_id = m.id and mp.mtpt_id = mtpt.id and mtpt.maty_id = mt.id and pt.id = mtpt.prty_id\\012\\011\\011\\011\\011and mt.code = 'GENE' and pt.code = 'LIBRARY_ID' \\012\\011\\011\\011group by m.id) as counter_table \\012\\011where c < 1; \\012\\011\\012\\011if counter > 0 then \\012\\011\\011-- skip migration if there is at least one gene without library_id\\012\\011\\011return;\\012\\011end if;\\012\\011\\012\\011\\012\\011insert into property_types\\012\\011\\011(id\\012\\011\\011,code\\012\\011\\011,description\\012\\011\\011,label\\012\\011\\011,daty_id\\012\\011\\011,pers_id_registerer\\012\\011\\011,dbin_id)\\012\\011values \\012\\011\\011(nextval('PROPERTY_TYPE_ID_SEQ')\\012\\011\\011,'GENE_SYMBOLS'\\012\\011\\011,'Gene symbols'\\012\\011\\011,'Gene symbols'\\012\\011\\011,(select id from data_types where code ='VARCHAR')\\012\\011\\011,(select id from persons where user_id ='system')\\012\\011\\011,(select id from database_instances where is_original_source = 'T')\\012\\011);\\012\\011\\011\\012\\011insert into material_type_property_types( \\012\\011  id,\\012\\011  maty_id,\\012\\011  prty_id,\\012\\011  is_mandatory,\\012\\011  pers_id_registerer,\\012\\011  ordinal\\012\\011) values(\\012\\011\\011\\011nextval('mtpt_id_seq'), \\012\\011\\011\\011(select id from material_types where code = 'GENE'),\\012\\011\\011\\011(select id from property_types where code = 'GENE_SYMBOLS'),\\012\\011\\011\\011false,\\012\\011\\011\\011(select id from persons where user_id ='system'),\\012\\011\\011\\011(select max(ordinal)+1 from material_type_property_types \\012\\011\\011\\011\\011where maty_id = (select id from material_types where code = 'GENE'))\\012\\011\\011);\\012\\012\\011--------------------------------------------------\\012\\011-- create temporary table with all gene migration information\\012\\011--------------------------------------------------\\012\\012\\011create temp table genes \\012\\011(\\012\\011\\011id tech_id,\\012\\011\\011code code,\\012\\011\\011library_id generic_value,\\012\\011\\011gene_codes generic_value,\\012\\011\\011new_id tech_id,\\012\\011\\011library_tech_id tech_id\\011\\011\\012\\011);\\012\\011\\012\\011insert into genes (id, code, library_id, library_tech_id)\\012\\011\\011(select m.id, m.code, mp.value as library_id, mp.id as library_tech_id from materials m, material_properties mp, material_type_property_types mtpt, property_types pt, material_types mt\\012\\011\\011where mp.mate_id = m.id and  mp.mtpt_id = mtpt.id and pt.id = mtpt.prty_id and pt.code = 'LIBRARY_ID' and mt.id = m.maty_id and mt.id = mtpt.maty_id and mt.code = 'GENE');\\012\\011\\012\\011update genes set new_id = map.to_id from (select g_from.id as from_id, min(g_to.id) as to_id  from genes g_from, genes g_to where g_from.library_id = g_to.library_id group by g_from.id) as map where map.from_id = id;\\011\\012\\011\\012\\011update genes set gene_codes = map.gene_codes from (select g_from.library_id as lib_id, merge_words(distinct g_to.code) as gene_codes from genes g_from, genes g_to where g_from.library_id = g_to.library_id group by g_from.library_id) as map where map.lib_id = library_id;\\011\\012\\012\\011--------------------------------------------------\\012\\011-- update gene references\\012\\011--------------------------------------------------\\012\\012\\011update EXPERIMENTS set MATE_ID_STUDY_OBJECT = genes.new_id from genes where genes.id = MATE_ID_STUDY_OBJECT and not genes.id = genes.new_id;\\012\\011update EXPERIMENT_PROPERTIES set  MATE_PROP_ID = genes.new_id from genes where genes.id = MATE_PROP_ID and not genes.id = genes.new_id;\\012\\011update MATERIAL_PROPERTIES set  MATE_PROP_ID = genes.new_id from genes where genes.id = MATE_PROP_ID and not genes.id = genes.new_id;\\012\\011update SAMPLE_PROPERTIES set  MATE_PROP_ID = genes.new_id from genes where genes.id = MATE_PROP_ID and not genes.id = genes.new_id;\\012\\011update DATA_SET_PROPERTIES set  MATE_PROP_ID = genes.new_id from genes where genes.id = MATE_PROP_ID and not genes.id = genes.new_id;\\012\\011\\012\\011delete from  material_properties where mate_id in (select id from genes where not genes.id = genes.new_id);\\012\\011delete from MATERIALS where id in (select id from genes where not genes.id = genes.new_id);\\012\\012\\011delete from genes where id in (select id from genes where not genes.id = genes.new_id);\\012\\012\\012\\011--------------------------------------------------\\012\\011-- replace gene code with library_id\\012\\011--------------------------------------------------\\012\\011\\012\\011update materials set code = genes.library_id from genes where materials.id = genes.id ;\\012\\011delete from material_properties where id in (select library_tech_id from genes);\\012\\011\\012\\011--------------------------------------------------\\012\\011-- create a gene symbols property for each gene\\012\\011--------------------------------------------------\\012\\011\\012\\011insert into material_properties\\012\\011\\011(id\\012\\011  , mate_id\\012\\011  , mtpt_id\\012\\011  , "value"\\012\\011  , pers_id_registerer)\\012\\011\\011(select nextval('material_property_id_seq') id\\012\\011  \\011, genes.id  mate_id\\012\\011    , (select mtpt.id\\012\\011    \\011\\011from   material_type_property_types mtpt, material_types mt, property_types pt\\012\\011    \\011\\011where  pt.code = 'GENE_SYMBOLS' and mt.code = 'GENE' and mtpt.prty_id = pt.id\\012\\011        \\011and mtpt.maty_id = mt.id) mtpt_id\\012\\011    , genes.gene_codes "value"\\012\\011    , (select id from persons where user_id = 'system') pers_id_registerer\\012\\011 \\011from genes); \\012\\012\\011--------------------------------------------------\\012\\011-- delete temporary table\\012\\011--------------------------------------------------\\012\\011\\012\\011drop table genes;\\012\\011\\012END;\\012$$ LANGUAGE 'plpgsql';\\012\\012select REPLACE_GENE_SYMBOL_BY_GENE_ID();\\012drop function REPLACE_GENE_SYMBOL_BY_GENE_ID();\\012DROP AGGREGATE merge_words(text);\\012drop function merge_words(text,text);\\012\\012\\012--------------------------------------------------------------------------------------\\012--------------------------------------------------------------------------------------\\012\\012UPDATE sample_types SET code = 'SIRNA_WELL' WHERE code = 'OLIGO_WELL';\\012UPDATE material_types SET code = 'SIRNA' WHERE code = 'OLIGO';\\012UPDATE property_types SET code = 'SIRNA', label = 'siRNA' WHERE code = 'OLIGO';\\012\\012\\012\\012\\012\\012\\012\\012\\012\\012\\012\\012\\012\\012\\012\\012\\012\\012\\012\\012	\N
+./sourceTest/sql/postgresql/060/017=database_version_logs.tsv:059	source/sql/postgresql/migration/migration-058-059.sql	SUCCESS	2010-09-29 13:37:07.231	-- Migration from 058 to 059\\012\\012-- Add ENTITY_TYPE_CODE column to QUERIES\\012ALTER TABLE queries ADD COLUMN entity_type_code CODE;\\012\\012------------------------------------------------------------------------------------\\012--  Purpose:  Create trigger that checks if entity_type_code specified in a query\\012--            matches a code of an entity of type specified in query_type.\\012------------------------------------------------------------------------------------\\012\\012CREATE OR REPLACE FUNCTION query_entity_type_code_check() RETURNS trigger AS $$\\012DECLARE\\012   counter  INTEGER;\\012BEGIN\\012   if (NEW.entity_type_code IS NOT NULL) then\\012     if (NEW.query_type = 'GENERIC') then\\012       RAISE EXCEPTION 'Insert/Update of query (Name: %) failed, as entity_type has to be null for GENERIC queries.', NEW.name;\\012     elsif (NEW.query_type = 'EXPERIMENT') then\\012       SELECT count(*) INTO counter FROM experiment_types WHERE code = NEW.entity_type_code;\\012\\011\\011 elsif (NEW.query_type = 'DATA_SET') then\\012       SELECT count(*) INTO counter FROM data_set_types WHERE code = NEW.entity_type_code;\\012\\011\\011 elsif (NEW.query_type = 'MATERIAL') then\\012       SELECT count(*) INTO counter FROM material_types WHERE code = NEW.entity_type_code;\\012\\011\\011 elsif (NEW.query_type = 'SAMPLE') then\\012       SELECT count(*) INTO counter FROM sample_types WHERE code = NEW.entity_type_code;\\012\\011\\011 end if;\\012\\011\\011 if (counter = 0) then\\012\\011\\011\\011 RAISE EXCEPTION 'Insert/Update of query (Name: %) failed because % type (Code: %) does not exist.', NEW.name, NEW.query_type, NEW.entity_type_code;\\012\\011\\011 end if;\\011\\011\\011\\012   end if;\\012   RETURN NEW;\\012END;\\012$$ LANGUAGE 'plpgsql';\\012\\012CREATE TRIGGER query_entity_type_code_check BEFORE INSERT OR UPDATE ON queries\\012    FOR EACH ROW EXECUTE PROCEDURE query_entity_type_code_check();\\012	\N
+./sourceTest/sql/postgresql/060/schema-060.sql:    LANGUAGE plpgsql
+./sourceTest/sql/postgresql/060/schema-060.sql:    LANGUAGE plpgsql
+./sourceTest/sql/postgresql/060/schema-060.sql:    LANGUAGE plpgsql
+./sourceTest/sql/postgresql/060/schema-060.sql:    LANGUAGE plpgsql
+./sourceTest/sql/postgresql/060/schema-060.sql:    LANGUAGE plpgsql
+./sourceTest/sql/postgresql/060/schema-060.sql:    LANGUAGE plpgsql
+./sourceTest/sql/postgresql/060/schema-060.sql:    LANGUAGE plpgsql
+./sourceTest/sql/postgresql/060/schema-060.sql:    LANGUAGE plpgsql
+./sourceTest/sql/postgresql/060/schema-060.sql:    LANGUAGE plpgsql
+./sourceTest/sql/postgresql/061/.svn/text-base/017=database_version_logs.tsv.svn-base:027	D:\\User\\felmer\\dev-workspace\\openbis/source/sql/postgresql/027/function-027.sql	SUCCESS	2008-11-05 09:18:00.403	-- Creating Functions\\012\\012------------------------------------------------------------------------------------\\012--  Purpose:  Create function RENAME_SEQUENCE() that is required for renaming the sequences belonging to tables\\012------------------------------------------------------------------------------------\\012CREATE FUNCTION RENAME_SEQUENCE(OLD_NAME VARCHAR, NEW_NAME VARCHAR) RETURNS INTEGER AS $$\\012DECLARE\\012  CURR_SEQ_VAL   INTEGER;\\012BEGIN\\012  SELECT INTO CURR_SEQ_VAL NEXTVAL(OLD_NAME);\\012  EXECUTE 'CREATE SEQUENCE ' || NEW_NAME || ' START WITH ' || CURR_SEQ_VAL;\\012  EXECUTE 'DROP SEQUENCE ' || OLD_NAME;\\012  RETURN CURR_SEQ_VAL;\\012END;\\012$$ LANGUAGE 'plpgsql';\\012\\012\\012------------------------------------------------------------------------------------\\012--  Purpose:  Create trigger CONTROLLED_VOCABULARY_CHECK \\012------------------------------------------------------------------------------------\\012\\012CREATE OR REPLACE FUNCTION CONTROLLED_VOCABULARY_CHECK() RETURNS trigger AS $$\\012DECLARE\\012   v_code  CODE;\\012BEGIN\\012\\012   select code into v_code from data_types where id = NEW.daty_id;\\012\\012   -- Check if the data is of type "CONTROLLEDVOCABULARY"\\012   if v_code = 'CONTROLLEDVOCABULARY' then\\012      if NEW.covo_id IS NULL then\\012         RAISE EXCEPTION 'Insert/Update of Property Type (Code: %) failed, as its Data Type is CONTROLLEDVOCABULARY, but it is not linked to a Controlled Vocabulary.', NEW.code;\\012      end if;\\012   end if;\\012\\012   RETURN NEW;\\012\\012END;\\012$$ LANGUAGE 'plpgsql';\\012\\012CREATE TRIGGER CONTROLLED_VOCABULARY_CHECK BEFORE INSERT OR UPDATE ON PROPERTY_TYPES\\012    FOR EACH ROW EXECUTE PROCEDURE CONTROLLED_VOCABULARY_CHECK();\\012\\012\\012------------------------------------------------------------------------------------\\012--  Purpose:  Create trigger EXTERNAL_DATA_STORAGE_FORMAT_CHECK \\012------------------------------------------------------------------------------------\\012\\012CREATE OR REPLACE FUNCTION EXTERNAL_DATA_STORAGE_FORMAT_CHECK() RETURNS trigger AS $$\\012DECLARE\\012   v_covo_code  CODE;\\012   data_code CODE;\\012BEGIN\\012\\012   select code into v_covo_code from controlled_vocabularies\\012      where is_internal_namespace = true and \\012         id = (select covo_id from controlled_vocabulary_terms where id = NEW.cvte_id_stor_fmt);\\012   -- Check if the data storage format is a term of the controlled vocabulary "STORAGE_FORMAT"\\012   if v_covo_code != 'STORAGE_FORMAT' then\\012      select code into data_code from data where id = NEW.data_id; \\012      RAISE EXCEPTION 'Insert/Update of Data (Code: %) failed, as its Storage Format is %, but is required to be STORAGE_FORMAT.', data_code, v_covo_code;\\012   end if;\\012\\012   RETURN NEW;\\012\\012END;\\012$$ LANGUAGE 'plpgsql';\\012\\012CREATE TRIGGER EXTERNAL_DATA_STORAGE_FORMAT_CHECK BEFORE INSERT OR UPDATE ON EXTERNAL_DATA\\012    FOR EACH ROW EXECUTE PROCEDURE EXTERNAL_DATA_STORAGE_FORMAT_CHECK();\\012\\012------------------------------------------------------------------------------------\\012--  Purpose:  Create trigger SAMPLE_CODE_UNIQUENESS_CHECK \\012------------------------------------------------------------------------------------\\012\\012CREATE OR REPLACE FUNCTION SAMPLE_CODE_UNIQUENESS_CHECK() RETURNS trigger AS $$\\012DECLARE\\012   counter  INTEGER;\\012BEGIN\\012\\011IF (NEW.samp_id_part_of is NULL) THEN\\012\\011\\011IF (NEW.dbin_id is not NULL) THEN\\012\\011\\011\\011SELECT count(*) into counter FROM samples \\012\\011\\011\\011\\011where id != NEW.id and code = NEW.code and samp_id_part_of is NULL and dbin_id = NEW.dbin_id;\\012\\011\\011\\011IF (counter > 0) THEN\\012\\011\\011\\011\\011RAISE EXCEPTION 'Insert/Update of Sample (Code: %) failed because database instance sample with the same code already exists.', NEW.code;\\012\\011\\011\\011END IF;\\012\\011\\011ELSIF (NEW.grou_id is not NULL) THEN\\012\\011\\011\\011SELECT count(*) into counter FROM samples \\012\\011\\011\\011\\011where id != NEW.id and code = NEW.code and samp_id_part_of is NULL and grou_id = NEW.grou_id;\\012\\011\\011\\011IF (counter > 0) THEN\\012\\011\\011\\011\\011RAISE EXCEPTION 'Insert/Update of Sample (Code: %) failed because group sample with the same code already exists.', NEW.code;\\012\\011\\011\\011END IF;\\012\\011\\011END IF;\\012        ELSE\\012\\011\\011IF (NEW.dbin_id is not NULL) THEN\\012\\011\\011\\011SELECT count(*) into counter FROM samples \\012\\011\\011\\011\\011where id != NEW.id and code = NEW.code and samp_id_part_of = NEW.samp_id_part_of and dbin_id = NEW.dbin_id;\\012\\011\\011\\011IF (counter > 0) THEN\\012\\011\\011\\011\\011RAISE EXCEPTION 'Insert/Update of Sample (Code: %) failed because database instance sample with the same code and being the part of the same parent already exists.', NEW.code;\\012\\011\\011\\011END IF;\\012\\011\\011ELSIF (NEW.grou_id is not NULL) THEN\\012\\011\\011\\011SELECT count(*) into counter FROM samples \\012\\011\\011\\011\\011where id != NEW.id and code = NEW.code and samp_id_part_of = NEW.samp_id_part_of and grou_id = NEW.grou_id;\\012\\011\\011\\011IF (counter > 0) THEN\\012\\011\\011\\011\\011RAISE EXCEPTION 'Insert/Update of Sample (Code: %) failed because group sample with the same code and being the part of the same parent already exists.', NEW.code;\\012\\011\\011\\011END IF;\\012\\011\\011END IF;\\012        END IF;   \\012   RETURN NEW;\\012END;\\012$$ LANGUAGE 'plpgsql';\\012\\012CREATE TRIGGER SAMPLE_CODE_UNIQUENESS_CHECK BEFORE INSERT OR UPDATE ON SAMPLES\\012    FOR EACH ROW EXECUTE PROCEDURE SAMPLE_CODE_UNIQUENESS_CHECK();\\012	\N
+./sourceTest/sql/postgresql/061/.svn/text-base/017=database_version_logs.tsv.svn-base:028	source/sql/postgresql/migration/migration-027-028.sql	SUCCESS	2008-11-18 13:24:17.508	-- Create EXPERIMENT_ATTACHMENT_CONTENTS.\\012CREATE TABLE EXPERIMENT_ATTACHMENT_CONTENTS (ID TECH_ID NOT NULL,VALUE FILE NOT NULL);\\012CREATE SEQUENCE EXPERIMENT_ATTACHMENT_CONTENT_ID_SEQ;\\012ALTER TABLE EXPERIMENT_ATTACHMENT_CONTENTS ADD CONSTRAINT EXAC_PK PRIMARY KEY(ID);\\012\\012-- Alter EXPERIMENT_ATTACHMENTS by adding the new column which has a NULL constraint.\\012-- The NOT NULL constraint is added later on.\\012ALTER TABLE EXPERIMENT_ATTACHMENTS ADD COLUMN EXAC_ID TECH_ID;\\012\\012-- Does the VALUE migration between EXPERIMENT_ATTACHMENTS to EXPERIMENT_ATTACHMENT_CONTENTS.\\012CREATE OR REPLACE FUNCTION move_exp_att_content() RETURNS integer AS $$\\012DECLARE\\012    rec RECORD;\\012    seq BIGINT;\\012BEGIN\\012  FOR rec IN SELECT id, value FROM EXPERIMENT_ATTACHMENTS LOOP\\012  \\011seq := nextval('EXPERIMENT_ATTACHMENT_CONTENT_ID_SEQ');\\012    INSERT INTO EXPERIMENT_ATTACHMENT_CONTENTS (id, value) VALUES (seq, rec.value);\\012    UPDATE EXPERIMENT_ATTACHMENTS SET exac_id = seq WHERE id = rec.id;\\012  END LOOP;\\012  RETURN 1;\\012END;\\012$$ LANGUAGE 'plpgsql';\\012\\012-- Call the function.\\012SELECT move_exp_att_content();\\012DROP FUNCTION move_exp_att_content();\\012\\012\\012-- Finish EXPERIMENT_ATTACHMENTS changes.\\012ALTER TABLE EXPERIMENT_ATTACHMENTS ADD CONSTRAINT EXAT_CONT_FK FOREIGN KEY (EXAC_ID) REFERENCES EXPERIMENT_ATTACHMENT_CONTENTS(ID);\\012ALTER TABLE EXPERIMENT_ATTACHMENTS DROP COLUMN VALUE;\\012ALTER TABLE EXPERIMENT_ATTACHMENTS ALTER COLUMN EXAC_ID SET NOT NULL;\\012	\N
+./sourceTest/sql/postgresql/061/.svn/text-base/017=database_version_logs.tsv.svn-base:029	source/sql/postgresql/migration/migration-028-029.sql	SUCCESS	2009-03-18 10:50:20.105	-- -------\\012-- add modification_timestamp field to allow edition with Hibernate\\012-- -------\\012\\012ALTER TABLE samples\\012\\011ADD COLUMN modification_timestamp TIME_STAMP DEFAULT CURRENT_TIMESTAMP;\\012\\012ALTER TABLE experiments\\012\\011ADD COLUMN modification_timestamp TIME_STAMP DEFAULT CURRENT_TIMESTAMP;\\012\\012ALTER TABLE materials\\012\\011ADD COLUMN modification_timestamp TIME_STAMP DEFAULT CURRENT_TIMESTAMP;\\012\\012ALTER TABLE experiment_properties\\012\\011ADD COLUMN modification_timestamp TIME_STAMP DEFAULT CURRENT_TIMESTAMP;\\012\\012ALTER TABLE material_properties\\012\\011ADD COLUMN modification_timestamp TIME_STAMP DEFAULT CURRENT_TIMESTAMP;\\012\\012ALTER TABLE sample_properties\\012\\011ADD COLUMN modification_timestamp TIME_STAMP DEFAULT CURRENT_TIMESTAMP;\\012\\012-- -------\\012-- add property data type which references materials\\012-- -------\\012\\012ALTER TABLE property_types\\012\\011ADD COLUMN maty_prop_id tech_id;\\012\\012ALTER TABLE property_types\\012\\011ADD CONSTRAINT prty_maty_fk FOREIGN KEY (maty_prop_id) REFERENCES material_types(id);\\012\\012ALTER TABLE experiment_properties\\012\\011ADD COLUMN mate_prop_id tech_id;\\012\\012ALTER TABLE material_properties\\012\\011ADD COLUMN mate_prop_id tech_id;\\012\\012ALTER TABLE sample_properties\\012\\011ADD COLUMN mate_prop_id tech_id;\\012\\012ALTER TABLE experiment_properties\\012\\011ADD CONSTRAINT expr_mapr_fk FOREIGN KEY (mate_prop_id) REFERENCES materials(id);\\012\\012ALTER TABLE material_properties\\012\\011ADD CONSTRAINT mapr_mapr_fk FOREIGN KEY (mate_prop_id) REFERENCES materials(id);\\012\\012ALTER TABLE sample_properties\\012\\011ADD CONSTRAINT sapr_mapr_fk FOREIGN KEY (mate_prop_id) REFERENCES materials(id);\\012\\012insert into data_types\\012(id\\012 ,code\\012 ,description)\\012 values \\012 (nextval('DATA_TYPE_ID_SEQ')\\012 ,'MATERIAL'\\012 ,'Reference to a material'\\012);\\012\\012ALTER TABLE MATERIAL_PROPERTIES DROP CONSTRAINT MAPR_CK;\\012ALTER TABLE MATERIAL_PROPERTIES ADD CONSTRAINT MAPR_CK CHECK \\012\\011((VALUE IS NOT NULL AND CVTE_ID IS NULL AND MATE_PROP_ID IS NULL) OR \\012\\011 (VALUE IS NULL AND CVTE_ID IS NOT NULL AND MATE_PROP_ID IS NULL) OR\\012\\011 (VALUE IS NULL AND CVTE_ID IS NULL AND MATE_PROP_ID IS NOT NULL)\\012\\011);\\012\\012ALTER TABLE EXPERIMENT_PROPERTIES DROP CONSTRAINT EXPR_CK;\\012ALTER TABLE EXPERIMENT_PROPERTIES ADD CONSTRAINT EXPR_CK CHECK \\012\\011((VALUE IS NOT NULL AND CVTE_ID IS NULL AND MATE_PROP_ID IS NULL) OR \\012\\011 (VALUE IS NULL AND CVTE_ID IS NOT NULL AND MATE_PROP_ID IS NULL) OR\\012\\011 (VALUE IS NULL AND CVTE_ID IS NULL AND MATE_PROP_ID IS NOT NULL)\\012\\011);\\012\\012ALTER TABLE SAMPLE_PROPERTIES DROP CONSTRAINT SAPR_CK;\\012ALTER TABLE SAMPLE_PROPERTIES ADD CONSTRAINT SAPR_CK CHECK \\012\\011((VALUE IS NOT NULL AND CVTE_ID IS NULL AND MATE_PROP_ID IS NULL) OR \\012\\011 (VALUE IS NULL AND CVTE_ID IS NOT NULL AND MATE_PROP_ID IS NULL) OR\\012\\011 (VALUE IS NULL AND CVTE_ID IS NULL AND MATE_PROP_ID IS NOT NULL)\\012\\011);\\012\\012------------------------------------------------------------------------------------\\012--  Purpose:  Create trigger MATERIAL/SAMPLE/EXPERIMENT _PROPERTY_WITH_MATERIAL_DATA_TYPE_CHECK\\012--            It checks that if material property value is assigned to the entity,\\012--\\011\\011\\011\\011\\011\\011then the material type is equal to the one described by property type.\\012------------------------------------------------------------------------------------\\012\\012CREATE OR REPLACE FUNCTION MATERIAL_PROPERTY_WITH_MATERIAL_DATA_TYPE_CHECK() RETURNS trigger AS $$\\012DECLARE\\012   v_type_id  CODE;\\012   v_type_id_prop  CODE;\\012BEGIN\\012   if NEW.mate_prop_id IS NOT NULL then\\012\\011\\011\\011-- find material type id of the property type \\012\\011\\011\\011select pt.maty_prop_id into v_type_id_prop \\012\\011\\011\\011  from material_type_property_types etpt, property_types pt \\012\\011\\011\\011 where NEW.mtpt_id = etpt.id AND etpt.prty_id = pt.id;\\012\\011\\011\\012\\011\\011\\011if v_type_id_prop IS NOT NULL then\\012\\011\\011\\011\\011-- find material type id of the material which consists the entity's property value\\012\\011\\011\\011\\011select entity.maty_id into v_type_id \\012\\011\\011\\011\\011  from materials entity\\012\\011\\011\\011\\011 where NEW.mate_prop_id = entity.id;\\012\\011\\011\\011\\011if v_type_id != v_type_id_prop then\\012\\011\\011\\011\\011\\011RAISE EXCEPTION 'Insert/Update of property value referencing material (id: %) failed, as referenced material type is different than expected (id %, expected id: %).', \\012\\011\\011\\011\\011\\011\\011\\011 NEW.mate_prop_id, v_type_id, v_type_id_prop;\\012\\011\\011\\011\\011end if;\\012\\011\\011\\011end if;\\012   end if;\\012   RETURN NEW;\\012END;\\012$$ LANGUAGE 'plpgsql';\\012\\012CREATE TRIGGER MATERIAL_PROPERTY_WITH_MATERIAL_DATA_TYPE_CHECK BEFORE INSERT OR UPDATE ON material_properties\\012    FOR EACH ROW EXECUTE PROCEDURE MATERIAL_PROPERTY_WITH_MATERIAL_DATA_TYPE_CHECK();\\012    \\012CREATE OR REPLACE FUNCTION SAMPLE_PROPERTY_WITH_MATERIAL_DATA_TYPE_CHECK() RETURNS trigger AS $$\\012DECLARE\\012   v_type_id  CODE;\\012   v_type_id_prop  CODE;\\012BEGIN\\012   if NEW.mate_prop_id IS NOT NULL then\\012\\011\\011\\011-- find material type id of the property type \\012\\011\\011\\011select pt.maty_prop_id into v_type_id_prop \\012\\011\\011\\011  from sample_type_property_types etpt, property_types pt \\012\\011\\011\\011 where NEW.stpt_id = etpt.id AND etpt.prty_id = pt.id;\\012\\011\\011\\012\\011\\011\\011if v_type_id_prop IS NOT NULL then\\012\\011\\011\\011\\011-- find material type id of the material which consists the entity's property value\\012\\011\\011\\011\\011select entity.maty_id into v_type_id \\012\\011\\011\\011\\011  from materials entity\\012\\011\\011\\011\\011 where NEW.mate_prop_id = entity.id;\\012\\011\\011\\011\\011if v_type_id != v_type_id_prop then\\012\\011\\011\\011\\011\\011RAISE EXCEPTION 'Insert/Update of property value referencing material (id: %) failed, as referenced material type is different than expected (id %, expected id: %).', \\012\\011\\011\\011\\011\\011\\011\\011\\011\\011\\011\\011\\011 NEW.mate_prop_id, v_type_id, v_type_id_prop;\\012\\011\\011\\011\\011end if;\\012\\011\\011\\011end if;\\012   end if;\\012   RETURN NEW;\\012END;\\012$$ LANGUAGE 'plpgsql';\\012\\012CREATE TRIGGER SAMPLE_PROPERTY_WITH_MATERIAL_DATA_TYPE_CHECK BEFORE INSERT OR UPDATE ON sample_properties\\012    FOR EACH ROW EXECUTE PROCEDURE SAMPLE_PROPERTY_WITH_MATERIAL_DATA_TYPE_CHECK();\\012    \\012CREATE OR REPLACE FUNCTION EXPERIMENT_PROPERTY_WITH_MATERIAL_DATA_TYPE_CHECK() RETURNS trigger AS $$\\012DECLARE\\012   v_type_id  CODE;\\012   v_type_id_prop  CODE;\\012BEGIN\\012   if NEW.mate_prop_id IS NOT NULL then\\012\\011\\011\\011-- find material type id of the property type \\012\\011\\011\\011select pt.maty_prop_id into v_type_id_prop \\012\\011\\011\\011  from experiment_type_property_types etpt, property_types pt \\012\\011\\011\\011 where NEW.etpt_id = etpt.id AND etpt.prty_id = pt.id;\\012\\011\\011\\012\\011\\011\\011if v_type_id_prop IS NOT NULL then\\012\\011\\011\\011\\011-- find material type id of the material which consists the entity's property value\\012\\011\\011\\011\\011select entity.maty_id into v_type_id \\012\\011\\011\\011\\011  from materials entity\\012\\011\\011\\011\\011 where NEW.mate_prop_id = entity.id;\\012\\011\\011\\011\\011if v_type_id != v_type_id_prop then\\012\\011\\011\\011\\011\\011RAISE EXCEPTION 'Insert/Update of property value referencing material (id: %) failed, as referenced material type is different than expected (id %, expected id: %).', \\012\\011\\011\\011\\011\\011\\011\\011\\011\\011\\011\\011\\011 NEW.mate_prop_id, v_type_id, v_type_id_prop;\\012\\011\\011\\011\\011end if;\\012\\011\\011\\011end if;\\012   end if;\\012   RETURN NEW;\\012END;\\012$$ LANGUAGE 'plpgsql';\\012\\012CREATE TRIGGER EXPERIMENT_PROPERTY_WITH_MATERIAL_DATA_TYPE_CHECK BEFORE INSERT OR UPDATE ON experiment_properties\\012    FOR EACH ROW EXECUTE PROCEDURE EXPERIMENT_PROPERTY_WITH_MATERIAL_DATA_TYPE_CHECK();\\012       \\012-- -------\\012-- remove the reminescents of the OBSERVABLE_TYPE\\012-- -------\\012\\012ALTER TABLE data\\012\\011DROP CONSTRAINT data_obty_fk;\\012\\012ALTER TABLE data_set_types\\012\\011DROP CONSTRAINT obty_pk;\\012\\012ALTER TABLE data_set_types\\012\\011ADD CONSTRAINT dsty_pk PRIMARY KEY (id);\\012\\012ALTER TABLE data\\012\\011ADD CONSTRAINT data_dsty_fk FOREIGN KEY (dsty_id) REFERENCES data_set_types(id);\\012\\012ALTER TABLE data_set_types\\012\\011DROP CONSTRAINT obty_bk_uk;\\012\\012ALTER TABLE data_set_types\\012\\011DROP CONSTRAINT obty_dbin_fk;\\012\\012ALTER TABLE data_set_types\\012\\011ADD CONSTRAINT dsty_bk_uk UNIQUE (code, dbin_id);\\012\\012ALTER TABLE data_set_types\\012\\011ADD CONSTRAINT dsty_dbin_fk FOREIGN KEY (dbin_id) REFERENCES database_instances(id);\\012\\012DROP INDEX data_obty_fk_i;\\012\\012CREATE INDEX data_dsty_fk_i ON data(dsty_id);\\012	\N
+./sourceTest/sql/postgresql/061/.svn/text-base/017=database_version_logs.tsv.svn-base:030	source/sql/postgresql/migration/migration-029-030.sql	SUCCESS	2009-03-23 15:34:44.72	-- -------\\012-- add modification_timestamp field to allow edition with Hibernate\\012-- -------\\012ALTER TABLE data\\012\\011ADD COLUMN modification_timestamp TIME_STAMP DEFAULT CURRENT_TIMESTAMP;\\012ALTER TABLE experiment_types\\012\\011ADD COLUMN modification_timestamp TIME_STAMP DEFAULT CURRENT_TIMESTAMP;\\012ALTER TABLE sample_types\\012\\011ADD COLUMN modification_timestamp TIME_STAMP DEFAULT CURRENT_TIMESTAMP;\\012ALTER TABLE material_types\\012\\011ADD COLUMN modification_timestamp TIME_STAMP DEFAULT CURRENT_TIMESTAMP;\\012ALTER TABLE data_set_types\\012\\011ADD COLUMN modification_timestamp TIME_STAMP DEFAULT CURRENT_TIMESTAMP;\\012ALTER TABLE controlled_vocabularies\\012\\011ADD COLUMN modification_timestamp TIME_STAMP DEFAULT CURRENT_TIMESTAMP;\\012-- -------\\012-- add properties to data sets\\012-- -------\\012CREATE TABLE DATA_SET_PROPERTIES (ID TECH_ID NOT NULL,DS_ID TECH_ID NOT NULL,DSTPT_ID TECH_ID NOT NULL,VALUE GENERIC_VALUE,CVTE_ID TECH_ID, MATE_PROP_ID TECH_ID, PERS_ID_REGISTERER TECH_ID NOT NULL,REGISTRATION_TIMESTAMP TIME_STAMP_DFL NOT NULL DEFAULT CURRENT_TIMESTAMP, MODIFICATION_TIMESTAMP TIME_STAMP DEFAULT CURRENT_TIMESTAMP);\\012CREATE TABLE DATA_SET_TYPE_PROPERTY_TYPES (ID TECH_ID NOT NULL,DSTY_ID TECH_ID NOT NULL,PRTY_ID TECH_ID NOT NULL,IS_MANDATORY BOOLEAN_CHAR NOT NULL DEFAULT 'F',IS_MANAGED_INTERNALLY BOOLEAN_CHAR NOT NULL DEFAULT 'F',PERS_ID_REGISTERER TECH_ID NOT NULL,REGISTRATION_TIMESTAMP TIME_STAMP_DFL NOT NULL DEFAULT CURRENT_TIMESTAMP);\\012\\012CREATE SEQUENCE DATA_SET_PROPERTY_ID_SEQ;\\012CREATE SEQUENCE DSTPT_ID_SEQ;\\012\\012ALTER TABLE DATA_SET_TYPE_PROPERTY_TYPES ADD CONSTRAINT DSTPT_PK PRIMARY KEY(ID);\\012ALTER TABLE DATA_SET_PROPERTIES ADD CONSTRAINT DSPR_PK PRIMARY KEY(ID);\\012\\012ALTER TABLE DATA_SET_TYPE_PROPERTY_TYPES ADD CONSTRAINT DSTPT_BK_UK UNIQUE(DSTY_ID,PRTY_ID);\\012ALTER TABLE DATA_SET_PROPERTIES ADD CONSTRAINT DSPR_BK_UK UNIQUE(DS_ID,DSTPT_ID);\\012\\012\\012ALTER TABLE DATA_SET_TYPE_PROPERTY_TYPES ADD CONSTRAINT DSTPT_DSTY_FK FOREIGN KEY (DSTY_ID) REFERENCES DATA_SET_TYPES(ID);\\012ALTER TABLE DATA_SET_TYPE_PROPERTY_TYPES ADD CONSTRAINT DSTPT_PERS_FK FOREIGN KEY (PERS_ID_REGISTERER) REFERENCES PERSONS(ID);\\012ALTER TABLE DATA_SET_TYPE_PROPERTY_TYPES ADD CONSTRAINT DSTPT_PRTY_FK FOREIGN KEY (PRTY_ID) REFERENCES PROPERTY_TYPES(ID);\\012ALTER TABLE DATA_SET_PROPERTIES ADD CONSTRAINT DSPR_CVTE_FK FOREIGN KEY (CVTE_ID) REFERENCES CONTROLLED_VOCABULARY_TERMS(ID);\\012ALTER TABLE DATA_SET_PROPERTIES ADD CONSTRAINT DSPR_DSTPT_FK FOREIGN KEY (DSTPT_ID) REFERENCES DATA_SET_TYPE_PROPERTY_TYPES(ID) ON DELETE CASCADE;\\012ALTER TABLE DATA_SET_PROPERTIES ADD CONSTRAINT DSPR_DS_FK FOREIGN KEY (DS_ID) REFERENCES DATA(ID);\\012ALTER TABLE DATA_SET_PROPERTIES ADD CONSTRAINT DSPR_PERS_FK FOREIGN KEY (PERS_ID_REGISTERER) REFERENCES PERSONS(ID);\\012ALTER TABLE DATA_SET_PROPERTIES ADD CONSTRAINT DSPR_MAPR_FK FOREIGN KEY (MATE_PROP_ID) REFERENCES MATERIALS(ID);\\012\\012ALTER TABLE DATA_SET_PROPERTIES ADD CONSTRAINT DSPR_CK CHECK \\012\\011((VALUE IS NOT NULL AND CVTE_ID IS NULL AND MATE_PROP_ID IS NULL) OR \\012\\011 (VALUE IS NULL AND CVTE_ID IS NOT NULL AND MATE_PROP_ID IS NULL) OR\\012\\011 (VALUE IS NULL AND CVTE_ID IS NULL AND MATE_PROP_ID IS NOT NULL)\\012\\011);\\012\\012CREATE INDEX DSPR_CVTE_FK_I ON DATA_SET_PROPERTIES (CVTE_ID);\\012CREATE INDEX DSPR_DSTPT_FK_I ON DATA_SET_PROPERTIES (DSTPT_ID);\\012CREATE INDEX DSPR_DS_FK_I ON DATA_SET_PROPERTIES (DS_ID);\\012CREATE INDEX DSPR_PERS_FK_I ON DATA_SET_PROPERTIES (PERS_ID_REGISTERER);\\012CREATE INDEX DSTPT_DSTY_FK_I ON DATA_SET_TYPE_PROPERTY_TYPES (DSTY_ID);\\012CREATE INDEX DSTPT_PERS_FK_I ON DATA_SET_TYPE_PROPERTY_TYPES (PERS_ID_REGISTERER);\\012CREATE INDEX DSTPT_PRTY_FK_I ON DATA_SET_TYPE_PROPERTY_TYPES (PRTY_ID);\\012\\012CREATE OR REPLACE FUNCTION DATA_SET_PROPERTY_WITH_MATERIAL_DATA_TYPE_CHECK() RETURNS trigger AS $$\\012DECLARE\\012   v_type_id  CODE;\\012   v_type_id_prop  CODE;\\012BEGIN\\012   if NEW.mate_prop_id IS NOT NULL then\\012\\011\\011\\011-- find material type id of the property type \\012\\011\\011\\011select pt.maty_prop_id into v_type_id_prop \\012\\011\\011\\011  from data_set_type_property_types dstpt, property_types pt \\012\\011\\011\\011 where NEW.dstpt_id = dstpt.id AND dstpt.prty_id = pt.id;\\012\\011\\011\\012\\011\\011\\011if v_type_id_prop IS NOT NULL then\\012\\011\\011\\011\\011-- find material type id of the material which consists the entity's property value\\012\\011\\011\\011\\011select entity.maty_id into v_type_id \\012\\011\\011\\011\\011  from materials entity\\012\\011\\011\\011\\011 where NEW.mate_prop_id = entity.id;\\012\\011\\011\\011\\011if v_type_id != v_type_id_prop then\\012\\011\\011\\011\\011\\011RAISE EXCEPTION 'Insert/Update of property value referencing material (id: %) failed, as referenced material type is different than expected (id %, expected id: %).', \\012\\011\\011\\011\\011\\011\\011\\011\\011\\011\\011\\011\\011 NEW.mate_prop_id, v_type_id, v_type_id_prop;\\012\\011\\011\\011\\011end if;\\012\\011\\011\\011end if;\\012   end if;\\012   RETURN NEW;\\012END;\\012$$ LANGUAGE 'plpgsql';\\012\\012CREATE TRIGGER DATA_SET_PROPERTY_WITH_MATERIAL_DATA_TYPE_CHECK BEFORE INSERT OR UPDATE ON data_set_properties\\012    FOR EACH ROW EXECUTE PROCEDURE DATA_SET_PROPERTY_WITH_MATERIAL_DATA_TYPE_CHECK();   \\012	\N
+./sourceTest/sql/postgresql/061/.svn/text-base/017=database_version_logs.tsv.svn-base:032	source/sql/postgresql/migration/migration-031-032.sql	SUCCESS	2009-04-09 09:36:36.2	-- -------\\012-- Modify MATERIAL_BATCHES\\012-- -------\\012\\012ALTER TABLE material_batches\\012    DROP COLUMN proc_id;\\012\\012-- -------\\012-- Modify SAMPLES\\012-- -------\\012\\012ALTER TABLE samples\\012    ADD COLUMN expe_id tech_id;\\012\\012ALTER TABLE samples\\012    ADD CONSTRAINT samp_expe_fk FOREIGN KEY (expe_id) REFERENCES experiments(id);\\012\\012CREATE INDEX samp_expe_fk_i ON samples USING btree (expe_id);\\012\\012-- relink samples directly to experiments\\012\\012UPDATE samples\\012SET expe_id = (SELECT e.id FROM experiments e, procedures p, sample_inputs si \\012               WHERE si.samp_id = samples.id AND si.proc_id = p.id AND p.expe_id = e.id AND e.inva_id IS NULL);\\012\\012\\012-- -------\\012-- Modify DATA\\012-- -------\\012\\012ALTER TABLE data\\012    ADD COLUMN expe_id tech_id;\\012\\012ALTER TABLE data\\012    ADD CONSTRAINT data_expe_fk FOREIGN KEY (expe_id) REFERENCES experiments(id);\\012\\012CREATE INDEX data_expe_fk_i ON data USING btree (expe_id);\\012\\012UPDATE data\\012SET expe_id = (SELECT e.id FROM experiments e, procedures p \\012               WHERE data.proc_id_produced_by = p.id AND p.expe_id = e.id);\\012\\012ALTER TABLE data\\012    ALTER COLUMN expe_id SET NOT NULL;\\012\\012ALTER TABLE data\\012    DROP COLUMN proc_id_produced_by;\\012\\012-- -------\\012-- Drop PROCEDURES, PROCEDURE_TYPES, and SAMPLE_INPUTS\\012-- -------\\012\\012DROP TABLE sample_inputs;\\012DROP TABLE procedures;\\012DROP TABLE procedure_types;\\012\\012DROP SEQUENCE procedure_id_seq;\\012DROP SEQUENCE procedure_type_id_seq;\\012\\012-- -------\\012-- Add CODE_SEQ\\012-- -------\\012\\012CREATE SEQUENCE CODE_SEQ;\\012\\012-- -------\\012-- Add new columns to DATA_STORES\\012-- -------\\012\\012ALTER TABLE data_stores\\012    ADD COLUMN remote_url character varying(250),\\012    ADD COLUMN session_token character varying(50),\\012    ADD COLUMN modification_timestamp time_stamp DEFAULT now();\\012\\012UPDATE data_stores\\012SET remote_url = '', session_token='';\\012\\012ALTER TABLE data_stores\\012    ALTER COLUMN remote_url SET NOT NULL,\\012    ALTER COLUMN session_token SET NOT NULL;\\012\\012-- -------\\012-- Drop foreign keys onto DATA_STORES\\012-- -------\\012\\012ALTER TABLE database_instances\\012    DROP COLUMN dast_id;\\012\\012ALTER TABLE groups\\012    DROP COLUMN dast_id;\\012\\012ALTER TABLE projects\\012    DROP COLUMN dast_id;\\012\\012ALTER TABLE experiments\\012    DROP COLUMN dast_id;\\012\\012-- -------\\012-- Add foreign key from DATA onto DATA_STORES\\012-- -------\\012\\012ALTER TABLE data\\012    ADD COLUMN dast_id tech_id;\\012\\012ALTER TABLE data\\012    ADD CONSTRAINT data_dast_fk FOREIGN KEY (dast_id) REFERENCES data_stores(id);\\012\\012UPDATE data\\012SET dast_id = (select id from data_stores where code = 'STANDARD');\\012\\012ALTER TABLE data\\012    ALTER COLUMN dast_id SET NOT NULL;\\012\\012\\012------------------------------------------------------------------------------------\\012--  Purpose:  Replace trigger SAMPLE_CODE_UNIQUENESS_CHECK \\012------------------------------------------------------------------------------------\\012\\012CREATE OR REPLACE FUNCTION SAMPLE_CODE_UNIQUENESS_CHECK() RETURNS trigger AS $$\\012DECLARE\\012   counter  INTEGER;\\012BEGIN\\012    LOCK TABLE samples IN EXCLUSIVE MODE;\\012    IF (NEW.samp_id_part_of is NULL) THEN\\012        IF (NEW.dbin_id is not NULL) THEN\\012            SELECT count(*) into counter FROM samples \\012                where id != NEW.id and code = NEW.code and samp_id_part_of is NULL and dbin_id = NEW.dbin_id;\\012            IF (counter > 0) THEN\\012                RAISE EXCEPTION 'Insert/Update of Sample (Code: %) failed because database instance sample with the same code already exists.', NEW.code;\\012            END IF;\\012        ELSIF (NEW.grou_id is not NULL) THEN\\012            SELECT count(*) into counter FROM samples \\012                where id != NEW.id and code = NEW.code and samp_id_part_of is NULL and grou_id = NEW.grou_id;\\012            IF (counter > 0) THEN\\012                RAISE EXCEPTION 'Insert/Update of Sample (Code: %) failed because group sample with the same code already exists.', NEW.code;\\012            END IF;\\012        END IF;\\012        ELSE\\012        IF (NEW.dbin_id is not NULL) THEN\\012            SELECT count(*) into counter FROM samples \\012                where id != NEW.id and code = NEW.code and samp_id_part_of = NEW.samp_id_part_of and dbin_id = NEW.dbin_id;\\012            IF (counter > 0) THEN\\012                RAISE EXCEPTION 'Insert/Update of Sample (Code: %) failed because database instance sample with the same code and being the part of the same parent already exists.', NEW.code;\\012            END IF;\\012        ELSIF (NEW.grou_id is not NULL) THEN\\012            SELECT count(*) into counter FROM samples \\012                where id != NEW.id and code = NEW.code and samp_id_part_of = NEW.samp_id_part_of and grou_id = NEW.grou_id;\\012            IF (counter > 0) THEN\\012                RAISE EXCEPTION 'Insert/Update of Sample (Code: %) failed because group sample with the same code and being the part of the same parent already exists.', NEW.code;\\012            END IF;\\012        END IF;\\012        END IF;   \\012   RETURN NEW;\\012END;\\012$$ LANGUAGE 'plpgsql';\\012\\012\\012\\012	\N
+./sourceTest/sql/postgresql/061/.svn/text-base/017=database_version_logs.tsv.svn-base:034	source/sql/postgresql/migration/migration-033-034.sql	SUCCESS	2009-05-26 08:32:49.935	------------------------------------------------------------------------------------\\012-- Create sequence for generating permanent identifiers starting with nextval of existing dataset sequence.\\012------------------------------------------------------------------------------------\\012CREATE FUNCTION CREATE_SEQUENCE(EXISTING_SEQUENCE VARCHAR, NEW_SEQUENCE VARCHAR) RETURNS VOID AS $$\\012DECLARE\\012  CURR_SEQ_VAL   INTEGER;\\012BEGIN\\012  SELECT INTO CURR_SEQ_VAL NEXTVAL(EXISTING_SEQUENCE);\\012  EXECUTE 'CREATE SEQUENCE ' || NEW_SEQUENCE || ' START WITH ' || CURR_SEQ_VAL;\\012  RETURN;\\012END;\\012$$ LANGUAGE 'plpgsql';\\012\\012SELECT CREATE_SEQUENCE('DATA_ID_SEQ', 'PERM_ID_SEQ');\\012DROP FUNCTION CREATE_SEQUENCE(VARCHAR, VARCHAR);\\012\\012------------------------------------------------------------------------------------\\012-- Add perm_id columns to samples and experiments.\\012------------------------------------------------------------------------------------\\012ALTER TABLE SAMPLES ADD COLUMN PERM_ID CODE;\\012ALTER TABLE EXPERIMENTS ADD COLUMN PERM_ID CODE;\\012\\012UPDATE SAMPLES SET PERM_ID = to_char(registration_timestamp,'YYYYMMDDHHSSMS') || '-' || NEXTVAL('PERM_ID_SEQ');\\012UPDATE EXPERIMENTS SET PERM_ID = to_char(registration_timestamp,'YYYYMMDDHHSSMS') || '-' || NEXTVAL('PERM_ID_SEQ');\\012ALTER TABLE SAMPLES ALTER COLUMN PERM_ID SET NOT NULL;\\012ALTER TABLE EXPERIMENTS ALTER COLUMN PERM_ID SET NOT NULL;\\012ALTER TABLE SAMPLES ADD CONSTRAINT SAMP_PI_UK UNIQUE(PERM_ID);\\012ALTER TABLE EXPERIMENTS ADD CONSTRAINT EXPE_PI_UK UNIQUE(PERM_ID);\\012\\012\\012------------------------------------------------------------------------------------\\012-- Add column is_chosen_from_list to controlled_vocabularies.\\012------------------------------------------------------------------------------------\\012ALTER TABLE controlled_vocabularies ADD COLUMN is_chosen_from_list BOOLEAN_CHAR NOT NULL DEFAULT TRUE;\\012ALTER TABLE controlled_vocabularies ADD COLUMN source_uri CHARACTER VARYING(250);\\012------------------------------------------------------------------------------------\\012-- Modify Data table - remove arc connection between Sample and Data table, use a flag instead\\012------------------------------------------------------------------------------------\\012\\012-- add new columns\\012\\012ALTER TABLE data\\012    ADD COLUMN is_derived boolean_char;\\012ALTER TABLE data\\012    ADD COLUMN samp_id tech_id;\\012\\012-- update values in new columns\\012\\012UPDATE data\\012    SET is_derived = (samp_id_derived_from IS NOT NULL); \\012UPDATE data\\012    SET samp_id = samp_id_derived_from \\012    WHERE is_derived = 'TRUE';\\012UPDATE data\\012    SET samp_id = samp_id_acquired_from \\012    WHERE is_derived = 'FALSE';\\012\\012-- add constraints and indexes to new columns\\012\\012ALTER TABLE data\\012    ALTER COLUMN is_derived SET NOT NULL;\\012ALTER TABLE data\\012    ALTER COLUMN samp_id SET NOT NULL;   \\012ALTER TABLE data\\012    ADD CONSTRAINT data_samp_fk FOREIGN KEY (samp_id) REFERENCES samples (id);\\012CREATE INDEX data_samp_fk_i ON data USING btree (samp_id);\\012\\012-- remove old columns\\012\\012ALTER TABLE data\\012    DROP COLUMN samp_id_acquired_from;\\012ALTER TABLE data\\012    DROP COLUMN samp_id_derived_from;\\012    \\012------------------------------------------------------------------------------------\\012-- Granting SELECT privilege to group openbis_readonly\\012------------------------------------------------------------------------------------\\012\\012GRANT SELECT ON SEQUENCE attachment_content_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE attachment_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE code_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE controlled_vocabulary_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE cvte_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE data_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE data_set_property_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE data_set_relationship_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE data_set_type_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE data_store_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE data_type_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE database_instance_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE dstpt_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE etpt_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE event_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE experiment_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE experiment_property_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE experiment_type_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE file_format_type_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE group_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE invalidation_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE locator_type_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE material_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE material_property_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE material_type_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE mtpt_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE perm_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE person_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE project_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE property_type_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE role_assignment_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE sample_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE sample_property_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE sample_type_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE stpt_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE attachment_contents TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE attachments TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE controlled_vocabularies TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE controlled_vocabulary_terms TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE data TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE data_set_properties TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE data_set_relationships TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE data_set_type_property_types TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE data_set_types TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE data_stores TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE data_types TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE database_instances TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE database_version_logs TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE events TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE experiment_properties TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE experiment_type_property_types TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE experiment_types TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE experiments TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE external_data TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE file_format_types TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE groups TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE invalidations TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE locator_types TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE material_properties TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE material_type_property_types TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE material_types TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE materials TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE persons TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE projects TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE property_types TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE role_assignments TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE sample_properties TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE sample_type_property_types TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE sample_types TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE samples TO GROUP OPENBIS_READONLY;\\012\\012------------------------------------------------------------------------------------\\012-- Delete MATERIAL_BATCHES table\\012------------------------------------------------------------------------------------\\012\\012-- WARNING: Potential data lost!!!\\012-- WARNING: Potential data lost!!!\\012-- WARNING: Potential data lost!!!\\012\\012DROP TABLE SAMPLE_MATERIAL_BATCHES;\\012DROP TABLE MATERIAL_BATCHES;\\012DROP SEQUENCE MATERIAL_BATCH_ID_SEQ;\\012\\012------------------------------------------------------------------------------------\\012-- Delete MATE_ID_INHIBITOR_OF from table MATERIALS\\012------------------------------------------------------------------------------------\\012\\012-- WARNING: Potential data lost!!!\\012-- WARNING: Potential data lost!!!\\012-- WARNING: Potential data lost!!!\\012\\012ALTER TABLE MATERIALS DROP COLUMN MATE_ID_INHIBITOR_OF;\\012	\N
+./sourceTest/sql/postgresql/061/.svn/text-base/017=database_version_logs.tsv.svn-base:041	source/sql/postgresql/migration/migration-040-041.sql	SUCCESS	2009-09-14 13:48:57.539	-- Create FILTERS table\\012\\012CREATE TABLE FILTERS (ID TECH_ID NOT NULL, DBIN_ID TECH_ID NOT NULL, NAME VARCHAR(200) NOT NULL, DESCRIPTION DESCRIPTION_1000,REGISTRATION_TIMESTAMP TIME_STAMP_DFL NOT NULL DEFAULT CURRENT_TIMESTAMP, PERS_ID_REGISTERER TECH_ID NOT NULL, MODIFICATION_TIMESTAMP TIME_STAMP DEFAULT CURRENT_TIMESTAMP, EXPRESSION VARCHAR(2000) NOT NULL, IS_PUBLIC BOOLEAN NOT NULL, GRID_ID VARCHAR(200) NOT NULL);\\012CREATE SEQUENCE FILTER_ID_SEQ;\\012ALTER TABLE FILTERS ADD CONSTRAINT FILT_PK PRIMARY KEY(ID);\\012ALTER TABLE FILTERS ADD CONSTRAINT FILT_BK_UK UNIQUE(NAME, DBIN_ID, GRID_ID);\\012ALTER TABLE FILTERS ADD CONSTRAINT FILT_PERS_FK FOREIGN KEY (PERS_ID_REGISTERER) REFERENCES PERSONS(ID);\\012ALTER TABLE FILTERS ADD CONSTRAINT FILT_DBIN_FK FOREIGN KEY (DBIN_ID) REFERENCES DATABASE_INSTANCES(ID);\\012CREATE INDEX FILT_PERS_FK_I ON FILTERS (PERS_ID_REGISTERER);\\012CREATE INDEX FILT_DBIN_FK_I ON FILTERS (DBIN_ID);\\012GRANT SELECT ON SEQUENCE filter_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE filters TO GROUP OPENBIS_READONLY;\\012\\012-- Add missing foreign key to role assignments authorization group\\012ALTER TABLE ROLE_ASSIGNMENTS ADD CONSTRAINT ROAS_AG_FK_GRANTEE FOREIGN KEY (AG_ID_GRANTEE) REFERENCES AUTHORIZATION_GROUPS(ID);\\012\\012--------------------------------------------------------------------------------------------------\\012-- Modify dataset connections:\\012-- 1. connection with sample shouldn't be mandatory any more\\012-- 2. introduce an arc condition that dataset cannot be connected with a sample and a parent dataset at the same time\\012--------------------------------------------------------------------------------------------------\\012\\012-- Weaken data-sample connection constraint - allow dataset to have no connection with sample\\012ALTER TABLE data ALTER COLUMN samp_id DROP NOT NULL;\\012\\012-- Remove data-sample connection for datasets that have a parent\\012\\012UPDATE data \\012   SET samp_id = NULL \\012 WHERE id IN (SELECT DISTINCT data_id_child FROM data_set_relationships);\\012\\012-- With PostgreSQL 8.4 one can check that before migration there were no cycles in dataset relationships:\\012--\\012-- WITH RECURSIVE data_set_parents(id, parent_ids, cycle) AS (\\012--         SELECT  r.data_id_child AS id, \\012--                 ARRAY[CAST (r.data_id_parent AS bigint)] AS parent_ids, \\012--                 false AS cycle \\012--         FROM data_set_relationships r\\012--     UNION ALL\\012--         SELECT  r.data_id_child,\\012--                 CAST (r.data_id_parent AS bigint) || p.parent_ids,\\012--                 r.data_id_child = ANY(p.parent_ids)\\012--         FROM data_set_relationships r, data_set_parents p\\012--         WHERE r.data_id_parent = p.id AND NOT cycle\\012-- )\\012-- SELECT count(*) AS cycles FROM data_set_parents WHERE cycle = true;\\012\\012---------------------------------------------------------------------------------------------------\\012--  Purpose:  Create DEFERRED triggers:\\012--            * check_dataset_relationships_on_data_table_modification,\\012--            * check_dataset_relationships_on_relationships_table_modification.\\012--            They check that after all modifications of database (just before commit) \\012--            if 'data'/'data_set_relationships' tables are among modified tables \\012--            dataset is not connected with a sample and a parent dataset at the same time.\\012--            This connections are held in two different tables so simple immediate trigger \\012--            with arc check cannot be used and we need two deferred triggers.\\012----------------------------------------------------------------------------------------------------\\012\\012-- trigger for 'data' table\\012\\012CREATE OR REPLACE FUNCTION check_dataset_relationships_on_data_table_modification() RETURNS trigger AS $$\\012DECLARE\\012\\011counter\\011INTEGER;\\012BEGIN\\012\\011-- if there is a connection with a Sample there should not be any connection with a parent Data Set\\012\\011IF (NEW.samp_id IS NOT NULL) THEN\\012\\011\\011-- count number of parents\\012\\011\\011SELECT count(*) INTO counter \\012\\011\\011\\011FROM data_set_relationships \\012\\011\\011\\011WHERE data_id_child = OLD.id;\\012\\011\\011IF (counter > 0) THEN\\012\\011\\011\\011RAISE EXCEPTION 'Insert/Update of Data Set (Code: %) failed because it cannot be connected with a Sample and a parent Data Set at the same time.', OLD.code;\\012\\011\\011END IF;\\012\\011END IF;\\012  RETURN NEW;\\012END;\\012$$ LANGUAGE 'plpgsql';\\012\\012CREATE CONSTRAINT TRIGGER check_dataset_relationships_on_data_table_modification \\012  AFTER INSERT OR UPDATE ON data\\012\\011DEFERRABLE INITIALLY DEFERRED\\012\\011FOR EACH ROW \\012\\011EXECUTE PROCEDURE check_dataset_relationships_on_data_table_modification();\\012\\012-- trigger for 'data_set_relationships'\\012\\012CREATE OR REPLACE FUNCTION check_dataset_relationships_on_relationships_table_modification() RETURNS trigger AS $$\\012DECLARE\\012\\011counter\\011INTEGER;\\012\\011sample_id\\011TECH_ID;\\012\\011data_code\\011CODE;\\012BEGIN\\012\\011-- child will have a parent added so it should not be connected with any sample\\012\\011SELECT samp_id, code INTO sample_id, data_code \\012\\011\\011FROM data \\012\\011\\011WHERE id = NEW.data_id_child;\\012\\011IF (sample_id IS NOT NULL) THEN\\012\\011\\011RAISE EXCEPTION 'Insert/Update of Data Set (Code: %) failed because it cannot be connected to a Sample and to a parent Data Set at the same time.', data_code;\\012\\011END IF;\\012\\011RETURN NEW;\\012END;\\012$$ LANGUAGE 'plpgsql';\\012  \\012CREATE CONSTRAINT TRIGGER check_dataset_relationships_on_relationships_table_modification \\012  AFTER INSERT OR UPDATE ON data_set_relationships\\012\\011DEFERRABLE INITIALLY DEFERRED\\012\\011FOR EACH ROW \\012\\011EXECUTE PROCEDURE check_dataset_relationships_on_relationships_table_modification();\\012	\N
+./sourceTest/sql/postgresql/061/.svn/text-base/017=database_version_logs.tsv.svn-base:053	source/sql/postgresql/migration/migration-052-053.sql	SUCCESS	2010-06-08 15:27:55.032	-- Migration from 052 to 053\\012\\012-- Change code uniqueness check for samples of specific type.\\012-- If sample_types.is_subcode_unique flag is set to 'true', additional check is performed \\012-- on codes of samples of the type. Subcodes will have to be unique as well.\\012\\012ALTER TABLE sample_types ADD COLUMN is_subcode_unique boolean_char NOT NULL DEFAULT false;\\012\\012CREATE OR REPLACE FUNCTION SAMPLE_SUBCODE_UNIQUENESS_CHECK() RETURNS trigger AS $$\\012DECLARE\\012   counter  INTEGER;\\012   unique_subcode  BOOLEAN_CHAR;\\012BEGIN\\012  LOCK TABLE samples IN EXCLUSIVE MODE;\\012  \\012  SELECT is_subcode_unique into unique_subcode FROM sample_types WHERE id = NEW.saty_id;\\012  \\012  IF (unique_subcode) THEN\\012    IF (NEW.dbin_id is not NULL) THEN\\012\\011\\011\\011SELECT count(*) into counter FROM samples \\012\\011\\011\\011\\011where id != NEW.id and code = NEW.code and saty_id = NEW.saty_id and dbin_id = NEW.dbin_id;\\012\\011\\011\\011IF (counter > 0) THEN\\012\\011\\011\\011\\011RAISE EXCEPTION 'Insert/Update of Sample (Code: %) failed because database instance sample of the same type with the same subcode already exists.', NEW.code;\\012\\011\\011\\011END IF;\\012\\011\\011ELSIF (NEW.grou_id is not NULL) THEN\\012\\011\\011\\011SELECT count(*) into counter FROM samples \\012\\011\\011\\011\\011where id != NEW.id and code = NEW.code and saty_id = NEW.saty_id and grou_id = NEW.grou_id;\\012\\011\\011\\011IF (counter > 0) THEN\\012\\011\\011\\011\\011RAISE EXCEPTION 'Insert/Update of Sample (Code: %) failed because space sample of the same type with the same subcode already exists.', NEW.code;\\012\\011\\011\\011END IF;\\012\\011\\011END IF;\\012  END IF;\\012  \\012  RETURN NEW;\\012END;\\012$$ LANGUAGE 'plpgsql';\\012\\012CREATE TRIGGER SAMPLE_SUBCODE_UNIQUENESS_CHECK BEFORE INSERT OR UPDATE ON SAMPLES\\012    FOR EACH ROW EXECUTE PROCEDURE SAMPLE_SUBCODE_UNIQUENESS_CHECK();\\012    \\012-- Fixing error messages in old trigger\\012\\012CREATE OR REPLACE FUNCTION SAMPLE_CODE_UNIQUENESS_CHECK() RETURNS trigger AS $$\\012DECLARE\\012   counter  INTEGER;\\012BEGIN\\012  LOCK TABLE samples IN EXCLUSIVE MODE;\\012  \\012\\011  IF (NEW.samp_id_part_of is NULL) THEN\\012\\011\\011  IF (NEW.dbin_id is not NULL) THEN\\012\\011\\011\\011  SELECT count(*) into counter FROM samples \\012\\011\\011      where id != NEW.id and code = NEW.code and samp_id_part_of is NULL and dbin_id = NEW.dbin_id;\\012        IF (counter > 0) THEN\\012\\011\\011\\011\\011  RAISE EXCEPTION 'Insert/Update of Sample (Code: %) failed because database instance sample with the same code already exists.', NEW.code;\\012        END IF;\\012\\011\\011  ELSIF (NEW.grou_id is not NULL) THEN\\012\\011\\011\\011  SELECT count(*) into counter FROM samples \\012\\011\\011\\011\\011  where id != NEW.id and code = NEW.code and samp_id_part_of is NULL and grou_id = NEW.grou_id;\\012\\011\\011\\011  IF (counter > 0) THEN\\012\\011\\011\\011\\011  RAISE EXCEPTION 'Insert/Update of Sample (Code: %) failed because space sample with the same code already exists.', NEW.code;\\012\\011\\011\\011  END IF;\\012      END IF;\\012    ELSE\\012\\011\\011  IF (NEW.dbin_id is not NULL) THEN\\012\\011\\011\\011  SELECT count(*) into counter FROM samples \\012\\011\\011\\011\\011  where id != NEW.id and code = NEW.code and samp_id_part_of = NEW.samp_id_part_of and dbin_id = NEW.dbin_id;\\012\\011\\011\\011  IF (counter > 0) THEN\\012\\011\\011\\011\\011  RAISE EXCEPTION 'Insert/Update of Sample (Code: %) failed because database instance sample with the same code and being the part of the same container already exists.', NEW.code;\\012\\011\\011\\011  END IF;\\012\\011\\011  ELSIF (NEW.grou_id is not NULL) THEN\\012\\011\\011\\011  SELECT count(*) into counter FROM samples \\012\\011\\011\\011\\011  where id != NEW.id and code = NEW.code and samp_id_part_of = NEW.samp_id_part_of and grou_id = NEW.grou_id;\\012\\011\\011\\011  IF (counter > 0) THEN\\012\\011\\011\\011\\011  RAISE EXCEPTION 'Insert/Update of Sample (Code: %) failed because space sample with the same code and being the part of the same container already exists.', NEW.code;\\012\\011\\011\\011  END IF;\\012\\011\\011  END IF;\\012     END IF;   \\012  \\012  RETURN NEW;\\012END;\\012$$ LANGUAGE 'plpgsql';\\012	\N
+./sourceTest/sql/postgresql/061/.svn/text-base/017=database_version_logs.tsv.svn-base:054	source/sql/postgresql/migration/migration-053-054.sql	SUCCESS	2010-07-27 11:30:46.766	-- Migration from 053 to 054\\012\\012\\012-- Add RELATIONSHIP_TYPES table\\012CREATE TABLE relationship_types (id TECH_ID NOT NULL, code CODE NOT NULL, label COLUMN_LABEL, parent_label COLUMN_LABEL, child_label COLUMN_LABEL, description DESCRIPTION_2000, registration_timestamp TIME_STAMP_DFL NOT NULL DEFAULT CURRENT_TIMESTAMP, pers_id_registerer TECH_ID NOT NULL, is_managed_internally BOOLEAN_CHAR NOT NULL DEFAULT 'F', is_internal_namespace BOOLEAN_CHAR NOT NULL DEFAULT 'F', dbin_id TECH_ID NOT NULL);\\012\\012-- Add SAMPLE_RELATIONSHIPS table\\012CREATE TABLE sample_relationships (id TECH_ID NOT NULL, sample_id_parent TECH_ID NOT NULL, relationship_id TECH_ID NOT NULL, sample_id_child TECH_ID NOT NULL);\\012\\012-- Add/update constraints\\012ALTER TABLE relationship_types ADD CONSTRAINT rety_pk PRIMARY KEY (id);\\012ALTER TABLE relationship_types ADD CONSTRAINT rety_uk UNIQUE(code,dbin_id);\\012ALTER TABLE sample_relationships ADD CONSTRAINT sare_pk PRIMARY KEY (id);\\012ALTER TABLE sample_relationships ADD CONSTRAINT sare_bk_uk UNIQUE(sample_id_child,sample_id_parent,relationship_id);\\012ALTER TABLE sample_relationships ADD CONSTRAINT sare_data_fk_child FOREIGN KEY (sample_id_child) REFERENCES samples(id) ON DELETE CASCADE;\\012ALTER TABLE sample_relationships ADD CONSTRAINT sare_data_fk_parent FOREIGN KEY (sample_id_parent) REFERENCES samples(id) ON DELETE CASCADE;\\012ALTER TABLE sample_relationships ADD CONSTRAINT sare_data_fk_relationship FOREIGN KEY (relationship_id) REFERENCES relationship_types(id);\\012\\012-- Create index\\012CREATE INDEX sare_data_fk_i_child ON sample_relationships (sample_id_child);\\012CREATE INDEX sare_data_fk_i_parent ON sample_relationships (sample_id_parent);\\012CREATE INDEX sare_data_fk_i_relationship ON sample_relationships (relationship_id);\\012\\012-- Create sequence for RELATIONSHIP_TYPES\\012CREATE SEQUENCE RELATIONSHIP_TYPE_ID_SEQ;\\012CREATE SEQUENCE SAMPLE_RELATIONSHIP_ID_SEQ;\\012\\012-- Create initial relationships\\012insert into relationship_types\\012(id, \\012code, \\012label, \\012parent_label, \\012child_label, \\012description, \\012pers_id_registerer, \\012is_managed_internally, \\012is_internal_namespace, \\012dbin_id) \\012values\\012(\\012nextval('RELATIONSHIP_TYPE_ID_SEQ'),\\012'PARENT_CHILD',\\012'Parent - Child', \\012'Parent', \\012'Child', \\012'Parent - Child relationship', \\012(select id from persons where user_id ='system'), \\012'T', \\012'T', \\012(select id from database_instances where is_original_source = 'T')\\012);\\012\\012insert into relationship_types\\012(id, \\012code, \\012label, \\012parent_label, \\012child_label, \\012description, \\012pers_id_registerer, \\012is_managed_internally, \\012is_internal_namespace, \\012dbin_id) \\012values\\012(\\012nextval('RELATIONSHIP_TYPE_ID_SEQ'),\\012'PLATE_CONTROL_LAYOUT',\\012'Plate - Control Layout', \\012'Plate', \\012'Control Layout', \\012'Plate - Control Layout relationship', \\012(select id from persons where user_id ='system'), \\012'T', \\012'T', \\012(select id from database_instances where is_original_source = 'T')\\012); \\012\\012\\012-- Migrate sample relationships to new schema\\012INSERT INTO sample_relationships (id, sample_id_parent,sample_id_child,relationship_id) (select distinct nextval('SAMPLE_RELATIONSHIP_ID_SEQ') as id, s.SAMP_ID_GENERATED_FROM as parent_id, s.ID as child_id, rt.id as relationship_id from samples s, relationship_types rt  WHERE rt.code = 'PARENT_CHILD' and s.SAMP_ID_GENERATED_FROM is not null); \\012INSERT INTO sample_relationships (id, sample_id_parent,sample_id_child,relationship_id) (select distinct nextval('SAMPLE_RELATIONSHIP_ID_SEQ') as id, s.SAMP_ID_CONTROL_LAYOUT as parent_id, s.ID as child_id, rt.id as relationship_id from samples s, relationship_types rt  WHERE rt.code = 'PLATE_CONTROL_LAYOUT' and s.SAMP_ID_CONTROL_LAYOUT is not null);\\012\\012-- Drop old sample relations\\012ALTER TABLE SAMPLES DROP COLUMN SAMP_ID_TOP;\\012ALTER TABLE SAMPLES DROP COLUMN SAMP_ID_GENERATED_FROM;\\012ALTER TABLE SAMPLES DROP COLUMN SAMP_ID_CONTROL_LAYOUT;\\012\\012--------------------------------------------------------------------------------------\\012--------------------------------------------------------------------------------------\\012-- This is a screening specific migration. Nothing will be performed on openBIS databases \\012-- which are not screening specific.\\012-- \\012-- This migration for each existing connection between oligo well, oligo material and gene material\\012-- creates a direct connection between the well and the gene. \\012--------------------------------------------------------------------------------------\\012--------------------------------------------------------------------------------------\\012 \\012\\011\\012CREATE OR REPLACE FUNCTION CONNECT_WELLS_WITH_GENES() RETURNS void AS $$\\012DECLARE\\012\\011counter  int;\\012\\011oligo_well_exists bool;\\012BEGIN\\012\\011--------------------------------------------------\\012\\011-- create a gene property and assign it to oligo well\\012\\011--------------------------------------------------\\012\\011\\012\\011select true \\012\\011into oligo_well_exists\\012\\011from sample_types \\012\\011where code = 'OLIGO_WELL';\\012\\011\\012\\011if oligo_well_exists IS NULL then \\012\\011\\011-- skip migration if there are no oligo wells\\012\\011\\011return;\\012\\011end if;   \\012\\011\\012\\011insert into property_types(\\012\\011\\011id, \\012\\011\\011code, description, label, \\012\\011\\011daty_id,\\012\\011\\011pers_id_registerer,\\012\\011\\011dbin_id,\\012\\011\\011maty_prop_id) \\012\\011values(\\012\\011\\011\\011nextval('PROPERTY_TYPE_ID_SEQ'), \\012\\011\\011\\011'GENE','Inhibited gene','Gene',\\012\\011\\011\\011(select id from data_types where code = 'MATERIAL'), \\012\\011\\011\\011(select id from persons where user_id ='system'), \\012\\011\\011\\011(select id from database_instances where is_original_source = 'T'), \\012\\011\\011\\011(select id from material_types where code = 'GENE')\\012\\011\\011);\\012\\011\\011\\012\\011insert into sample_type_property_types( \\012\\011  id,\\012\\011  saty_id,\\012\\011  prty_id,\\012\\011  is_mandatory,\\012\\011  pers_id_registerer,\\012\\011  ordinal\\012\\011) values(\\012\\011\\011\\011nextval('stpt_id_seq'), \\012\\011\\011\\011(select id from sample_types where code = 'OLIGO_WELL'),\\012\\011\\011\\011(select id from property_types where code = 'GENE'),\\012\\011\\011\\011false,\\012\\011\\011\\011(select id from persons where user_id ='system'),\\012\\011\\011\\011(select max(ordinal)+1 from sample_type_property_types \\012\\011\\011\\011\\011where saty_id = (select id from sample_types where code = 'OLIGO_WELL'))\\012\\011\\011);\\012\\012\\011--------------------------------------------------\\012\\011-- create a gene material property for each oligo well\\012\\011--------------------------------------------------\\012\\011\\011\\012\\011select \\011count(*)\\012\\011into counter\\012\\011from\\012\\011\\011samples well, sample_types well_type, sample_properties well_props, \\012\\011\\011materials well_material, material_properties well_material_props,\\012\\011\\011materials nested_well_material\\012\\011where\\012\\011\\011well_type.code = 'OLIGO_WELL' and\\012\\011\\011-- find 'well_material' assigned to the well\\012\\011\\011well_props.samp_id = well.id and well_material.id = well_props.mate_prop_id and \\012\\011\\011-- additional joins to entity type tables\\012\\011\\011well_type.id = well.saty_id and\\012\\011\\011-- well content material property\\012\\011\\011well_material_props.mate_id = well_material.id and \\012\\011\\011-- material connected to the material in the well (e.g. gene)\\012\\011\\011well_material_props.mate_prop_id = nested_well_material.id and\\012\\011\\011nested_well_material.maty_id = (select id from material_types where code = 'GENE');\\012\\011\\012\\011if counter = 0 then \\012\\011\\011-- skip migration if there are no genes indirectly connected to oligo wells\\012\\011\\011return;\\012\\011end if;   \\012\\012\\011insert into sample_properties(id, samp_id, stpt_id, mate_prop_id, pers_id_registerer) (\\012\\011\\011select \\011nextval('sample_property_id_seq') id, \\012\\011\\011\\011well.id samp_id, \\012\\011\\011\\011(select stpt.id from sample_type_property_types stpt, property_types props where stpt.prty_id = props.id and props.code='GENE') stpt_id,\\012\\011\\011\\011nested_well_material.id mate_prop_id,\\012\\011\\011\\011(select id from persons where user_id ='system') pers_id_registerer \\012\\011\\011from\\012\\011\\011\\011samples well, sample_types well_type, sample_properties well_props, \\012\\011\\011\\011materials well_material, material_properties well_material_props,\\012\\011\\011\\011materials nested_well_material\\012\\011\\011where\\012\\011\\011\\011well_type.code = 'OLIGO_WELL' and\\012\\011\\011\\011-- find 'well_material' assigned to the well\\012\\011\\011\\011well_props.samp_id = well.id and well_material.id = well_props.mate_prop_id and \\012\\011\\011\\011-- additional joins to entity type tables\\012\\011\\011\\011well_type.id = well.saty_id and\\012\\011\\011\\011-- well content material property\\012\\011\\011\\011well_material_props.mate_id = well_material.id and \\012\\011\\011\\011-- material connected to the material in the well (e.g. gene)\\012\\011\\011\\011well_material_props.mate_prop_id = nested_well_material.id and\\012\\011\\011\\011nested_well_material.maty_id = (select id from material_types where code = 'GENE')\\012\\011);\\012\\012END;\\012$$ LANGUAGE 'plpgsql';\\012\\012select CONNECT_WELLS_WITH_GENES();\\012drop function CONNECT_WELLS_WITH_GENES();\\012\\012--------------------------------------------------------------------------------------\\012--------------------------------------------------------------------------------------\\012\\012-- drop dataset triggers\\012\\012DROP TRIGGER check_dataset_relationships_on_data_table_modification ON data;\\012DROP FUNCTION check_dataset_relationships_on_data_table_modification();\\012DROP TRIGGER check_dataset_relationships_on_relationships_table_modification ON data_set_relationships;\\012DROP FUNCTION check_dataset_relationships_on_relationships_table_modification();\\012 \\012\\012\\012\\012\\012\\012\\012\\012	\N
+./sourceTest/sql/postgresql/061/.svn/text-base/017=database_version_logs.tsv.svn-base:056	source/sql/postgresql/migration/migration-055-056.sql	SUCCESS	2010-09-10 09:06:20.278	-- Migration from 055 to 056\\012\\012--------------------------------------------------------------------------------------\\012--------------------------------------------------------------------------------------\\012-- Screening specific migration. Nothing will be performed on openBIS databases \\012-- which are not screening specific.\\012--------------------------------------------------------------------------------------\\012--------------------------------------------------------------------------------------\\012\\012CREATE OR REPLACE FUNCTION merge_words(text, text) RETURNS text AS $$\\012DECLARE\\012  BEGIN\\012    IF  character_length($1) > 0 THEN\\012      RETURN $1 || ' ' || $2;\\012    ELSE\\012      RETURN $2;\\012    END IF;\\012  END;\\012$$ LANGUAGE plpgsql;\\012\\012CREATE AGGREGATE merge_words(text)\\012(\\012  SFUNC = merge_words,\\012  STYPE = text\\012);\\012\\012\\012CREATE OR REPLACE FUNCTION REPLACE_GENE_SYMBOL_BY_GENE_ID() RETURNS void AS $$\\012DECLARE\\012\\011counter  int;\\012\\011library_id_assigned_to_gene bool;\\012BEGIN\\012\\011--------------------------------------------------\\012\\011-- create a GENE_SYMBOL property and assign it to GENE\\012\\011--------------------------------------------------\\012\\011\\012\\011select true  \\012\\011into library_id_assigned_to_gene \\012\\011from material_type_property_types mtpt, material_types mt, property_types pt  \\012\\011where mtpt.maty_id = mt.id and mtpt.prty_id = pt.id \\012\\011\\011and mt.code = 'GENE' and pt.code = 'LIBRARY_ID';\\012\\011\\012\\011if library_id_assigned_to_gene IS NULL then \\012\\011\\011-- skip migration if gene has no library_id property\\012\\011\\011return;\\012\\011end if; \\012\\011\\012\\011\\012\\011select count(*)\\012\\011into counter \\012\\011from  \\012\\011\\011(select m.id, count(mp.id) as c \\012\\011\\011\\011from materials m, material_types mt, material_properties mp, material_type_property_types mtpt, property_types pt \\012\\011\\011\\011where m.maty_id = mt.id and mp.mate_id = m.id and mp.mtpt_id = mtpt.id and mtpt.maty_id = mt.id and pt.id = mtpt.prty_id\\012\\011\\011\\011\\011and mt.code = 'GENE' and pt.code = 'LIBRARY_ID' \\012\\011\\011\\011group by m.id) as counter_table \\012\\011where c < 1; \\012\\011\\012\\011if counter > 0 then \\012\\011\\011-- skip migration if there is at least one gene without library_id\\012\\011\\011return;\\012\\011end if;\\012\\011\\012\\011\\012\\011insert into property_types\\012\\011\\011(id\\012\\011\\011,code\\012\\011\\011,description\\012\\011\\011,label\\012\\011\\011,daty_id\\012\\011\\011,pers_id_registerer\\012\\011\\011,dbin_id)\\012\\011values \\012\\011\\011(nextval('PROPERTY_TYPE_ID_SEQ')\\012\\011\\011,'GENE_SYMBOLS'\\012\\011\\011,'Gene symbols'\\012\\011\\011,'Gene symbols'\\012\\011\\011,(select id from data_types where code ='VARCHAR')\\012\\011\\011,(select id from persons where user_id ='system')\\012\\011\\011,(select id from database_instances where is_original_source = 'T')\\012\\011);\\012\\011\\011\\012\\011insert into material_type_property_types( \\012\\011  id,\\012\\011  maty_id,\\012\\011  prty_id,\\012\\011  is_mandatory,\\012\\011  pers_id_registerer,\\012\\011  ordinal\\012\\011) values(\\012\\011\\011\\011nextval('mtpt_id_seq'), \\012\\011\\011\\011(select id from material_types where code = 'GENE'),\\012\\011\\011\\011(select id from property_types where code = 'GENE_SYMBOLS'),\\012\\011\\011\\011false,\\012\\011\\011\\011(select id from persons where user_id ='system'),\\012\\011\\011\\011(select max(ordinal)+1 from material_type_property_types \\012\\011\\011\\011\\011where maty_id = (select id from material_types where code = 'GENE'))\\012\\011\\011);\\012\\012\\011--------------------------------------------------\\012\\011-- create temporary table with all gene migration information\\012\\011--------------------------------------------------\\012\\012\\011create temp table genes \\012\\011(\\012\\011\\011id tech_id,\\012\\011\\011code code,\\012\\011\\011library_id generic_value,\\012\\011\\011gene_codes generic_value,\\012\\011\\011new_id tech_id,\\012\\011\\011library_tech_id tech_id\\011\\011\\012\\011);\\012\\011\\012\\011insert into genes (id, code, library_id, library_tech_id)\\012\\011\\011(select m.id, m.code, mp.value as library_id, mp.id as library_tech_id from materials m, material_properties mp, material_type_property_types mtpt, property_types pt, material_types mt\\012\\011\\011where mp.mate_id = m.id and  mp.mtpt_id = mtpt.id and pt.id = mtpt.prty_id and pt.code = 'LIBRARY_ID' and mt.id = m.maty_id and mt.id = mtpt.maty_id and mt.code = 'GENE');\\012\\011\\012\\011update genes set new_id = map.to_id from (select g_from.id as from_id, min(g_to.id) as to_id  from genes g_from, genes g_to where g_from.library_id = g_to.library_id group by g_from.id) as map where map.from_id = id;\\011\\012\\011\\012\\011update genes set gene_codes = map.gene_codes from (select g_from.library_id as lib_id, merge_words(distinct g_to.code) as gene_codes from genes g_from, genes g_to where g_from.library_id = g_to.library_id group by g_from.library_id) as map where map.lib_id = library_id;\\011\\012\\012\\011--------------------------------------------------\\012\\011-- update gene references\\012\\011--------------------------------------------------\\012\\012\\011update EXPERIMENTS set MATE_ID_STUDY_OBJECT = genes.new_id from genes where genes.id = MATE_ID_STUDY_OBJECT and not genes.id = genes.new_id;\\012\\011update EXPERIMENT_PROPERTIES set  MATE_PROP_ID = genes.new_id from genes where genes.id = MATE_PROP_ID and not genes.id = genes.new_id;\\012\\011update MATERIAL_PROPERTIES set  MATE_PROP_ID = genes.new_id from genes where genes.id = MATE_PROP_ID and not genes.id = genes.new_id;\\012\\011update SAMPLE_PROPERTIES set  MATE_PROP_ID = genes.new_id from genes where genes.id = MATE_PROP_ID and not genes.id = genes.new_id;\\012\\011update DATA_SET_PROPERTIES set  MATE_PROP_ID = genes.new_id from genes where genes.id = MATE_PROP_ID and not genes.id = genes.new_id;\\012\\011\\012\\011delete from  material_properties where mate_id in (select id from genes where not genes.id = genes.new_id);\\012\\011delete from MATERIALS where id in (select id from genes where not genes.id = genes.new_id);\\012\\012\\011delete from genes where id in (select id from genes where not genes.id = genes.new_id);\\012\\012\\012\\011--------------------------------------------------\\012\\011-- replace gene code with library_id\\012\\011--------------------------------------------------\\012\\011\\012\\011update materials set code = genes.library_id from genes where materials.id = genes.id ;\\012\\011delete from material_properties where id in (select library_tech_id from genes);\\012\\011\\012\\011--------------------------------------------------\\012\\011-- create a gene symbols property for each gene\\012\\011--------------------------------------------------\\012\\011\\012\\011insert into material_properties\\012\\011\\011(id\\012\\011  , mate_id\\012\\011  , mtpt_id\\012\\011  , "value"\\012\\011  , pers_id_registerer)\\012\\011\\011(select nextval('material_property_id_seq') id\\012\\011  \\011, genes.id  mate_id\\012\\011    , (select mtpt.id\\012\\011    \\011\\011from   material_type_property_types mtpt, material_types mt, property_types pt\\012\\011    \\011\\011where  pt.code = 'GENE_SYMBOLS' and mt.code = 'GENE' and mtpt.prty_id = pt.id\\012\\011        \\011and mtpt.maty_id = mt.id) mtpt_id\\012\\011    , genes.gene_codes "value"\\012\\011    , (select id from persons where user_id = 'system') pers_id_registerer\\012\\011 \\011from genes); \\012\\012\\011--------------------------------------------------\\012\\011-- delete temporary table\\012\\011--------------------------------------------------\\012\\011\\012\\011drop table genes;\\012\\011\\012END;\\012$$ LANGUAGE 'plpgsql';\\012\\012select REPLACE_GENE_SYMBOL_BY_GENE_ID();\\012drop function REPLACE_GENE_SYMBOL_BY_GENE_ID();\\012DROP AGGREGATE merge_words(text);\\012drop function merge_words(text,text);\\012\\012\\012--------------------------------------------------------------------------------------\\012--------------------------------------------------------------------------------------\\012\\012UPDATE sample_types SET code = 'SIRNA_WELL' WHERE code = 'OLIGO_WELL';\\012UPDATE material_types SET code = 'SIRNA' WHERE code = 'OLIGO';\\012UPDATE property_types SET code = 'SIRNA', label = 'siRNA' WHERE code = 'OLIGO';\\012\\012\\012\\012\\012\\012\\012\\012\\012\\012\\012\\012\\012\\012\\012\\012\\012\\012\\012\\012	\N
+./sourceTest/sql/postgresql/061/.svn/text-base/017=database_version_logs.tsv.svn-base:059	source/sql/postgresql/migration/migration-058-059.sql	SUCCESS	2010-09-29 13:37:07.231	-- Migration from 058 to 059\\012\\012-- Add ENTITY_TYPE_CODE column to QUERIES\\012ALTER TABLE queries ADD COLUMN entity_type_code CODE;\\012\\012------------------------------------------------------------------------------------\\012--  Purpose:  Create trigger that checks if entity_type_code specified in a query\\012--            matches a code of an entity of type specified in query_type.\\012------------------------------------------------------------------------------------\\012\\012CREATE OR REPLACE FUNCTION query_entity_type_code_check() RETURNS trigger AS $$\\012DECLARE\\012   counter  INTEGER;\\012BEGIN\\012   if (NEW.entity_type_code IS NOT NULL) then\\012     if (NEW.query_type = 'GENERIC') then\\012       RAISE EXCEPTION 'Insert/Update of query (Name: %) failed, as entity_type has to be null for GENERIC queries.', NEW.name;\\012     elsif (NEW.query_type = 'EXPERIMENT') then\\012       SELECT count(*) INTO counter FROM experiment_types WHERE code = NEW.entity_type_code;\\012\\011\\011 elsif (NEW.query_type = 'DATA_SET') then\\012       SELECT count(*) INTO counter FROM data_set_types WHERE code = NEW.entity_type_code;\\012\\011\\011 elsif (NEW.query_type = 'MATERIAL') then\\012       SELECT count(*) INTO counter FROM material_types WHERE code = NEW.entity_type_code;\\012\\011\\011 elsif (NEW.query_type = 'SAMPLE') then\\012       SELECT count(*) INTO counter FROM sample_types WHERE code = NEW.entity_type_code;\\012\\011\\011 end if;\\012\\011\\011 if (counter = 0) then\\012\\011\\011\\011 RAISE EXCEPTION 'Insert/Update of query (Name: %) failed because % type (Code: %) does not exist.', NEW.name, NEW.query_type, NEW.entity_type_code;\\012\\011\\011 end if;\\011\\011\\011\\012   end if;\\012   RETURN NEW;\\012END;\\012$$ LANGUAGE 'plpgsql';\\012\\012CREATE TRIGGER query_entity_type_code_check BEFORE INSERT OR UPDATE ON queries\\012    FOR EACH ROW EXECUTE PROCEDURE query_entity_type_code_check();\\012	\N
+./sourceTest/sql/postgresql/061/.svn/text-base/schema-061.sql.svn-base:    LANGUAGE plpgsql
+./sourceTest/sql/postgresql/061/.svn/text-base/schema-061.sql.svn-base:    LANGUAGE plpgsql
+./sourceTest/sql/postgresql/061/.svn/text-base/schema-061.sql.svn-base:    LANGUAGE plpgsql
+./sourceTest/sql/postgresql/061/.svn/text-base/schema-061.sql.svn-base:    LANGUAGE plpgsql
+./sourceTest/sql/postgresql/061/.svn/text-base/schema-061.sql.svn-base:    LANGUAGE plpgsql
+./sourceTest/sql/postgresql/061/.svn/text-base/schema-061.sql.svn-base:    LANGUAGE plpgsql
+./sourceTest/sql/postgresql/061/.svn/text-base/schema-061.sql.svn-base:    LANGUAGE plpgsql
+./sourceTest/sql/postgresql/061/.svn/text-base/schema-061.sql.svn-base:    LANGUAGE plpgsql
+./sourceTest/sql/postgresql/061/.svn/text-base/schema-061.sql.svn-base:    LANGUAGE plpgsql
+./sourceTest/sql/postgresql/061/017=database_version_logs.tsv:027	D:\\User\\felmer\\dev-workspace\\openbis/source/sql/postgresql/027/function-027.sql	SUCCESS	2008-11-05 09:18:00.403	-- Creating Functions\\012\\012------------------------------------------------------------------------------------\\012--  Purpose:  Create function RENAME_SEQUENCE() that is required for renaming the sequences belonging to tables\\012------------------------------------------------------------------------------------\\012CREATE FUNCTION RENAME_SEQUENCE(OLD_NAME VARCHAR, NEW_NAME VARCHAR) RETURNS INTEGER AS $$\\012DECLARE\\012  CURR_SEQ_VAL   INTEGER;\\012BEGIN\\012  SELECT INTO CURR_SEQ_VAL NEXTVAL(OLD_NAME);\\012  EXECUTE 'CREATE SEQUENCE ' || NEW_NAME || ' START WITH ' || CURR_SEQ_VAL;\\012  EXECUTE 'DROP SEQUENCE ' || OLD_NAME;\\012  RETURN CURR_SEQ_VAL;\\012END;\\012$$ LANGUAGE 'plpgsql';\\012\\012\\012------------------------------------------------------------------------------------\\012--  Purpose:  Create trigger CONTROLLED_VOCABULARY_CHECK \\012------------------------------------------------------------------------------------\\012\\012CREATE OR REPLACE FUNCTION CONTROLLED_VOCABULARY_CHECK() RETURNS trigger AS $$\\012DECLARE\\012   v_code  CODE;\\012BEGIN\\012\\012   select code into v_code from data_types where id = NEW.daty_id;\\012\\012   -- Check if the data is of type "CONTROLLEDVOCABULARY"\\012   if v_code = 'CONTROLLEDVOCABULARY' then\\012      if NEW.covo_id IS NULL then\\012         RAISE EXCEPTION 'Insert/Update of Property Type (Code: %) failed, as its Data Type is CONTROLLEDVOCABULARY, but it is not linked to a Controlled Vocabulary.', NEW.code;\\012      end if;\\012   end if;\\012\\012   RETURN NEW;\\012\\012END;\\012$$ LANGUAGE 'plpgsql';\\012\\012CREATE TRIGGER CONTROLLED_VOCABULARY_CHECK BEFORE INSERT OR UPDATE ON PROPERTY_TYPES\\012    FOR EACH ROW EXECUTE PROCEDURE CONTROLLED_VOCABULARY_CHECK();\\012\\012\\012------------------------------------------------------------------------------------\\012--  Purpose:  Create trigger EXTERNAL_DATA_STORAGE_FORMAT_CHECK \\012------------------------------------------------------------------------------------\\012\\012CREATE OR REPLACE FUNCTION EXTERNAL_DATA_STORAGE_FORMAT_CHECK() RETURNS trigger AS $$\\012DECLARE\\012   v_covo_code  CODE;\\012   data_code CODE;\\012BEGIN\\012\\012   select code into v_covo_code from controlled_vocabularies\\012      where is_internal_namespace = true and \\012         id = (select covo_id from controlled_vocabulary_terms where id = NEW.cvte_id_stor_fmt);\\012   -- Check if the data storage format is a term of the controlled vocabulary "STORAGE_FORMAT"\\012   if v_covo_code != 'STORAGE_FORMAT' then\\012      select code into data_code from data where id = NEW.data_id; \\012      RAISE EXCEPTION 'Insert/Update of Data (Code: %) failed, as its Storage Format is %, but is required to be STORAGE_FORMAT.', data_code, v_covo_code;\\012   end if;\\012\\012   RETURN NEW;\\012\\012END;\\012$$ LANGUAGE 'plpgsql';\\012\\012CREATE TRIGGER EXTERNAL_DATA_STORAGE_FORMAT_CHECK BEFORE INSERT OR UPDATE ON EXTERNAL_DATA\\012    FOR EACH ROW EXECUTE PROCEDURE EXTERNAL_DATA_STORAGE_FORMAT_CHECK();\\012\\012------------------------------------------------------------------------------------\\012--  Purpose:  Create trigger SAMPLE_CODE_UNIQUENESS_CHECK \\012------------------------------------------------------------------------------------\\012\\012CREATE OR REPLACE FUNCTION SAMPLE_CODE_UNIQUENESS_CHECK() RETURNS trigger AS $$\\012DECLARE\\012   counter  INTEGER;\\012BEGIN\\012\\011IF (NEW.samp_id_part_of is NULL) THEN\\012\\011\\011IF (NEW.dbin_id is not NULL) THEN\\012\\011\\011\\011SELECT count(*) into counter FROM samples \\012\\011\\011\\011\\011where id != NEW.id and code = NEW.code and samp_id_part_of is NULL and dbin_id = NEW.dbin_id;\\012\\011\\011\\011IF (counter > 0) THEN\\012\\011\\011\\011\\011RAISE EXCEPTION 'Insert/Update of Sample (Code: %) failed because database instance sample with the same code already exists.', NEW.code;\\012\\011\\011\\011END IF;\\012\\011\\011ELSIF (NEW.grou_id is not NULL) THEN\\012\\011\\011\\011SELECT count(*) into counter FROM samples \\012\\011\\011\\011\\011where id != NEW.id and code = NEW.code and samp_id_part_of is NULL and grou_id = NEW.grou_id;\\012\\011\\011\\011IF (counter > 0) THEN\\012\\011\\011\\011\\011RAISE EXCEPTION 'Insert/Update of Sample (Code: %) failed because group sample with the same code already exists.', NEW.code;\\012\\011\\011\\011END IF;\\012\\011\\011END IF;\\012        ELSE\\012\\011\\011IF (NEW.dbin_id is not NULL) THEN\\012\\011\\011\\011SELECT count(*) into counter FROM samples \\012\\011\\011\\011\\011where id != NEW.id and code = NEW.code and samp_id_part_of = NEW.samp_id_part_of and dbin_id = NEW.dbin_id;\\012\\011\\011\\011IF (counter > 0) THEN\\012\\011\\011\\011\\011RAISE EXCEPTION 'Insert/Update of Sample (Code: %) failed because database instance sample with the same code and being the part of the same parent already exists.', NEW.code;\\012\\011\\011\\011END IF;\\012\\011\\011ELSIF (NEW.grou_id is not NULL) THEN\\012\\011\\011\\011SELECT count(*) into counter FROM samples \\012\\011\\011\\011\\011where id != NEW.id and code = NEW.code and samp_id_part_of = NEW.samp_id_part_of and grou_id = NEW.grou_id;\\012\\011\\011\\011IF (counter > 0) THEN\\012\\011\\011\\011\\011RAISE EXCEPTION 'Insert/Update of Sample (Code: %) failed because group sample with the same code and being the part of the same parent already exists.', NEW.code;\\012\\011\\011\\011END IF;\\012\\011\\011END IF;\\012        END IF;   \\012   RETURN NEW;\\012END;\\012$$ LANGUAGE 'plpgsql';\\012\\012CREATE TRIGGER SAMPLE_CODE_UNIQUENESS_CHECK BEFORE INSERT OR UPDATE ON SAMPLES\\012    FOR EACH ROW EXECUTE PROCEDURE SAMPLE_CODE_UNIQUENESS_CHECK();\\012	\N
+./sourceTest/sql/postgresql/061/017=database_version_logs.tsv:028	source/sql/postgresql/migration/migration-027-028.sql	SUCCESS	2008-11-18 13:24:17.508	-- Create EXPERIMENT_ATTACHMENT_CONTENTS.\\012CREATE TABLE EXPERIMENT_ATTACHMENT_CONTENTS (ID TECH_ID NOT NULL,VALUE FILE NOT NULL);\\012CREATE SEQUENCE EXPERIMENT_ATTACHMENT_CONTENT_ID_SEQ;\\012ALTER TABLE EXPERIMENT_ATTACHMENT_CONTENTS ADD CONSTRAINT EXAC_PK PRIMARY KEY(ID);\\012\\012-- Alter EXPERIMENT_ATTACHMENTS by adding the new column which has a NULL constraint.\\012-- The NOT NULL constraint is added later on.\\012ALTER TABLE EXPERIMENT_ATTACHMENTS ADD COLUMN EXAC_ID TECH_ID;\\012\\012-- Does the VALUE migration between EXPERIMENT_ATTACHMENTS to EXPERIMENT_ATTACHMENT_CONTENTS.\\012CREATE OR REPLACE FUNCTION move_exp_att_content() RETURNS integer AS $$\\012DECLARE\\012    rec RECORD;\\012    seq BIGINT;\\012BEGIN\\012  FOR rec IN SELECT id, value FROM EXPERIMENT_ATTACHMENTS LOOP\\012  \\011seq := nextval('EXPERIMENT_ATTACHMENT_CONTENT_ID_SEQ');\\012    INSERT INTO EXPERIMENT_ATTACHMENT_CONTENTS (id, value) VALUES (seq, rec.value);\\012    UPDATE EXPERIMENT_ATTACHMENTS SET exac_id = seq WHERE id = rec.id;\\012  END LOOP;\\012  RETURN 1;\\012END;\\012$$ LANGUAGE 'plpgsql';\\012\\012-- Call the function.\\012SELECT move_exp_att_content();\\012DROP FUNCTION move_exp_att_content();\\012\\012\\012-- Finish EXPERIMENT_ATTACHMENTS changes.\\012ALTER TABLE EXPERIMENT_ATTACHMENTS ADD CONSTRAINT EXAT_CONT_FK FOREIGN KEY (EXAC_ID) REFERENCES EXPERIMENT_ATTACHMENT_CONTENTS(ID);\\012ALTER TABLE EXPERIMENT_ATTACHMENTS DROP COLUMN VALUE;\\012ALTER TABLE EXPERIMENT_ATTACHMENTS ALTER COLUMN EXAC_ID SET NOT NULL;\\012	\N
+./sourceTest/sql/postgresql/061/017=database_version_logs.tsv:029	source/sql/postgresql/migration/migration-028-029.sql	SUCCESS	2009-03-18 10:50:20.105	-- -------\\012-- add modification_timestamp field to allow edition with Hibernate\\012-- -------\\012\\012ALTER TABLE samples\\012\\011ADD COLUMN modification_timestamp TIME_STAMP DEFAULT CURRENT_TIMESTAMP;\\012\\012ALTER TABLE experiments\\012\\011ADD COLUMN modification_timestamp TIME_STAMP DEFAULT CURRENT_TIMESTAMP;\\012\\012ALTER TABLE materials\\012\\011ADD COLUMN modification_timestamp TIME_STAMP DEFAULT CURRENT_TIMESTAMP;\\012\\012ALTER TABLE experiment_properties\\012\\011ADD COLUMN modification_timestamp TIME_STAMP DEFAULT CURRENT_TIMESTAMP;\\012\\012ALTER TABLE material_properties\\012\\011ADD COLUMN modification_timestamp TIME_STAMP DEFAULT CURRENT_TIMESTAMP;\\012\\012ALTER TABLE sample_properties\\012\\011ADD COLUMN modification_timestamp TIME_STAMP DEFAULT CURRENT_TIMESTAMP;\\012\\012-- -------\\012-- add property data type which references materials\\012-- -------\\012\\012ALTER TABLE property_types\\012\\011ADD COLUMN maty_prop_id tech_id;\\012\\012ALTER TABLE property_types\\012\\011ADD CONSTRAINT prty_maty_fk FOREIGN KEY (maty_prop_id) REFERENCES material_types(id);\\012\\012ALTER TABLE experiment_properties\\012\\011ADD COLUMN mate_prop_id tech_id;\\012\\012ALTER TABLE material_properties\\012\\011ADD COLUMN mate_prop_id tech_id;\\012\\012ALTER TABLE sample_properties\\012\\011ADD COLUMN mate_prop_id tech_id;\\012\\012ALTER TABLE experiment_properties\\012\\011ADD CONSTRAINT expr_mapr_fk FOREIGN KEY (mate_prop_id) REFERENCES materials(id);\\012\\012ALTER TABLE material_properties\\012\\011ADD CONSTRAINT mapr_mapr_fk FOREIGN KEY (mate_prop_id) REFERENCES materials(id);\\012\\012ALTER TABLE sample_properties\\012\\011ADD CONSTRAINT sapr_mapr_fk FOREIGN KEY (mate_prop_id) REFERENCES materials(id);\\012\\012insert into data_types\\012(id\\012 ,code\\012 ,description)\\012 values \\012 (nextval('DATA_TYPE_ID_SEQ')\\012 ,'MATERIAL'\\012 ,'Reference to a material'\\012);\\012\\012ALTER TABLE MATERIAL_PROPERTIES DROP CONSTRAINT MAPR_CK;\\012ALTER TABLE MATERIAL_PROPERTIES ADD CONSTRAINT MAPR_CK CHECK \\012\\011((VALUE IS NOT NULL AND CVTE_ID IS NULL AND MATE_PROP_ID IS NULL) OR \\012\\011 (VALUE IS NULL AND CVTE_ID IS NOT NULL AND MATE_PROP_ID IS NULL) OR\\012\\011 (VALUE IS NULL AND CVTE_ID IS NULL AND MATE_PROP_ID IS NOT NULL)\\012\\011);\\012\\012ALTER TABLE EXPERIMENT_PROPERTIES DROP CONSTRAINT EXPR_CK;\\012ALTER TABLE EXPERIMENT_PROPERTIES ADD CONSTRAINT EXPR_CK CHECK \\012\\011((VALUE IS NOT NULL AND CVTE_ID IS NULL AND MATE_PROP_ID IS NULL) OR \\012\\011 (VALUE IS NULL AND CVTE_ID IS NOT NULL AND MATE_PROP_ID IS NULL) OR\\012\\011 (VALUE IS NULL AND CVTE_ID IS NULL AND MATE_PROP_ID IS NOT NULL)\\012\\011);\\012\\012ALTER TABLE SAMPLE_PROPERTIES DROP CONSTRAINT SAPR_CK;\\012ALTER TABLE SAMPLE_PROPERTIES ADD CONSTRAINT SAPR_CK CHECK \\012\\011((VALUE IS NOT NULL AND CVTE_ID IS NULL AND MATE_PROP_ID IS NULL) OR \\012\\011 (VALUE IS NULL AND CVTE_ID IS NOT NULL AND MATE_PROP_ID IS NULL) OR\\012\\011 (VALUE IS NULL AND CVTE_ID IS NULL AND MATE_PROP_ID IS NOT NULL)\\012\\011);\\012\\012------------------------------------------------------------------------------------\\012--  Purpose:  Create trigger MATERIAL/SAMPLE/EXPERIMENT _PROPERTY_WITH_MATERIAL_DATA_TYPE_CHECK\\012--            It checks that if material property value is assigned to the entity,\\012--\\011\\011\\011\\011\\011\\011then the material type is equal to the one described by property type.\\012------------------------------------------------------------------------------------\\012\\012CREATE OR REPLACE FUNCTION MATERIAL_PROPERTY_WITH_MATERIAL_DATA_TYPE_CHECK() RETURNS trigger AS $$\\012DECLARE\\012   v_type_id  CODE;\\012   v_type_id_prop  CODE;\\012BEGIN\\012   if NEW.mate_prop_id IS NOT NULL then\\012\\011\\011\\011-- find material type id of the property type \\012\\011\\011\\011select pt.maty_prop_id into v_type_id_prop \\012\\011\\011\\011  from material_type_property_types etpt, property_types pt \\012\\011\\011\\011 where NEW.mtpt_id = etpt.id AND etpt.prty_id = pt.id;\\012\\011\\011\\012\\011\\011\\011if v_type_id_prop IS NOT NULL then\\012\\011\\011\\011\\011-- find material type id of the material which consists the entity's property value\\012\\011\\011\\011\\011select entity.maty_id into v_type_id \\012\\011\\011\\011\\011  from materials entity\\012\\011\\011\\011\\011 where NEW.mate_prop_id = entity.id;\\012\\011\\011\\011\\011if v_type_id != v_type_id_prop then\\012\\011\\011\\011\\011\\011RAISE EXCEPTION 'Insert/Update of property value referencing material (id: %) failed, as referenced material type is different than expected (id %, expected id: %).', \\012\\011\\011\\011\\011\\011\\011\\011 NEW.mate_prop_id, v_type_id, v_type_id_prop;\\012\\011\\011\\011\\011end if;\\012\\011\\011\\011end if;\\012   end if;\\012   RETURN NEW;\\012END;\\012$$ LANGUAGE 'plpgsql';\\012\\012CREATE TRIGGER MATERIAL_PROPERTY_WITH_MATERIAL_DATA_TYPE_CHECK BEFORE INSERT OR UPDATE ON material_properties\\012    FOR EACH ROW EXECUTE PROCEDURE MATERIAL_PROPERTY_WITH_MATERIAL_DATA_TYPE_CHECK();\\012    \\012CREATE OR REPLACE FUNCTION SAMPLE_PROPERTY_WITH_MATERIAL_DATA_TYPE_CHECK() RETURNS trigger AS $$\\012DECLARE\\012   v_type_id  CODE;\\012   v_type_id_prop  CODE;\\012BEGIN\\012   if NEW.mate_prop_id IS NOT NULL then\\012\\011\\011\\011-- find material type id of the property type \\012\\011\\011\\011select pt.maty_prop_id into v_type_id_prop \\012\\011\\011\\011  from sample_type_property_types etpt, property_types pt \\012\\011\\011\\011 where NEW.stpt_id = etpt.id AND etpt.prty_id = pt.id;\\012\\011\\011\\012\\011\\011\\011if v_type_id_prop IS NOT NULL then\\012\\011\\011\\011\\011-- find material type id of the material which consists the entity's property value\\012\\011\\011\\011\\011select entity.maty_id into v_type_id \\012\\011\\011\\011\\011  from materials entity\\012\\011\\011\\011\\011 where NEW.mate_prop_id = entity.id;\\012\\011\\011\\011\\011if v_type_id != v_type_id_prop then\\012\\011\\011\\011\\011\\011RAISE EXCEPTION 'Insert/Update of property value referencing material (id: %) failed, as referenced material type is different than expected (id %, expected id: %).', \\012\\011\\011\\011\\011\\011\\011\\011\\011\\011\\011\\011\\011 NEW.mate_prop_id, v_type_id, v_type_id_prop;\\012\\011\\011\\011\\011end if;\\012\\011\\011\\011end if;\\012   end if;\\012   RETURN NEW;\\012END;\\012$$ LANGUAGE 'plpgsql';\\012\\012CREATE TRIGGER SAMPLE_PROPERTY_WITH_MATERIAL_DATA_TYPE_CHECK BEFORE INSERT OR UPDATE ON sample_properties\\012    FOR EACH ROW EXECUTE PROCEDURE SAMPLE_PROPERTY_WITH_MATERIAL_DATA_TYPE_CHECK();\\012    \\012CREATE OR REPLACE FUNCTION EXPERIMENT_PROPERTY_WITH_MATERIAL_DATA_TYPE_CHECK() RETURNS trigger AS $$\\012DECLARE\\012   v_type_id  CODE;\\012   v_type_id_prop  CODE;\\012BEGIN\\012   if NEW.mate_prop_id IS NOT NULL then\\012\\011\\011\\011-- find material type id of the property type \\012\\011\\011\\011select pt.maty_prop_id into v_type_id_prop \\012\\011\\011\\011  from experiment_type_property_types etpt, property_types pt \\012\\011\\011\\011 where NEW.etpt_id = etpt.id AND etpt.prty_id = pt.id;\\012\\011\\011\\012\\011\\011\\011if v_type_id_prop IS NOT NULL then\\012\\011\\011\\011\\011-- find material type id of the material which consists the entity's property value\\012\\011\\011\\011\\011select entity.maty_id into v_type_id \\012\\011\\011\\011\\011  from materials entity\\012\\011\\011\\011\\011 where NEW.mate_prop_id = entity.id;\\012\\011\\011\\011\\011if v_type_id != v_type_id_prop then\\012\\011\\011\\011\\011\\011RAISE EXCEPTION 'Insert/Update of property value referencing material (id: %) failed, as referenced material type is different than expected (id %, expected id: %).', \\012\\011\\011\\011\\011\\011\\011\\011\\011\\011\\011\\011\\011 NEW.mate_prop_id, v_type_id, v_type_id_prop;\\012\\011\\011\\011\\011end if;\\012\\011\\011\\011end if;\\012   end if;\\012   RETURN NEW;\\012END;\\012$$ LANGUAGE 'plpgsql';\\012\\012CREATE TRIGGER EXPERIMENT_PROPERTY_WITH_MATERIAL_DATA_TYPE_CHECK BEFORE INSERT OR UPDATE ON experiment_properties\\012    FOR EACH ROW EXECUTE PROCEDURE EXPERIMENT_PROPERTY_WITH_MATERIAL_DATA_TYPE_CHECK();\\012       \\012-- -------\\012-- remove the reminescents of the OBSERVABLE_TYPE\\012-- -------\\012\\012ALTER TABLE data\\012\\011DROP CONSTRAINT data_obty_fk;\\012\\012ALTER TABLE data_set_types\\012\\011DROP CONSTRAINT obty_pk;\\012\\012ALTER TABLE data_set_types\\012\\011ADD CONSTRAINT dsty_pk PRIMARY KEY (id);\\012\\012ALTER TABLE data\\012\\011ADD CONSTRAINT data_dsty_fk FOREIGN KEY (dsty_id) REFERENCES data_set_types(id);\\012\\012ALTER TABLE data_set_types\\012\\011DROP CONSTRAINT obty_bk_uk;\\012\\012ALTER TABLE data_set_types\\012\\011DROP CONSTRAINT obty_dbin_fk;\\012\\012ALTER TABLE data_set_types\\012\\011ADD CONSTRAINT dsty_bk_uk UNIQUE (code, dbin_id);\\012\\012ALTER TABLE data_set_types\\012\\011ADD CONSTRAINT dsty_dbin_fk FOREIGN KEY (dbin_id) REFERENCES database_instances(id);\\012\\012DROP INDEX data_obty_fk_i;\\012\\012CREATE INDEX data_dsty_fk_i ON data(dsty_id);\\012	\N
+./sourceTest/sql/postgresql/061/017=database_version_logs.tsv:030	source/sql/postgresql/migration/migration-029-030.sql	SUCCESS	2009-03-23 15:34:44.72	-- -------\\012-- add modification_timestamp field to allow edition with Hibernate\\012-- -------\\012ALTER TABLE data\\012\\011ADD COLUMN modification_timestamp TIME_STAMP DEFAULT CURRENT_TIMESTAMP;\\012ALTER TABLE experiment_types\\012\\011ADD COLUMN modification_timestamp TIME_STAMP DEFAULT CURRENT_TIMESTAMP;\\012ALTER TABLE sample_types\\012\\011ADD COLUMN modification_timestamp TIME_STAMP DEFAULT CURRENT_TIMESTAMP;\\012ALTER TABLE material_types\\012\\011ADD COLUMN modification_timestamp TIME_STAMP DEFAULT CURRENT_TIMESTAMP;\\012ALTER TABLE data_set_types\\012\\011ADD COLUMN modification_timestamp TIME_STAMP DEFAULT CURRENT_TIMESTAMP;\\012ALTER TABLE controlled_vocabularies\\012\\011ADD COLUMN modification_timestamp TIME_STAMP DEFAULT CURRENT_TIMESTAMP;\\012-- -------\\012-- add properties to data sets\\012-- -------\\012CREATE TABLE DATA_SET_PROPERTIES (ID TECH_ID NOT NULL,DS_ID TECH_ID NOT NULL,DSTPT_ID TECH_ID NOT NULL,VALUE GENERIC_VALUE,CVTE_ID TECH_ID, MATE_PROP_ID TECH_ID, PERS_ID_REGISTERER TECH_ID NOT NULL,REGISTRATION_TIMESTAMP TIME_STAMP_DFL NOT NULL DEFAULT CURRENT_TIMESTAMP, MODIFICATION_TIMESTAMP TIME_STAMP DEFAULT CURRENT_TIMESTAMP);\\012CREATE TABLE DATA_SET_TYPE_PROPERTY_TYPES (ID TECH_ID NOT NULL,DSTY_ID TECH_ID NOT NULL,PRTY_ID TECH_ID NOT NULL,IS_MANDATORY BOOLEAN_CHAR NOT NULL DEFAULT 'F',IS_MANAGED_INTERNALLY BOOLEAN_CHAR NOT NULL DEFAULT 'F',PERS_ID_REGISTERER TECH_ID NOT NULL,REGISTRATION_TIMESTAMP TIME_STAMP_DFL NOT NULL DEFAULT CURRENT_TIMESTAMP);\\012\\012CREATE SEQUENCE DATA_SET_PROPERTY_ID_SEQ;\\012CREATE SEQUENCE DSTPT_ID_SEQ;\\012\\012ALTER TABLE DATA_SET_TYPE_PROPERTY_TYPES ADD CONSTRAINT DSTPT_PK PRIMARY KEY(ID);\\012ALTER TABLE DATA_SET_PROPERTIES ADD CONSTRAINT DSPR_PK PRIMARY KEY(ID);\\012\\012ALTER TABLE DATA_SET_TYPE_PROPERTY_TYPES ADD CONSTRAINT DSTPT_BK_UK UNIQUE(DSTY_ID,PRTY_ID);\\012ALTER TABLE DATA_SET_PROPERTIES ADD CONSTRAINT DSPR_BK_UK UNIQUE(DS_ID,DSTPT_ID);\\012\\012\\012ALTER TABLE DATA_SET_TYPE_PROPERTY_TYPES ADD CONSTRAINT DSTPT_DSTY_FK FOREIGN KEY (DSTY_ID) REFERENCES DATA_SET_TYPES(ID);\\012ALTER TABLE DATA_SET_TYPE_PROPERTY_TYPES ADD CONSTRAINT DSTPT_PERS_FK FOREIGN KEY (PERS_ID_REGISTERER) REFERENCES PERSONS(ID);\\012ALTER TABLE DATA_SET_TYPE_PROPERTY_TYPES ADD CONSTRAINT DSTPT_PRTY_FK FOREIGN KEY (PRTY_ID) REFERENCES PROPERTY_TYPES(ID);\\012ALTER TABLE DATA_SET_PROPERTIES ADD CONSTRAINT DSPR_CVTE_FK FOREIGN KEY (CVTE_ID) REFERENCES CONTROLLED_VOCABULARY_TERMS(ID);\\012ALTER TABLE DATA_SET_PROPERTIES ADD CONSTRAINT DSPR_DSTPT_FK FOREIGN KEY (DSTPT_ID) REFERENCES DATA_SET_TYPE_PROPERTY_TYPES(ID) ON DELETE CASCADE;\\012ALTER TABLE DATA_SET_PROPERTIES ADD CONSTRAINT DSPR_DS_FK FOREIGN KEY (DS_ID) REFERENCES DATA(ID);\\012ALTER TABLE DATA_SET_PROPERTIES ADD CONSTRAINT DSPR_PERS_FK FOREIGN KEY (PERS_ID_REGISTERER) REFERENCES PERSONS(ID);\\012ALTER TABLE DATA_SET_PROPERTIES ADD CONSTRAINT DSPR_MAPR_FK FOREIGN KEY (MATE_PROP_ID) REFERENCES MATERIALS(ID);\\012\\012ALTER TABLE DATA_SET_PROPERTIES ADD CONSTRAINT DSPR_CK CHECK \\012\\011((VALUE IS NOT NULL AND CVTE_ID IS NULL AND MATE_PROP_ID IS NULL) OR \\012\\011 (VALUE IS NULL AND CVTE_ID IS NOT NULL AND MATE_PROP_ID IS NULL) OR\\012\\011 (VALUE IS NULL AND CVTE_ID IS NULL AND MATE_PROP_ID IS NOT NULL)\\012\\011);\\012\\012CREATE INDEX DSPR_CVTE_FK_I ON DATA_SET_PROPERTIES (CVTE_ID);\\012CREATE INDEX DSPR_DSTPT_FK_I ON DATA_SET_PROPERTIES (DSTPT_ID);\\012CREATE INDEX DSPR_DS_FK_I ON DATA_SET_PROPERTIES (DS_ID);\\012CREATE INDEX DSPR_PERS_FK_I ON DATA_SET_PROPERTIES (PERS_ID_REGISTERER);\\012CREATE INDEX DSTPT_DSTY_FK_I ON DATA_SET_TYPE_PROPERTY_TYPES (DSTY_ID);\\012CREATE INDEX DSTPT_PERS_FK_I ON DATA_SET_TYPE_PROPERTY_TYPES (PERS_ID_REGISTERER);\\012CREATE INDEX DSTPT_PRTY_FK_I ON DATA_SET_TYPE_PROPERTY_TYPES (PRTY_ID);\\012\\012CREATE OR REPLACE FUNCTION DATA_SET_PROPERTY_WITH_MATERIAL_DATA_TYPE_CHECK() RETURNS trigger AS $$\\012DECLARE\\012   v_type_id  CODE;\\012   v_type_id_prop  CODE;\\012BEGIN\\012   if NEW.mate_prop_id IS NOT NULL then\\012\\011\\011\\011-- find material type id of the property type \\012\\011\\011\\011select pt.maty_prop_id into v_type_id_prop \\012\\011\\011\\011  from data_set_type_property_types dstpt, property_types pt \\012\\011\\011\\011 where NEW.dstpt_id = dstpt.id AND dstpt.prty_id = pt.id;\\012\\011\\011\\012\\011\\011\\011if v_type_id_prop IS NOT NULL then\\012\\011\\011\\011\\011-- find material type id of the material which consists the entity's property value\\012\\011\\011\\011\\011select entity.maty_id into v_type_id \\012\\011\\011\\011\\011  from materials entity\\012\\011\\011\\011\\011 where NEW.mate_prop_id = entity.id;\\012\\011\\011\\011\\011if v_type_id != v_type_id_prop then\\012\\011\\011\\011\\011\\011RAISE EXCEPTION 'Insert/Update of property value referencing material (id: %) failed, as referenced material type is different than expected (id %, expected id: %).', \\012\\011\\011\\011\\011\\011\\011\\011\\011\\011\\011\\011\\011 NEW.mate_prop_id, v_type_id, v_type_id_prop;\\012\\011\\011\\011\\011end if;\\012\\011\\011\\011end if;\\012   end if;\\012   RETURN NEW;\\012END;\\012$$ LANGUAGE 'plpgsql';\\012\\012CREATE TRIGGER DATA_SET_PROPERTY_WITH_MATERIAL_DATA_TYPE_CHECK BEFORE INSERT OR UPDATE ON data_set_properties\\012    FOR EACH ROW EXECUTE PROCEDURE DATA_SET_PROPERTY_WITH_MATERIAL_DATA_TYPE_CHECK();   \\012	\N
+./sourceTest/sql/postgresql/061/017=database_version_logs.tsv:032	source/sql/postgresql/migration/migration-031-032.sql	SUCCESS	2009-04-09 09:36:36.2	-- -------\\012-- Modify MATERIAL_BATCHES\\012-- -------\\012\\012ALTER TABLE material_batches\\012    DROP COLUMN proc_id;\\012\\012-- -------\\012-- Modify SAMPLES\\012-- -------\\012\\012ALTER TABLE samples\\012    ADD COLUMN expe_id tech_id;\\012\\012ALTER TABLE samples\\012    ADD CONSTRAINT samp_expe_fk FOREIGN KEY (expe_id) REFERENCES experiments(id);\\012\\012CREATE INDEX samp_expe_fk_i ON samples USING btree (expe_id);\\012\\012-- relink samples directly to experiments\\012\\012UPDATE samples\\012SET expe_id = (SELECT e.id FROM experiments e, procedures p, sample_inputs si \\012               WHERE si.samp_id = samples.id AND si.proc_id = p.id AND p.expe_id = e.id AND e.inva_id IS NULL);\\012\\012\\012-- -------\\012-- Modify DATA\\012-- -------\\012\\012ALTER TABLE data\\012    ADD COLUMN expe_id tech_id;\\012\\012ALTER TABLE data\\012    ADD CONSTRAINT data_expe_fk FOREIGN KEY (expe_id) REFERENCES experiments(id);\\012\\012CREATE INDEX data_expe_fk_i ON data USING btree (expe_id);\\012\\012UPDATE data\\012SET expe_id = (SELECT e.id FROM experiments e, procedures p \\012               WHERE data.proc_id_produced_by = p.id AND p.expe_id = e.id);\\012\\012ALTER TABLE data\\012    ALTER COLUMN expe_id SET NOT NULL;\\012\\012ALTER TABLE data\\012    DROP COLUMN proc_id_produced_by;\\012\\012-- -------\\012-- Drop PROCEDURES, PROCEDURE_TYPES, and SAMPLE_INPUTS\\012-- -------\\012\\012DROP TABLE sample_inputs;\\012DROP TABLE procedures;\\012DROP TABLE procedure_types;\\012\\012DROP SEQUENCE procedure_id_seq;\\012DROP SEQUENCE procedure_type_id_seq;\\012\\012-- -------\\012-- Add CODE_SEQ\\012-- -------\\012\\012CREATE SEQUENCE CODE_SEQ;\\012\\012-- -------\\012-- Add new columns to DATA_STORES\\012-- -------\\012\\012ALTER TABLE data_stores\\012    ADD COLUMN remote_url character varying(250),\\012    ADD COLUMN session_token character varying(50),\\012    ADD COLUMN modification_timestamp time_stamp DEFAULT now();\\012\\012UPDATE data_stores\\012SET remote_url = '', session_token='';\\012\\012ALTER TABLE data_stores\\012    ALTER COLUMN remote_url SET NOT NULL,\\012    ALTER COLUMN session_token SET NOT NULL;\\012\\012-- -------\\012-- Drop foreign keys onto DATA_STORES\\012-- -------\\012\\012ALTER TABLE database_instances\\012    DROP COLUMN dast_id;\\012\\012ALTER TABLE groups\\012    DROP COLUMN dast_id;\\012\\012ALTER TABLE projects\\012    DROP COLUMN dast_id;\\012\\012ALTER TABLE experiments\\012    DROP COLUMN dast_id;\\012\\012-- -------\\012-- Add foreign key from DATA onto DATA_STORES\\012-- -------\\012\\012ALTER TABLE data\\012    ADD COLUMN dast_id tech_id;\\012\\012ALTER TABLE data\\012    ADD CONSTRAINT data_dast_fk FOREIGN KEY (dast_id) REFERENCES data_stores(id);\\012\\012UPDATE data\\012SET dast_id = (select id from data_stores where code = 'STANDARD');\\012\\012ALTER TABLE data\\012    ALTER COLUMN dast_id SET NOT NULL;\\012\\012\\012------------------------------------------------------------------------------------\\012--  Purpose:  Replace trigger SAMPLE_CODE_UNIQUENESS_CHECK \\012------------------------------------------------------------------------------------\\012\\012CREATE OR REPLACE FUNCTION SAMPLE_CODE_UNIQUENESS_CHECK() RETURNS trigger AS $$\\012DECLARE\\012   counter  INTEGER;\\012BEGIN\\012    LOCK TABLE samples IN EXCLUSIVE MODE;\\012    IF (NEW.samp_id_part_of is NULL) THEN\\012        IF (NEW.dbin_id is not NULL) THEN\\012            SELECT count(*) into counter FROM samples \\012                where id != NEW.id and code = NEW.code and samp_id_part_of is NULL and dbin_id = NEW.dbin_id;\\012            IF (counter > 0) THEN\\012                RAISE EXCEPTION 'Insert/Update of Sample (Code: %) failed because database instance sample with the same code already exists.', NEW.code;\\012            END IF;\\012        ELSIF (NEW.grou_id is not NULL) THEN\\012            SELECT count(*) into counter FROM samples \\012                where id != NEW.id and code = NEW.code and samp_id_part_of is NULL and grou_id = NEW.grou_id;\\012            IF (counter > 0) THEN\\012                RAISE EXCEPTION 'Insert/Update of Sample (Code: %) failed because group sample with the same code already exists.', NEW.code;\\012            END IF;\\012        END IF;\\012        ELSE\\012        IF (NEW.dbin_id is not NULL) THEN\\012            SELECT count(*) into counter FROM samples \\012                where id != NEW.id and code = NEW.code and samp_id_part_of = NEW.samp_id_part_of and dbin_id = NEW.dbin_id;\\012            IF (counter > 0) THEN\\012                RAISE EXCEPTION 'Insert/Update of Sample (Code: %) failed because database instance sample with the same code and being the part of the same parent already exists.', NEW.code;\\012            END IF;\\012        ELSIF (NEW.grou_id is not NULL) THEN\\012            SELECT count(*) into counter FROM samples \\012                where id != NEW.id and code = NEW.code and samp_id_part_of = NEW.samp_id_part_of and grou_id = NEW.grou_id;\\012            IF (counter > 0) THEN\\012                RAISE EXCEPTION 'Insert/Update of Sample (Code: %) failed because group sample with the same code and being the part of the same parent already exists.', NEW.code;\\012            END IF;\\012        END IF;\\012        END IF;   \\012   RETURN NEW;\\012END;\\012$$ LANGUAGE 'plpgsql';\\012\\012\\012\\012	\N
+./sourceTest/sql/postgresql/061/017=database_version_logs.tsv:034	source/sql/postgresql/migration/migration-033-034.sql	SUCCESS	2009-05-26 08:32:49.935	------------------------------------------------------------------------------------\\012-- Create sequence for generating permanent identifiers starting with nextval of existing dataset sequence.\\012------------------------------------------------------------------------------------\\012CREATE FUNCTION CREATE_SEQUENCE(EXISTING_SEQUENCE VARCHAR, NEW_SEQUENCE VARCHAR) RETURNS VOID AS $$\\012DECLARE\\012  CURR_SEQ_VAL   INTEGER;\\012BEGIN\\012  SELECT INTO CURR_SEQ_VAL NEXTVAL(EXISTING_SEQUENCE);\\012  EXECUTE 'CREATE SEQUENCE ' || NEW_SEQUENCE || ' START WITH ' || CURR_SEQ_VAL;\\012  RETURN;\\012END;\\012$$ LANGUAGE 'plpgsql';\\012\\012SELECT CREATE_SEQUENCE('DATA_ID_SEQ', 'PERM_ID_SEQ');\\012DROP FUNCTION CREATE_SEQUENCE(VARCHAR, VARCHAR);\\012\\012------------------------------------------------------------------------------------\\012-- Add perm_id columns to samples and experiments.\\012------------------------------------------------------------------------------------\\012ALTER TABLE SAMPLES ADD COLUMN PERM_ID CODE;\\012ALTER TABLE EXPERIMENTS ADD COLUMN PERM_ID CODE;\\012\\012UPDATE SAMPLES SET PERM_ID = to_char(registration_timestamp,'YYYYMMDDHHSSMS') || '-' || NEXTVAL('PERM_ID_SEQ');\\012UPDATE EXPERIMENTS SET PERM_ID = to_char(registration_timestamp,'YYYYMMDDHHSSMS') || '-' || NEXTVAL('PERM_ID_SEQ');\\012ALTER TABLE SAMPLES ALTER COLUMN PERM_ID SET NOT NULL;\\012ALTER TABLE EXPERIMENTS ALTER COLUMN PERM_ID SET NOT NULL;\\012ALTER TABLE SAMPLES ADD CONSTRAINT SAMP_PI_UK UNIQUE(PERM_ID);\\012ALTER TABLE EXPERIMENTS ADD CONSTRAINT EXPE_PI_UK UNIQUE(PERM_ID);\\012\\012\\012------------------------------------------------------------------------------------\\012-- Add column is_chosen_from_list to controlled_vocabularies.\\012------------------------------------------------------------------------------------\\012ALTER TABLE controlled_vocabularies ADD COLUMN is_chosen_from_list BOOLEAN_CHAR NOT NULL DEFAULT TRUE;\\012ALTER TABLE controlled_vocabularies ADD COLUMN source_uri CHARACTER VARYING(250);\\012------------------------------------------------------------------------------------\\012-- Modify Data table - remove arc connection between Sample and Data table, use a flag instead\\012------------------------------------------------------------------------------------\\012\\012-- add new columns\\012\\012ALTER TABLE data\\012    ADD COLUMN is_derived boolean_char;\\012ALTER TABLE data\\012    ADD COLUMN samp_id tech_id;\\012\\012-- update values in new columns\\012\\012UPDATE data\\012    SET is_derived = (samp_id_derived_from IS NOT NULL); \\012UPDATE data\\012    SET samp_id = samp_id_derived_from \\012    WHERE is_derived = 'TRUE';\\012UPDATE data\\012    SET samp_id = samp_id_acquired_from \\012    WHERE is_derived = 'FALSE';\\012\\012-- add constraints and indexes to new columns\\012\\012ALTER TABLE data\\012    ALTER COLUMN is_derived SET NOT NULL;\\012ALTER TABLE data\\012    ALTER COLUMN samp_id SET NOT NULL;   \\012ALTER TABLE data\\012    ADD CONSTRAINT data_samp_fk FOREIGN KEY (samp_id) REFERENCES samples (id);\\012CREATE INDEX data_samp_fk_i ON data USING btree (samp_id);\\012\\012-- remove old columns\\012\\012ALTER TABLE data\\012    DROP COLUMN samp_id_acquired_from;\\012ALTER TABLE data\\012    DROP COLUMN samp_id_derived_from;\\012    \\012------------------------------------------------------------------------------------\\012-- Granting SELECT privilege to group openbis_readonly\\012------------------------------------------------------------------------------------\\012\\012GRANT SELECT ON SEQUENCE attachment_content_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE attachment_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE code_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE controlled_vocabulary_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE cvte_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE data_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE data_set_property_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE data_set_relationship_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE data_set_type_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE data_store_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE data_type_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE database_instance_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE dstpt_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE etpt_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE event_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE experiment_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE experiment_property_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE experiment_type_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE file_format_type_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE group_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE invalidation_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE locator_type_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE material_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE material_property_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE material_type_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE mtpt_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE perm_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE person_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE project_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE property_type_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE role_assignment_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE sample_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE sample_property_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE sample_type_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE stpt_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE attachment_contents TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE attachments TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE controlled_vocabularies TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE controlled_vocabulary_terms TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE data TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE data_set_properties TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE data_set_relationships TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE data_set_type_property_types TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE data_set_types TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE data_stores TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE data_types TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE database_instances TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE database_version_logs TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE events TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE experiment_properties TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE experiment_type_property_types TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE experiment_types TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE experiments TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE external_data TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE file_format_types TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE groups TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE invalidations TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE locator_types TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE material_properties TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE material_type_property_types TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE material_types TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE materials TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE persons TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE projects TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE property_types TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE role_assignments TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE sample_properties TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE sample_type_property_types TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE sample_types TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE samples TO GROUP OPENBIS_READONLY;\\012\\012------------------------------------------------------------------------------------\\012-- Delete MATERIAL_BATCHES table\\012------------------------------------------------------------------------------------\\012\\012-- WARNING: Potential data lost!!!\\012-- WARNING: Potential data lost!!!\\012-- WARNING: Potential data lost!!!\\012\\012DROP TABLE SAMPLE_MATERIAL_BATCHES;\\012DROP TABLE MATERIAL_BATCHES;\\012DROP SEQUENCE MATERIAL_BATCH_ID_SEQ;\\012\\012------------------------------------------------------------------------------------\\012-- Delete MATE_ID_INHIBITOR_OF from table MATERIALS\\012------------------------------------------------------------------------------------\\012\\012-- WARNING: Potential data lost!!!\\012-- WARNING: Potential data lost!!!\\012-- WARNING: Potential data lost!!!\\012\\012ALTER TABLE MATERIALS DROP COLUMN MATE_ID_INHIBITOR_OF;\\012	\N
+./sourceTest/sql/postgresql/061/017=database_version_logs.tsv:041	source/sql/postgresql/migration/migration-040-041.sql	SUCCESS	2009-09-14 13:48:57.539	-- Create FILTERS table\\012\\012CREATE TABLE FILTERS (ID TECH_ID NOT NULL, DBIN_ID TECH_ID NOT NULL, NAME VARCHAR(200) NOT NULL, DESCRIPTION DESCRIPTION_1000,REGISTRATION_TIMESTAMP TIME_STAMP_DFL NOT NULL DEFAULT CURRENT_TIMESTAMP, PERS_ID_REGISTERER TECH_ID NOT NULL, MODIFICATION_TIMESTAMP TIME_STAMP DEFAULT CURRENT_TIMESTAMP, EXPRESSION VARCHAR(2000) NOT NULL, IS_PUBLIC BOOLEAN NOT NULL, GRID_ID VARCHAR(200) NOT NULL);\\012CREATE SEQUENCE FILTER_ID_SEQ;\\012ALTER TABLE FILTERS ADD CONSTRAINT FILT_PK PRIMARY KEY(ID);\\012ALTER TABLE FILTERS ADD CONSTRAINT FILT_BK_UK UNIQUE(NAME, DBIN_ID, GRID_ID);\\012ALTER TABLE FILTERS ADD CONSTRAINT FILT_PERS_FK FOREIGN KEY (PERS_ID_REGISTERER) REFERENCES PERSONS(ID);\\012ALTER TABLE FILTERS ADD CONSTRAINT FILT_DBIN_FK FOREIGN KEY (DBIN_ID) REFERENCES DATABASE_INSTANCES(ID);\\012CREATE INDEX FILT_PERS_FK_I ON FILTERS (PERS_ID_REGISTERER);\\012CREATE INDEX FILT_DBIN_FK_I ON FILTERS (DBIN_ID);\\012GRANT SELECT ON SEQUENCE filter_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE filters TO GROUP OPENBIS_READONLY;\\012\\012-- Add missing foreign key to role assignments authorization group\\012ALTER TABLE ROLE_ASSIGNMENTS ADD CONSTRAINT ROAS_AG_FK_GRANTEE FOREIGN KEY (AG_ID_GRANTEE) REFERENCES AUTHORIZATION_GROUPS(ID);\\012\\012--------------------------------------------------------------------------------------------------\\012-- Modify dataset connections:\\012-- 1. connection with sample shouldn't be mandatory any more\\012-- 2. introduce an arc condition that dataset cannot be connected with a sample and a parent dataset at the same time\\012--------------------------------------------------------------------------------------------------\\012\\012-- Weaken data-sample connection constraint - allow dataset to have no connection with sample\\012ALTER TABLE data ALTER COLUMN samp_id DROP NOT NULL;\\012\\012-- Remove data-sample connection for datasets that have a parent\\012\\012UPDATE data \\012   SET samp_id = NULL \\012 WHERE id IN (SELECT DISTINCT data_id_child FROM data_set_relationships);\\012\\012-- With PostgreSQL 8.4 one can check that before migration there were no cycles in dataset relationships:\\012--\\012-- WITH RECURSIVE data_set_parents(id, parent_ids, cycle) AS (\\012--         SELECT  r.data_id_child AS id, \\012--                 ARRAY[CAST (r.data_id_parent AS bigint)] AS parent_ids, \\012--                 false AS cycle \\012--         FROM data_set_relationships r\\012--     UNION ALL\\012--         SELECT  r.data_id_child,\\012--                 CAST (r.data_id_parent AS bigint) || p.parent_ids,\\012--                 r.data_id_child = ANY(p.parent_ids)\\012--         FROM data_set_relationships r, data_set_parents p\\012--         WHERE r.data_id_parent = p.id AND NOT cycle\\012-- )\\012-- SELECT count(*) AS cycles FROM data_set_parents WHERE cycle = true;\\012\\012---------------------------------------------------------------------------------------------------\\012--  Purpose:  Create DEFERRED triggers:\\012--            * check_dataset_relationships_on_data_table_modification,\\012--            * check_dataset_relationships_on_relationships_table_modification.\\012--            They check that after all modifications of database (just before commit) \\012--            if 'data'/'data_set_relationships' tables are among modified tables \\012--            dataset is not connected with a sample and a parent dataset at the same time.\\012--            This connections are held in two different tables so simple immediate trigger \\012--            with arc check cannot be used and we need two deferred triggers.\\012----------------------------------------------------------------------------------------------------\\012\\012-- trigger for 'data' table\\012\\012CREATE OR REPLACE FUNCTION check_dataset_relationships_on_data_table_modification() RETURNS trigger AS $$\\012DECLARE\\012\\011counter\\011INTEGER;\\012BEGIN\\012\\011-- if there is a connection with a Sample there should not be any connection with a parent Data Set\\012\\011IF (NEW.samp_id IS NOT NULL) THEN\\012\\011\\011-- count number of parents\\012\\011\\011SELECT count(*) INTO counter \\012\\011\\011\\011FROM data_set_relationships \\012\\011\\011\\011WHERE data_id_child = OLD.id;\\012\\011\\011IF (counter > 0) THEN\\012\\011\\011\\011RAISE EXCEPTION 'Insert/Update of Data Set (Code: %) failed because it cannot be connected with a Sample and a parent Data Set at the same time.', OLD.code;\\012\\011\\011END IF;\\012\\011END IF;\\012  RETURN NEW;\\012END;\\012$$ LANGUAGE 'plpgsql';\\012\\012CREATE CONSTRAINT TRIGGER check_dataset_relationships_on_data_table_modification \\012  AFTER INSERT OR UPDATE ON data\\012\\011DEFERRABLE INITIALLY DEFERRED\\012\\011FOR EACH ROW \\012\\011EXECUTE PROCEDURE check_dataset_relationships_on_data_table_modification();\\012\\012-- trigger for 'data_set_relationships'\\012\\012CREATE OR REPLACE FUNCTION check_dataset_relationships_on_relationships_table_modification() RETURNS trigger AS $$\\012DECLARE\\012\\011counter\\011INTEGER;\\012\\011sample_id\\011TECH_ID;\\012\\011data_code\\011CODE;\\012BEGIN\\012\\011-- child will have a parent added so it should not be connected with any sample\\012\\011SELECT samp_id, code INTO sample_id, data_code \\012\\011\\011FROM data \\012\\011\\011WHERE id = NEW.data_id_child;\\012\\011IF (sample_id IS NOT NULL) THEN\\012\\011\\011RAISE EXCEPTION 'Insert/Update of Data Set (Code: %) failed because it cannot be connected to a Sample and to a parent Data Set at the same time.', data_code;\\012\\011END IF;\\012\\011RETURN NEW;\\012END;\\012$$ LANGUAGE 'plpgsql';\\012  \\012CREATE CONSTRAINT TRIGGER check_dataset_relationships_on_relationships_table_modification \\012  AFTER INSERT OR UPDATE ON data_set_relationships\\012\\011DEFERRABLE INITIALLY DEFERRED\\012\\011FOR EACH ROW \\012\\011EXECUTE PROCEDURE check_dataset_relationships_on_relationships_table_modification();\\012	\N
+./sourceTest/sql/postgresql/061/017=database_version_logs.tsv:053	source/sql/postgresql/migration/migration-052-053.sql	SUCCESS	2010-06-08 15:27:55.032	-- Migration from 052 to 053\\012\\012-- Change code uniqueness check for samples of specific type.\\012-- If sample_types.is_subcode_unique flag is set to 'true', additional check is performed \\012-- on codes of samples of the type. Subcodes will have to be unique as well.\\012\\012ALTER TABLE sample_types ADD COLUMN is_subcode_unique boolean_char NOT NULL DEFAULT false;\\012\\012CREATE OR REPLACE FUNCTION SAMPLE_SUBCODE_UNIQUENESS_CHECK() RETURNS trigger AS $$\\012DECLARE\\012   counter  INTEGER;\\012   unique_subcode  BOOLEAN_CHAR;\\012BEGIN\\012  LOCK TABLE samples IN EXCLUSIVE MODE;\\012  \\012  SELECT is_subcode_unique into unique_subcode FROM sample_types WHERE id = NEW.saty_id;\\012  \\012  IF (unique_subcode) THEN\\012    IF (NEW.dbin_id is not NULL) THEN\\012\\011\\011\\011SELECT count(*) into counter FROM samples \\012\\011\\011\\011\\011where id != NEW.id and code = NEW.code and saty_id = NEW.saty_id and dbin_id = NEW.dbin_id;\\012\\011\\011\\011IF (counter > 0) THEN\\012\\011\\011\\011\\011RAISE EXCEPTION 'Insert/Update of Sample (Code: %) failed because database instance sample of the same type with the same subcode already exists.', NEW.code;\\012\\011\\011\\011END IF;\\012\\011\\011ELSIF (NEW.grou_id is not NULL) THEN\\012\\011\\011\\011SELECT count(*) into counter FROM samples \\012\\011\\011\\011\\011where id != NEW.id and code = NEW.code and saty_id = NEW.saty_id and grou_id = NEW.grou_id;\\012\\011\\011\\011IF (counter > 0) THEN\\012\\011\\011\\011\\011RAISE EXCEPTION 'Insert/Update of Sample (Code: %) failed because space sample of the same type with the same subcode already exists.', NEW.code;\\012\\011\\011\\011END IF;\\012\\011\\011END IF;\\012  END IF;\\012  \\012  RETURN NEW;\\012END;\\012$$ LANGUAGE 'plpgsql';\\012\\012CREATE TRIGGER SAMPLE_SUBCODE_UNIQUENESS_CHECK BEFORE INSERT OR UPDATE ON SAMPLES\\012    FOR EACH ROW EXECUTE PROCEDURE SAMPLE_SUBCODE_UNIQUENESS_CHECK();\\012    \\012-- Fixing error messages in old trigger\\012\\012CREATE OR REPLACE FUNCTION SAMPLE_CODE_UNIQUENESS_CHECK() RETURNS trigger AS $$\\012DECLARE\\012   counter  INTEGER;\\012BEGIN\\012  LOCK TABLE samples IN EXCLUSIVE MODE;\\012  \\012\\011  IF (NEW.samp_id_part_of is NULL) THEN\\012\\011\\011  IF (NEW.dbin_id is not NULL) THEN\\012\\011\\011\\011  SELECT count(*) into counter FROM samples \\012\\011\\011      where id != NEW.id and code = NEW.code and samp_id_part_of is NULL and dbin_id = NEW.dbin_id;\\012        IF (counter > 0) THEN\\012\\011\\011\\011\\011  RAISE EXCEPTION 'Insert/Update of Sample (Code: %) failed because database instance sample with the same code already exists.', NEW.code;\\012        END IF;\\012\\011\\011  ELSIF (NEW.grou_id is not NULL) THEN\\012\\011\\011\\011  SELECT count(*) into counter FROM samples \\012\\011\\011\\011\\011  where id != NEW.id and code = NEW.code and samp_id_part_of is NULL and grou_id = NEW.grou_id;\\012\\011\\011\\011  IF (counter > 0) THEN\\012\\011\\011\\011\\011  RAISE EXCEPTION 'Insert/Update of Sample (Code: %) failed because space sample with the same code already exists.', NEW.code;\\012\\011\\011\\011  END IF;\\012      END IF;\\012    ELSE\\012\\011\\011  IF (NEW.dbin_id is not NULL) THEN\\012\\011\\011\\011  SELECT count(*) into counter FROM samples \\012\\011\\011\\011\\011  where id != NEW.id and code = NEW.code and samp_id_part_of = NEW.samp_id_part_of and dbin_id = NEW.dbin_id;\\012\\011\\011\\011  IF (counter > 0) THEN\\012\\011\\011\\011\\011  RAISE EXCEPTION 'Insert/Update of Sample (Code: %) failed because database instance sample with the same code and being the part of the same container already exists.', NEW.code;\\012\\011\\011\\011  END IF;\\012\\011\\011  ELSIF (NEW.grou_id is not NULL) THEN\\012\\011\\011\\011  SELECT count(*) into counter FROM samples \\012\\011\\011\\011\\011  where id != NEW.id and code = NEW.code and samp_id_part_of = NEW.samp_id_part_of and grou_id = NEW.grou_id;\\012\\011\\011\\011  IF (counter > 0) THEN\\012\\011\\011\\011\\011  RAISE EXCEPTION 'Insert/Update of Sample (Code: %) failed because space sample with the same code and being the part of the same container already exists.', NEW.code;\\012\\011\\011\\011  END IF;\\012\\011\\011  END IF;\\012     END IF;   \\012  \\012  RETURN NEW;\\012END;\\012$$ LANGUAGE 'plpgsql';\\012	\N
+./sourceTest/sql/postgresql/061/017=database_version_logs.tsv:054	source/sql/postgresql/migration/migration-053-054.sql	SUCCESS	2010-07-27 11:30:46.766	-- Migration from 053 to 054\\012\\012\\012-- Add RELATIONSHIP_TYPES table\\012CREATE TABLE relationship_types (id TECH_ID NOT NULL, code CODE NOT NULL, label COLUMN_LABEL, parent_label COLUMN_LABEL, child_label COLUMN_LABEL, description DESCRIPTION_2000, registration_timestamp TIME_STAMP_DFL NOT NULL DEFAULT CURRENT_TIMESTAMP, pers_id_registerer TECH_ID NOT NULL, is_managed_internally BOOLEAN_CHAR NOT NULL DEFAULT 'F', is_internal_namespace BOOLEAN_CHAR NOT NULL DEFAULT 'F', dbin_id TECH_ID NOT NULL);\\012\\012-- Add SAMPLE_RELATIONSHIPS table\\012CREATE TABLE sample_relationships (id TECH_ID NOT NULL, sample_id_parent TECH_ID NOT NULL, relationship_id TECH_ID NOT NULL, sample_id_child TECH_ID NOT NULL);\\012\\012-- Add/update constraints\\012ALTER TABLE relationship_types ADD CONSTRAINT rety_pk PRIMARY KEY (id);\\012ALTER TABLE relationship_types ADD CONSTRAINT rety_uk UNIQUE(code,dbin_id);\\012ALTER TABLE sample_relationships ADD CONSTRAINT sare_pk PRIMARY KEY (id);\\012ALTER TABLE sample_relationships ADD CONSTRAINT sare_bk_uk UNIQUE(sample_id_child,sample_id_parent,relationship_id);\\012ALTER TABLE sample_relationships ADD CONSTRAINT sare_data_fk_child FOREIGN KEY (sample_id_child) REFERENCES samples(id) ON DELETE CASCADE;\\012ALTER TABLE sample_relationships ADD CONSTRAINT sare_data_fk_parent FOREIGN KEY (sample_id_parent) REFERENCES samples(id) ON DELETE CASCADE;\\012ALTER TABLE sample_relationships ADD CONSTRAINT sare_data_fk_relationship FOREIGN KEY (relationship_id) REFERENCES relationship_types(id);\\012\\012-- Create index\\012CREATE INDEX sare_data_fk_i_child ON sample_relationships (sample_id_child);\\012CREATE INDEX sare_data_fk_i_parent ON sample_relationships (sample_id_parent);\\012CREATE INDEX sare_data_fk_i_relationship ON sample_relationships (relationship_id);\\012\\012-- Create sequence for RELATIONSHIP_TYPES\\012CREATE SEQUENCE RELATIONSHIP_TYPE_ID_SEQ;\\012CREATE SEQUENCE SAMPLE_RELATIONSHIP_ID_SEQ;\\012\\012-- Create initial relationships\\012insert into relationship_types\\012(id, \\012code, \\012label, \\012parent_label, \\012child_label, \\012description, \\012pers_id_registerer, \\012is_managed_internally, \\012is_internal_namespace, \\012dbin_id) \\012values\\012(\\012nextval('RELATIONSHIP_TYPE_ID_SEQ'),\\012'PARENT_CHILD',\\012'Parent - Child', \\012'Parent', \\012'Child', \\012'Parent - Child relationship', \\012(select id from persons where user_id ='system'), \\012'T', \\012'T', \\012(select id from database_instances where is_original_source = 'T')\\012);\\012\\012insert into relationship_types\\012(id, \\012code, \\012label, \\012parent_label, \\012child_label, \\012description, \\012pers_id_registerer, \\012is_managed_internally, \\012is_internal_namespace, \\012dbin_id) \\012values\\012(\\012nextval('RELATIONSHIP_TYPE_ID_SEQ'),\\012'PLATE_CONTROL_LAYOUT',\\012'Plate - Control Layout', \\012'Plate', \\012'Control Layout', \\012'Plate - Control Layout relationship', \\012(select id from persons where user_id ='system'), \\012'T', \\012'T', \\012(select id from database_instances where is_original_source = 'T')\\012); \\012\\012\\012-- Migrate sample relationships to new schema\\012INSERT INTO sample_relationships (id, sample_id_parent,sample_id_child,relationship_id) (select distinct nextval('SAMPLE_RELATIONSHIP_ID_SEQ') as id, s.SAMP_ID_GENERATED_FROM as parent_id, s.ID as child_id, rt.id as relationship_id from samples s, relationship_types rt  WHERE rt.code = 'PARENT_CHILD' and s.SAMP_ID_GENERATED_FROM is not null); \\012INSERT INTO sample_relationships (id, sample_id_parent,sample_id_child,relationship_id) (select distinct nextval('SAMPLE_RELATIONSHIP_ID_SEQ') as id, s.SAMP_ID_CONTROL_LAYOUT as parent_id, s.ID as child_id, rt.id as relationship_id from samples s, relationship_types rt  WHERE rt.code = 'PLATE_CONTROL_LAYOUT' and s.SAMP_ID_CONTROL_LAYOUT is not null);\\012\\012-- Drop old sample relations\\012ALTER TABLE SAMPLES DROP COLUMN SAMP_ID_TOP;\\012ALTER TABLE SAMPLES DROP COLUMN SAMP_ID_GENERATED_FROM;\\012ALTER TABLE SAMPLES DROP COLUMN SAMP_ID_CONTROL_LAYOUT;\\012\\012--------------------------------------------------------------------------------------\\012--------------------------------------------------------------------------------------\\012-- This is a screening specific migration. Nothing will be performed on openBIS databases \\012-- which are not screening specific.\\012-- \\012-- This migration for each existing connection between oligo well, oligo material and gene material\\012-- creates a direct connection between the well and the gene. \\012--------------------------------------------------------------------------------------\\012--------------------------------------------------------------------------------------\\012 \\012\\011\\012CREATE OR REPLACE FUNCTION CONNECT_WELLS_WITH_GENES() RETURNS void AS $$\\012DECLARE\\012\\011counter  int;\\012\\011oligo_well_exists bool;\\012BEGIN\\012\\011--------------------------------------------------\\012\\011-- create a gene property and assign it to oligo well\\012\\011--------------------------------------------------\\012\\011\\012\\011select true \\012\\011into oligo_well_exists\\012\\011from sample_types \\012\\011where code = 'OLIGO_WELL';\\012\\011\\012\\011if oligo_well_exists IS NULL then \\012\\011\\011-- skip migration if there are no oligo wells\\012\\011\\011return;\\012\\011end if;   \\012\\011\\012\\011insert into property_types(\\012\\011\\011id, \\012\\011\\011code, description, label, \\012\\011\\011daty_id,\\012\\011\\011pers_id_registerer,\\012\\011\\011dbin_id,\\012\\011\\011maty_prop_id) \\012\\011values(\\012\\011\\011\\011nextval('PROPERTY_TYPE_ID_SEQ'), \\012\\011\\011\\011'GENE','Inhibited gene','Gene',\\012\\011\\011\\011(select id from data_types where code = 'MATERIAL'), \\012\\011\\011\\011(select id from persons where user_id ='system'), \\012\\011\\011\\011(select id from database_instances where is_original_source = 'T'), \\012\\011\\011\\011(select id from material_types where code = 'GENE')\\012\\011\\011);\\012\\011\\011\\012\\011insert into sample_type_property_types( \\012\\011  id,\\012\\011  saty_id,\\012\\011  prty_id,\\012\\011  is_mandatory,\\012\\011  pers_id_registerer,\\012\\011  ordinal\\012\\011) values(\\012\\011\\011\\011nextval('stpt_id_seq'), \\012\\011\\011\\011(select id from sample_types where code = 'OLIGO_WELL'),\\012\\011\\011\\011(select id from property_types where code = 'GENE'),\\012\\011\\011\\011false,\\012\\011\\011\\011(select id from persons where user_id ='system'),\\012\\011\\011\\011(select max(ordinal)+1 from sample_type_property_types \\012\\011\\011\\011\\011where saty_id = (select id from sample_types where code = 'OLIGO_WELL'))\\012\\011\\011);\\012\\012\\011--------------------------------------------------\\012\\011-- create a gene material property for each oligo well\\012\\011--------------------------------------------------\\012\\011\\011\\012\\011select \\011count(*)\\012\\011into counter\\012\\011from\\012\\011\\011samples well, sample_types well_type, sample_properties well_props, \\012\\011\\011materials well_material, material_properties well_material_props,\\012\\011\\011materials nested_well_material\\012\\011where\\012\\011\\011well_type.code = 'OLIGO_WELL' and\\012\\011\\011-- find 'well_material' assigned to the well\\012\\011\\011well_props.samp_id = well.id and well_material.id = well_props.mate_prop_id and \\012\\011\\011-- additional joins to entity type tables\\012\\011\\011well_type.id = well.saty_id and\\012\\011\\011-- well content material property\\012\\011\\011well_material_props.mate_id = well_material.id and \\012\\011\\011-- material connected to the material in the well (e.g. gene)\\012\\011\\011well_material_props.mate_prop_id = nested_well_material.id and\\012\\011\\011nested_well_material.maty_id = (select id from material_types where code = 'GENE');\\012\\011\\012\\011if counter = 0 then \\012\\011\\011-- skip migration if there are no genes indirectly connected to oligo wells\\012\\011\\011return;\\012\\011end if;   \\012\\012\\011insert into sample_properties(id, samp_id, stpt_id, mate_prop_id, pers_id_registerer) (\\012\\011\\011select \\011nextval('sample_property_id_seq') id, \\012\\011\\011\\011well.id samp_id, \\012\\011\\011\\011(select stpt.id from sample_type_property_types stpt, property_types props where stpt.prty_id = props.id and props.code='GENE') stpt_id,\\012\\011\\011\\011nested_well_material.id mate_prop_id,\\012\\011\\011\\011(select id from persons where user_id ='system') pers_id_registerer \\012\\011\\011from\\012\\011\\011\\011samples well, sample_types well_type, sample_properties well_props, \\012\\011\\011\\011materials well_material, material_properties well_material_props,\\012\\011\\011\\011materials nested_well_material\\012\\011\\011where\\012\\011\\011\\011well_type.code = 'OLIGO_WELL' and\\012\\011\\011\\011-- find 'well_material' assigned to the well\\012\\011\\011\\011well_props.samp_id = well.id and well_material.id = well_props.mate_prop_id and \\012\\011\\011\\011-- additional joins to entity type tables\\012\\011\\011\\011well_type.id = well.saty_id and\\012\\011\\011\\011-- well content material property\\012\\011\\011\\011well_material_props.mate_id = well_material.id and \\012\\011\\011\\011-- material connected to the material in the well (e.g. gene)\\012\\011\\011\\011well_material_props.mate_prop_id = nested_well_material.id and\\012\\011\\011\\011nested_well_material.maty_id = (select id from material_types where code = 'GENE')\\012\\011);\\012\\012END;\\012$$ LANGUAGE 'plpgsql';\\012\\012select CONNECT_WELLS_WITH_GENES();\\012drop function CONNECT_WELLS_WITH_GENES();\\012\\012--------------------------------------------------------------------------------------\\012--------------------------------------------------------------------------------------\\012\\012-- drop dataset triggers\\012\\012DROP TRIGGER check_dataset_relationships_on_data_table_modification ON data;\\012DROP FUNCTION check_dataset_relationships_on_data_table_modification();\\012DROP TRIGGER check_dataset_relationships_on_relationships_table_modification ON data_set_relationships;\\012DROP FUNCTION check_dataset_relationships_on_relationships_table_modification();\\012 \\012\\012\\012\\012\\012\\012\\012\\012	\N
+./sourceTest/sql/postgresql/061/017=database_version_logs.tsv:056	source/sql/postgresql/migration/migration-055-056.sql	SUCCESS	2010-09-10 09:06:20.278	-- Migration from 055 to 056\\012\\012--------------------------------------------------------------------------------------\\012--------------------------------------------------------------------------------------\\012-- Screening specific migration. Nothing will be performed on openBIS databases \\012-- which are not screening specific.\\012--------------------------------------------------------------------------------------\\012--------------------------------------------------------------------------------------\\012\\012CREATE OR REPLACE FUNCTION merge_words(text, text) RETURNS text AS $$\\012DECLARE\\012  BEGIN\\012    IF  character_length($1) > 0 THEN\\012      RETURN $1 || ' ' || $2;\\012    ELSE\\012      RETURN $2;\\012    END IF;\\012  END;\\012$$ LANGUAGE plpgsql;\\012\\012CREATE AGGREGATE merge_words(text)\\012(\\012  SFUNC = merge_words,\\012  STYPE = text\\012);\\012\\012\\012CREATE OR REPLACE FUNCTION REPLACE_GENE_SYMBOL_BY_GENE_ID() RETURNS void AS $$\\012DECLARE\\012\\011counter  int;\\012\\011library_id_assigned_to_gene bool;\\012BEGIN\\012\\011--------------------------------------------------\\012\\011-- create a GENE_SYMBOL property and assign it to GENE\\012\\011--------------------------------------------------\\012\\011\\012\\011select true  \\012\\011into library_id_assigned_to_gene \\012\\011from material_type_property_types mtpt, material_types mt, property_types pt  \\012\\011where mtpt.maty_id = mt.id and mtpt.prty_id = pt.id \\012\\011\\011and mt.code = 'GENE' and pt.code = 'LIBRARY_ID';\\012\\011\\012\\011if library_id_assigned_to_gene IS NULL then \\012\\011\\011-- skip migration if gene has no library_id property\\012\\011\\011return;\\012\\011end if; \\012\\011\\012\\011\\012\\011select count(*)\\012\\011into counter \\012\\011from  \\012\\011\\011(select m.id, count(mp.id) as c \\012\\011\\011\\011from materials m, material_types mt, material_properties mp, material_type_property_types mtpt, property_types pt \\012\\011\\011\\011where m.maty_id = mt.id and mp.mate_id = m.id and mp.mtpt_id = mtpt.id and mtpt.maty_id = mt.id and pt.id = mtpt.prty_id\\012\\011\\011\\011\\011and mt.code = 'GENE' and pt.code = 'LIBRARY_ID' \\012\\011\\011\\011group by m.id) as counter_table \\012\\011where c < 1; \\012\\011\\012\\011if counter > 0 then \\012\\011\\011-- skip migration if there is at least one gene without library_id\\012\\011\\011return;\\012\\011end if;\\012\\011\\012\\011\\012\\011insert into property_types\\012\\011\\011(id\\012\\011\\011,code\\012\\011\\011,description\\012\\011\\011,label\\012\\011\\011,daty_id\\012\\011\\011,pers_id_registerer\\012\\011\\011,dbin_id)\\012\\011values \\012\\011\\011(nextval('PROPERTY_TYPE_ID_SEQ')\\012\\011\\011,'GENE_SYMBOLS'\\012\\011\\011,'Gene symbols'\\012\\011\\011,'Gene symbols'\\012\\011\\011,(select id from data_types where code ='VARCHAR')\\012\\011\\011,(select id from persons where user_id ='system')\\012\\011\\011,(select id from database_instances where is_original_source = 'T')\\012\\011);\\012\\011\\011\\012\\011insert into material_type_property_types( \\012\\011  id,\\012\\011  maty_id,\\012\\011  prty_id,\\012\\011  is_mandatory,\\012\\011  pers_id_registerer,\\012\\011  ordinal\\012\\011) values(\\012\\011\\011\\011nextval('mtpt_id_seq'), \\012\\011\\011\\011(select id from material_types where code = 'GENE'),\\012\\011\\011\\011(select id from property_types where code = 'GENE_SYMBOLS'),\\012\\011\\011\\011false,\\012\\011\\011\\011(select id from persons where user_id ='system'),\\012\\011\\011\\011(select max(ordinal)+1 from material_type_property_types \\012\\011\\011\\011\\011where maty_id = (select id from material_types where code = 'GENE'))\\012\\011\\011);\\012\\012\\011--------------------------------------------------\\012\\011-- create temporary table with all gene migration information\\012\\011--------------------------------------------------\\012\\012\\011create temp table genes \\012\\011(\\012\\011\\011id tech_id,\\012\\011\\011code code,\\012\\011\\011library_id generic_value,\\012\\011\\011gene_codes generic_value,\\012\\011\\011new_id tech_id,\\012\\011\\011library_tech_id tech_id\\011\\011\\012\\011);\\012\\011\\012\\011insert into genes (id, code, library_id, library_tech_id)\\012\\011\\011(select m.id, m.code, mp.value as library_id, mp.id as library_tech_id from materials m, material_properties mp, material_type_property_types mtpt, property_types pt, material_types mt\\012\\011\\011where mp.mate_id = m.id and  mp.mtpt_id = mtpt.id and pt.id = mtpt.prty_id and pt.code = 'LIBRARY_ID' and mt.id = m.maty_id and mt.id = mtpt.maty_id and mt.code = 'GENE');\\012\\011\\012\\011update genes set new_id = map.to_id from (select g_from.id as from_id, min(g_to.id) as to_id  from genes g_from, genes g_to where g_from.library_id = g_to.library_id group by g_from.id) as map where map.from_id = id;\\011\\012\\011\\012\\011update genes set gene_codes = map.gene_codes from (select g_from.library_id as lib_id, merge_words(distinct g_to.code) as gene_codes from genes g_from, genes g_to where g_from.library_id = g_to.library_id group by g_from.library_id) as map where map.lib_id = library_id;\\011\\012\\012\\011--------------------------------------------------\\012\\011-- update gene references\\012\\011--------------------------------------------------\\012\\012\\011update EXPERIMENTS set MATE_ID_STUDY_OBJECT = genes.new_id from genes where genes.id = MATE_ID_STUDY_OBJECT and not genes.id = genes.new_id;\\012\\011update EXPERIMENT_PROPERTIES set  MATE_PROP_ID = genes.new_id from genes where genes.id = MATE_PROP_ID and not genes.id = genes.new_id;\\012\\011update MATERIAL_PROPERTIES set  MATE_PROP_ID = genes.new_id from genes where genes.id = MATE_PROP_ID and not genes.id = genes.new_id;\\012\\011update SAMPLE_PROPERTIES set  MATE_PROP_ID = genes.new_id from genes where genes.id = MATE_PROP_ID and not genes.id = genes.new_id;\\012\\011update DATA_SET_PROPERTIES set  MATE_PROP_ID = genes.new_id from genes where genes.id = MATE_PROP_ID and not genes.id = genes.new_id;\\012\\011\\012\\011delete from  material_properties where mate_id in (select id from genes where not genes.id = genes.new_id);\\012\\011delete from MATERIALS where id in (select id from genes where not genes.id = genes.new_id);\\012\\012\\011delete from genes where id in (select id from genes where not genes.id = genes.new_id);\\012\\012\\012\\011--------------------------------------------------\\012\\011-- replace gene code with library_id\\012\\011--------------------------------------------------\\012\\011\\012\\011update materials set code = genes.library_id from genes where materials.id = genes.id ;\\012\\011delete from material_properties where id in (select library_tech_id from genes);\\012\\011\\012\\011--------------------------------------------------\\012\\011-- create a gene symbols property for each gene\\012\\011--------------------------------------------------\\012\\011\\012\\011insert into material_properties\\012\\011\\011(id\\012\\011  , mate_id\\012\\011  , mtpt_id\\012\\011  , "value"\\012\\011  , pers_id_registerer)\\012\\011\\011(select nextval('material_property_id_seq') id\\012\\011  \\011, genes.id  mate_id\\012\\011    , (select mtpt.id\\012\\011    \\011\\011from   material_type_property_types mtpt, material_types mt, property_types pt\\012\\011    \\011\\011where  pt.code = 'GENE_SYMBOLS' and mt.code = 'GENE' and mtpt.prty_id = pt.id\\012\\011        \\011and mtpt.maty_id = mt.id) mtpt_id\\012\\011    , genes.gene_codes "value"\\012\\011    , (select id from persons where user_id = 'system') pers_id_registerer\\012\\011 \\011from genes); \\012\\012\\011--------------------------------------------------\\012\\011-- delete temporary table\\012\\011--------------------------------------------------\\012\\011\\012\\011drop table genes;\\012\\011\\012END;\\012$$ LANGUAGE 'plpgsql';\\012\\012select REPLACE_GENE_SYMBOL_BY_GENE_ID();\\012drop function REPLACE_GENE_SYMBOL_BY_GENE_ID();\\012DROP AGGREGATE merge_words(text);\\012drop function merge_words(text,text);\\012\\012\\012--------------------------------------------------------------------------------------\\012--------------------------------------------------------------------------------------\\012\\012UPDATE sample_types SET code = 'SIRNA_WELL' WHERE code = 'OLIGO_WELL';\\012UPDATE material_types SET code = 'SIRNA' WHERE code = 'OLIGO';\\012UPDATE property_types SET code = 'SIRNA', label = 'siRNA' WHERE code = 'OLIGO';\\012\\012\\012\\012\\012\\012\\012\\012\\012\\012\\012\\012\\012\\012\\012\\012\\012\\012\\012\\012	\N
+./sourceTest/sql/postgresql/061/017=database_version_logs.tsv:059	source/sql/postgresql/migration/migration-058-059.sql	SUCCESS	2010-09-29 13:37:07.231	-- Migration from 058 to 059\\012\\012-- Add ENTITY_TYPE_CODE column to QUERIES\\012ALTER TABLE queries ADD COLUMN entity_type_code CODE;\\012\\012------------------------------------------------------------------------------------\\012--  Purpose:  Create trigger that checks if entity_type_code specified in a query\\012--            matches a code of an entity of type specified in query_type.\\012------------------------------------------------------------------------------------\\012\\012CREATE OR REPLACE FUNCTION query_entity_type_code_check() RETURNS trigger AS $$\\012DECLARE\\012   counter  INTEGER;\\012BEGIN\\012   if (NEW.entity_type_code IS NOT NULL) then\\012     if (NEW.query_type = 'GENERIC') then\\012       RAISE EXCEPTION 'Insert/Update of query (Name: %) failed, as entity_type has to be null for GENERIC queries.', NEW.name;\\012     elsif (NEW.query_type = 'EXPERIMENT') then\\012       SELECT count(*) INTO counter FROM experiment_types WHERE code = NEW.entity_type_code;\\012\\011\\011 elsif (NEW.query_type = 'DATA_SET') then\\012       SELECT count(*) INTO counter FROM data_set_types WHERE code = NEW.entity_type_code;\\012\\011\\011 elsif (NEW.query_type = 'MATERIAL') then\\012       SELECT count(*) INTO counter FROM material_types WHERE code = NEW.entity_type_code;\\012\\011\\011 elsif (NEW.query_type = 'SAMPLE') then\\012       SELECT count(*) INTO counter FROM sample_types WHERE code = NEW.entity_type_code;\\012\\011\\011 end if;\\012\\011\\011 if (counter = 0) then\\012\\011\\011\\011 RAISE EXCEPTION 'Insert/Update of query (Name: %) failed because % type (Code: %) does not exist.', NEW.name, NEW.query_type, NEW.entity_type_code;\\012\\011\\011 end if;\\011\\011\\011\\012   end if;\\012   RETURN NEW;\\012END;\\012$$ LANGUAGE 'plpgsql';\\012\\012CREATE TRIGGER query_entity_type_code_check BEFORE INSERT OR UPDATE ON queries\\012    FOR EACH ROW EXECUTE PROCEDURE query_entity_type_code_check();\\012	\N
+./sourceTest/sql/postgresql/061/schema-061.sql:    LANGUAGE plpgsql
+./sourceTest/sql/postgresql/061/schema-061.sql:    LANGUAGE plpgsql
+./sourceTest/sql/postgresql/061/schema-061.sql:    LANGUAGE plpgsql
+./sourceTest/sql/postgresql/061/schema-061.sql:    LANGUAGE plpgsql
+./sourceTest/sql/postgresql/061/schema-061.sql:    LANGUAGE plpgsql
+./sourceTest/sql/postgresql/061/schema-061.sql:    LANGUAGE plpgsql
+./sourceTest/sql/postgresql/061/schema-061.sql:    LANGUAGE plpgsql
+./sourceTest/sql/postgresql/061/schema-061.sql:    LANGUAGE plpgsql
+./sourceTest/sql/postgresql/061/schema-061.sql:    LANGUAGE plpgsql
+./sourceTest/sql/postgresql/062/.svn/text-base/017=database_version_logs.tsv.svn-base:027	D:\\User\\felmer\\dev-workspace\\openbis/source/sql/postgresql/027/function-027.sql	SUCCESS	2008-11-05 09:18:00.403	-- Creating Functions\\012\\012------------------------------------------------------------------------------------\\012--  Purpose:  Create function RENAME_SEQUENCE() that is required for renaming the sequences belonging to tables\\012------------------------------------------------------------------------------------\\012CREATE FUNCTION RENAME_SEQUENCE(OLD_NAME VARCHAR, NEW_NAME VARCHAR) RETURNS INTEGER AS $$\\012DECLARE\\012  CURR_SEQ_VAL   INTEGER;\\012BEGIN\\012  SELECT INTO CURR_SEQ_VAL NEXTVAL(OLD_NAME);\\012  EXECUTE 'CREATE SEQUENCE ' || NEW_NAME || ' START WITH ' || CURR_SEQ_VAL;\\012  EXECUTE 'DROP SEQUENCE ' || OLD_NAME;\\012  RETURN CURR_SEQ_VAL;\\012END;\\012$$ LANGUAGE 'plpgsql';\\012\\012\\012------------------------------------------------------------------------------------\\012--  Purpose:  Create trigger CONTROLLED_VOCABULARY_CHECK \\012------------------------------------------------------------------------------------\\012\\012CREATE OR REPLACE FUNCTION CONTROLLED_VOCABULARY_CHECK() RETURNS trigger AS $$\\012DECLARE\\012   v_code  CODE;\\012BEGIN\\012\\012   select code into v_code from data_types where id = NEW.daty_id;\\012\\012   -- Check if the data is of type "CONTROLLEDVOCABULARY"\\012   if v_code = 'CONTROLLEDVOCABULARY' then\\012      if NEW.covo_id IS NULL then\\012         RAISE EXCEPTION 'Insert/Update of Property Type (Code: %) failed, as its Data Type is CONTROLLEDVOCABULARY, but it is not linked to a Controlled Vocabulary.', NEW.code;\\012      end if;\\012   end if;\\012\\012   RETURN NEW;\\012\\012END;\\012$$ LANGUAGE 'plpgsql';\\012\\012CREATE TRIGGER CONTROLLED_VOCABULARY_CHECK BEFORE INSERT OR UPDATE ON PROPERTY_TYPES\\012    FOR EACH ROW EXECUTE PROCEDURE CONTROLLED_VOCABULARY_CHECK();\\012\\012\\012------------------------------------------------------------------------------------\\012--  Purpose:  Create trigger EXTERNAL_DATA_STORAGE_FORMAT_CHECK \\012------------------------------------------------------------------------------------\\012\\012CREATE OR REPLACE FUNCTION EXTERNAL_DATA_STORAGE_FORMAT_CHECK() RETURNS trigger AS $$\\012DECLARE\\012   v_covo_code  CODE;\\012   data_code CODE;\\012BEGIN\\012\\012   select code into v_covo_code from controlled_vocabularies\\012      where is_internal_namespace = true and \\012         id = (select covo_id from controlled_vocabulary_terms where id = NEW.cvte_id_stor_fmt);\\012   -- Check if the data storage format is a term of the controlled vocabulary "STORAGE_FORMAT"\\012   if v_covo_code != 'STORAGE_FORMAT' then\\012      select code into data_code from data where id = NEW.data_id; \\012      RAISE EXCEPTION 'Insert/Update of Data (Code: %) failed, as its Storage Format is %, but is required to be STORAGE_FORMAT.', data_code, v_covo_code;\\012   end if;\\012\\012   RETURN NEW;\\012\\012END;\\012$$ LANGUAGE 'plpgsql';\\012\\012CREATE TRIGGER EXTERNAL_DATA_STORAGE_FORMAT_CHECK BEFORE INSERT OR UPDATE ON EXTERNAL_DATA\\012    FOR EACH ROW EXECUTE PROCEDURE EXTERNAL_DATA_STORAGE_FORMAT_CHECK();\\012\\012------------------------------------------------------------------------------------\\012--  Purpose:  Create trigger SAMPLE_CODE_UNIQUENESS_CHECK \\012------------------------------------------------------------------------------------\\012\\012CREATE OR REPLACE FUNCTION SAMPLE_CODE_UNIQUENESS_CHECK() RETURNS trigger AS $$\\012DECLARE\\012   counter  INTEGER;\\012BEGIN\\012\\011IF (NEW.samp_id_part_of is NULL) THEN\\012\\011\\011IF (NEW.dbin_id is not NULL) THEN\\012\\011\\011\\011SELECT count(*) into counter FROM samples \\012\\011\\011\\011\\011where id != NEW.id and code = NEW.code and samp_id_part_of is NULL and dbin_id = NEW.dbin_id;\\012\\011\\011\\011IF (counter > 0) THEN\\012\\011\\011\\011\\011RAISE EXCEPTION 'Insert/Update of Sample (Code: %) failed because database instance sample with the same code already exists.', NEW.code;\\012\\011\\011\\011END IF;\\012\\011\\011ELSIF (NEW.grou_id is not NULL) THEN\\012\\011\\011\\011SELECT count(*) into counter FROM samples \\012\\011\\011\\011\\011where id != NEW.id and code = NEW.code and samp_id_part_of is NULL and grou_id = NEW.grou_id;\\012\\011\\011\\011IF (counter > 0) THEN\\012\\011\\011\\011\\011RAISE EXCEPTION 'Insert/Update of Sample (Code: %) failed because group sample with the same code already exists.', NEW.code;\\012\\011\\011\\011END IF;\\012\\011\\011END IF;\\012        ELSE\\012\\011\\011IF (NEW.dbin_id is not NULL) THEN\\012\\011\\011\\011SELECT count(*) into counter FROM samples \\012\\011\\011\\011\\011where id != NEW.id and code = NEW.code and samp_id_part_of = NEW.samp_id_part_of and dbin_id = NEW.dbin_id;\\012\\011\\011\\011IF (counter > 0) THEN\\012\\011\\011\\011\\011RAISE EXCEPTION 'Insert/Update of Sample (Code: %) failed because database instance sample with the same code and being the part of the same parent already exists.', NEW.code;\\012\\011\\011\\011END IF;\\012\\011\\011ELSIF (NEW.grou_id is not NULL) THEN\\012\\011\\011\\011SELECT count(*) into counter FROM samples \\012\\011\\011\\011\\011where id != NEW.id and code = NEW.code and samp_id_part_of = NEW.samp_id_part_of and grou_id = NEW.grou_id;\\012\\011\\011\\011IF (counter > 0) THEN\\012\\011\\011\\011\\011RAISE EXCEPTION 'Insert/Update of Sample (Code: %) failed because group sample with the same code and being the part of the same parent already exists.', NEW.code;\\012\\011\\011\\011END IF;\\012\\011\\011END IF;\\012        END IF;   \\012   RETURN NEW;\\012END;\\012$$ LANGUAGE 'plpgsql';\\012\\012CREATE TRIGGER SAMPLE_CODE_UNIQUENESS_CHECK BEFORE INSERT OR UPDATE ON SAMPLES\\012    FOR EACH ROW EXECUTE PROCEDURE SAMPLE_CODE_UNIQUENESS_CHECK();\\012	\N
+./sourceTest/sql/postgresql/062/.svn/text-base/017=database_version_logs.tsv.svn-base:028	source/sql/postgresql/migration/migration-027-028.sql	SUCCESS	2008-11-18 13:24:17.508	-- Create EXPERIMENT_ATTACHMENT_CONTENTS.\\012CREATE TABLE EXPERIMENT_ATTACHMENT_CONTENTS (ID TECH_ID NOT NULL,VALUE FILE NOT NULL);\\012CREATE SEQUENCE EXPERIMENT_ATTACHMENT_CONTENT_ID_SEQ;\\012ALTER TABLE EXPERIMENT_ATTACHMENT_CONTENTS ADD CONSTRAINT EXAC_PK PRIMARY KEY(ID);\\012\\012-- Alter EXPERIMENT_ATTACHMENTS by adding the new column which has a NULL constraint.\\012-- The NOT NULL constraint is added later on.\\012ALTER TABLE EXPERIMENT_ATTACHMENTS ADD COLUMN EXAC_ID TECH_ID;\\012\\012-- Does the VALUE migration between EXPERIMENT_ATTACHMENTS to EXPERIMENT_ATTACHMENT_CONTENTS.\\012CREATE OR REPLACE FUNCTION move_exp_att_content() RETURNS integer AS $$\\012DECLARE\\012    rec RECORD;\\012    seq BIGINT;\\012BEGIN\\012  FOR rec IN SELECT id, value FROM EXPERIMENT_ATTACHMENTS LOOP\\012  \\011seq := nextval('EXPERIMENT_ATTACHMENT_CONTENT_ID_SEQ');\\012    INSERT INTO EXPERIMENT_ATTACHMENT_CONTENTS (id, value) VALUES (seq, rec.value);\\012    UPDATE EXPERIMENT_ATTACHMENTS SET exac_id = seq WHERE id = rec.id;\\012  END LOOP;\\012  RETURN 1;\\012END;\\012$$ LANGUAGE 'plpgsql';\\012\\012-- Call the function.\\012SELECT move_exp_att_content();\\012DROP FUNCTION move_exp_att_content();\\012\\012\\012-- Finish EXPERIMENT_ATTACHMENTS changes.\\012ALTER TABLE EXPERIMENT_ATTACHMENTS ADD CONSTRAINT EXAT_CONT_FK FOREIGN KEY (EXAC_ID) REFERENCES EXPERIMENT_ATTACHMENT_CONTENTS(ID);\\012ALTER TABLE EXPERIMENT_ATTACHMENTS DROP COLUMN VALUE;\\012ALTER TABLE EXPERIMENT_ATTACHMENTS ALTER COLUMN EXAC_ID SET NOT NULL;\\012	\N
+./sourceTest/sql/postgresql/062/.svn/text-base/017=database_version_logs.tsv.svn-base:029	source/sql/postgresql/migration/migration-028-029.sql	SUCCESS	2009-03-18 10:50:20.105	-- -------\\012-- add modification_timestamp field to allow edition with Hibernate\\012-- -------\\012\\012ALTER TABLE samples\\012\\011ADD COLUMN modification_timestamp TIME_STAMP DEFAULT CURRENT_TIMESTAMP;\\012\\012ALTER TABLE experiments\\012\\011ADD COLUMN modification_timestamp TIME_STAMP DEFAULT CURRENT_TIMESTAMP;\\012\\012ALTER TABLE materials\\012\\011ADD COLUMN modification_timestamp TIME_STAMP DEFAULT CURRENT_TIMESTAMP;\\012\\012ALTER TABLE experiment_properties\\012\\011ADD COLUMN modification_timestamp TIME_STAMP DEFAULT CURRENT_TIMESTAMP;\\012\\012ALTER TABLE material_properties\\012\\011ADD COLUMN modification_timestamp TIME_STAMP DEFAULT CURRENT_TIMESTAMP;\\012\\012ALTER TABLE sample_properties\\012\\011ADD COLUMN modification_timestamp TIME_STAMP DEFAULT CURRENT_TIMESTAMP;\\012\\012-- -------\\012-- add property data type which references materials\\012-- -------\\012\\012ALTER TABLE property_types\\012\\011ADD COLUMN maty_prop_id tech_id;\\012\\012ALTER TABLE property_types\\012\\011ADD CONSTRAINT prty_maty_fk FOREIGN KEY (maty_prop_id) REFERENCES material_types(id);\\012\\012ALTER TABLE experiment_properties\\012\\011ADD COLUMN mate_prop_id tech_id;\\012\\012ALTER TABLE material_properties\\012\\011ADD COLUMN mate_prop_id tech_id;\\012\\012ALTER TABLE sample_properties\\012\\011ADD COLUMN mate_prop_id tech_id;\\012\\012ALTER TABLE experiment_properties\\012\\011ADD CONSTRAINT expr_mapr_fk FOREIGN KEY (mate_prop_id) REFERENCES materials(id);\\012\\012ALTER TABLE material_properties\\012\\011ADD CONSTRAINT mapr_mapr_fk FOREIGN KEY (mate_prop_id) REFERENCES materials(id);\\012\\012ALTER TABLE sample_properties\\012\\011ADD CONSTRAINT sapr_mapr_fk FOREIGN KEY (mate_prop_id) REFERENCES materials(id);\\012\\012insert into data_types\\012(id\\012 ,code\\012 ,description)\\012 values \\012 (nextval('DATA_TYPE_ID_SEQ')\\012 ,'MATERIAL'\\012 ,'Reference to a material'\\012);\\012\\012ALTER TABLE MATERIAL_PROPERTIES DROP CONSTRAINT MAPR_CK;\\012ALTER TABLE MATERIAL_PROPERTIES ADD CONSTRAINT MAPR_CK CHECK \\012\\011((VALUE IS NOT NULL AND CVTE_ID IS NULL AND MATE_PROP_ID IS NULL) OR \\012\\011 (VALUE IS NULL AND CVTE_ID IS NOT NULL AND MATE_PROP_ID IS NULL) OR\\012\\011 (VALUE IS NULL AND CVTE_ID IS NULL AND MATE_PROP_ID IS NOT NULL)\\012\\011);\\012\\012ALTER TABLE EXPERIMENT_PROPERTIES DROP CONSTRAINT EXPR_CK;\\012ALTER TABLE EXPERIMENT_PROPERTIES ADD CONSTRAINT EXPR_CK CHECK \\012\\011((VALUE IS NOT NULL AND CVTE_ID IS NULL AND MATE_PROP_ID IS NULL) OR \\012\\011 (VALUE IS NULL AND CVTE_ID IS NOT NULL AND MATE_PROP_ID IS NULL) OR\\012\\011 (VALUE IS NULL AND CVTE_ID IS NULL AND MATE_PROP_ID IS NOT NULL)\\012\\011);\\012\\012ALTER TABLE SAMPLE_PROPERTIES DROP CONSTRAINT SAPR_CK;\\012ALTER TABLE SAMPLE_PROPERTIES ADD CONSTRAINT SAPR_CK CHECK \\012\\011((VALUE IS NOT NULL AND CVTE_ID IS NULL AND MATE_PROP_ID IS NULL) OR \\012\\011 (VALUE IS NULL AND CVTE_ID IS NOT NULL AND MATE_PROP_ID IS NULL) OR\\012\\011 (VALUE IS NULL AND CVTE_ID IS NULL AND MATE_PROP_ID IS NOT NULL)\\012\\011);\\012\\012------------------------------------------------------------------------------------\\012--  Purpose:  Create trigger MATERIAL/SAMPLE/EXPERIMENT _PROPERTY_WITH_MATERIAL_DATA_TYPE_CHECK\\012--            It checks that if material property value is assigned to the entity,\\012--\\011\\011\\011\\011\\011\\011then the material type is equal to the one described by property type.\\012------------------------------------------------------------------------------------\\012\\012CREATE OR REPLACE FUNCTION MATERIAL_PROPERTY_WITH_MATERIAL_DATA_TYPE_CHECK() RETURNS trigger AS $$\\012DECLARE\\012   v_type_id  CODE;\\012   v_type_id_prop  CODE;\\012BEGIN\\012   if NEW.mate_prop_id IS NOT NULL then\\012\\011\\011\\011-- find material type id of the property type \\012\\011\\011\\011select pt.maty_prop_id into v_type_id_prop \\012\\011\\011\\011  from material_type_property_types etpt, property_types pt \\012\\011\\011\\011 where NEW.mtpt_id = etpt.id AND etpt.prty_id = pt.id;\\012\\011\\011\\012\\011\\011\\011if v_type_id_prop IS NOT NULL then\\012\\011\\011\\011\\011-- find material type id of the material which consists the entity's property value\\012\\011\\011\\011\\011select entity.maty_id into v_type_id \\012\\011\\011\\011\\011  from materials entity\\012\\011\\011\\011\\011 where NEW.mate_prop_id = entity.id;\\012\\011\\011\\011\\011if v_type_id != v_type_id_prop then\\012\\011\\011\\011\\011\\011RAISE EXCEPTION 'Insert/Update of property value referencing material (id: %) failed, as referenced material type is different than expected (id %, expected id: %).', \\012\\011\\011\\011\\011\\011\\011\\011 NEW.mate_prop_id, v_type_id, v_type_id_prop;\\012\\011\\011\\011\\011end if;\\012\\011\\011\\011end if;\\012   end if;\\012   RETURN NEW;\\012END;\\012$$ LANGUAGE 'plpgsql';\\012\\012CREATE TRIGGER MATERIAL_PROPERTY_WITH_MATERIAL_DATA_TYPE_CHECK BEFORE INSERT OR UPDATE ON material_properties\\012    FOR EACH ROW EXECUTE PROCEDURE MATERIAL_PROPERTY_WITH_MATERIAL_DATA_TYPE_CHECK();\\012    \\012CREATE OR REPLACE FUNCTION SAMPLE_PROPERTY_WITH_MATERIAL_DATA_TYPE_CHECK() RETURNS trigger AS $$\\012DECLARE\\012   v_type_id  CODE;\\012   v_type_id_prop  CODE;\\012BEGIN\\012   if NEW.mate_prop_id IS NOT NULL then\\012\\011\\011\\011-- find material type id of the property type \\012\\011\\011\\011select pt.maty_prop_id into v_type_id_prop \\012\\011\\011\\011  from sample_type_property_types etpt, property_types pt \\012\\011\\011\\011 where NEW.stpt_id = etpt.id AND etpt.prty_id = pt.id;\\012\\011\\011\\012\\011\\011\\011if v_type_id_prop IS NOT NULL then\\012\\011\\011\\011\\011-- find material type id of the material which consists the entity's property value\\012\\011\\011\\011\\011select entity.maty_id into v_type_id \\012\\011\\011\\011\\011  from materials entity\\012\\011\\011\\011\\011 where NEW.mate_prop_id = entity.id;\\012\\011\\011\\011\\011if v_type_id != v_type_id_prop then\\012\\011\\011\\011\\011\\011RAISE EXCEPTION 'Insert/Update of property value referencing material (id: %) failed, as referenced material type is different than expected (id %, expected id: %).', \\012\\011\\011\\011\\011\\011\\011\\011\\011\\011\\011\\011\\011 NEW.mate_prop_id, v_type_id, v_type_id_prop;\\012\\011\\011\\011\\011end if;\\012\\011\\011\\011end if;\\012   end if;\\012   RETURN NEW;\\012END;\\012$$ LANGUAGE 'plpgsql';\\012\\012CREATE TRIGGER SAMPLE_PROPERTY_WITH_MATERIAL_DATA_TYPE_CHECK BEFORE INSERT OR UPDATE ON sample_properties\\012    FOR EACH ROW EXECUTE PROCEDURE SAMPLE_PROPERTY_WITH_MATERIAL_DATA_TYPE_CHECK();\\012    \\012CREATE OR REPLACE FUNCTION EXPERIMENT_PROPERTY_WITH_MATERIAL_DATA_TYPE_CHECK() RETURNS trigger AS $$\\012DECLARE\\012   v_type_id  CODE;\\012   v_type_id_prop  CODE;\\012BEGIN\\012   if NEW.mate_prop_id IS NOT NULL then\\012\\011\\011\\011-- find material type id of the property type \\012\\011\\011\\011select pt.maty_prop_id into v_type_id_prop \\012\\011\\011\\011  from experiment_type_property_types etpt, property_types pt \\012\\011\\011\\011 where NEW.etpt_id = etpt.id AND etpt.prty_id = pt.id;\\012\\011\\011\\012\\011\\011\\011if v_type_id_prop IS NOT NULL then\\012\\011\\011\\011\\011-- find material type id of the material which consists the entity's property value\\012\\011\\011\\011\\011select entity.maty_id into v_type_id \\012\\011\\011\\011\\011  from materials entity\\012\\011\\011\\011\\011 where NEW.mate_prop_id = entity.id;\\012\\011\\011\\011\\011if v_type_id != v_type_id_prop then\\012\\011\\011\\011\\011\\011RAISE EXCEPTION 'Insert/Update of property value referencing material (id: %) failed, as referenced material type is different than expected (id %, expected id: %).', \\012\\011\\011\\011\\011\\011\\011\\011\\011\\011\\011\\011\\011 NEW.mate_prop_id, v_type_id, v_type_id_prop;\\012\\011\\011\\011\\011end if;\\012\\011\\011\\011end if;\\012   end if;\\012   RETURN NEW;\\012END;\\012$$ LANGUAGE 'plpgsql';\\012\\012CREATE TRIGGER EXPERIMENT_PROPERTY_WITH_MATERIAL_DATA_TYPE_CHECK BEFORE INSERT OR UPDATE ON experiment_properties\\012    FOR EACH ROW EXECUTE PROCEDURE EXPERIMENT_PROPERTY_WITH_MATERIAL_DATA_TYPE_CHECK();\\012       \\012-- -------\\012-- remove the reminescents of the OBSERVABLE_TYPE\\012-- -------\\012\\012ALTER TABLE data\\012\\011DROP CONSTRAINT data_obty_fk;\\012\\012ALTER TABLE data_set_types\\012\\011DROP CONSTRAINT obty_pk;\\012\\012ALTER TABLE data_set_types\\012\\011ADD CONSTRAINT dsty_pk PRIMARY KEY (id);\\012\\012ALTER TABLE data\\012\\011ADD CONSTRAINT data_dsty_fk FOREIGN KEY (dsty_id) REFERENCES data_set_types(id);\\012\\012ALTER TABLE data_set_types\\012\\011DROP CONSTRAINT obty_bk_uk;\\012\\012ALTER TABLE data_set_types\\012\\011DROP CONSTRAINT obty_dbin_fk;\\012\\012ALTER TABLE data_set_types\\012\\011ADD CONSTRAINT dsty_bk_uk UNIQUE (code, dbin_id);\\012\\012ALTER TABLE data_set_types\\012\\011ADD CONSTRAINT dsty_dbin_fk FOREIGN KEY (dbin_id) REFERENCES database_instances(id);\\012\\012DROP INDEX data_obty_fk_i;\\012\\012CREATE INDEX data_dsty_fk_i ON data(dsty_id);\\012	\N
+./sourceTest/sql/postgresql/062/.svn/text-base/017=database_version_logs.tsv.svn-base:030	source/sql/postgresql/migration/migration-029-030.sql	SUCCESS	2009-03-23 15:34:44.72	-- -------\\012-- add modification_timestamp field to allow edition with Hibernate\\012-- -------\\012ALTER TABLE data\\012\\011ADD COLUMN modification_timestamp TIME_STAMP DEFAULT CURRENT_TIMESTAMP;\\012ALTER TABLE experiment_types\\012\\011ADD COLUMN modification_timestamp TIME_STAMP DEFAULT CURRENT_TIMESTAMP;\\012ALTER TABLE sample_types\\012\\011ADD COLUMN modification_timestamp TIME_STAMP DEFAULT CURRENT_TIMESTAMP;\\012ALTER TABLE material_types\\012\\011ADD COLUMN modification_timestamp TIME_STAMP DEFAULT CURRENT_TIMESTAMP;\\012ALTER TABLE data_set_types\\012\\011ADD COLUMN modification_timestamp TIME_STAMP DEFAULT CURRENT_TIMESTAMP;\\012ALTER TABLE controlled_vocabularies\\012\\011ADD COLUMN modification_timestamp TIME_STAMP DEFAULT CURRENT_TIMESTAMP;\\012-- -------\\012-- add properties to data sets\\012-- -------\\012CREATE TABLE DATA_SET_PROPERTIES (ID TECH_ID NOT NULL,DS_ID TECH_ID NOT NULL,DSTPT_ID TECH_ID NOT NULL,VALUE GENERIC_VALUE,CVTE_ID TECH_ID, MATE_PROP_ID TECH_ID, PERS_ID_REGISTERER TECH_ID NOT NULL,REGISTRATION_TIMESTAMP TIME_STAMP_DFL NOT NULL DEFAULT CURRENT_TIMESTAMP, MODIFICATION_TIMESTAMP TIME_STAMP DEFAULT CURRENT_TIMESTAMP);\\012CREATE TABLE DATA_SET_TYPE_PROPERTY_TYPES (ID TECH_ID NOT NULL,DSTY_ID TECH_ID NOT NULL,PRTY_ID TECH_ID NOT NULL,IS_MANDATORY BOOLEAN_CHAR NOT NULL DEFAULT 'F',IS_MANAGED_INTERNALLY BOOLEAN_CHAR NOT NULL DEFAULT 'F',PERS_ID_REGISTERER TECH_ID NOT NULL,REGISTRATION_TIMESTAMP TIME_STAMP_DFL NOT NULL DEFAULT CURRENT_TIMESTAMP);\\012\\012CREATE SEQUENCE DATA_SET_PROPERTY_ID_SEQ;\\012CREATE SEQUENCE DSTPT_ID_SEQ;\\012\\012ALTER TABLE DATA_SET_TYPE_PROPERTY_TYPES ADD CONSTRAINT DSTPT_PK PRIMARY KEY(ID);\\012ALTER TABLE DATA_SET_PROPERTIES ADD CONSTRAINT DSPR_PK PRIMARY KEY(ID);\\012\\012ALTER TABLE DATA_SET_TYPE_PROPERTY_TYPES ADD CONSTRAINT DSTPT_BK_UK UNIQUE(DSTY_ID,PRTY_ID);\\012ALTER TABLE DATA_SET_PROPERTIES ADD CONSTRAINT DSPR_BK_UK UNIQUE(DS_ID,DSTPT_ID);\\012\\012\\012ALTER TABLE DATA_SET_TYPE_PROPERTY_TYPES ADD CONSTRAINT DSTPT_DSTY_FK FOREIGN KEY (DSTY_ID) REFERENCES DATA_SET_TYPES(ID);\\012ALTER TABLE DATA_SET_TYPE_PROPERTY_TYPES ADD CONSTRAINT DSTPT_PERS_FK FOREIGN KEY (PERS_ID_REGISTERER) REFERENCES PERSONS(ID);\\012ALTER TABLE DATA_SET_TYPE_PROPERTY_TYPES ADD CONSTRAINT DSTPT_PRTY_FK FOREIGN KEY (PRTY_ID) REFERENCES PROPERTY_TYPES(ID);\\012ALTER TABLE DATA_SET_PROPERTIES ADD CONSTRAINT DSPR_CVTE_FK FOREIGN KEY (CVTE_ID) REFERENCES CONTROLLED_VOCABULARY_TERMS(ID);\\012ALTER TABLE DATA_SET_PROPERTIES ADD CONSTRAINT DSPR_DSTPT_FK FOREIGN KEY (DSTPT_ID) REFERENCES DATA_SET_TYPE_PROPERTY_TYPES(ID) ON DELETE CASCADE;\\012ALTER TABLE DATA_SET_PROPERTIES ADD CONSTRAINT DSPR_DS_FK FOREIGN KEY (DS_ID) REFERENCES DATA(ID);\\012ALTER TABLE DATA_SET_PROPERTIES ADD CONSTRAINT DSPR_PERS_FK FOREIGN KEY (PERS_ID_REGISTERER) REFERENCES PERSONS(ID);\\012ALTER TABLE DATA_SET_PROPERTIES ADD CONSTRAINT DSPR_MAPR_FK FOREIGN KEY (MATE_PROP_ID) REFERENCES MATERIALS(ID);\\012\\012ALTER TABLE DATA_SET_PROPERTIES ADD CONSTRAINT DSPR_CK CHECK \\012\\011((VALUE IS NOT NULL AND CVTE_ID IS NULL AND MATE_PROP_ID IS NULL) OR \\012\\011 (VALUE IS NULL AND CVTE_ID IS NOT NULL AND MATE_PROP_ID IS NULL) OR\\012\\011 (VALUE IS NULL AND CVTE_ID IS NULL AND MATE_PROP_ID IS NOT NULL)\\012\\011);\\012\\012CREATE INDEX DSPR_CVTE_FK_I ON DATA_SET_PROPERTIES (CVTE_ID);\\012CREATE INDEX DSPR_DSTPT_FK_I ON DATA_SET_PROPERTIES (DSTPT_ID);\\012CREATE INDEX DSPR_DS_FK_I ON DATA_SET_PROPERTIES (DS_ID);\\012CREATE INDEX DSPR_PERS_FK_I ON DATA_SET_PROPERTIES (PERS_ID_REGISTERER);\\012CREATE INDEX DSTPT_DSTY_FK_I ON DATA_SET_TYPE_PROPERTY_TYPES (DSTY_ID);\\012CREATE INDEX DSTPT_PERS_FK_I ON DATA_SET_TYPE_PROPERTY_TYPES (PERS_ID_REGISTERER);\\012CREATE INDEX DSTPT_PRTY_FK_I ON DATA_SET_TYPE_PROPERTY_TYPES (PRTY_ID);\\012\\012CREATE OR REPLACE FUNCTION DATA_SET_PROPERTY_WITH_MATERIAL_DATA_TYPE_CHECK() RETURNS trigger AS $$\\012DECLARE\\012   v_type_id  CODE;\\012   v_type_id_prop  CODE;\\012BEGIN\\012   if NEW.mate_prop_id IS NOT NULL then\\012\\011\\011\\011-- find material type id of the property type \\012\\011\\011\\011select pt.maty_prop_id into v_type_id_prop \\012\\011\\011\\011  from data_set_type_property_types dstpt, property_types pt \\012\\011\\011\\011 where NEW.dstpt_id = dstpt.id AND dstpt.prty_id = pt.id;\\012\\011\\011\\012\\011\\011\\011if v_type_id_prop IS NOT NULL then\\012\\011\\011\\011\\011-- find material type id of the material which consists the entity's property value\\012\\011\\011\\011\\011select entity.maty_id into v_type_id \\012\\011\\011\\011\\011  from materials entity\\012\\011\\011\\011\\011 where NEW.mate_prop_id = entity.id;\\012\\011\\011\\011\\011if v_type_id != v_type_id_prop then\\012\\011\\011\\011\\011\\011RAISE EXCEPTION 'Insert/Update of property value referencing material (id: %) failed, as referenced material type is different than expected (id %, expected id: %).', \\012\\011\\011\\011\\011\\011\\011\\011\\011\\011\\011\\011\\011 NEW.mate_prop_id, v_type_id, v_type_id_prop;\\012\\011\\011\\011\\011end if;\\012\\011\\011\\011end if;\\012   end if;\\012   RETURN NEW;\\012END;\\012$$ LANGUAGE 'plpgsql';\\012\\012CREATE TRIGGER DATA_SET_PROPERTY_WITH_MATERIAL_DATA_TYPE_CHECK BEFORE INSERT OR UPDATE ON data_set_properties\\012    FOR EACH ROW EXECUTE PROCEDURE DATA_SET_PROPERTY_WITH_MATERIAL_DATA_TYPE_CHECK();   \\012	\N
+./sourceTest/sql/postgresql/062/.svn/text-base/017=database_version_logs.tsv.svn-base:032	source/sql/postgresql/migration/migration-031-032.sql	SUCCESS	2009-04-09 09:36:36.2	-- -------\\012-- Modify MATERIAL_BATCHES\\012-- -------\\012\\012ALTER TABLE material_batches\\012    DROP COLUMN proc_id;\\012\\012-- -------\\012-- Modify SAMPLES\\012-- -------\\012\\012ALTER TABLE samples\\012    ADD COLUMN expe_id tech_id;\\012\\012ALTER TABLE samples\\012    ADD CONSTRAINT samp_expe_fk FOREIGN KEY (expe_id) REFERENCES experiments(id);\\012\\012CREATE INDEX samp_expe_fk_i ON samples USING btree (expe_id);\\012\\012-- relink samples directly to experiments\\012\\012UPDATE samples\\012SET expe_id = (SELECT e.id FROM experiments e, procedures p, sample_inputs si \\012               WHERE si.samp_id = samples.id AND si.proc_id = p.id AND p.expe_id = e.id AND e.inva_id IS NULL);\\012\\012\\012-- -------\\012-- Modify DATA\\012-- -------\\012\\012ALTER TABLE data\\012    ADD COLUMN expe_id tech_id;\\012\\012ALTER TABLE data\\012    ADD CONSTRAINT data_expe_fk FOREIGN KEY (expe_id) REFERENCES experiments(id);\\012\\012CREATE INDEX data_expe_fk_i ON data USING btree (expe_id);\\012\\012UPDATE data\\012SET expe_id = (SELECT e.id FROM experiments e, procedures p \\012               WHERE data.proc_id_produced_by = p.id AND p.expe_id = e.id);\\012\\012ALTER TABLE data\\012    ALTER COLUMN expe_id SET NOT NULL;\\012\\012ALTER TABLE data\\012    DROP COLUMN proc_id_produced_by;\\012\\012-- -------\\012-- Drop PROCEDURES, PROCEDURE_TYPES, and SAMPLE_INPUTS\\012-- -------\\012\\012DROP TABLE sample_inputs;\\012DROP TABLE procedures;\\012DROP TABLE procedure_types;\\012\\012DROP SEQUENCE procedure_id_seq;\\012DROP SEQUENCE procedure_type_id_seq;\\012\\012-- -------\\012-- Add CODE_SEQ\\012-- -------\\012\\012CREATE SEQUENCE CODE_SEQ;\\012\\012-- -------\\012-- Add new columns to DATA_STORES\\012-- -------\\012\\012ALTER TABLE data_stores\\012    ADD COLUMN remote_url character varying(250),\\012    ADD COLUMN session_token character varying(50),\\012    ADD COLUMN modification_timestamp time_stamp DEFAULT now();\\012\\012UPDATE data_stores\\012SET remote_url = '', session_token='';\\012\\012ALTER TABLE data_stores\\012    ALTER COLUMN remote_url SET NOT NULL,\\012    ALTER COLUMN session_token SET NOT NULL;\\012\\012-- -------\\012-- Drop foreign keys onto DATA_STORES\\012-- -------\\012\\012ALTER TABLE database_instances\\012    DROP COLUMN dast_id;\\012\\012ALTER TABLE groups\\012    DROP COLUMN dast_id;\\012\\012ALTER TABLE projects\\012    DROP COLUMN dast_id;\\012\\012ALTER TABLE experiments\\012    DROP COLUMN dast_id;\\012\\012-- -------\\012-- Add foreign key from DATA onto DATA_STORES\\012-- -------\\012\\012ALTER TABLE data\\012    ADD COLUMN dast_id tech_id;\\012\\012ALTER TABLE data\\012    ADD CONSTRAINT data_dast_fk FOREIGN KEY (dast_id) REFERENCES data_stores(id);\\012\\012UPDATE data\\012SET dast_id = (select id from data_stores where code = 'STANDARD');\\012\\012ALTER TABLE data\\012    ALTER COLUMN dast_id SET NOT NULL;\\012\\012\\012------------------------------------------------------------------------------------\\012--  Purpose:  Replace trigger SAMPLE_CODE_UNIQUENESS_CHECK \\012------------------------------------------------------------------------------------\\012\\012CREATE OR REPLACE FUNCTION SAMPLE_CODE_UNIQUENESS_CHECK() RETURNS trigger AS $$\\012DECLARE\\012   counter  INTEGER;\\012BEGIN\\012    LOCK TABLE samples IN EXCLUSIVE MODE;\\012    IF (NEW.samp_id_part_of is NULL) THEN\\012        IF (NEW.dbin_id is not NULL) THEN\\012            SELECT count(*) into counter FROM samples \\012                where id != NEW.id and code = NEW.code and samp_id_part_of is NULL and dbin_id = NEW.dbin_id;\\012            IF (counter > 0) THEN\\012                RAISE EXCEPTION 'Insert/Update of Sample (Code: %) failed because database instance sample with the same code already exists.', NEW.code;\\012            END IF;\\012        ELSIF (NEW.grou_id is not NULL) THEN\\012            SELECT count(*) into counter FROM samples \\012                where id != NEW.id and code = NEW.code and samp_id_part_of is NULL and grou_id = NEW.grou_id;\\012            IF (counter > 0) THEN\\012                RAISE EXCEPTION 'Insert/Update of Sample (Code: %) failed because group sample with the same code already exists.', NEW.code;\\012            END IF;\\012        END IF;\\012        ELSE\\012        IF (NEW.dbin_id is not NULL) THEN\\012            SELECT count(*) into counter FROM samples \\012                where id != NEW.id and code = NEW.code and samp_id_part_of = NEW.samp_id_part_of and dbin_id = NEW.dbin_id;\\012            IF (counter > 0) THEN\\012                RAISE EXCEPTION 'Insert/Update of Sample (Code: %) failed because database instance sample with the same code and being the part of the same parent already exists.', NEW.code;\\012            END IF;\\012        ELSIF (NEW.grou_id is not NULL) THEN\\012            SELECT count(*) into counter FROM samples \\012                where id != NEW.id and code = NEW.code and samp_id_part_of = NEW.samp_id_part_of and grou_id = NEW.grou_id;\\012            IF (counter > 0) THEN\\012                RAISE EXCEPTION 'Insert/Update of Sample (Code: %) failed because group sample with the same code and being the part of the same parent already exists.', NEW.code;\\012            END IF;\\012        END IF;\\012        END IF;   \\012   RETURN NEW;\\012END;\\012$$ LANGUAGE 'plpgsql';\\012\\012\\012\\012	\N
+./sourceTest/sql/postgresql/062/.svn/text-base/017=database_version_logs.tsv.svn-base:034	source/sql/postgresql/migration/migration-033-034.sql	SUCCESS	2009-05-26 08:32:49.935	------------------------------------------------------------------------------------\\012-- Create sequence for generating permanent identifiers starting with nextval of existing dataset sequence.\\012------------------------------------------------------------------------------------\\012CREATE FUNCTION CREATE_SEQUENCE(EXISTING_SEQUENCE VARCHAR, NEW_SEQUENCE VARCHAR) RETURNS VOID AS $$\\012DECLARE\\012  CURR_SEQ_VAL   INTEGER;\\012BEGIN\\012  SELECT INTO CURR_SEQ_VAL NEXTVAL(EXISTING_SEQUENCE);\\012  EXECUTE 'CREATE SEQUENCE ' || NEW_SEQUENCE || ' START WITH ' || CURR_SEQ_VAL;\\012  RETURN;\\012END;\\012$$ LANGUAGE 'plpgsql';\\012\\012SELECT CREATE_SEQUENCE('DATA_ID_SEQ', 'PERM_ID_SEQ');\\012DROP FUNCTION CREATE_SEQUENCE(VARCHAR, VARCHAR);\\012\\012------------------------------------------------------------------------------------\\012-- Add perm_id columns to samples and experiments.\\012------------------------------------------------------------------------------------\\012ALTER TABLE SAMPLES ADD COLUMN PERM_ID CODE;\\012ALTER TABLE EXPERIMENTS ADD COLUMN PERM_ID CODE;\\012\\012UPDATE SAMPLES SET PERM_ID = to_char(registration_timestamp,'YYYYMMDDHHSSMS') || '-' || NEXTVAL('PERM_ID_SEQ');\\012UPDATE EXPERIMENTS SET PERM_ID = to_char(registration_timestamp,'YYYYMMDDHHSSMS') || '-' || NEXTVAL('PERM_ID_SEQ');\\012ALTER TABLE SAMPLES ALTER COLUMN PERM_ID SET NOT NULL;\\012ALTER TABLE EXPERIMENTS ALTER COLUMN PERM_ID SET NOT NULL;\\012ALTER TABLE SAMPLES ADD CONSTRAINT SAMP_PI_UK UNIQUE(PERM_ID);\\012ALTER TABLE EXPERIMENTS ADD CONSTRAINT EXPE_PI_UK UNIQUE(PERM_ID);\\012\\012\\012------------------------------------------------------------------------------------\\012-- Add column is_chosen_from_list to controlled_vocabularies.\\012------------------------------------------------------------------------------------\\012ALTER TABLE controlled_vocabularies ADD COLUMN is_chosen_from_list BOOLEAN_CHAR NOT NULL DEFAULT TRUE;\\012ALTER TABLE controlled_vocabularies ADD COLUMN source_uri CHARACTER VARYING(250);\\012------------------------------------------------------------------------------------\\012-- Modify Data table - remove arc connection between Sample and Data table, use a flag instead\\012------------------------------------------------------------------------------------\\012\\012-- add new columns\\012\\012ALTER TABLE data\\012    ADD COLUMN is_derived boolean_char;\\012ALTER TABLE data\\012    ADD COLUMN samp_id tech_id;\\012\\012-- update values in new columns\\012\\012UPDATE data\\012    SET is_derived = (samp_id_derived_from IS NOT NULL); \\012UPDATE data\\012    SET samp_id = samp_id_derived_from \\012    WHERE is_derived = 'TRUE';\\012UPDATE data\\012    SET samp_id = samp_id_acquired_from \\012    WHERE is_derived = 'FALSE';\\012\\012-- add constraints and indexes to new columns\\012\\012ALTER TABLE data\\012    ALTER COLUMN is_derived SET NOT NULL;\\012ALTER TABLE data\\012    ALTER COLUMN samp_id SET NOT NULL;   \\012ALTER TABLE data\\012    ADD CONSTRAINT data_samp_fk FOREIGN KEY (samp_id) REFERENCES samples (id);\\012CREATE INDEX data_samp_fk_i ON data USING btree (samp_id);\\012\\012-- remove old columns\\012\\012ALTER TABLE data\\012    DROP COLUMN samp_id_acquired_from;\\012ALTER TABLE data\\012    DROP COLUMN samp_id_derived_from;\\012    \\012------------------------------------------------------------------------------------\\012-- Granting SELECT privilege to group openbis_readonly\\012------------------------------------------------------------------------------------\\012\\012GRANT SELECT ON SEQUENCE attachment_content_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE attachment_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE code_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE controlled_vocabulary_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE cvte_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE data_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE data_set_property_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE data_set_relationship_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE data_set_type_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE data_store_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE data_type_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE database_instance_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE dstpt_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE etpt_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE event_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE experiment_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE experiment_property_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE experiment_type_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE file_format_type_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE group_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE invalidation_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE locator_type_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE material_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE material_property_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE material_type_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE mtpt_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE perm_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE person_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE project_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE property_type_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE role_assignment_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE sample_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE sample_property_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE sample_type_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE stpt_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE attachment_contents TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE attachments TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE controlled_vocabularies TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE controlled_vocabulary_terms TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE data TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE data_set_properties TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE data_set_relationships TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE data_set_type_property_types TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE data_set_types TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE data_stores TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE data_types TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE database_instances TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE database_version_logs TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE events TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE experiment_properties TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE experiment_type_property_types TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE experiment_types TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE experiments TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE external_data TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE file_format_types TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE groups TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE invalidations TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE locator_types TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE material_properties TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE material_type_property_types TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE material_types TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE materials TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE persons TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE projects TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE property_types TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE role_assignments TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE sample_properties TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE sample_type_property_types TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE sample_types TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE samples TO GROUP OPENBIS_READONLY;\\012\\012------------------------------------------------------------------------------------\\012-- Delete MATERIAL_BATCHES table\\012------------------------------------------------------------------------------------\\012\\012-- WARNING: Potential data lost!!!\\012-- WARNING: Potential data lost!!!\\012-- WARNING: Potential data lost!!!\\012\\012DROP TABLE SAMPLE_MATERIAL_BATCHES;\\012DROP TABLE MATERIAL_BATCHES;\\012DROP SEQUENCE MATERIAL_BATCH_ID_SEQ;\\012\\012------------------------------------------------------------------------------------\\012-- Delete MATE_ID_INHIBITOR_OF from table MATERIALS\\012------------------------------------------------------------------------------------\\012\\012-- WARNING: Potential data lost!!!\\012-- WARNING: Potential data lost!!!\\012-- WARNING: Potential data lost!!!\\012\\012ALTER TABLE MATERIALS DROP COLUMN MATE_ID_INHIBITOR_OF;\\012	\N
+./sourceTest/sql/postgresql/062/.svn/text-base/017=database_version_logs.tsv.svn-base:041	source/sql/postgresql/migration/migration-040-041.sql	SUCCESS	2009-09-14 13:48:57.539	-- Create FILTERS table\\012\\012CREATE TABLE FILTERS (ID TECH_ID NOT NULL, DBIN_ID TECH_ID NOT NULL, NAME VARCHAR(200) NOT NULL, DESCRIPTION DESCRIPTION_1000,REGISTRATION_TIMESTAMP TIME_STAMP_DFL NOT NULL DEFAULT CURRENT_TIMESTAMP, PERS_ID_REGISTERER TECH_ID NOT NULL, MODIFICATION_TIMESTAMP TIME_STAMP DEFAULT CURRENT_TIMESTAMP, EXPRESSION VARCHAR(2000) NOT NULL, IS_PUBLIC BOOLEAN NOT NULL, GRID_ID VARCHAR(200) NOT NULL);\\012CREATE SEQUENCE FILTER_ID_SEQ;\\012ALTER TABLE FILTERS ADD CONSTRAINT FILT_PK PRIMARY KEY(ID);\\012ALTER TABLE FILTERS ADD CONSTRAINT FILT_BK_UK UNIQUE(NAME, DBIN_ID, GRID_ID);\\012ALTER TABLE FILTERS ADD CONSTRAINT FILT_PERS_FK FOREIGN KEY (PERS_ID_REGISTERER) REFERENCES PERSONS(ID);\\012ALTER TABLE FILTERS ADD CONSTRAINT FILT_DBIN_FK FOREIGN KEY (DBIN_ID) REFERENCES DATABASE_INSTANCES(ID);\\012CREATE INDEX FILT_PERS_FK_I ON FILTERS (PERS_ID_REGISTERER);\\012CREATE INDEX FILT_DBIN_FK_I ON FILTERS (DBIN_ID);\\012GRANT SELECT ON SEQUENCE filter_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE filters TO GROUP OPENBIS_READONLY;\\012\\012-- Add missing foreign key to role assignments authorization group\\012ALTER TABLE ROLE_ASSIGNMENTS ADD CONSTRAINT ROAS_AG_FK_GRANTEE FOREIGN KEY (AG_ID_GRANTEE) REFERENCES AUTHORIZATION_GROUPS(ID);\\012\\012--------------------------------------------------------------------------------------------------\\012-- Modify dataset connections:\\012-- 1. connection with sample shouldn't be mandatory any more\\012-- 2. introduce an arc condition that dataset cannot be connected with a sample and a parent dataset at the same time\\012--------------------------------------------------------------------------------------------------\\012\\012-- Weaken data-sample connection constraint - allow dataset to have no connection with sample\\012ALTER TABLE data ALTER COLUMN samp_id DROP NOT NULL;\\012\\012-- Remove data-sample connection for datasets that have a parent\\012\\012UPDATE data \\012   SET samp_id = NULL \\012 WHERE id IN (SELECT DISTINCT data_id_child FROM data_set_relationships);\\012\\012-- With PostgreSQL 8.4 one can check that before migration there were no cycles in dataset relationships:\\012--\\012-- WITH RECURSIVE data_set_parents(id, parent_ids, cycle) AS (\\012--         SELECT  r.data_id_child AS id, \\012--                 ARRAY[CAST (r.data_id_parent AS bigint)] AS parent_ids, \\012--                 false AS cycle \\012--         FROM data_set_relationships r\\012--     UNION ALL\\012--         SELECT  r.data_id_child,\\012--                 CAST (r.data_id_parent AS bigint) || p.parent_ids,\\012--                 r.data_id_child = ANY(p.parent_ids)\\012--         FROM data_set_relationships r, data_set_parents p\\012--         WHERE r.data_id_parent = p.id AND NOT cycle\\012-- )\\012-- SELECT count(*) AS cycles FROM data_set_parents WHERE cycle = true;\\012\\012---------------------------------------------------------------------------------------------------\\012--  Purpose:  Create DEFERRED triggers:\\012--            * check_dataset_relationships_on_data_table_modification,\\012--            * check_dataset_relationships_on_relationships_table_modification.\\012--            They check that after all modifications of database (just before commit) \\012--            if 'data'/'data_set_relationships' tables are among modified tables \\012--            dataset is not connected with a sample and a parent dataset at the same time.\\012--            This connections are held in two different tables so simple immediate trigger \\012--            with arc check cannot be used and we need two deferred triggers.\\012----------------------------------------------------------------------------------------------------\\012\\012-- trigger for 'data' table\\012\\012CREATE OR REPLACE FUNCTION check_dataset_relationships_on_data_table_modification() RETURNS trigger AS $$\\012DECLARE\\012\\011counter\\011INTEGER;\\012BEGIN\\012\\011-- if there is a connection with a Sample there should not be any connection with a parent Data Set\\012\\011IF (NEW.samp_id IS NOT NULL) THEN\\012\\011\\011-- count number of parents\\012\\011\\011SELECT count(*) INTO counter \\012\\011\\011\\011FROM data_set_relationships \\012\\011\\011\\011WHERE data_id_child = OLD.id;\\012\\011\\011IF (counter > 0) THEN\\012\\011\\011\\011RAISE EXCEPTION 'Insert/Update of Data Set (Code: %) failed because it cannot be connected with a Sample and a parent Data Set at the same time.', OLD.code;\\012\\011\\011END IF;\\012\\011END IF;\\012  RETURN NEW;\\012END;\\012$$ LANGUAGE 'plpgsql';\\012\\012CREATE CONSTRAINT TRIGGER check_dataset_relationships_on_data_table_modification \\012  AFTER INSERT OR UPDATE ON data\\012\\011DEFERRABLE INITIALLY DEFERRED\\012\\011FOR EACH ROW \\012\\011EXECUTE PROCEDURE check_dataset_relationships_on_data_table_modification();\\012\\012-- trigger for 'data_set_relationships'\\012\\012CREATE OR REPLACE FUNCTION check_dataset_relationships_on_relationships_table_modification() RETURNS trigger AS $$\\012DECLARE\\012\\011counter\\011INTEGER;\\012\\011sample_id\\011TECH_ID;\\012\\011data_code\\011CODE;\\012BEGIN\\012\\011-- child will have a parent added so it should not be connected with any sample\\012\\011SELECT samp_id, code INTO sample_id, data_code \\012\\011\\011FROM data \\012\\011\\011WHERE id = NEW.data_id_child;\\012\\011IF (sample_id IS NOT NULL) THEN\\012\\011\\011RAISE EXCEPTION 'Insert/Update of Data Set (Code: %) failed because it cannot be connected to a Sample and to a parent Data Set at the same time.', data_code;\\012\\011END IF;\\012\\011RETURN NEW;\\012END;\\012$$ LANGUAGE 'plpgsql';\\012  \\012CREATE CONSTRAINT TRIGGER check_dataset_relationships_on_relationships_table_modification \\012  AFTER INSERT OR UPDATE ON data_set_relationships\\012\\011DEFERRABLE INITIALLY DEFERRED\\012\\011FOR EACH ROW \\012\\011EXECUTE PROCEDURE check_dataset_relationships_on_relationships_table_modification();\\012	\N
+./sourceTest/sql/postgresql/062/.svn/text-base/017=database_version_logs.tsv.svn-base:053	source/sql/postgresql/migration/migration-052-053.sql	SUCCESS	2010-06-08 15:27:55.032	-- Migration from 052 to 053\\012\\012-- Change code uniqueness check for samples of specific type.\\012-- If sample_types.is_subcode_unique flag is set to 'true', additional check is performed \\012-- on codes of samples of the type. Subcodes will have to be unique as well.\\012\\012ALTER TABLE sample_types ADD COLUMN is_subcode_unique boolean_char NOT NULL DEFAULT false;\\012\\012CREATE OR REPLACE FUNCTION SAMPLE_SUBCODE_UNIQUENESS_CHECK() RETURNS trigger AS $$\\012DECLARE\\012   counter  INTEGER;\\012   unique_subcode  BOOLEAN_CHAR;\\012BEGIN\\012  LOCK TABLE samples IN EXCLUSIVE MODE;\\012  \\012  SELECT is_subcode_unique into unique_subcode FROM sample_types WHERE id = NEW.saty_id;\\012  \\012  IF (unique_subcode) THEN\\012    IF (NEW.dbin_id is not NULL) THEN\\012\\011\\011\\011SELECT count(*) into counter FROM samples \\012\\011\\011\\011\\011where id != NEW.id and code = NEW.code and saty_id = NEW.saty_id and dbin_id = NEW.dbin_id;\\012\\011\\011\\011IF (counter > 0) THEN\\012\\011\\011\\011\\011RAISE EXCEPTION 'Insert/Update of Sample (Code: %) failed because database instance sample of the same type with the same subcode already exists.', NEW.code;\\012\\011\\011\\011END IF;\\012\\011\\011ELSIF (NEW.grou_id is not NULL) THEN\\012\\011\\011\\011SELECT count(*) into counter FROM samples \\012\\011\\011\\011\\011where id != NEW.id and code = NEW.code and saty_id = NEW.saty_id and grou_id = NEW.grou_id;\\012\\011\\011\\011IF (counter > 0) THEN\\012\\011\\011\\011\\011RAISE EXCEPTION 'Insert/Update of Sample (Code: %) failed because space sample of the same type with the same subcode already exists.', NEW.code;\\012\\011\\011\\011END IF;\\012\\011\\011END IF;\\012  END IF;\\012  \\012  RETURN NEW;\\012END;\\012$$ LANGUAGE 'plpgsql';\\012\\012CREATE TRIGGER SAMPLE_SUBCODE_UNIQUENESS_CHECK BEFORE INSERT OR UPDATE ON SAMPLES\\012    FOR EACH ROW EXECUTE PROCEDURE SAMPLE_SUBCODE_UNIQUENESS_CHECK();\\012    \\012-- Fixing error messages in old trigger\\012\\012CREATE OR REPLACE FUNCTION SAMPLE_CODE_UNIQUENESS_CHECK() RETURNS trigger AS $$\\012DECLARE\\012   counter  INTEGER;\\012BEGIN\\012  LOCK TABLE samples IN EXCLUSIVE MODE;\\012  \\012\\011  IF (NEW.samp_id_part_of is NULL) THEN\\012\\011\\011  IF (NEW.dbin_id is not NULL) THEN\\012\\011\\011\\011  SELECT count(*) into counter FROM samples \\012\\011\\011      where id != NEW.id and code = NEW.code and samp_id_part_of is NULL and dbin_id = NEW.dbin_id;\\012        IF (counter > 0) THEN\\012\\011\\011\\011\\011  RAISE EXCEPTION 'Insert/Update of Sample (Code: %) failed because database instance sample with the same code already exists.', NEW.code;\\012        END IF;\\012\\011\\011  ELSIF (NEW.grou_id is not NULL) THEN\\012\\011\\011\\011  SELECT count(*) into counter FROM samples \\012\\011\\011\\011\\011  where id != NEW.id and code = NEW.code and samp_id_part_of is NULL and grou_id = NEW.grou_id;\\012\\011\\011\\011  IF (counter > 0) THEN\\012\\011\\011\\011\\011  RAISE EXCEPTION 'Insert/Update of Sample (Code: %) failed because space sample with the same code already exists.', NEW.code;\\012\\011\\011\\011  END IF;\\012      END IF;\\012    ELSE\\012\\011\\011  IF (NEW.dbin_id is not NULL) THEN\\012\\011\\011\\011  SELECT count(*) into counter FROM samples \\012\\011\\011\\011\\011  where id != NEW.id and code = NEW.code and samp_id_part_of = NEW.samp_id_part_of and dbin_id = NEW.dbin_id;\\012\\011\\011\\011  IF (counter > 0) THEN\\012\\011\\011\\011\\011  RAISE EXCEPTION 'Insert/Update of Sample (Code: %) failed because database instance sample with the same code and being the part of the same container already exists.', NEW.code;\\012\\011\\011\\011  END IF;\\012\\011\\011  ELSIF (NEW.grou_id is not NULL) THEN\\012\\011\\011\\011  SELECT count(*) into counter FROM samples \\012\\011\\011\\011\\011  where id != NEW.id and code = NEW.code and samp_id_part_of = NEW.samp_id_part_of and grou_id = NEW.grou_id;\\012\\011\\011\\011  IF (counter > 0) THEN\\012\\011\\011\\011\\011  RAISE EXCEPTION 'Insert/Update of Sample (Code: %) failed because space sample with the same code and being the part of the same container already exists.', NEW.code;\\012\\011\\011\\011  END IF;\\012\\011\\011  END IF;\\012     END IF;   \\012  \\012  RETURN NEW;\\012END;\\012$$ LANGUAGE 'plpgsql';\\012	\N
+./sourceTest/sql/postgresql/062/.svn/text-base/017=database_version_logs.tsv.svn-base:054	source/sql/postgresql/migration/migration-053-054.sql	SUCCESS	2010-07-27 11:30:46.766	-- Migration from 053 to 054\\012\\012\\012-- Add RELATIONSHIP_TYPES table\\012CREATE TABLE relationship_types (id TECH_ID NOT NULL, code CODE NOT NULL, label COLUMN_LABEL, parent_label COLUMN_LABEL, child_label COLUMN_LABEL, description DESCRIPTION_2000, registration_timestamp TIME_STAMP_DFL NOT NULL DEFAULT CURRENT_TIMESTAMP, pers_id_registerer TECH_ID NOT NULL, is_managed_internally BOOLEAN_CHAR NOT NULL DEFAULT 'F', is_internal_namespace BOOLEAN_CHAR NOT NULL DEFAULT 'F', dbin_id TECH_ID NOT NULL);\\012\\012-- Add SAMPLE_RELATIONSHIPS table\\012CREATE TABLE sample_relationships (id TECH_ID NOT NULL, sample_id_parent TECH_ID NOT NULL, relationship_id TECH_ID NOT NULL, sample_id_child TECH_ID NOT NULL);\\012\\012-- Add/update constraints\\012ALTER TABLE relationship_types ADD CONSTRAINT rety_pk PRIMARY KEY (id);\\012ALTER TABLE relationship_types ADD CONSTRAINT rety_uk UNIQUE(code,dbin_id);\\012ALTER TABLE sample_relationships ADD CONSTRAINT sare_pk PRIMARY KEY (id);\\012ALTER TABLE sample_relationships ADD CONSTRAINT sare_bk_uk UNIQUE(sample_id_child,sample_id_parent,relationship_id);\\012ALTER TABLE sample_relationships ADD CONSTRAINT sare_data_fk_child FOREIGN KEY (sample_id_child) REFERENCES samples(id) ON DELETE CASCADE;\\012ALTER TABLE sample_relationships ADD CONSTRAINT sare_data_fk_parent FOREIGN KEY (sample_id_parent) REFERENCES samples(id) ON DELETE CASCADE;\\012ALTER TABLE sample_relationships ADD CONSTRAINT sare_data_fk_relationship FOREIGN KEY (relationship_id) REFERENCES relationship_types(id);\\012\\012-- Create index\\012CREATE INDEX sare_data_fk_i_child ON sample_relationships (sample_id_child);\\012CREATE INDEX sare_data_fk_i_parent ON sample_relationships (sample_id_parent);\\012CREATE INDEX sare_data_fk_i_relationship ON sample_relationships (relationship_id);\\012\\012-- Create sequence for RELATIONSHIP_TYPES\\012CREATE SEQUENCE RELATIONSHIP_TYPE_ID_SEQ;\\012CREATE SEQUENCE SAMPLE_RELATIONSHIP_ID_SEQ;\\012\\012-- Create initial relationships\\012insert into relationship_types\\012(id, \\012code, \\012label, \\012parent_label, \\012child_label, \\012description, \\012pers_id_registerer, \\012is_managed_internally, \\012is_internal_namespace, \\012dbin_id) \\012values\\012(\\012nextval('RELATIONSHIP_TYPE_ID_SEQ'),\\012'PARENT_CHILD',\\012'Parent - Child', \\012'Parent', \\012'Child', \\012'Parent - Child relationship', \\012(select id from persons where user_id ='system'), \\012'T', \\012'T', \\012(select id from database_instances where is_original_source = 'T')\\012);\\012\\012insert into relationship_types\\012(id, \\012code, \\012label, \\012parent_label, \\012child_label, \\012description, \\012pers_id_registerer, \\012is_managed_internally, \\012is_internal_namespace, \\012dbin_id) \\012values\\012(\\012nextval('RELATIONSHIP_TYPE_ID_SEQ'),\\012'PLATE_CONTROL_LAYOUT',\\012'Plate - Control Layout', \\012'Plate', \\012'Control Layout', \\012'Plate - Control Layout relationship', \\012(select id from persons where user_id ='system'), \\012'T', \\012'T', \\012(select id from database_instances where is_original_source = 'T')\\012); \\012\\012\\012-- Migrate sample relationships to new schema\\012INSERT INTO sample_relationships (id, sample_id_parent,sample_id_child,relationship_id) (select distinct nextval('SAMPLE_RELATIONSHIP_ID_SEQ') as id, s.SAMP_ID_GENERATED_FROM as parent_id, s.ID as child_id, rt.id as relationship_id from samples s, relationship_types rt  WHERE rt.code = 'PARENT_CHILD' and s.SAMP_ID_GENERATED_FROM is not null); \\012INSERT INTO sample_relationships (id, sample_id_parent,sample_id_child,relationship_id) (select distinct nextval('SAMPLE_RELATIONSHIP_ID_SEQ') as id, s.SAMP_ID_CONTROL_LAYOUT as parent_id, s.ID as child_id, rt.id as relationship_id from samples s, relationship_types rt  WHERE rt.code = 'PLATE_CONTROL_LAYOUT' and s.SAMP_ID_CONTROL_LAYOUT is not null);\\012\\012-- Drop old sample relations\\012ALTER TABLE SAMPLES DROP COLUMN SAMP_ID_TOP;\\012ALTER TABLE SAMPLES DROP COLUMN SAMP_ID_GENERATED_FROM;\\012ALTER TABLE SAMPLES DROP COLUMN SAMP_ID_CONTROL_LAYOUT;\\012\\012--------------------------------------------------------------------------------------\\012--------------------------------------------------------------------------------------\\012-- This is a screening specific migration. Nothing will be performed on openBIS databases \\012-- which are not screening specific.\\012-- \\012-- This migration for each existing connection between oligo well, oligo material and gene material\\012-- creates a direct connection between the well and the gene. \\012--------------------------------------------------------------------------------------\\012--------------------------------------------------------------------------------------\\012 \\012\\011\\012CREATE OR REPLACE FUNCTION CONNECT_WELLS_WITH_GENES() RETURNS void AS $$\\012DECLARE\\012\\011counter  int;\\012\\011oligo_well_exists bool;\\012BEGIN\\012\\011--------------------------------------------------\\012\\011-- create a gene property and assign it to oligo well\\012\\011--------------------------------------------------\\012\\011\\012\\011select true \\012\\011into oligo_well_exists\\012\\011from sample_types \\012\\011where code = 'OLIGO_WELL';\\012\\011\\012\\011if oligo_well_exists IS NULL then \\012\\011\\011-- skip migration if there are no oligo wells\\012\\011\\011return;\\012\\011end if;   \\012\\011\\012\\011insert into property_types(\\012\\011\\011id, \\012\\011\\011code, description, label, \\012\\011\\011daty_id,\\012\\011\\011pers_id_registerer,\\012\\011\\011dbin_id,\\012\\011\\011maty_prop_id) \\012\\011values(\\012\\011\\011\\011nextval('PROPERTY_TYPE_ID_SEQ'), \\012\\011\\011\\011'GENE','Inhibited gene','Gene',\\012\\011\\011\\011(select id from data_types where code = 'MATERIAL'), \\012\\011\\011\\011(select id from persons where user_id ='system'), \\012\\011\\011\\011(select id from database_instances where is_original_source = 'T'), \\012\\011\\011\\011(select id from material_types where code = 'GENE')\\012\\011\\011);\\012\\011\\011\\012\\011insert into sample_type_property_types( \\012\\011  id,\\012\\011  saty_id,\\012\\011  prty_id,\\012\\011  is_mandatory,\\012\\011  pers_id_registerer,\\012\\011  ordinal\\012\\011) values(\\012\\011\\011\\011nextval('stpt_id_seq'), \\012\\011\\011\\011(select id from sample_types where code = 'OLIGO_WELL'),\\012\\011\\011\\011(select id from property_types where code = 'GENE'),\\012\\011\\011\\011false,\\012\\011\\011\\011(select id from persons where user_id ='system'),\\012\\011\\011\\011(select max(ordinal)+1 from sample_type_property_types \\012\\011\\011\\011\\011where saty_id = (select id from sample_types where code = 'OLIGO_WELL'))\\012\\011\\011);\\012\\012\\011--------------------------------------------------\\012\\011-- create a gene material property for each oligo well\\012\\011--------------------------------------------------\\012\\011\\011\\012\\011select \\011count(*)\\012\\011into counter\\012\\011from\\012\\011\\011samples well, sample_types well_type, sample_properties well_props, \\012\\011\\011materials well_material, material_properties well_material_props,\\012\\011\\011materials nested_well_material\\012\\011where\\012\\011\\011well_type.code = 'OLIGO_WELL' and\\012\\011\\011-- find 'well_material' assigned to the well\\012\\011\\011well_props.samp_id = well.id and well_material.id = well_props.mate_prop_id and \\012\\011\\011-- additional joins to entity type tables\\012\\011\\011well_type.id = well.saty_id and\\012\\011\\011-- well content material property\\012\\011\\011well_material_props.mate_id = well_material.id and \\012\\011\\011-- material connected to the material in the well (e.g. gene)\\012\\011\\011well_material_props.mate_prop_id = nested_well_material.id and\\012\\011\\011nested_well_material.maty_id = (select id from material_types where code = 'GENE');\\012\\011\\012\\011if counter = 0 then \\012\\011\\011-- skip migration if there are no genes indirectly connected to oligo wells\\012\\011\\011return;\\012\\011end if;   \\012\\012\\011insert into sample_properties(id, samp_id, stpt_id, mate_prop_id, pers_id_registerer) (\\012\\011\\011select \\011nextval('sample_property_id_seq') id, \\012\\011\\011\\011well.id samp_id, \\012\\011\\011\\011(select stpt.id from sample_type_property_types stpt, property_types props where stpt.prty_id = props.id and props.code='GENE') stpt_id,\\012\\011\\011\\011nested_well_material.id mate_prop_id,\\012\\011\\011\\011(select id from persons where user_id ='system') pers_id_registerer \\012\\011\\011from\\012\\011\\011\\011samples well, sample_types well_type, sample_properties well_props, \\012\\011\\011\\011materials well_material, material_properties well_material_props,\\012\\011\\011\\011materials nested_well_material\\012\\011\\011where\\012\\011\\011\\011well_type.code = 'OLIGO_WELL' and\\012\\011\\011\\011-- find 'well_material' assigned to the well\\012\\011\\011\\011well_props.samp_id = well.id and well_material.id = well_props.mate_prop_id and \\012\\011\\011\\011-- additional joins to entity type tables\\012\\011\\011\\011well_type.id = well.saty_id and\\012\\011\\011\\011-- well content material property\\012\\011\\011\\011well_material_props.mate_id = well_material.id and \\012\\011\\011\\011-- material connected to the material in the well (e.g. gene)\\012\\011\\011\\011well_material_props.mate_prop_id = nested_well_material.id and\\012\\011\\011\\011nested_well_material.maty_id = (select id from material_types where code = 'GENE')\\012\\011);\\012\\012END;\\012$$ LANGUAGE 'plpgsql';\\012\\012select CONNECT_WELLS_WITH_GENES();\\012drop function CONNECT_WELLS_WITH_GENES();\\012\\012--------------------------------------------------------------------------------------\\012--------------------------------------------------------------------------------------\\012\\012-- drop dataset triggers\\012\\012DROP TRIGGER check_dataset_relationships_on_data_table_modification ON data;\\012DROP FUNCTION check_dataset_relationships_on_data_table_modification();\\012DROP TRIGGER check_dataset_relationships_on_relationships_table_modification ON data_set_relationships;\\012DROP FUNCTION check_dataset_relationships_on_relationships_table_modification();\\012 \\012\\012\\012\\012\\012\\012\\012\\012	\N
+./sourceTest/sql/postgresql/062/.svn/text-base/017=database_version_logs.tsv.svn-base:056	source/sql/postgresql/migration/migration-055-056.sql	SUCCESS	2010-09-10 09:06:20.278	-- Migration from 055 to 056\\012\\012--------------------------------------------------------------------------------------\\012--------------------------------------------------------------------------------------\\012-- Screening specific migration. Nothing will be performed on openBIS databases \\012-- which are not screening specific.\\012--------------------------------------------------------------------------------------\\012--------------------------------------------------------------------------------------\\012\\012CREATE OR REPLACE FUNCTION merge_words(text, text) RETURNS text AS $$\\012DECLARE\\012  BEGIN\\012    IF  character_length($1) > 0 THEN\\012      RETURN $1 || ' ' || $2;\\012    ELSE\\012      RETURN $2;\\012    END IF;\\012  END;\\012$$ LANGUAGE plpgsql;\\012\\012CREATE AGGREGATE merge_words(text)\\012(\\012  SFUNC = merge_words,\\012  STYPE = text\\012);\\012\\012\\012CREATE OR REPLACE FUNCTION REPLACE_GENE_SYMBOL_BY_GENE_ID() RETURNS void AS $$\\012DECLARE\\012\\011counter  int;\\012\\011library_id_assigned_to_gene bool;\\012BEGIN\\012\\011--------------------------------------------------\\012\\011-- create a GENE_SYMBOL property and assign it to GENE\\012\\011--------------------------------------------------\\012\\011\\012\\011select true  \\012\\011into library_id_assigned_to_gene \\012\\011from material_type_property_types mtpt, material_types mt, property_types pt  \\012\\011where mtpt.maty_id = mt.id and mtpt.prty_id = pt.id \\012\\011\\011and mt.code = 'GENE' and pt.code = 'LIBRARY_ID';\\012\\011\\012\\011if library_id_assigned_to_gene IS NULL then \\012\\011\\011-- skip migration if gene has no library_id property\\012\\011\\011return;\\012\\011end if; \\012\\011\\012\\011\\012\\011select count(*)\\012\\011into counter \\012\\011from  \\012\\011\\011(select m.id, count(mp.id) as c \\012\\011\\011\\011from materials m, material_types mt, material_properties mp, material_type_property_types mtpt, property_types pt \\012\\011\\011\\011where m.maty_id = mt.id and mp.mate_id = m.id and mp.mtpt_id = mtpt.id and mtpt.maty_id = mt.id and pt.id = mtpt.prty_id\\012\\011\\011\\011\\011and mt.code = 'GENE' and pt.code = 'LIBRARY_ID' \\012\\011\\011\\011group by m.id) as counter_table \\012\\011where c < 1; \\012\\011\\012\\011if counter > 0 then \\012\\011\\011-- skip migration if there is at least one gene without library_id\\012\\011\\011return;\\012\\011end if;\\012\\011\\012\\011\\012\\011insert into property_types\\012\\011\\011(id\\012\\011\\011,code\\012\\011\\011,description\\012\\011\\011,label\\012\\011\\011,daty_id\\012\\011\\011,pers_id_registerer\\012\\011\\011,dbin_id)\\012\\011values \\012\\011\\011(nextval('PROPERTY_TYPE_ID_SEQ')\\012\\011\\011,'GENE_SYMBOLS'\\012\\011\\011,'Gene symbols'\\012\\011\\011,'Gene symbols'\\012\\011\\011,(select id from data_types where code ='VARCHAR')\\012\\011\\011,(select id from persons where user_id ='system')\\012\\011\\011,(select id from database_instances where is_original_source = 'T')\\012\\011);\\012\\011\\011\\012\\011insert into material_type_property_types( \\012\\011  id,\\012\\011  maty_id,\\012\\011  prty_id,\\012\\011  is_mandatory,\\012\\011  pers_id_registerer,\\012\\011  ordinal\\012\\011) values(\\012\\011\\011\\011nextval('mtpt_id_seq'), \\012\\011\\011\\011(select id from material_types where code = 'GENE'),\\012\\011\\011\\011(select id from property_types where code = 'GENE_SYMBOLS'),\\012\\011\\011\\011false,\\012\\011\\011\\011(select id from persons where user_id ='system'),\\012\\011\\011\\011(select max(ordinal)+1 from material_type_property_types \\012\\011\\011\\011\\011where maty_id = (select id from material_types where code = 'GENE'))\\012\\011\\011);\\012\\012\\011--------------------------------------------------\\012\\011-- create temporary table with all gene migration information\\012\\011--------------------------------------------------\\012\\012\\011create temp table genes \\012\\011(\\012\\011\\011id tech_id,\\012\\011\\011code code,\\012\\011\\011library_id generic_value,\\012\\011\\011gene_codes generic_value,\\012\\011\\011new_id tech_id,\\012\\011\\011library_tech_id tech_id\\011\\011\\012\\011);\\012\\011\\012\\011insert into genes (id, code, library_id, library_tech_id)\\012\\011\\011(select m.id, m.code, mp.value as library_id, mp.id as library_tech_id from materials m, material_properties mp, material_type_property_types mtpt, property_types pt, material_types mt\\012\\011\\011where mp.mate_id = m.id and  mp.mtpt_id = mtpt.id and pt.id = mtpt.prty_id and pt.code = 'LIBRARY_ID' and mt.id = m.maty_id and mt.id = mtpt.maty_id and mt.code = 'GENE');\\012\\011\\012\\011update genes set new_id = map.to_id from (select g_from.id as from_id, min(g_to.id) as to_id  from genes g_from, genes g_to where g_from.library_id = g_to.library_id group by g_from.id) as map where map.from_id = id;\\011\\012\\011\\012\\011update genes set gene_codes = map.gene_codes from (select g_from.library_id as lib_id, merge_words(distinct g_to.code) as gene_codes from genes g_from, genes g_to where g_from.library_id = g_to.library_id group by g_from.library_id) as map where map.lib_id = library_id;\\011\\012\\012\\011--------------------------------------------------\\012\\011-- update gene references\\012\\011--------------------------------------------------\\012\\012\\011update EXPERIMENTS set MATE_ID_STUDY_OBJECT = genes.new_id from genes where genes.id = MATE_ID_STUDY_OBJECT and not genes.id = genes.new_id;\\012\\011update EXPERIMENT_PROPERTIES set  MATE_PROP_ID = genes.new_id from genes where genes.id = MATE_PROP_ID and not genes.id = genes.new_id;\\012\\011update MATERIAL_PROPERTIES set  MATE_PROP_ID = genes.new_id from genes where genes.id = MATE_PROP_ID and not genes.id = genes.new_id;\\012\\011update SAMPLE_PROPERTIES set  MATE_PROP_ID = genes.new_id from genes where genes.id = MATE_PROP_ID and not genes.id = genes.new_id;\\012\\011update DATA_SET_PROPERTIES set  MATE_PROP_ID = genes.new_id from genes where genes.id = MATE_PROP_ID and not genes.id = genes.new_id;\\012\\011\\012\\011delete from  material_properties where mate_id in (select id from genes where not genes.id = genes.new_id);\\012\\011delete from MATERIALS where id in (select id from genes where not genes.id = genes.new_id);\\012\\012\\011delete from genes where id in (select id from genes where not genes.id = genes.new_id);\\012\\012\\012\\011--------------------------------------------------\\012\\011-- replace gene code with library_id\\012\\011--------------------------------------------------\\012\\011\\012\\011update materials set code = genes.library_id from genes where materials.id = genes.id ;\\012\\011delete from material_properties where id in (select library_tech_id from genes);\\012\\011\\012\\011--------------------------------------------------\\012\\011-- create a gene symbols property for each gene\\012\\011--------------------------------------------------\\012\\011\\012\\011insert into material_properties\\012\\011\\011(id\\012\\011  , mate_id\\012\\011  , mtpt_id\\012\\011  , "value"\\012\\011  , pers_id_registerer)\\012\\011\\011(select nextval('material_property_id_seq') id\\012\\011  \\011, genes.id  mate_id\\012\\011    , (select mtpt.id\\012\\011    \\011\\011from   material_type_property_types mtpt, material_types mt, property_types pt\\012\\011    \\011\\011where  pt.code = 'GENE_SYMBOLS' and mt.code = 'GENE' and mtpt.prty_id = pt.id\\012\\011        \\011and mtpt.maty_id = mt.id) mtpt_id\\012\\011    , genes.gene_codes "value"\\012\\011    , (select id from persons where user_id = 'system') pers_id_registerer\\012\\011 \\011from genes); \\012\\012\\011--------------------------------------------------\\012\\011-- delete temporary table\\012\\011--------------------------------------------------\\012\\011\\012\\011drop table genes;\\012\\011\\012END;\\012$$ LANGUAGE 'plpgsql';\\012\\012select REPLACE_GENE_SYMBOL_BY_GENE_ID();\\012drop function REPLACE_GENE_SYMBOL_BY_GENE_ID();\\012DROP AGGREGATE merge_words(text);\\012drop function merge_words(text,text);\\012\\012\\012--------------------------------------------------------------------------------------\\012--------------------------------------------------------------------------------------\\012\\012UPDATE sample_types SET code = 'SIRNA_WELL' WHERE code = 'OLIGO_WELL';\\012UPDATE material_types SET code = 'SIRNA' WHERE code = 'OLIGO';\\012UPDATE property_types SET code = 'SIRNA', label = 'siRNA' WHERE code = 'OLIGO';\\012\\012\\012\\012\\012\\012\\012\\012\\012\\012\\012\\012\\012\\012\\012\\012\\012\\012\\012\\012	\N
+./sourceTest/sql/postgresql/062/.svn/text-base/017=database_version_logs.tsv.svn-base:059	source/sql/postgresql/migration/migration-058-059.sql	SUCCESS	2010-09-29 13:37:07.231	-- Migration from 058 to 059\\012\\012-- Add ENTITY_TYPE_CODE column to QUERIES\\012ALTER TABLE queries ADD COLUMN entity_type_code CODE;\\012\\012------------------------------------------------------------------------------------\\012--  Purpose:  Create trigger that checks if entity_type_code specified in a query\\012--            matches a code of an entity of type specified in query_type.\\012------------------------------------------------------------------------------------\\012\\012CREATE OR REPLACE FUNCTION query_entity_type_code_check() RETURNS trigger AS $$\\012DECLARE\\012   counter  INTEGER;\\012BEGIN\\012   if (NEW.entity_type_code IS NOT NULL) then\\012     if (NEW.query_type = 'GENERIC') then\\012       RAISE EXCEPTION 'Insert/Update of query (Name: %) failed, as entity_type has to be null for GENERIC queries.', NEW.name;\\012     elsif (NEW.query_type = 'EXPERIMENT') then\\012       SELECT count(*) INTO counter FROM experiment_types WHERE code = NEW.entity_type_code;\\012\\011\\011 elsif (NEW.query_type = 'DATA_SET') then\\012       SELECT count(*) INTO counter FROM data_set_types WHERE code = NEW.entity_type_code;\\012\\011\\011 elsif (NEW.query_type = 'MATERIAL') then\\012       SELECT count(*) INTO counter FROM material_types WHERE code = NEW.entity_type_code;\\012\\011\\011 elsif (NEW.query_type = 'SAMPLE') then\\012       SELECT count(*) INTO counter FROM sample_types WHERE code = NEW.entity_type_code;\\012\\011\\011 end if;\\012\\011\\011 if (counter = 0) then\\012\\011\\011\\011 RAISE EXCEPTION 'Insert/Update of query (Name: %) failed because % type (Code: %) does not exist.', NEW.name, NEW.query_type, NEW.entity_type_code;\\012\\011\\011 end if;\\011\\011\\011\\012   end if;\\012   RETURN NEW;\\012END;\\012$$ LANGUAGE 'plpgsql';\\012\\012CREATE TRIGGER query_entity_type_code_check BEFORE INSERT OR UPDATE ON queries\\012    FOR EACH ROW EXECUTE PROCEDURE query_entity_type_code_check();\\012	\N
+./sourceTest/sql/postgresql/062/.svn/text-base/017=database_version_logs.tsv.svn-base:062	source/sql/postgresql/migration/migration-061-062.sql	SUCCESS	2010-11-25 16:02:07.224	\\012CREATE OR REPLACE FUNCTION sample_code_uniqueness_check() RETURNS trigger\\012    LANGUAGE plpgsql\\012    AS $$\\012DECLARE\\012   counter  INTEGER;\\012BEGIN\\012  LOCK TABLE samples IN EXCLUSIVE MODE;\\012  \\012\\011  IF (NEW.samp_id_part_of is NULL) THEN\\012\\011\\011  IF (NEW.dbin_id is not NULL) THEN\\012\\011\\011\\011  SELECT count(*) into counter FROM samples \\012\\011\\011      where id != NEW.id and code = NEW.code and samp_id_part_of is NULL and dbin_id = NEW.dbin_id;\\012        IF (counter > 0) THEN\\012\\011\\011\\011\\011  RAISE EXCEPTION 'Insert/Update of Sample (Code: %) failed because database instance sample with the same code already exists.', NEW.code;\\012        END IF;\\012\\011\\011  ELSIF (NEW.space_id is not NULL) THEN\\012\\011\\011\\011  SELECT count(*) into counter FROM samples \\012\\011\\011\\011\\011  where id != NEW.id and code = NEW.code and samp_id_part_of is NULL and space_id = NEW.grou_id;\\012\\011\\011\\011  IF (counter > 0) THEN\\012\\011\\011\\011\\011  RAISE EXCEPTION 'Insert/Update of Sample (Code: %) failed because space sample with the same code already exists.', NEW.code;\\012\\011\\011\\011  END IF;\\012      END IF;\\012    ELSE\\012\\011\\011  IF (NEW.dbin_id is not NULL) THEN\\012\\011\\011\\011  SELECT count(*) into counter FROM samples \\012\\011\\011\\011\\011  where id != NEW.id and code = NEW.code and samp_id_part_of = NEW.samp_id_part_of and dbin_id = NEW.dbin_id;\\012\\011\\011\\011  IF (counter > 0) THEN\\012\\011\\011\\011\\011  RAISE EXCEPTION 'Insert/Update of Sample (Code: %) failed because database instance sample with the same code and being the part of the same container already exists.', NEW.code;\\012\\011\\011\\011  END IF;\\012\\011\\011  ELSIF (NEW.space_id is not NULL) THEN\\012\\011\\011\\011  SELECT count(*) into counter FROM samples \\012\\011\\011\\011\\011  where id != NEW.id and code = NEW.code and samp_id_part_of = NEW.samp_id_part_of and space_id = NEW.space_id;\\012\\011\\011\\011  IF (counter > 0) THEN\\012\\011\\011\\011\\011  RAISE EXCEPTION 'Insert/Update of Sample (Code: %) failed because space sample with the same code and being the part of the same container already exists.', NEW.code;\\012\\011\\011\\011  END IF;\\012\\011\\011  END IF;\\012     END IF;   \\012  \\012  RETURN NEW;\\012END;\\012$$;\\012\\012\\012CREATE OR REPLACE FUNCTION sample_subcode_uniqueness_check() RETURNS trigger\\012    LANGUAGE plpgsql\\012    AS $$\\012DECLARE\\012   counter  INTEGER;\\012   unique_subcode  BOOLEAN_CHAR;\\012BEGIN\\012  LOCK TABLE samples IN EXCLUSIVE MODE;\\012  \\012  SELECT is_subcode_unique into unique_subcode FROM sample_types WHERE id = NEW.saty_id;\\012  \\012  IF (unique_subcode) THEN\\012    IF (NEW.dbin_id is not NULL) THEN\\012\\011\\011\\011SELECT count(*) into counter FROM samples \\012\\011\\011\\011\\011where id != NEW.id and code = NEW.code and saty_id = NEW.saty_id and dbin_id = NEW.dbin_id;\\012\\011\\011\\011IF (counter > 0) THEN\\012\\011\\011\\011\\011RAISE EXCEPTION 'Insert/Update of Sample (Code: %) failed because database instance sample of the same type with the same subcode already exists.', NEW.code;\\012\\011\\011\\011END IF;\\012\\011\\011ELSIF (NEW.space_id is not NULL) THEN\\012\\011\\011\\011SELECT count(*) into counter FROM samples \\012\\011\\011\\011\\011where id != NEW.id and code = NEW.code and saty_id = NEW.saty_id and space_id = NEW.space_id;\\012\\011\\011\\011IF (counter > 0) THEN\\012\\011\\011\\011\\011RAISE EXCEPTION 'Insert/Update of Sample (Code: %) failed because space sample of the same type with the same subcode already exists.', NEW.code;\\012\\011\\011\\011END IF;\\012\\011\\011END IF;\\012  END IF;\\012  \\012  RETURN NEW;\\012END;\\012$$;\\012\\012ALTER TABLE groups RENAME TO spaces;\\012\\012ALTER SEQUENCE group_id_seq RENAME TO space_id_seq;\\012\\012ALTER TABLE persons\\011RENAME grou_id TO space_id;\\012ALTER TABLE projects RENAME grou_id TO space_id;\\012ALTER TABLE role_assignments RENAME grou_id TO space_id;\\012ALTER TABLE samples\\011RENAME grou_id TO space_id;\\012\\012-- migrate EVENTS table\\012\\012ALTER TABLE events\\012\\011DROP CONSTRAINT evnt_et_enum_ck;\\012\\012update events set entity_type = 'SPACE' where entity_type = 'GROUP';\\012\\012ALTER TABLE events ADD CONSTRAINT evnt_et_enum_ck CHECK \\012\\011(entity_type IN ('ATTACHMENT', 'DATASET', 'EXPERIMENT', 'SPACE', 'MATERIAL', 'PROJECT', 'PROPERTY_TYPE', 'SAMPLE', 'VOCABULARY', 'AUTHORIZATION_GROUP')); \\012\\012ALTER TABLE persons\\012\\011DROP CONSTRAINT pers_grou_fk;\\012\\012ALTER TABLE persons\\012\\011ADD CONSTRAINT pers_space_fk FOREIGN KEY (space_id) REFERENCES spaces(id);\\012\\012ALTER TABLE projects\\012\\011DROP CONSTRAINT proj_bk_uk;\\012\\012ALTER TABLE projects\\012\\011DROP CONSTRAINT proj_grou_fk;\\012\\012ALTER TABLE projects\\012\\011ADD CONSTRAINT proj_bk_uk UNIQUE (code, space_id);\\012\\012ALTER TABLE projects\\012\\011ADD CONSTRAINT proj_space_fk FOREIGN KEY (space_id) REFERENCES spaces(id);\\012\\012ALTER TABLE role_assignments\\012\\011DROP CONSTRAINT roas_dbin_grou_arc_ck;\\012\\012ALTER TABLE role_assignments\\012\\011DROP CONSTRAINT roas_ag_group_bk_uk;\\012\\012ALTER TABLE role_assignments\\012\\011DROP CONSTRAINT roas_pe_group_bk_uk;\\012\\012ALTER TABLE role_assignments\\012\\011DROP CONSTRAINT roas_grou_fk;\\012\\012ALTER TABLE role_assignments\\012\\011ADD CONSTRAINT roas_dbin_space_arc_ck CHECK ((((dbin_id IS NOT NULL) AND (space_id IS NULL)) OR ((dbin_id IS NULL) AND (space_id IS NOT NULL))));\\012\\012ALTER TABLE role_assignments\\012\\011ADD CONSTRAINT roas_ag_space_bk_uk UNIQUE (ag_id_grantee, role_code, space_id);\\012\\012ALTER TABLE role_assignments\\012\\011ADD CONSTRAINT roas_pe_space_bk_uk UNIQUE (pers_id_grantee, role_code, space_id);\\012\\012ALTER TABLE role_assignments\\012\\011ADD CONSTRAINT roas_space_fk FOREIGN KEY (space_id) REFERENCES spaces(id);\\012\\012ALTER TABLE samples\\012\\011DROP CONSTRAINT samp_dbin_grou_arc_ck;\\012\\012ALTER TABLE samples\\012\\011DROP CONSTRAINT samp_grou_fk;\\012\\012ALTER TABLE samples\\012\\011ADD CONSTRAINT samp_dbin_space_arc_ck CHECK ((((dbin_id IS NOT NULL) AND (space_id IS NULL)) OR ((dbin_id IS NULL) AND (space_id IS NOT NULL))));\\012\\012ALTER TABLE samples\\012\\011ADD CONSTRAINT samp_space_fk FOREIGN KEY (space_id) REFERENCES spaces(id);\\012\\012ALTER TABLE spaces\\012  DROP CONSTRAINT grou_bk_uk,\\012  ADD CONSTRAINT space_bk_uk UNIQUE (code, dbin_id);\\012\\012ALTER TABLE spaces\\012  DROP CONSTRAINT grou_dbin_fk,\\012  ADD CONSTRAINT space_dbin_fk FOREIGN KEY (dbin_id) REFERENCES database_instances(id);\\012\\012ALTER TABLE spaces\\012  DROP CONSTRAINT grou_pers_fk_registerer,\\012  ADD CONSTRAINT space_pers_fk_registerer FOREIGN KEY (pers_id_registerer) REFERENCES persons(id);\\012\\012ALTER INDEX pers_grou_fk_i RENAME TO pers_space_fk_i;\\012\\012ALTER INDEX proj_grou_fk_i RENAME TO proj_space_fk_i;\\012\\012ALTER INDEX roas_grou_fk_i RENAME TO roas_space_fk_i;\\012\\012ALTER INDEX grou_pk RENAME TO space_pk;\\012\\012ALTER INDEX grou_dbin_fk_i RENAME TO space_dbin_fk_i;\\012\\012ALTER INDEX grou_pers_registered_by_fk_i RENAME TO space_pers_registered_by_fk_i;\\012\\012	\N
+./sourceTest/sql/postgresql/062/.svn/text-base/schema-062.sql.svn-base:    LANGUAGE plpgsql
+./sourceTest/sql/postgresql/062/.svn/text-base/schema-062.sql.svn-base:    LANGUAGE plpgsql
+./sourceTest/sql/postgresql/062/.svn/text-base/schema-062.sql.svn-base:    LANGUAGE plpgsql
+./sourceTest/sql/postgresql/062/.svn/text-base/schema-062.sql.svn-base:    LANGUAGE plpgsql
+./sourceTest/sql/postgresql/062/.svn/text-base/schema-062.sql.svn-base:    LANGUAGE plpgsql
+./sourceTest/sql/postgresql/062/.svn/text-base/schema-062.sql.svn-base:    LANGUAGE plpgsql
+./sourceTest/sql/postgresql/062/.svn/text-base/schema-062.sql.svn-base:    LANGUAGE plpgsql
+./sourceTest/sql/postgresql/062/.svn/text-base/schema-062.sql.svn-base:    LANGUAGE plpgsql
+./sourceTest/sql/postgresql/062/.svn/text-base/schema-062.sql.svn-base:    LANGUAGE plpgsql
+./sourceTest/sql/postgresql/062/017=database_version_logs.tsv:027	D:\\User\\felmer\\dev-workspace\\openbis/source/sql/postgresql/027/function-027.sql	SUCCESS	2008-11-05 09:18:00.403	-- Creating Functions\\012\\012------------------------------------------------------------------------------------\\012--  Purpose:  Create function RENAME_SEQUENCE() that is required for renaming the sequences belonging to tables\\012------------------------------------------------------------------------------------\\012CREATE FUNCTION RENAME_SEQUENCE(OLD_NAME VARCHAR, NEW_NAME VARCHAR) RETURNS INTEGER AS $$\\012DECLARE\\012  CURR_SEQ_VAL   INTEGER;\\012BEGIN\\012  SELECT INTO CURR_SEQ_VAL NEXTVAL(OLD_NAME);\\012  EXECUTE 'CREATE SEQUENCE ' || NEW_NAME || ' START WITH ' || CURR_SEQ_VAL;\\012  EXECUTE 'DROP SEQUENCE ' || OLD_NAME;\\012  RETURN CURR_SEQ_VAL;\\012END;\\012$$ LANGUAGE 'plpgsql';\\012\\012\\012------------------------------------------------------------------------------------\\012--  Purpose:  Create trigger CONTROLLED_VOCABULARY_CHECK \\012------------------------------------------------------------------------------------\\012\\012CREATE OR REPLACE FUNCTION CONTROLLED_VOCABULARY_CHECK() RETURNS trigger AS $$\\012DECLARE\\012   v_code  CODE;\\012BEGIN\\012\\012   select code into v_code from data_types where id = NEW.daty_id;\\012\\012   -- Check if the data is of type "CONTROLLEDVOCABULARY"\\012   if v_code = 'CONTROLLEDVOCABULARY' then\\012      if NEW.covo_id IS NULL then\\012         RAISE EXCEPTION 'Insert/Update of Property Type (Code: %) failed, as its Data Type is CONTROLLEDVOCABULARY, but it is not linked to a Controlled Vocabulary.', NEW.code;\\012      end if;\\012   end if;\\012\\012   RETURN NEW;\\012\\012END;\\012$$ LANGUAGE 'plpgsql';\\012\\012CREATE TRIGGER CONTROLLED_VOCABULARY_CHECK BEFORE INSERT OR UPDATE ON PROPERTY_TYPES\\012    FOR EACH ROW EXECUTE PROCEDURE CONTROLLED_VOCABULARY_CHECK();\\012\\012\\012------------------------------------------------------------------------------------\\012--  Purpose:  Create trigger EXTERNAL_DATA_STORAGE_FORMAT_CHECK \\012------------------------------------------------------------------------------------\\012\\012CREATE OR REPLACE FUNCTION EXTERNAL_DATA_STORAGE_FORMAT_CHECK() RETURNS trigger AS $$\\012DECLARE\\012   v_covo_code  CODE;\\012   data_code CODE;\\012BEGIN\\012\\012   select code into v_covo_code from controlled_vocabularies\\012      where is_internal_namespace = true and \\012         id = (select covo_id from controlled_vocabulary_terms where id = NEW.cvte_id_stor_fmt);\\012   -- Check if the data storage format is a term of the controlled vocabulary "STORAGE_FORMAT"\\012   if v_covo_code != 'STORAGE_FORMAT' then\\012      select code into data_code from data where id = NEW.data_id; \\012      RAISE EXCEPTION 'Insert/Update of Data (Code: %) failed, as its Storage Format is %, but is required to be STORAGE_FORMAT.', data_code, v_covo_code;\\012   end if;\\012\\012   RETURN NEW;\\012\\012END;\\012$$ LANGUAGE 'plpgsql';\\012\\012CREATE TRIGGER EXTERNAL_DATA_STORAGE_FORMAT_CHECK BEFORE INSERT OR UPDATE ON EXTERNAL_DATA\\012    FOR EACH ROW EXECUTE PROCEDURE EXTERNAL_DATA_STORAGE_FORMAT_CHECK();\\012\\012------------------------------------------------------------------------------------\\012--  Purpose:  Create trigger SAMPLE_CODE_UNIQUENESS_CHECK \\012------------------------------------------------------------------------------------\\012\\012CREATE OR REPLACE FUNCTION SAMPLE_CODE_UNIQUENESS_CHECK() RETURNS trigger AS $$\\012DECLARE\\012   counter  INTEGER;\\012BEGIN\\012\\011IF (NEW.samp_id_part_of is NULL) THEN\\012\\011\\011IF (NEW.dbin_id is not NULL) THEN\\012\\011\\011\\011SELECT count(*) into counter FROM samples \\012\\011\\011\\011\\011where id != NEW.id and code = NEW.code and samp_id_part_of is NULL and dbin_id = NEW.dbin_id;\\012\\011\\011\\011IF (counter > 0) THEN\\012\\011\\011\\011\\011RAISE EXCEPTION 'Insert/Update of Sample (Code: %) failed because database instance sample with the same code already exists.', NEW.code;\\012\\011\\011\\011END IF;\\012\\011\\011ELSIF (NEW.grou_id is not NULL) THEN\\012\\011\\011\\011SELECT count(*) into counter FROM samples \\012\\011\\011\\011\\011where id != NEW.id and code = NEW.code and samp_id_part_of is NULL and grou_id = NEW.grou_id;\\012\\011\\011\\011IF (counter > 0) THEN\\012\\011\\011\\011\\011RAISE EXCEPTION 'Insert/Update of Sample (Code: %) failed because group sample with the same code already exists.', NEW.code;\\012\\011\\011\\011END IF;\\012\\011\\011END IF;\\012        ELSE\\012\\011\\011IF (NEW.dbin_id is not NULL) THEN\\012\\011\\011\\011SELECT count(*) into counter FROM samples \\012\\011\\011\\011\\011where id != NEW.id and code = NEW.code and samp_id_part_of = NEW.samp_id_part_of and dbin_id = NEW.dbin_id;\\012\\011\\011\\011IF (counter > 0) THEN\\012\\011\\011\\011\\011RAISE EXCEPTION 'Insert/Update of Sample (Code: %) failed because database instance sample with the same code and being the part of the same parent already exists.', NEW.code;\\012\\011\\011\\011END IF;\\012\\011\\011ELSIF (NEW.grou_id is not NULL) THEN\\012\\011\\011\\011SELECT count(*) into counter FROM samples \\012\\011\\011\\011\\011where id != NEW.id and code = NEW.code and samp_id_part_of = NEW.samp_id_part_of and grou_id = NEW.grou_id;\\012\\011\\011\\011IF (counter > 0) THEN\\012\\011\\011\\011\\011RAISE EXCEPTION 'Insert/Update of Sample (Code: %) failed because group sample with the same code and being the part of the same parent already exists.', NEW.code;\\012\\011\\011\\011END IF;\\012\\011\\011END IF;\\012        END IF;   \\012   RETURN NEW;\\012END;\\012$$ LANGUAGE 'plpgsql';\\012\\012CREATE TRIGGER SAMPLE_CODE_UNIQUENESS_CHECK BEFORE INSERT OR UPDATE ON SAMPLES\\012    FOR EACH ROW EXECUTE PROCEDURE SAMPLE_CODE_UNIQUENESS_CHECK();\\012	\N
+./sourceTest/sql/postgresql/062/017=database_version_logs.tsv:028	source/sql/postgresql/migration/migration-027-028.sql	SUCCESS	2008-11-18 13:24:17.508	-- Create EXPERIMENT_ATTACHMENT_CONTENTS.\\012CREATE TABLE EXPERIMENT_ATTACHMENT_CONTENTS (ID TECH_ID NOT NULL,VALUE FILE NOT NULL);\\012CREATE SEQUENCE EXPERIMENT_ATTACHMENT_CONTENT_ID_SEQ;\\012ALTER TABLE EXPERIMENT_ATTACHMENT_CONTENTS ADD CONSTRAINT EXAC_PK PRIMARY KEY(ID);\\012\\012-- Alter EXPERIMENT_ATTACHMENTS by adding the new column which has a NULL constraint.\\012-- The NOT NULL constraint is added later on.\\012ALTER TABLE EXPERIMENT_ATTACHMENTS ADD COLUMN EXAC_ID TECH_ID;\\012\\012-- Does the VALUE migration between EXPERIMENT_ATTACHMENTS to EXPERIMENT_ATTACHMENT_CONTENTS.\\012CREATE OR REPLACE FUNCTION move_exp_att_content() RETURNS integer AS $$\\012DECLARE\\012    rec RECORD;\\012    seq BIGINT;\\012BEGIN\\012  FOR rec IN SELECT id, value FROM EXPERIMENT_ATTACHMENTS LOOP\\012  \\011seq := nextval('EXPERIMENT_ATTACHMENT_CONTENT_ID_SEQ');\\012    INSERT INTO EXPERIMENT_ATTACHMENT_CONTENTS (id, value) VALUES (seq, rec.value);\\012    UPDATE EXPERIMENT_ATTACHMENTS SET exac_id = seq WHERE id = rec.id;\\012  END LOOP;\\012  RETURN 1;\\012END;\\012$$ LANGUAGE 'plpgsql';\\012\\012-- Call the function.\\012SELECT move_exp_att_content();\\012DROP FUNCTION move_exp_att_content();\\012\\012\\012-- Finish EXPERIMENT_ATTACHMENTS changes.\\012ALTER TABLE EXPERIMENT_ATTACHMENTS ADD CONSTRAINT EXAT_CONT_FK FOREIGN KEY (EXAC_ID) REFERENCES EXPERIMENT_ATTACHMENT_CONTENTS(ID);\\012ALTER TABLE EXPERIMENT_ATTACHMENTS DROP COLUMN VALUE;\\012ALTER TABLE EXPERIMENT_ATTACHMENTS ALTER COLUMN EXAC_ID SET NOT NULL;\\012	\N
+./sourceTest/sql/postgresql/062/017=database_version_logs.tsv:029	source/sql/postgresql/migration/migration-028-029.sql	SUCCESS	2009-03-18 10:50:20.105	-- -------\\012-- add modification_timestamp field to allow edition with Hibernate\\012-- -------\\012\\012ALTER TABLE samples\\012\\011ADD COLUMN modification_timestamp TIME_STAMP DEFAULT CURRENT_TIMESTAMP;\\012\\012ALTER TABLE experiments\\012\\011ADD COLUMN modification_timestamp TIME_STAMP DEFAULT CURRENT_TIMESTAMP;\\012\\012ALTER TABLE materials\\012\\011ADD COLUMN modification_timestamp TIME_STAMP DEFAULT CURRENT_TIMESTAMP;\\012\\012ALTER TABLE experiment_properties\\012\\011ADD COLUMN modification_timestamp TIME_STAMP DEFAULT CURRENT_TIMESTAMP;\\012\\012ALTER TABLE material_properties\\012\\011ADD COLUMN modification_timestamp TIME_STAMP DEFAULT CURRENT_TIMESTAMP;\\012\\012ALTER TABLE sample_properties\\012\\011ADD COLUMN modification_timestamp TIME_STAMP DEFAULT CURRENT_TIMESTAMP;\\012\\012-- -------\\012-- add property data type which references materials\\012-- -------\\012\\012ALTER TABLE property_types\\012\\011ADD COLUMN maty_prop_id tech_id;\\012\\012ALTER TABLE property_types\\012\\011ADD CONSTRAINT prty_maty_fk FOREIGN KEY (maty_prop_id) REFERENCES material_types(id);\\012\\012ALTER TABLE experiment_properties\\012\\011ADD COLUMN mate_prop_id tech_id;\\012\\012ALTER TABLE material_properties\\012\\011ADD COLUMN mate_prop_id tech_id;\\012\\012ALTER TABLE sample_properties\\012\\011ADD COLUMN mate_prop_id tech_id;\\012\\012ALTER TABLE experiment_properties\\012\\011ADD CONSTRAINT expr_mapr_fk FOREIGN KEY (mate_prop_id) REFERENCES materials(id);\\012\\012ALTER TABLE material_properties\\012\\011ADD CONSTRAINT mapr_mapr_fk FOREIGN KEY (mate_prop_id) REFERENCES materials(id);\\012\\012ALTER TABLE sample_properties\\012\\011ADD CONSTRAINT sapr_mapr_fk FOREIGN KEY (mate_prop_id) REFERENCES materials(id);\\012\\012insert into data_types\\012(id\\012 ,code\\012 ,description)\\012 values \\012 (nextval('DATA_TYPE_ID_SEQ')\\012 ,'MATERIAL'\\012 ,'Reference to a material'\\012);\\012\\012ALTER TABLE MATERIAL_PROPERTIES DROP CONSTRAINT MAPR_CK;\\012ALTER TABLE MATERIAL_PROPERTIES ADD CONSTRAINT MAPR_CK CHECK \\012\\011((VALUE IS NOT NULL AND CVTE_ID IS NULL AND MATE_PROP_ID IS NULL) OR \\012\\011 (VALUE IS NULL AND CVTE_ID IS NOT NULL AND MATE_PROP_ID IS NULL) OR\\012\\011 (VALUE IS NULL AND CVTE_ID IS NULL AND MATE_PROP_ID IS NOT NULL)\\012\\011);\\012\\012ALTER TABLE EXPERIMENT_PROPERTIES DROP CONSTRAINT EXPR_CK;\\012ALTER TABLE EXPERIMENT_PROPERTIES ADD CONSTRAINT EXPR_CK CHECK \\012\\011((VALUE IS NOT NULL AND CVTE_ID IS NULL AND MATE_PROP_ID IS NULL) OR \\012\\011 (VALUE IS NULL AND CVTE_ID IS NOT NULL AND MATE_PROP_ID IS NULL) OR\\012\\011 (VALUE IS NULL AND CVTE_ID IS NULL AND MATE_PROP_ID IS NOT NULL)\\012\\011);\\012\\012ALTER TABLE SAMPLE_PROPERTIES DROP CONSTRAINT SAPR_CK;\\012ALTER TABLE SAMPLE_PROPERTIES ADD CONSTRAINT SAPR_CK CHECK \\012\\011((VALUE IS NOT NULL AND CVTE_ID IS NULL AND MATE_PROP_ID IS NULL) OR \\012\\011 (VALUE IS NULL AND CVTE_ID IS NOT NULL AND MATE_PROP_ID IS NULL) OR\\012\\011 (VALUE IS NULL AND CVTE_ID IS NULL AND MATE_PROP_ID IS NOT NULL)\\012\\011);\\012\\012------------------------------------------------------------------------------------\\012--  Purpose:  Create trigger MATERIAL/SAMPLE/EXPERIMENT _PROPERTY_WITH_MATERIAL_DATA_TYPE_CHECK\\012--            It checks that if material property value is assigned to the entity,\\012--\\011\\011\\011\\011\\011\\011then the material type is equal to the one described by property type.\\012------------------------------------------------------------------------------------\\012\\012CREATE OR REPLACE FUNCTION MATERIAL_PROPERTY_WITH_MATERIAL_DATA_TYPE_CHECK() RETURNS trigger AS $$\\012DECLARE\\012   v_type_id  CODE;\\012   v_type_id_prop  CODE;\\012BEGIN\\012   if NEW.mate_prop_id IS NOT NULL then\\012\\011\\011\\011-- find material type id of the property type \\012\\011\\011\\011select pt.maty_prop_id into v_type_id_prop \\012\\011\\011\\011  from material_type_property_types etpt, property_types pt \\012\\011\\011\\011 where NEW.mtpt_id = etpt.id AND etpt.prty_id = pt.id;\\012\\011\\011\\012\\011\\011\\011if v_type_id_prop IS NOT NULL then\\012\\011\\011\\011\\011-- find material type id of the material which consists the entity's property value\\012\\011\\011\\011\\011select entity.maty_id into v_type_id \\012\\011\\011\\011\\011  from materials entity\\012\\011\\011\\011\\011 where NEW.mate_prop_id = entity.id;\\012\\011\\011\\011\\011if v_type_id != v_type_id_prop then\\012\\011\\011\\011\\011\\011RAISE EXCEPTION 'Insert/Update of property value referencing material (id: %) failed, as referenced material type is different than expected (id %, expected id: %).', \\012\\011\\011\\011\\011\\011\\011\\011 NEW.mate_prop_id, v_type_id, v_type_id_prop;\\012\\011\\011\\011\\011end if;\\012\\011\\011\\011end if;\\012   end if;\\012   RETURN NEW;\\012END;\\012$$ LANGUAGE 'plpgsql';\\012\\012CREATE TRIGGER MATERIAL_PROPERTY_WITH_MATERIAL_DATA_TYPE_CHECK BEFORE INSERT OR UPDATE ON material_properties\\012    FOR EACH ROW EXECUTE PROCEDURE MATERIAL_PROPERTY_WITH_MATERIAL_DATA_TYPE_CHECK();\\012    \\012CREATE OR REPLACE FUNCTION SAMPLE_PROPERTY_WITH_MATERIAL_DATA_TYPE_CHECK() RETURNS trigger AS $$\\012DECLARE\\012   v_type_id  CODE;\\012   v_type_id_prop  CODE;\\012BEGIN\\012   if NEW.mate_prop_id IS NOT NULL then\\012\\011\\011\\011-- find material type id of the property type \\012\\011\\011\\011select pt.maty_prop_id into v_type_id_prop \\012\\011\\011\\011  from sample_type_property_types etpt, property_types pt \\012\\011\\011\\011 where NEW.stpt_id = etpt.id AND etpt.prty_id = pt.id;\\012\\011\\011\\012\\011\\011\\011if v_type_id_prop IS NOT NULL then\\012\\011\\011\\011\\011-- find material type id of the material which consists the entity's property value\\012\\011\\011\\011\\011select entity.maty_id into v_type_id \\012\\011\\011\\011\\011  from materials entity\\012\\011\\011\\011\\011 where NEW.mate_prop_id = entity.id;\\012\\011\\011\\011\\011if v_type_id != v_type_id_prop then\\012\\011\\011\\011\\011\\011RAISE EXCEPTION 'Insert/Update of property value referencing material (id: %) failed, as referenced material type is different than expected (id %, expected id: %).', \\012\\011\\011\\011\\011\\011\\011\\011\\011\\011\\011\\011\\011 NEW.mate_prop_id, v_type_id, v_type_id_prop;\\012\\011\\011\\011\\011end if;\\012\\011\\011\\011end if;\\012   end if;\\012   RETURN NEW;\\012END;\\012$$ LANGUAGE 'plpgsql';\\012\\012CREATE TRIGGER SAMPLE_PROPERTY_WITH_MATERIAL_DATA_TYPE_CHECK BEFORE INSERT OR UPDATE ON sample_properties\\012    FOR EACH ROW EXECUTE PROCEDURE SAMPLE_PROPERTY_WITH_MATERIAL_DATA_TYPE_CHECK();\\012    \\012CREATE OR REPLACE FUNCTION EXPERIMENT_PROPERTY_WITH_MATERIAL_DATA_TYPE_CHECK() RETURNS trigger AS $$\\012DECLARE\\012   v_type_id  CODE;\\012   v_type_id_prop  CODE;\\012BEGIN\\012   if NEW.mate_prop_id IS NOT NULL then\\012\\011\\011\\011-- find material type id of the property type \\012\\011\\011\\011select pt.maty_prop_id into v_type_id_prop \\012\\011\\011\\011  from experiment_type_property_types etpt, property_types pt \\012\\011\\011\\011 where NEW.etpt_id = etpt.id AND etpt.prty_id = pt.id;\\012\\011\\011\\012\\011\\011\\011if v_type_id_prop IS NOT NULL then\\012\\011\\011\\011\\011-- find material type id of the material which consists the entity's property value\\012\\011\\011\\011\\011select entity.maty_id into v_type_id \\012\\011\\011\\011\\011  from materials entity\\012\\011\\011\\011\\011 where NEW.mate_prop_id = entity.id;\\012\\011\\011\\011\\011if v_type_id != v_type_id_prop then\\012\\011\\011\\011\\011\\011RAISE EXCEPTION 'Insert/Update of property value referencing material (id: %) failed, as referenced material type is different than expected (id %, expected id: %).', \\012\\011\\011\\011\\011\\011\\011\\011\\011\\011\\011\\011\\011 NEW.mate_prop_id, v_type_id, v_type_id_prop;\\012\\011\\011\\011\\011end if;\\012\\011\\011\\011end if;\\012   end if;\\012   RETURN NEW;\\012END;\\012$$ LANGUAGE 'plpgsql';\\012\\012CREATE TRIGGER EXPERIMENT_PROPERTY_WITH_MATERIAL_DATA_TYPE_CHECK BEFORE INSERT OR UPDATE ON experiment_properties\\012    FOR EACH ROW EXECUTE PROCEDURE EXPERIMENT_PROPERTY_WITH_MATERIAL_DATA_TYPE_CHECK();\\012       \\012-- -------\\012-- remove the reminescents of the OBSERVABLE_TYPE\\012-- -------\\012\\012ALTER TABLE data\\012\\011DROP CONSTRAINT data_obty_fk;\\012\\012ALTER TABLE data_set_types\\012\\011DROP CONSTRAINT obty_pk;\\012\\012ALTER TABLE data_set_types\\012\\011ADD CONSTRAINT dsty_pk PRIMARY KEY (id);\\012\\012ALTER TABLE data\\012\\011ADD CONSTRAINT data_dsty_fk FOREIGN KEY (dsty_id) REFERENCES data_set_types(id);\\012\\012ALTER TABLE data_set_types\\012\\011DROP CONSTRAINT obty_bk_uk;\\012\\012ALTER TABLE data_set_types\\012\\011DROP CONSTRAINT obty_dbin_fk;\\012\\012ALTER TABLE data_set_types\\012\\011ADD CONSTRAINT dsty_bk_uk UNIQUE (code, dbin_id);\\012\\012ALTER TABLE data_set_types\\012\\011ADD CONSTRAINT dsty_dbin_fk FOREIGN KEY (dbin_id) REFERENCES database_instances(id);\\012\\012DROP INDEX data_obty_fk_i;\\012\\012CREATE INDEX data_dsty_fk_i ON data(dsty_id);\\012	\N
+./sourceTest/sql/postgresql/062/017=database_version_logs.tsv:030	source/sql/postgresql/migration/migration-029-030.sql	SUCCESS	2009-03-23 15:34:44.72	-- -------\\012-- add modification_timestamp field to allow edition with Hibernate\\012-- -------\\012ALTER TABLE data\\012\\011ADD COLUMN modification_timestamp TIME_STAMP DEFAULT CURRENT_TIMESTAMP;\\012ALTER TABLE experiment_types\\012\\011ADD COLUMN modification_timestamp TIME_STAMP DEFAULT CURRENT_TIMESTAMP;\\012ALTER TABLE sample_types\\012\\011ADD COLUMN modification_timestamp TIME_STAMP DEFAULT CURRENT_TIMESTAMP;\\012ALTER TABLE material_types\\012\\011ADD COLUMN modification_timestamp TIME_STAMP DEFAULT CURRENT_TIMESTAMP;\\012ALTER TABLE data_set_types\\012\\011ADD COLUMN modification_timestamp TIME_STAMP DEFAULT CURRENT_TIMESTAMP;\\012ALTER TABLE controlled_vocabularies\\012\\011ADD COLUMN modification_timestamp TIME_STAMP DEFAULT CURRENT_TIMESTAMP;\\012-- -------\\012-- add properties to data sets\\012-- -------\\012CREATE TABLE DATA_SET_PROPERTIES (ID TECH_ID NOT NULL,DS_ID TECH_ID NOT NULL,DSTPT_ID TECH_ID NOT NULL,VALUE GENERIC_VALUE,CVTE_ID TECH_ID, MATE_PROP_ID TECH_ID, PERS_ID_REGISTERER TECH_ID NOT NULL,REGISTRATION_TIMESTAMP TIME_STAMP_DFL NOT NULL DEFAULT CURRENT_TIMESTAMP, MODIFICATION_TIMESTAMP TIME_STAMP DEFAULT CURRENT_TIMESTAMP);\\012CREATE TABLE DATA_SET_TYPE_PROPERTY_TYPES (ID TECH_ID NOT NULL,DSTY_ID TECH_ID NOT NULL,PRTY_ID TECH_ID NOT NULL,IS_MANDATORY BOOLEAN_CHAR NOT NULL DEFAULT 'F',IS_MANAGED_INTERNALLY BOOLEAN_CHAR NOT NULL DEFAULT 'F',PERS_ID_REGISTERER TECH_ID NOT NULL,REGISTRATION_TIMESTAMP TIME_STAMP_DFL NOT NULL DEFAULT CURRENT_TIMESTAMP);\\012\\012CREATE SEQUENCE DATA_SET_PROPERTY_ID_SEQ;\\012CREATE SEQUENCE DSTPT_ID_SEQ;\\012\\012ALTER TABLE DATA_SET_TYPE_PROPERTY_TYPES ADD CONSTRAINT DSTPT_PK PRIMARY KEY(ID);\\012ALTER TABLE DATA_SET_PROPERTIES ADD CONSTRAINT DSPR_PK PRIMARY KEY(ID);\\012\\012ALTER TABLE DATA_SET_TYPE_PROPERTY_TYPES ADD CONSTRAINT DSTPT_BK_UK UNIQUE(DSTY_ID,PRTY_ID);\\012ALTER TABLE DATA_SET_PROPERTIES ADD CONSTRAINT DSPR_BK_UK UNIQUE(DS_ID,DSTPT_ID);\\012\\012\\012ALTER TABLE DATA_SET_TYPE_PROPERTY_TYPES ADD CONSTRAINT DSTPT_DSTY_FK FOREIGN KEY (DSTY_ID) REFERENCES DATA_SET_TYPES(ID);\\012ALTER TABLE DATA_SET_TYPE_PROPERTY_TYPES ADD CONSTRAINT DSTPT_PERS_FK FOREIGN KEY (PERS_ID_REGISTERER) REFERENCES PERSONS(ID);\\012ALTER TABLE DATA_SET_TYPE_PROPERTY_TYPES ADD CONSTRAINT DSTPT_PRTY_FK FOREIGN KEY (PRTY_ID) REFERENCES PROPERTY_TYPES(ID);\\012ALTER TABLE DATA_SET_PROPERTIES ADD CONSTRAINT DSPR_CVTE_FK FOREIGN KEY (CVTE_ID) REFERENCES CONTROLLED_VOCABULARY_TERMS(ID);\\012ALTER TABLE DATA_SET_PROPERTIES ADD CONSTRAINT DSPR_DSTPT_FK FOREIGN KEY (DSTPT_ID) REFERENCES DATA_SET_TYPE_PROPERTY_TYPES(ID) ON DELETE CASCADE;\\012ALTER TABLE DATA_SET_PROPERTIES ADD CONSTRAINT DSPR_DS_FK FOREIGN KEY (DS_ID) REFERENCES DATA(ID);\\012ALTER TABLE DATA_SET_PROPERTIES ADD CONSTRAINT DSPR_PERS_FK FOREIGN KEY (PERS_ID_REGISTERER) REFERENCES PERSONS(ID);\\012ALTER TABLE DATA_SET_PROPERTIES ADD CONSTRAINT DSPR_MAPR_FK FOREIGN KEY (MATE_PROP_ID) REFERENCES MATERIALS(ID);\\012\\012ALTER TABLE DATA_SET_PROPERTIES ADD CONSTRAINT DSPR_CK CHECK \\012\\011((VALUE IS NOT NULL AND CVTE_ID IS NULL AND MATE_PROP_ID IS NULL) OR \\012\\011 (VALUE IS NULL AND CVTE_ID IS NOT NULL AND MATE_PROP_ID IS NULL) OR\\012\\011 (VALUE IS NULL AND CVTE_ID IS NULL AND MATE_PROP_ID IS NOT NULL)\\012\\011);\\012\\012CREATE INDEX DSPR_CVTE_FK_I ON DATA_SET_PROPERTIES (CVTE_ID);\\012CREATE INDEX DSPR_DSTPT_FK_I ON DATA_SET_PROPERTIES (DSTPT_ID);\\012CREATE INDEX DSPR_DS_FK_I ON DATA_SET_PROPERTIES (DS_ID);\\012CREATE INDEX DSPR_PERS_FK_I ON DATA_SET_PROPERTIES (PERS_ID_REGISTERER);\\012CREATE INDEX DSTPT_DSTY_FK_I ON DATA_SET_TYPE_PROPERTY_TYPES (DSTY_ID);\\012CREATE INDEX DSTPT_PERS_FK_I ON DATA_SET_TYPE_PROPERTY_TYPES (PERS_ID_REGISTERER);\\012CREATE INDEX DSTPT_PRTY_FK_I ON DATA_SET_TYPE_PROPERTY_TYPES (PRTY_ID);\\012\\012CREATE OR REPLACE FUNCTION DATA_SET_PROPERTY_WITH_MATERIAL_DATA_TYPE_CHECK() RETURNS trigger AS $$\\012DECLARE\\012   v_type_id  CODE;\\012   v_type_id_prop  CODE;\\012BEGIN\\012   if NEW.mate_prop_id IS NOT NULL then\\012\\011\\011\\011-- find material type id of the property type \\012\\011\\011\\011select pt.maty_prop_id into v_type_id_prop \\012\\011\\011\\011  from data_set_type_property_types dstpt, property_types pt \\012\\011\\011\\011 where NEW.dstpt_id = dstpt.id AND dstpt.prty_id = pt.id;\\012\\011\\011\\012\\011\\011\\011if v_type_id_prop IS NOT NULL then\\012\\011\\011\\011\\011-- find material type id of the material which consists the entity's property value\\012\\011\\011\\011\\011select entity.maty_id into v_type_id \\012\\011\\011\\011\\011  from materials entity\\012\\011\\011\\011\\011 where NEW.mate_prop_id = entity.id;\\012\\011\\011\\011\\011if v_type_id != v_type_id_prop then\\012\\011\\011\\011\\011\\011RAISE EXCEPTION 'Insert/Update of property value referencing material (id: %) failed, as referenced material type is different than expected (id %, expected id: %).', \\012\\011\\011\\011\\011\\011\\011\\011\\011\\011\\011\\011\\011 NEW.mate_prop_id, v_type_id, v_type_id_prop;\\012\\011\\011\\011\\011end if;\\012\\011\\011\\011end if;\\012   end if;\\012   RETURN NEW;\\012END;\\012$$ LANGUAGE 'plpgsql';\\012\\012CREATE TRIGGER DATA_SET_PROPERTY_WITH_MATERIAL_DATA_TYPE_CHECK BEFORE INSERT OR UPDATE ON data_set_properties\\012    FOR EACH ROW EXECUTE PROCEDURE DATA_SET_PROPERTY_WITH_MATERIAL_DATA_TYPE_CHECK();   \\012	\N
+./sourceTest/sql/postgresql/062/017=database_version_logs.tsv:032	source/sql/postgresql/migration/migration-031-032.sql	SUCCESS	2009-04-09 09:36:36.2	-- -------\\012-- Modify MATERIAL_BATCHES\\012-- -------\\012\\012ALTER TABLE material_batches\\012    DROP COLUMN proc_id;\\012\\012-- -------\\012-- Modify SAMPLES\\012-- -------\\012\\012ALTER TABLE samples\\012    ADD COLUMN expe_id tech_id;\\012\\012ALTER TABLE samples\\012    ADD CONSTRAINT samp_expe_fk FOREIGN KEY (expe_id) REFERENCES experiments(id);\\012\\012CREATE INDEX samp_expe_fk_i ON samples USING btree (expe_id);\\012\\012-- relink samples directly to experiments\\012\\012UPDATE samples\\012SET expe_id = (SELECT e.id FROM experiments e, procedures p, sample_inputs si \\012               WHERE si.samp_id = samples.id AND si.proc_id = p.id AND p.expe_id = e.id AND e.inva_id IS NULL);\\012\\012\\012-- -------\\012-- Modify DATA\\012-- -------\\012\\012ALTER TABLE data\\012    ADD COLUMN expe_id tech_id;\\012\\012ALTER TABLE data\\012    ADD CONSTRAINT data_expe_fk FOREIGN KEY (expe_id) REFERENCES experiments(id);\\012\\012CREATE INDEX data_expe_fk_i ON data USING btree (expe_id);\\012\\012UPDATE data\\012SET expe_id = (SELECT e.id FROM experiments e, procedures p \\012               WHERE data.proc_id_produced_by = p.id AND p.expe_id = e.id);\\012\\012ALTER TABLE data\\012    ALTER COLUMN expe_id SET NOT NULL;\\012\\012ALTER TABLE data\\012    DROP COLUMN proc_id_produced_by;\\012\\012-- -------\\012-- Drop PROCEDURES, PROCEDURE_TYPES, and SAMPLE_INPUTS\\012-- -------\\012\\012DROP TABLE sample_inputs;\\012DROP TABLE procedures;\\012DROP TABLE procedure_types;\\012\\012DROP SEQUENCE procedure_id_seq;\\012DROP SEQUENCE procedure_type_id_seq;\\012\\012-- -------\\012-- Add CODE_SEQ\\012-- -------\\012\\012CREATE SEQUENCE CODE_SEQ;\\012\\012-- -------\\012-- Add new columns to DATA_STORES\\012-- -------\\012\\012ALTER TABLE data_stores\\012    ADD COLUMN remote_url character varying(250),\\012    ADD COLUMN session_token character varying(50),\\012    ADD COLUMN modification_timestamp time_stamp DEFAULT now();\\012\\012UPDATE data_stores\\012SET remote_url = '', session_token='';\\012\\012ALTER TABLE data_stores\\012    ALTER COLUMN remote_url SET NOT NULL,\\012    ALTER COLUMN session_token SET NOT NULL;\\012\\012-- -------\\012-- Drop foreign keys onto DATA_STORES\\012-- -------\\012\\012ALTER TABLE database_instances\\012    DROP COLUMN dast_id;\\012\\012ALTER TABLE groups\\012    DROP COLUMN dast_id;\\012\\012ALTER TABLE projects\\012    DROP COLUMN dast_id;\\012\\012ALTER TABLE experiments\\012    DROP COLUMN dast_id;\\012\\012-- -------\\012-- Add foreign key from DATA onto DATA_STORES\\012-- -------\\012\\012ALTER TABLE data\\012    ADD COLUMN dast_id tech_id;\\012\\012ALTER TABLE data\\012    ADD CONSTRAINT data_dast_fk FOREIGN KEY (dast_id) REFERENCES data_stores(id);\\012\\012UPDATE data\\012SET dast_id = (select id from data_stores where code = 'STANDARD');\\012\\012ALTER TABLE data\\012    ALTER COLUMN dast_id SET NOT NULL;\\012\\012\\012------------------------------------------------------------------------------------\\012--  Purpose:  Replace trigger SAMPLE_CODE_UNIQUENESS_CHECK \\012------------------------------------------------------------------------------------\\012\\012CREATE OR REPLACE FUNCTION SAMPLE_CODE_UNIQUENESS_CHECK() RETURNS trigger AS $$\\012DECLARE\\012   counter  INTEGER;\\012BEGIN\\012    LOCK TABLE samples IN EXCLUSIVE MODE;\\012    IF (NEW.samp_id_part_of is NULL) THEN\\012        IF (NEW.dbin_id is not NULL) THEN\\012            SELECT count(*) into counter FROM samples \\012                where id != NEW.id and code = NEW.code and samp_id_part_of is NULL and dbin_id = NEW.dbin_id;\\012            IF (counter > 0) THEN\\012                RAISE EXCEPTION 'Insert/Update of Sample (Code: %) failed because database instance sample with the same code already exists.', NEW.code;\\012            END IF;\\012        ELSIF (NEW.grou_id is not NULL) THEN\\012            SELECT count(*) into counter FROM samples \\012                where id != NEW.id and code = NEW.code and samp_id_part_of is NULL and grou_id = NEW.grou_id;\\012            IF (counter > 0) THEN\\012                RAISE EXCEPTION 'Insert/Update of Sample (Code: %) failed because group sample with the same code already exists.', NEW.code;\\012            END IF;\\012        END IF;\\012        ELSE\\012        IF (NEW.dbin_id is not NULL) THEN\\012            SELECT count(*) into counter FROM samples \\012                where id != NEW.id and code = NEW.code and samp_id_part_of = NEW.samp_id_part_of and dbin_id = NEW.dbin_id;\\012            IF (counter > 0) THEN\\012                RAISE EXCEPTION 'Insert/Update of Sample (Code: %) failed because database instance sample with the same code and being the part of the same parent already exists.', NEW.code;\\012            END IF;\\012        ELSIF (NEW.grou_id is not NULL) THEN\\012            SELECT count(*) into counter FROM samples \\012                where id != NEW.id and code = NEW.code and samp_id_part_of = NEW.samp_id_part_of and grou_id = NEW.grou_id;\\012            IF (counter > 0) THEN\\012                RAISE EXCEPTION 'Insert/Update of Sample (Code: %) failed because group sample with the same code and being the part of the same parent already exists.', NEW.code;\\012            END IF;\\012        END IF;\\012        END IF;   \\012   RETURN NEW;\\012END;\\012$$ LANGUAGE 'plpgsql';\\012\\012\\012\\012	\N
+./sourceTest/sql/postgresql/062/017=database_version_logs.tsv:034	source/sql/postgresql/migration/migration-033-034.sql	SUCCESS	2009-05-26 08:32:49.935	------------------------------------------------------------------------------------\\012-- Create sequence for generating permanent identifiers starting with nextval of existing dataset sequence.\\012------------------------------------------------------------------------------------\\012CREATE FUNCTION CREATE_SEQUENCE(EXISTING_SEQUENCE VARCHAR, NEW_SEQUENCE VARCHAR) RETURNS VOID AS $$\\012DECLARE\\012  CURR_SEQ_VAL   INTEGER;\\012BEGIN\\012  SELECT INTO CURR_SEQ_VAL NEXTVAL(EXISTING_SEQUENCE);\\012  EXECUTE 'CREATE SEQUENCE ' || NEW_SEQUENCE || ' START WITH ' || CURR_SEQ_VAL;\\012  RETURN;\\012END;\\012$$ LANGUAGE 'plpgsql';\\012\\012SELECT CREATE_SEQUENCE('DATA_ID_SEQ', 'PERM_ID_SEQ');\\012DROP FUNCTION CREATE_SEQUENCE(VARCHAR, VARCHAR);\\012\\012------------------------------------------------------------------------------------\\012-- Add perm_id columns to samples and experiments.\\012------------------------------------------------------------------------------------\\012ALTER TABLE SAMPLES ADD COLUMN PERM_ID CODE;\\012ALTER TABLE EXPERIMENTS ADD COLUMN PERM_ID CODE;\\012\\012UPDATE SAMPLES SET PERM_ID = to_char(registration_timestamp,'YYYYMMDDHHSSMS') || '-' || NEXTVAL('PERM_ID_SEQ');\\012UPDATE EXPERIMENTS SET PERM_ID = to_char(registration_timestamp,'YYYYMMDDHHSSMS') || '-' || NEXTVAL('PERM_ID_SEQ');\\012ALTER TABLE SAMPLES ALTER COLUMN PERM_ID SET NOT NULL;\\012ALTER TABLE EXPERIMENTS ALTER COLUMN PERM_ID SET NOT NULL;\\012ALTER TABLE SAMPLES ADD CONSTRAINT SAMP_PI_UK UNIQUE(PERM_ID);\\012ALTER TABLE EXPERIMENTS ADD CONSTRAINT EXPE_PI_UK UNIQUE(PERM_ID);\\012\\012\\012------------------------------------------------------------------------------------\\012-- Add column is_chosen_from_list to controlled_vocabularies.\\012------------------------------------------------------------------------------------\\012ALTER TABLE controlled_vocabularies ADD COLUMN is_chosen_from_list BOOLEAN_CHAR NOT NULL DEFAULT TRUE;\\012ALTER TABLE controlled_vocabularies ADD COLUMN source_uri CHARACTER VARYING(250);\\012------------------------------------------------------------------------------------\\012-- Modify Data table - remove arc connection between Sample and Data table, use a flag instead\\012------------------------------------------------------------------------------------\\012\\012-- add new columns\\012\\012ALTER TABLE data\\012    ADD COLUMN is_derived boolean_char;\\012ALTER TABLE data\\012    ADD COLUMN samp_id tech_id;\\012\\012-- update values in new columns\\012\\012UPDATE data\\012    SET is_derived = (samp_id_derived_from IS NOT NULL); \\012UPDATE data\\012    SET samp_id = samp_id_derived_from \\012    WHERE is_derived = 'TRUE';\\012UPDATE data\\012    SET samp_id = samp_id_acquired_from \\012    WHERE is_derived = 'FALSE';\\012\\012-- add constraints and indexes to new columns\\012\\012ALTER TABLE data\\012    ALTER COLUMN is_derived SET NOT NULL;\\012ALTER TABLE data\\012    ALTER COLUMN samp_id SET NOT NULL;   \\012ALTER TABLE data\\012    ADD CONSTRAINT data_samp_fk FOREIGN KEY (samp_id) REFERENCES samples (id);\\012CREATE INDEX data_samp_fk_i ON data USING btree (samp_id);\\012\\012-- remove old columns\\012\\012ALTER TABLE data\\012    DROP COLUMN samp_id_acquired_from;\\012ALTER TABLE data\\012    DROP COLUMN samp_id_derived_from;\\012    \\012------------------------------------------------------------------------------------\\012-- Granting SELECT privilege to group openbis_readonly\\012------------------------------------------------------------------------------------\\012\\012GRANT SELECT ON SEQUENCE attachment_content_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE attachment_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE code_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE controlled_vocabulary_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE cvte_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE data_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE data_set_property_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE data_set_relationship_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE data_set_type_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE data_store_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE data_type_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE database_instance_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE dstpt_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE etpt_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE event_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE experiment_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE experiment_property_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE experiment_type_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE file_format_type_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE group_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE invalidation_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE locator_type_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE material_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE material_property_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE material_type_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE mtpt_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE perm_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE person_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE project_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE property_type_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE role_assignment_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE sample_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE sample_property_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE sample_type_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE stpt_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE attachment_contents TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE attachments TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE controlled_vocabularies TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE controlled_vocabulary_terms TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE data TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE data_set_properties TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE data_set_relationships TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE data_set_type_property_types TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE data_set_types TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE data_stores TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE data_types TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE database_instances TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE database_version_logs TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE events TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE experiment_properties TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE experiment_type_property_types TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE experiment_types TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE experiments TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE external_data TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE file_format_types TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE groups TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE invalidations TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE locator_types TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE material_properties TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE material_type_property_types TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE material_types TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE materials TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE persons TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE projects TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE property_types TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE role_assignments TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE sample_properties TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE sample_type_property_types TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE sample_types TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE samples TO GROUP OPENBIS_READONLY;\\012\\012------------------------------------------------------------------------------------\\012-- Delete MATERIAL_BATCHES table\\012------------------------------------------------------------------------------------\\012\\012-- WARNING: Potential data lost!!!\\012-- WARNING: Potential data lost!!!\\012-- WARNING: Potential data lost!!!\\012\\012DROP TABLE SAMPLE_MATERIAL_BATCHES;\\012DROP TABLE MATERIAL_BATCHES;\\012DROP SEQUENCE MATERIAL_BATCH_ID_SEQ;\\012\\012------------------------------------------------------------------------------------\\012-- Delete MATE_ID_INHIBITOR_OF from table MATERIALS\\012------------------------------------------------------------------------------------\\012\\012-- WARNING: Potential data lost!!!\\012-- WARNING: Potential data lost!!!\\012-- WARNING: Potential data lost!!!\\012\\012ALTER TABLE MATERIALS DROP COLUMN MATE_ID_INHIBITOR_OF;\\012	\N
+./sourceTest/sql/postgresql/062/017=database_version_logs.tsv:041	source/sql/postgresql/migration/migration-040-041.sql	SUCCESS	2009-09-14 13:48:57.539	-- Create FILTERS table\\012\\012CREATE TABLE FILTERS (ID TECH_ID NOT NULL, DBIN_ID TECH_ID NOT NULL, NAME VARCHAR(200) NOT NULL, DESCRIPTION DESCRIPTION_1000,REGISTRATION_TIMESTAMP TIME_STAMP_DFL NOT NULL DEFAULT CURRENT_TIMESTAMP, PERS_ID_REGISTERER TECH_ID NOT NULL, MODIFICATION_TIMESTAMP TIME_STAMP DEFAULT CURRENT_TIMESTAMP, EXPRESSION VARCHAR(2000) NOT NULL, IS_PUBLIC BOOLEAN NOT NULL, GRID_ID VARCHAR(200) NOT NULL);\\012CREATE SEQUENCE FILTER_ID_SEQ;\\012ALTER TABLE FILTERS ADD CONSTRAINT FILT_PK PRIMARY KEY(ID);\\012ALTER TABLE FILTERS ADD CONSTRAINT FILT_BK_UK UNIQUE(NAME, DBIN_ID, GRID_ID);\\012ALTER TABLE FILTERS ADD CONSTRAINT FILT_PERS_FK FOREIGN KEY (PERS_ID_REGISTERER) REFERENCES PERSONS(ID);\\012ALTER TABLE FILTERS ADD CONSTRAINT FILT_DBIN_FK FOREIGN KEY (DBIN_ID) REFERENCES DATABASE_INSTANCES(ID);\\012CREATE INDEX FILT_PERS_FK_I ON FILTERS (PERS_ID_REGISTERER);\\012CREATE INDEX FILT_DBIN_FK_I ON FILTERS (DBIN_ID);\\012GRANT SELECT ON SEQUENCE filter_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE filters TO GROUP OPENBIS_READONLY;\\012\\012-- Add missing foreign key to role assignments authorization group\\012ALTER TABLE ROLE_ASSIGNMENTS ADD CONSTRAINT ROAS_AG_FK_GRANTEE FOREIGN KEY (AG_ID_GRANTEE) REFERENCES AUTHORIZATION_GROUPS(ID);\\012\\012--------------------------------------------------------------------------------------------------\\012-- Modify dataset connections:\\012-- 1. connection with sample shouldn't be mandatory any more\\012-- 2. introduce an arc condition that dataset cannot be connected with a sample and a parent dataset at the same time\\012--------------------------------------------------------------------------------------------------\\012\\012-- Weaken data-sample connection constraint - allow dataset to have no connection with sample\\012ALTER TABLE data ALTER COLUMN samp_id DROP NOT NULL;\\012\\012-- Remove data-sample connection for datasets that have a parent\\012\\012UPDATE data \\012   SET samp_id = NULL \\012 WHERE id IN (SELECT DISTINCT data_id_child FROM data_set_relationships);\\012\\012-- With PostgreSQL 8.4 one can check that before migration there were no cycles in dataset relationships:\\012--\\012-- WITH RECURSIVE data_set_parents(id, parent_ids, cycle) AS (\\012--         SELECT  r.data_id_child AS id, \\012--                 ARRAY[CAST (r.data_id_parent AS bigint)] AS parent_ids, \\012--                 false AS cycle \\012--         FROM data_set_relationships r\\012--     UNION ALL\\012--         SELECT  r.data_id_child,\\012--                 CAST (r.data_id_parent AS bigint) || p.parent_ids,\\012--                 r.data_id_child = ANY(p.parent_ids)\\012--         FROM data_set_relationships r, data_set_parents p\\012--         WHERE r.data_id_parent = p.id AND NOT cycle\\012-- )\\012-- SELECT count(*) AS cycles FROM data_set_parents WHERE cycle = true;\\012\\012---------------------------------------------------------------------------------------------------\\012--  Purpose:  Create DEFERRED triggers:\\012--            * check_dataset_relationships_on_data_table_modification,\\012--            * check_dataset_relationships_on_relationships_table_modification.\\012--            They check that after all modifications of database (just before commit) \\012--            if 'data'/'data_set_relationships' tables are among modified tables \\012--            dataset is not connected with a sample and a parent dataset at the same time.\\012--            This connections are held in two different tables so simple immediate trigger \\012--            with arc check cannot be used and we need two deferred triggers.\\012----------------------------------------------------------------------------------------------------\\012\\012-- trigger for 'data' table\\012\\012CREATE OR REPLACE FUNCTION check_dataset_relationships_on_data_table_modification() RETURNS trigger AS $$\\012DECLARE\\012\\011counter\\011INTEGER;\\012BEGIN\\012\\011-- if there is a connection with a Sample there should not be any connection with a parent Data Set\\012\\011IF (NEW.samp_id IS NOT NULL) THEN\\012\\011\\011-- count number of parents\\012\\011\\011SELECT count(*) INTO counter \\012\\011\\011\\011FROM data_set_relationships \\012\\011\\011\\011WHERE data_id_child = OLD.id;\\012\\011\\011IF (counter > 0) THEN\\012\\011\\011\\011RAISE EXCEPTION 'Insert/Update of Data Set (Code: %) failed because it cannot be connected with a Sample and a parent Data Set at the same time.', OLD.code;\\012\\011\\011END IF;\\012\\011END IF;\\012  RETURN NEW;\\012END;\\012$$ LANGUAGE 'plpgsql';\\012\\012CREATE CONSTRAINT TRIGGER check_dataset_relationships_on_data_table_modification \\012  AFTER INSERT OR UPDATE ON data\\012\\011DEFERRABLE INITIALLY DEFERRED\\012\\011FOR EACH ROW \\012\\011EXECUTE PROCEDURE check_dataset_relationships_on_data_table_modification();\\012\\012-- trigger for 'data_set_relationships'\\012\\012CREATE OR REPLACE FUNCTION check_dataset_relationships_on_relationships_table_modification() RETURNS trigger AS $$\\012DECLARE\\012\\011counter\\011INTEGER;\\012\\011sample_id\\011TECH_ID;\\012\\011data_code\\011CODE;\\012BEGIN\\012\\011-- child will have a parent added so it should not be connected with any sample\\012\\011SELECT samp_id, code INTO sample_id, data_code \\012\\011\\011FROM data \\012\\011\\011WHERE id = NEW.data_id_child;\\012\\011IF (sample_id IS NOT NULL) THEN\\012\\011\\011RAISE EXCEPTION 'Insert/Update of Data Set (Code: %) failed because it cannot be connected to a Sample and to a parent Data Set at the same time.', data_code;\\012\\011END IF;\\012\\011RETURN NEW;\\012END;\\012$$ LANGUAGE 'plpgsql';\\012  \\012CREATE CONSTRAINT TRIGGER check_dataset_relationships_on_relationships_table_modification \\012  AFTER INSERT OR UPDATE ON data_set_relationships\\012\\011DEFERRABLE INITIALLY DEFERRED\\012\\011FOR EACH ROW \\012\\011EXECUTE PROCEDURE check_dataset_relationships_on_relationships_table_modification();\\012	\N
+./sourceTest/sql/postgresql/062/017=database_version_logs.tsv:053	source/sql/postgresql/migration/migration-052-053.sql	SUCCESS	2010-06-08 15:27:55.032	-- Migration from 052 to 053\\012\\012-- Change code uniqueness check for samples of specific type.\\012-- If sample_types.is_subcode_unique flag is set to 'true', additional check is performed \\012-- on codes of samples of the type. Subcodes will have to be unique as well.\\012\\012ALTER TABLE sample_types ADD COLUMN is_subcode_unique boolean_char NOT NULL DEFAULT false;\\012\\012CREATE OR REPLACE FUNCTION SAMPLE_SUBCODE_UNIQUENESS_CHECK() RETURNS trigger AS $$\\012DECLARE\\012   counter  INTEGER;\\012   unique_subcode  BOOLEAN_CHAR;\\012BEGIN\\012  LOCK TABLE samples IN EXCLUSIVE MODE;\\012  \\012  SELECT is_subcode_unique into unique_subcode FROM sample_types WHERE id = NEW.saty_id;\\012  \\012  IF (unique_subcode) THEN\\012    IF (NEW.dbin_id is not NULL) THEN\\012\\011\\011\\011SELECT count(*) into counter FROM samples \\012\\011\\011\\011\\011where id != NEW.id and code = NEW.code and saty_id = NEW.saty_id and dbin_id = NEW.dbin_id;\\012\\011\\011\\011IF (counter > 0) THEN\\012\\011\\011\\011\\011RAISE EXCEPTION 'Insert/Update of Sample (Code: %) failed because database instance sample of the same type with the same subcode already exists.', NEW.code;\\012\\011\\011\\011END IF;\\012\\011\\011ELSIF (NEW.grou_id is not NULL) THEN\\012\\011\\011\\011SELECT count(*) into counter FROM samples \\012\\011\\011\\011\\011where id != NEW.id and code = NEW.code and saty_id = NEW.saty_id and grou_id = NEW.grou_id;\\012\\011\\011\\011IF (counter > 0) THEN\\012\\011\\011\\011\\011RAISE EXCEPTION 'Insert/Update of Sample (Code: %) failed because space sample of the same type with the same subcode already exists.', NEW.code;\\012\\011\\011\\011END IF;\\012\\011\\011END IF;\\012  END IF;\\012  \\012  RETURN NEW;\\012END;\\012$$ LANGUAGE 'plpgsql';\\012\\012CREATE TRIGGER SAMPLE_SUBCODE_UNIQUENESS_CHECK BEFORE INSERT OR UPDATE ON SAMPLES\\012    FOR EACH ROW EXECUTE PROCEDURE SAMPLE_SUBCODE_UNIQUENESS_CHECK();\\012    \\012-- Fixing error messages in old trigger\\012\\012CREATE OR REPLACE FUNCTION SAMPLE_CODE_UNIQUENESS_CHECK() RETURNS trigger AS $$\\012DECLARE\\012   counter  INTEGER;\\012BEGIN\\012  LOCK TABLE samples IN EXCLUSIVE MODE;\\012  \\012\\011  IF (NEW.samp_id_part_of is NULL) THEN\\012\\011\\011  IF (NEW.dbin_id is not NULL) THEN\\012\\011\\011\\011  SELECT count(*) into counter FROM samples \\012\\011\\011      where id != NEW.id and code = NEW.code and samp_id_part_of is NULL and dbin_id = NEW.dbin_id;\\012        IF (counter > 0) THEN\\012\\011\\011\\011\\011  RAISE EXCEPTION 'Insert/Update of Sample (Code: %) failed because database instance sample with the same code already exists.', NEW.code;\\012        END IF;\\012\\011\\011  ELSIF (NEW.grou_id is not NULL) THEN\\012\\011\\011\\011  SELECT count(*) into counter FROM samples \\012\\011\\011\\011\\011  where id != NEW.id and code = NEW.code and samp_id_part_of is NULL and grou_id = NEW.grou_id;\\012\\011\\011\\011  IF (counter > 0) THEN\\012\\011\\011\\011\\011  RAISE EXCEPTION 'Insert/Update of Sample (Code: %) failed because space sample with the same code already exists.', NEW.code;\\012\\011\\011\\011  END IF;\\012      END IF;\\012    ELSE\\012\\011\\011  IF (NEW.dbin_id is not NULL) THEN\\012\\011\\011\\011  SELECT count(*) into counter FROM samples \\012\\011\\011\\011\\011  where id != NEW.id and code = NEW.code and samp_id_part_of = NEW.samp_id_part_of and dbin_id = NEW.dbin_id;\\012\\011\\011\\011  IF (counter > 0) THEN\\012\\011\\011\\011\\011  RAISE EXCEPTION 'Insert/Update of Sample (Code: %) failed because database instance sample with the same code and being the part of the same container already exists.', NEW.code;\\012\\011\\011\\011  END IF;\\012\\011\\011  ELSIF (NEW.grou_id is not NULL) THEN\\012\\011\\011\\011  SELECT count(*) into counter FROM samples \\012\\011\\011\\011\\011  where id != NEW.id and code = NEW.code and samp_id_part_of = NEW.samp_id_part_of and grou_id = NEW.grou_id;\\012\\011\\011\\011  IF (counter > 0) THEN\\012\\011\\011\\011\\011  RAISE EXCEPTION 'Insert/Update of Sample (Code: %) failed because space sample with the same code and being the part of the same container already exists.', NEW.code;\\012\\011\\011\\011  END IF;\\012\\011\\011  END IF;\\012     END IF;   \\012  \\012  RETURN NEW;\\012END;\\012$$ LANGUAGE 'plpgsql';\\012	\N
+./sourceTest/sql/postgresql/062/017=database_version_logs.tsv:054	source/sql/postgresql/migration/migration-053-054.sql	SUCCESS	2010-07-27 11:30:46.766	-- Migration from 053 to 054\\012\\012\\012-- Add RELATIONSHIP_TYPES table\\012CREATE TABLE relationship_types (id TECH_ID NOT NULL, code CODE NOT NULL, label COLUMN_LABEL, parent_label COLUMN_LABEL, child_label COLUMN_LABEL, description DESCRIPTION_2000, registration_timestamp TIME_STAMP_DFL NOT NULL DEFAULT CURRENT_TIMESTAMP, pers_id_registerer TECH_ID NOT NULL, is_managed_internally BOOLEAN_CHAR NOT NULL DEFAULT 'F', is_internal_namespace BOOLEAN_CHAR NOT NULL DEFAULT 'F', dbin_id TECH_ID NOT NULL);\\012\\012-- Add SAMPLE_RELATIONSHIPS table\\012CREATE TABLE sample_relationships (id TECH_ID NOT NULL, sample_id_parent TECH_ID NOT NULL, relationship_id TECH_ID NOT NULL, sample_id_child TECH_ID NOT NULL);\\012\\012-- Add/update constraints\\012ALTER TABLE relationship_types ADD CONSTRAINT rety_pk PRIMARY KEY (id);\\012ALTER TABLE relationship_types ADD CONSTRAINT rety_uk UNIQUE(code,dbin_id);\\012ALTER TABLE sample_relationships ADD CONSTRAINT sare_pk PRIMARY KEY (id);\\012ALTER TABLE sample_relationships ADD CONSTRAINT sare_bk_uk UNIQUE(sample_id_child,sample_id_parent,relationship_id);\\012ALTER TABLE sample_relationships ADD CONSTRAINT sare_data_fk_child FOREIGN KEY (sample_id_child) REFERENCES samples(id) ON DELETE CASCADE;\\012ALTER TABLE sample_relationships ADD CONSTRAINT sare_data_fk_parent FOREIGN KEY (sample_id_parent) REFERENCES samples(id) ON DELETE CASCADE;\\012ALTER TABLE sample_relationships ADD CONSTRAINT sare_data_fk_relationship FOREIGN KEY (relationship_id) REFERENCES relationship_types(id);\\012\\012-- Create index\\012CREATE INDEX sare_data_fk_i_child ON sample_relationships (sample_id_child);\\012CREATE INDEX sare_data_fk_i_parent ON sample_relationships (sample_id_parent);\\012CREATE INDEX sare_data_fk_i_relationship ON sample_relationships (relationship_id);\\012\\012-- Create sequence for RELATIONSHIP_TYPES\\012CREATE SEQUENCE RELATIONSHIP_TYPE_ID_SEQ;\\012CREATE SEQUENCE SAMPLE_RELATIONSHIP_ID_SEQ;\\012\\012-- Create initial relationships\\012insert into relationship_types\\012(id, \\012code, \\012label, \\012parent_label, \\012child_label, \\012description, \\012pers_id_registerer, \\012is_managed_internally, \\012is_internal_namespace, \\012dbin_id) \\012values\\012(\\012nextval('RELATIONSHIP_TYPE_ID_SEQ'),\\012'PARENT_CHILD',\\012'Parent - Child', \\012'Parent', \\012'Child', \\012'Parent - Child relationship', \\012(select id from persons where user_id ='system'), \\012'T', \\012'T', \\012(select id from database_instances where is_original_source = 'T')\\012);\\012\\012insert into relationship_types\\012(id, \\012code, \\012label, \\012parent_label, \\012child_label, \\012description, \\012pers_id_registerer, \\012is_managed_internally, \\012is_internal_namespace, \\012dbin_id) \\012values\\012(\\012nextval('RELATIONSHIP_TYPE_ID_SEQ'),\\012'PLATE_CONTROL_LAYOUT',\\012'Plate - Control Layout', \\012'Plate', \\012'Control Layout', \\012'Plate - Control Layout relationship', \\012(select id from persons where user_id ='system'), \\012'T', \\012'T', \\012(select id from database_instances where is_original_source = 'T')\\012); \\012\\012\\012-- Migrate sample relationships to new schema\\012INSERT INTO sample_relationships (id, sample_id_parent,sample_id_child,relationship_id) (select distinct nextval('SAMPLE_RELATIONSHIP_ID_SEQ') as id, s.SAMP_ID_GENERATED_FROM as parent_id, s.ID as child_id, rt.id as relationship_id from samples s, relationship_types rt  WHERE rt.code = 'PARENT_CHILD' and s.SAMP_ID_GENERATED_FROM is not null); \\012INSERT INTO sample_relationships (id, sample_id_parent,sample_id_child,relationship_id) (select distinct nextval('SAMPLE_RELATIONSHIP_ID_SEQ') as id, s.SAMP_ID_CONTROL_LAYOUT as parent_id, s.ID as child_id, rt.id as relationship_id from samples s, relationship_types rt  WHERE rt.code = 'PLATE_CONTROL_LAYOUT' and s.SAMP_ID_CONTROL_LAYOUT is not null);\\012\\012-- Drop old sample relations\\012ALTER TABLE SAMPLES DROP COLUMN SAMP_ID_TOP;\\012ALTER TABLE SAMPLES DROP COLUMN SAMP_ID_GENERATED_FROM;\\012ALTER TABLE SAMPLES DROP COLUMN SAMP_ID_CONTROL_LAYOUT;\\012\\012--------------------------------------------------------------------------------------\\012--------------------------------------------------------------------------------------\\012-- This is a screening specific migration. Nothing will be performed on openBIS databases \\012-- which are not screening specific.\\012-- \\012-- This migration for each existing connection between oligo well, oligo material and gene material\\012-- creates a direct connection between the well and the gene. \\012--------------------------------------------------------------------------------------\\012--------------------------------------------------------------------------------------\\012 \\012\\011\\012CREATE OR REPLACE FUNCTION CONNECT_WELLS_WITH_GENES() RETURNS void AS $$\\012DECLARE\\012\\011counter  int;\\012\\011oligo_well_exists bool;\\012BEGIN\\012\\011--------------------------------------------------\\012\\011-- create a gene property and assign it to oligo well\\012\\011--------------------------------------------------\\012\\011\\012\\011select true \\012\\011into oligo_well_exists\\012\\011from sample_types \\012\\011where code = 'OLIGO_WELL';\\012\\011\\012\\011if oligo_well_exists IS NULL then \\012\\011\\011-- skip migration if there are no oligo wells\\012\\011\\011return;\\012\\011end if;   \\012\\011\\012\\011insert into property_types(\\012\\011\\011id, \\012\\011\\011code, description, label, \\012\\011\\011daty_id,\\012\\011\\011pers_id_registerer,\\012\\011\\011dbin_id,\\012\\011\\011maty_prop_id) \\012\\011values(\\012\\011\\011\\011nextval('PROPERTY_TYPE_ID_SEQ'), \\012\\011\\011\\011'GENE','Inhibited gene','Gene',\\012\\011\\011\\011(select id from data_types where code = 'MATERIAL'), \\012\\011\\011\\011(select id from persons where user_id ='system'), \\012\\011\\011\\011(select id from database_instances where is_original_source = 'T'), \\012\\011\\011\\011(select id from material_types where code = 'GENE')\\012\\011\\011);\\012\\011\\011\\012\\011insert into sample_type_property_types( \\012\\011  id,\\012\\011  saty_id,\\012\\011  prty_id,\\012\\011  is_mandatory,\\012\\011  pers_id_registerer,\\012\\011  ordinal\\012\\011) values(\\012\\011\\011\\011nextval('stpt_id_seq'), \\012\\011\\011\\011(select id from sample_types where code = 'OLIGO_WELL'),\\012\\011\\011\\011(select id from property_types where code = 'GENE'),\\012\\011\\011\\011false,\\012\\011\\011\\011(select id from persons where user_id ='system'),\\012\\011\\011\\011(select max(ordinal)+1 from sample_type_property_types \\012\\011\\011\\011\\011where saty_id = (select id from sample_types where code = 'OLIGO_WELL'))\\012\\011\\011);\\012\\012\\011--------------------------------------------------\\012\\011-- create a gene material property for each oligo well\\012\\011--------------------------------------------------\\012\\011\\011\\012\\011select \\011count(*)\\012\\011into counter\\012\\011from\\012\\011\\011samples well, sample_types well_type, sample_properties well_props, \\012\\011\\011materials well_material, material_properties well_material_props,\\012\\011\\011materials nested_well_material\\012\\011where\\012\\011\\011well_type.code = 'OLIGO_WELL' and\\012\\011\\011-- find 'well_material' assigned to the well\\012\\011\\011well_props.samp_id = well.id and well_material.id = well_props.mate_prop_id and \\012\\011\\011-- additional joins to entity type tables\\012\\011\\011well_type.id = well.saty_id and\\012\\011\\011-- well content material property\\012\\011\\011well_material_props.mate_id = well_material.id and \\012\\011\\011-- material connected to the material in the well (e.g. gene)\\012\\011\\011well_material_props.mate_prop_id = nested_well_material.id and\\012\\011\\011nested_well_material.maty_id = (select id from material_types where code = 'GENE');\\012\\011\\012\\011if counter = 0 then \\012\\011\\011-- skip migration if there are no genes indirectly connected to oligo wells\\012\\011\\011return;\\012\\011end if;   \\012\\012\\011insert into sample_properties(id, samp_id, stpt_id, mate_prop_id, pers_id_registerer) (\\012\\011\\011select \\011nextval('sample_property_id_seq') id, \\012\\011\\011\\011well.id samp_id, \\012\\011\\011\\011(select stpt.id from sample_type_property_types stpt, property_types props where stpt.prty_id = props.id and props.code='GENE') stpt_id,\\012\\011\\011\\011nested_well_material.id mate_prop_id,\\012\\011\\011\\011(select id from persons where user_id ='system') pers_id_registerer \\012\\011\\011from\\012\\011\\011\\011samples well, sample_types well_type, sample_properties well_props, \\012\\011\\011\\011materials well_material, material_properties well_material_props,\\012\\011\\011\\011materials nested_well_material\\012\\011\\011where\\012\\011\\011\\011well_type.code = 'OLIGO_WELL' and\\012\\011\\011\\011-- find 'well_material' assigned to the well\\012\\011\\011\\011well_props.samp_id = well.id and well_material.id = well_props.mate_prop_id and \\012\\011\\011\\011-- additional joins to entity type tables\\012\\011\\011\\011well_type.id = well.saty_id and\\012\\011\\011\\011-- well content material property\\012\\011\\011\\011well_material_props.mate_id = well_material.id and \\012\\011\\011\\011-- material connected to the material in the well (e.g. gene)\\012\\011\\011\\011well_material_props.mate_prop_id = nested_well_material.id and\\012\\011\\011\\011nested_well_material.maty_id = (select id from material_types where code = 'GENE')\\012\\011);\\012\\012END;\\012$$ LANGUAGE 'plpgsql';\\012\\012select CONNECT_WELLS_WITH_GENES();\\012drop function CONNECT_WELLS_WITH_GENES();\\012\\012--------------------------------------------------------------------------------------\\012--------------------------------------------------------------------------------------\\012\\012-- drop dataset triggers\\012\\012DROP TRIGGER check_dataset_relationships_on_data_table_modification ON data;\\012DROP FUNCTION check_dataset_relationships_on_data_table_modification();\\012DROP TRIGGER check_dataset_relationships_on_relationships_table_modification ON data_set_relationships;\\012DROP FUNCTION check_dataset_relationships_on_relationships_table_modification();\\012 \\012\\012\\012\\012\\012\\012\\012\\012	\N
+./sourceTest/sql/postgresql/062/017=database_version_logs.tsv:056	source/sql/postgresql/migration/migration-055-056.sql	SUCCESS	2010-09-10 09:06:20.278	-- Migration from 055 to 056\\012\\012--------------------------------------------------------------------------------------\\012--------------------------------------------------------------------------------------\\012-- Screening specific migration. Nothing will be performed on openBIS databases \\012-- which are not screening specific.\\012--------------------------------------------------------------------------------------\\012--------------------------------------------------------------------------------------\\012\\012CREATE OR REPLACE FUNCTION merge_words(text, text) RETURNS text AS $$\\012DECLARE\\012  BEGIN\\012    IF  character_length($1) > 0 THEN\\012      RETURN $1 || ' ' || $2;\\012    ELSE\\012      RETURN $2;\\012    END IF;\\012  END;\\012$$ LANGUAGE plpgsql;\\012\\012CREATE AGGREGATE merge_words(text)\\012(\\012  SFUNC = merge_words,\\012  STYPE = text\\012);\\012\\012\\012CREATE OR REPLACE FUNCTION REPLACE_GENE_SYMBOL_BY_GENE_ID() RETURNS void AS $$\\012DECLARE\\012\\011counter  int;\\012\\011library_id_assigned_to_gene bool;\\012BEGIN\\012\\011--------------------------------------------------\\012\\011-- create a GENE_SYMBOL property and assign it to GENE\\012\\011--------------------------------------------------\\012\\011\\012\\011select true  \\012\\011into library_id_assigned_to_gene \\012\\011from material_type_property_types mtpt, material_types mt, property_types pt  \\012\\011where mtpt.maty_id = mt.id and mtpt.prty_id = pt.id \\012\\011\\011and mt.code = 'GENE' and pt.code = 'LIBRARY_ID';\\012\\011\\012\\011if library_id_assigned_to_gene IS NULL then \\012\\011\\011-- skip migration if gene has no library_id property\\012\\011\\011return;\\012\\011end if; \\012\\011\\012\\011\\012\\011select count(*)\\012\\011into counter \\012\\011from  \\012\\011\\011(select m.id, count(mp.id) as c \\012\\011\\011\\011from materials m, material_types mt, material_properties mp, material_type_property_types mtpt, property_types pt \\012\\011\\011\\011where m.maty_id = mt.id and mp.mate_id = m.id and mp.mtpt_id = mtpt.id and mtpt.maty_id = mt.id and pt.id = mtpt.prty_id\\012\\011\\011\\011\\011and mt.code = 'GENE' and pt.code = 'LIBRARY_ID' \\012\\011\\011\\011group by m.id) as counter_table \\012\\011where c < 1; \\012\\011\\012\\011if counter > 0 then \\012\\011\\011-- skip migration if there is at least one gene without library_id\\012\\011\\011return;\\012\\011end if;\\012\\011\\012\\011\\012\\011insert into property_types\\012\\011\\011(id\\012\\011\\011,code\\012\\011\\011,description\\012\\011\\011,label\\012\\011\\011,daty_id\\012\\011\\011,pers_id_registerer\\012\\011\\011,dbin_id)\\012\\011values \\012\\011\\011(nextval('PROPERTY_TYPE_ID_SEQ')\\012\\011\\011,'GENE_SYMBOLS'\\012\\011\\011,'Gene symbols'\\012\\011\\011,'Gene symbols'\\012\\011\\011,(select id from data_types where code ='VARCHAR')\\012\\011\\011,(select id from persons where user_id ='system')\\012\\011\\011,(select id from database_instances where is_original_source = 'T')\\012\\011);\\012\\011\\011\\012\\011insert into material_type_property_types( \\012\\011  id,\\012\\011  maty_id,\\012\\011  prty_id,\\012\\011  is_mandatory,\\012\\011  pers_id_registerer,\\012\\011  ordinal\\012\\011) values(\\012\\011\\011\\011nextval('mtpt_id_seq'), \\012\\011\\011\\011(select id from material_types where code = 'GENE'),\\012\\011\\011\\011(select id from property_types where code = 'GENE_SYMBOLS'),\\012\\011\\011\\011false,\\012\\011\\011\\011(select id from persons where user_id ='system'),\\012\\011\\011\\011(select max(ordinal)+1 from material_type_property_types \\012\\011\\011\\011\\011where maty_id = (select id from material_types where code = 'GENE'))\\012\\011\\011);\\012\\012\\011--------------------------------------------------\\012\\011-- create temporary table with all gene migration information\\012\\011--------------------------------------------------\\012\\012\\011create temp table genes \\012\\011(\\012\\011\\011id tech_id,\\012\\011\\011code code,\\012\\011\\011library_id generic_value,\\012\\011\\011gene_codes generic_value,\\012\\011\\011new_id tech_id,\\012\\011\\011library_tech_id tech_id\\011\\011\\012\\011);\\012\\011\\012\\011insert into genes (id, code, library_id, library_tech_id)\\012\\011\\011(select m.id, m.code, mp.value as library_id, mp.id as library_tech_id from materials m, material_properties mp, material_type_property_types mtpt, property_types pt, material_types mt\\012\\011\\011where mp.mate_id = m.id and  mp.mtpt_id = mtpt.id and pt.id = mtpt.prty_id and pt.code = 'LIBRARY_ID' and mt.id = m.maty_id and mt.id = mtpt.maty_id and mt.code = 'GENE');\\012\\011\\012\\011update genes set new_id = map.to_id from (select g_from.id as from_id, min(g_to.id) as to_id  from genes g_from, genes g_to where g_from.library_id = g_to.library_id group by g_from.id) as map where map.from_id = id;\\011\\012\\011\\012\\011update genes set gene_codes = map.gene_codes from (select g_from.library_id as lib_id, merge_words(distinct g_to.code) as gene_codes from genes g_from, genes g_to where g_from.library_id = g_to.library_id group by g_from.library_id) as map where map.lib_id = library_id;\\011\\012\\012\\011--------------------------------------------------\\012\\011-- update gene references\\012\\011--------------------------------------------------\\012\\012\\011update EXPERIMENTS set MATE_ID_STUDY_OBJECT = genes.new_id from genes where genes.id = MATE_ID_STUDY_OBJECT and not genes.id = genes.new_id;\\012\\011update EXPERIMENT_PROPERTIES set  MATE_PROP_ID = genes.new_id from genes where genes.id = MATE_PROP_ID and not genes.id = genes.new_id;\\012\\011update MATERIAL_PROPERTIES set  MATE_PROP_ID = genes.new_id from genes where genes.id = MATE_PROP_ID and not genes.id = genes.new_id;\\012\\011update SAMPLE_PROPERTIES set  MATE_PROP_ID = genes.new_id from genes where genes.id = MATE_PROP_ID and not genes.id = genes.new_id;\\012\\011update DATA_SET_PROPERTIES set  MATE_PROP_ID = genes.new_id from genes where genes.id = MATE_PROP_ID and not genes.id = genes.new_id;\\012\\011\\012\\011delete from  material_properties where mate_id in (select id from genes where not genes.id = genes.new_id);\\012\\011delete from MATERIALS where id in (select id from genes where not genes.id = genes.new_id);\\012\\012\\011delete from genes where id in (select id from genes where not genes.id = genes.new_id);\\012\\012\\012\\011--------------------------------------------------\\012\\011-- replace gene code with library_id\\012\\011--------------------------------------------------\\012\\011\\012\\011update materials set code = genes.library_id from genes where materials.id = genes.id ;\\012\\011delete from material_properties where id in (select library_tech_id from genes);\\012\\011\\012\\011--------------------------------------------------\\012\\011-- create a gene symbols property for each gene\\012\\011--------------------------------------------------\\012\\011\\012\\011insert into material_properties\\012\\011\\011(id\\012\\011  , mate_id\\012\\011  , mtpt_id\\012\\011  , "value"\\012\\011  , pers_id_registerer)\\012\\011\\011(select nextval('material_property_id_seq') id\\012\\011  \\011, genes.id  mate_id\\012\\011    , (select mtpt.id\\012\\011    \\011\\011from   material_type_property_types mtpt, material_types mt, property_types pt\\012\\011    \\011\\011where  pt.code = 'GENE_SYMBOLS' and mt.code = 'GENE' and mtpt.prty_id = pt.id\\012\\011        \\011and mtpt.maty_id = mt.id) mtpt_id\\012\\011    , genes.gene_codes "value"\\012\\011    , (select id from persons where user_id = 'system') pers_id_registerer\\012\\011 \\011from genes); \\012\\012\\011--------------------------------------------------\\012\\011-- delete temporary table\\012\\011--------------------------------------------------\\012\\011\\012\\011drop table genes;\\012\\011\\012END;\\012$$ LANGUAGE 'plpgsql';\\012\\012select REPLACE_GENE_SYMBOL_BY_GENE_ID();\\012drop function REPLACE_GENE_SYMBOL_BY_GENE_ID();\\012DROP AGGREGATE merge_words(text);\\012drop function merge_words(text,text);\\012\\012\\012--------------------------------------------------------------------------------------\\012--------------------------------------------------------------------------------------\\012\\012UPDATE sample_types SET code = 'SIRNA_WELL' WHERE code = 'OLIGO_WELL';\\012UPDATE material_types SET code = 'SIRNA' WHERE code = 'OLIGO';\\012UPDATE property_types SET code = 'SIRNA', label = 'siRNA' WHERE code = 'OLIGO';\\012\\012\\012\\012\\012\\012\\012\\012\\012\\012\\012\\012\\012\\012\\012\\012\\012\\012\\012\\012	\N
+./sourceTest/sql/postgresql/062/017=database_version_logs.tsv:059	source/sql/postgresql/migration/migration-058-059.sql	SUCCESS	2010-09-29 13:37:07.231	-- Migration from 058 to 059\\012\\012-- Add ENTITY_TYPE_CODE column to QUERIES\\012ALTER TABLE queries ADD COLUMN entity_type_code CODE;\\012\\012------------------------------------------------------------------------------------\\012--  Purpose:  Create trigger that checks if entity_type_code specified in a query\\012--            matches a code of an entity of type specified in query_type.\\012------------------------------------------------------------------------------------\\012\\012CREATE OR REPLACE FUNCTION query_entity_type_code_check() RETURNS trigger AS $$\\012DECLARE\\012   counter  INTEGER;\\012BEGIN\\012   if (NEW.entity_type_code IS NOT NULL) then\\012     if (NEW.query_type = 'GENERIC') then\\012       RAISE EXCEPTION 'Insert/Update of query (Name: %) failed, as entity_type has to be null for GENERIC queries.', NEW.name;\\012     elsif (NEW.query_type = 'EXPERIMENT') then\\012       SELECT count(*) INTO counter FROM experiment_types WHERE code = NEW.entity_type_code;\\012\\011\\011 elsif (NEW.query_type = 'DATA_SET') then\\012       SELECT count(*) INTO counter FROM data_set_types WHERE code = NEW.entity_type_code;\\012\\011\\011 elsif (NEW.query_type = 'MATERIAL') then\\012       SELECT count(*) INTO counter FROM material_types WHERE code = NEW.entity_type_code;\\012\\011\\011 elsif (NEW.query_type = 'SAMPLE') then\\012       SELECT count(*) INTO counter FROM sample_types WHERE code = NEW.entity_type_code;\\012\\011\\011 end if;\\012\\011\\011 if (counter = 0) then\\012\\011\\011\\011 RAISE EXCEPTION 'Insert/Update of query (Name: %) failed because % type (Code: %) does not exist.', NEW.name, NEW.query_type, NEW.entity_type_code;\\012\\011\\011 end if;\\011\\011\\011\\012   end if;\\012   RETURN NEW;\\012END;\\012$$ LANGUAGE 'plpgsql';\\012\\012CREATE TRIGGER query_entity_type_code_check BEFORE INSERT OR UPDATE ON queries\\012    FOR EACH ROW EXECUTE PROCEDURE query_entity_type_code_check();\\012	\N
+./sourceTest/sql/postgresql/062/017=database_version_logs.tsv:062	source/sql/postgresql/migration/migration-061-062.sql	SUCCESS	2010-11-25 16:02:07.224	\\012CREATE OR REPLACE FUNCTION sample_code_uniqueness_check() RETURNS trigger\\012    LANGUAGE plpgsql\\012    AS $$\\012DECLARE\\012   counter  INTEGER;\\012BEGIN\\012  LOCK TABLE samples IN EXCLUSIVE MODE;\\012  \\012\\011  IF (NEW.samp_id_part_of is NULL) THEN\\012\\011\\011  IF (NEW.dbin_id is not NULL) THEN\\012\\011\\011\\011  SELECT count(*) into counter FROM samples \\012\\011\\011      where id != NEW.id and code = NEW.code and samp_id_part_of is NULL and dbin_id = NEW.dbin_id;\\012        IF (counter > 0) THEN\\012\\011\\011\\011\\011  RAISE EXCEPTION 'Insert/Update of Sample (Code: %) failed because database instance sample with the same code already exists.', NEW.code;\\012        END IF;\\012\\011\\011  ELSIF (NEW.space_id is not NULL) THEN\\012\\011\\011\\011  SELECT count(*) into counter FROM samples \\012\\011\\011\\011\\011  where id != NEW.id and code = NEW.code and samp_id_part_of is NULL and space_id = NEW.grou_id;\\012\\011\\011\\011  IF (counter > 0) THEN\\012\\011\\011\\011\\011  RAISE EXCEPTION 'Insert/Update of Sample (Code: %) failed because space sample with the same code already exists.', NEW.code;\\012\\011\\011\\011  END IF;\\012      END IF;\\012    ELSE\\012\\011\\011  IF (NEW.dbin_id is not NULL) THEN\\012\\011\\011\\011  SELECT count(*) into counter FROM samples \\012\\011\\011\\011\\011  where id != NEW.id and code = NEW.code and samp_id_part_of = NEW.samp_id_part_of and dbin_id = NEW.dbin_id;\\012\\011\\011\\011  IF (counter > 0) THEN\\012\\011\\011\\011\\011  RAISE EXCEPTION 'Insert/Update of Sample (Code: %) failed because database instance sample with the same code and being the part of the same container already exists.', NEW.code;\\012\\011\\011\\011  END IF;\\012\\011\\011  ELSIF (NEW.space_id is not NULL) THEN\\012\\011\\011\\011  SELECT count(*) into counter FROM samples \\012\\011\\011\\011\\011  where id != NEW.id and code = NEW.code and samp_id_part_of = NEW.samp_id_part_of and space_id = NEW.space_id;\\012\\011\\011\\011  IF (counter > 0) THEN\\012\\011\\011\\011\\011  RAISE EXCEPTION 'Insert/Update of Sample (Code: %) failed because space sample with the same code and being the part of the same container already exists.', NEW.code;\\012\\011\\011\\011  END IF;\\012\\011\\011  END IF;\\012     END IF;   \\012  \\012  RETURN NEW;\\012END;\\012$$;\\012\\012\\012CREATE OR REPLACE FUNCTION sample_subcode_uniqueness_check() RETURNS trigger\\012    LANGUAGE plpgsql\\012    AS $$\\012DECLARE\\012   counter  INTEGER;\\012   unique_subcode  BOOLEAN_CHAR;\\012BEGIN\\012  LOCK TABLE samples IN EXCLUSIVE MODE;\\012  \\012  SELECT is_subcode_unique into unique_subcode FROM sample_types WHERE id = NEW.saty_id;\\012  \\012  IF (unique_subcode) THEN\\012    IF (NEW.dbin_id is not NULL) THEN\\012\\011\\011\\011SELECT count(*) into counter FROM samples \\012\\011\\011\\011\\011where id != NEW.id and code = NEW.code and saty_id = NEW.saty_id and dbin_id = NEW.dbin_id;\\012\\011\\011\\011IF (counter > 0) THEN\\012\\011\\011\\011\\011RAISE EXCEPTION 'Insert/Update of Sample (Code: %) failed because database instance sample of the same type with the same subcode already exists.', NEW.code;\\012\\011\\011\\011END IF;\\012\\011\\011ELSIF (NEW.space_id is not NULL) THEN\\012\\011\\011\\011SELECT count(*) into counter FROM samples \\012\\011\\011\\011\\011where id != NEW.id and code = NEW.code and saty_id = NEW.saty_id and space_id = NEW.space_id;\\012\\011\\011\\011IF (counter > 0) THEN\\012\\011\\011\\011\\011RAISE EXCEPTION 'Insert/Update of Sample (Code: %) failed because space sample of the same type with the same subcode already exists.', NEW.code;\\012\\011\\011\\011END IF;\\012\\011\\011END IF;\\012  END IF;\\012  \\012  RETURN NEW;\\012END;\\012$$;\\012\\012ALTER TABLE groups RENAME TO spaces;\\012\\012ALTER SEQUENCE group_id_seq RENAME TO space_id_seq;\\012\\012ALTER TABLE persons\\011RENAME grou_id TO space_id;\\012ALTER TABLE projects RENAME grou_id TO space_id;\\012ALTER TABLE role_assignments RENAME grou_id TO space_id;\\012ALTER TABLE samples\\011RENAME grou_id TO space_id;\\012\\012-- migrate EVENTS table\\012\\012ALTER TABLE events\\012\\011DROP CONSTRAINT evnt_et_enum_ck;\\012\\012update events set entity_type = 'SPACE' where entity_type = 'GROUP';\\012\\012ALTER TABLE events ADD CONSTRAINT evnt_et_enum_ck CHECK \\012\\011(entity_type IN ('ATTACHMENT', 'DATASET', 'EXPERIMENT', 'SPACE', 'MATERIAL', 'PROJECT', 'PROPERTY_TYPE', 'SAMPLE', 'VOCABULARY', 'AUTHORIZATION_GROUP')); \\012\\012ALTER TABLE persons\\012\\011DROP CONSTRAINT pers_grou_fk;\\012\\012ALTER TABLE persons\\012\\011ADD CONSTRAINT pers_space_fk FOREIGN KEY (space_id) REFERENCES spaces(id);\\012\\012ALTER TABLE projects\\012\\011DROP CONSTRAINT proj_bk_uk;\\012\\012ALTER TABLE projects\\012\\011DROP CONSTRAINT proj_grou_fk;\\012\\012ALTER TABLE projects\\012\\011ADD CONSTRAINT proj_bk_uk UNIQUE (code, space_id);\\012\\012ALTER TABLE projects\\012\\011ADD CONSTRAINT proj_space_fk FOREIGN KEY (space_id) REFERENCES spaces(id);\\012\\012ALTER TABLE role_assignments\\012\\011DROP CONSTRAINT roas_dbin_grou_arc_ck;\\012\\012ALTER TABLE role_assignments\\012\\011DROP CONSTRAINT roas_ag_group_bk_uk;\\012\\012ALTER TABLE role_assignments\\012\\011DROP CONSTRAINT roas_pe_group_bk_uk;\\012\\012ALTER TABLE role_assignments\\012\\011DROP CONSTRAINT roas_grou_fk;\\012\\012ALTER TABLE role_assignments\\012\\011ADD CONSTRAINT roas_dbin_space_arc_ck CHECK ((((dbin_id IS NOT NULL) AND (space_id IS NULL)) OR ((dbin_id IS NULL) AND (space_id IS NOT NULL))));\\012\\012ALTER TABLE role_assignments\\012\\011ADD CONSTRAINT roas_ag_space_bk_uk UNIQUE (ag_id_grantee, role_code, space_id);\\012\\012ALTER TABLE role_assignments\\012\\011ADD CONSTRAINT roas_pe_space_bk_uk UNIQUE (pers_id_grantee, role_code, space_id);\\012\\012ALTER TABLE role_assignments\\012\\011ADD CONSTRAINT roas_space_fk FOREIGN KEY (space_id) REFERENCES spaces(id);\\012\\012ALTER TABLE samples\\012\\011DROP CONSTRAINT samp_dbin_grou_arc_ck;\\012\\012ALTER TABLE samples\\012\\011DROP CONSTRAINT samp_grou_fk;\\012\\012ALTER TABLE samples\\012\\011ADD CONSTRAINT samp_dbin_space_arc_ck CHECK ((((dbin_id IS NOT NULL) AND (space_id IS NULL)) OR ((dbin_id IS NULL) AND (space_id IS NOT NULL))));\\012\\012ALTER TABLE samples\\012\\011ADD CONSTRAINT samp_space_fk FOREIGN KEY (space_id) REFERENCES spaces(id);\\012\\012ALTER TABLE spaces\\012  DROP CONSTRAINT grou_bk_uk,\\012  ADD CONSTRAINT space_bk_uk UNIQUE (code, dbin_id);\\012\\012ALTER TABLE spaces\\012  DROP CONSTRAINT grou_dbin_fk,\\012  ADD CONSTRAINT space_dbin_fk FOREIGN KEY (dbin_id) REFERENCES database_instances(id);\\012\\012ALTER TABLE spaces\\012  DROP CONSTRAINT grou_pers_fk_registerer,\\012  ADD CONSTRAINT space_pers_fk_registerer FOREIGN KEY (pers_id_registerer) REFERENCES persons(id);\\012\\012ALTER INDEX pers_grou_fk_i RENAME TO pers_space_fk_i;\\012\\012ALTER INDEX proj_grou_fk_i RENAME TO proj_space_fk_i;\\012\\012ALTER INDEX roas_grou_fk_i RENAME TO roas_space_fk_i;\\012\\012ALTER INDEX grou_pk RENAME TO space_pk;\\012\\012ALTER INDEX grou_dbin_fk_i RENAME TO space_dbin_fk_i;\\012\\012ALTER INDEX grou_pers_registered_by_fk_i RENAME TO space_pers_registered_by_fk_i;\\012\\012	\N
+./sourceTest/sql/postgresql/062/schema-062.sql:    LANGUAGE plpgsql
+./sourceTest/sql/postgresql/062/schema-062.sql:    LANGUAGE plpgsql
+./sourceTest/sql/postgresql/062/schema-062.sql:    LANGUAGE plpgsql
+./sourceTest/sql/postgresql/062/schema-062.sql:    LANGUAGE plpgsql
+./sourceTest/sql/postgresql/062/schema-062.sql:    LANGUAGE plpgsql
+./sourceTest/sql/postgresql/062/schema-062.sql:    LANGUAGE plpgsql
+./sourceTest/sql/postgresql/062/schema-062.sql:    LANGUAGE plpgsql
+./sourceTest/sql/postgresql/062/schema-062.sql:    LANGUAGE plpgsql
+./sourceTest/sql/postgresql/062/schema-062.sql:    LANGUAGE plpgsql
+./sourceTest/sql/postgresql/063/.svn/text-base/017=database_version_logs.tsv.svn-base:027	D:\\User\\felmer\\dev-workspace\\openbis/source/sql/postgresql/027/function-027.sql	SUCCESS	2008-11-05 09:18:00.403	-- Creating Functions\\012\\012------------------------------------------------------------------------------------\\012--  Purpose:  Create function RENAME_SEQUENCE() that is required for renaming the sequences belonging to tables\\012------------------------------------------------------------------------------------\\012CREATE FUNCTION RENAME_SEQUENCE(OLD_NAME VARCHAR, NEW_NAME VARCHAR) RETURNS INTEGER AS $$\\012DECLARE\\012  CURR_SEQ_VAL   INTEGER;\\012BEGIN\\012  SELECT INTO CURR_SEQ_VAL NEXTVAL(OLD_NAME);\\012  EXECUTE 'CREATE SEQUENCE ' || NEW_NAME || ' START WITH ' || CURR_SEQ_VAL;\\012  EXECUTE 'DROP SEQUENCE ' || OLD_NAME;\\012  RETURN CURR_SEQ_VAL;\\012END;\\012$$ LANGUAGE 'plpgsql';\\012\\012\\012------------------------------------------------------------------------------------\\012--  Purpose:  Create trigger CONTROLLED_VOCABULARY_CHECK \\012------------------------------------------------------------------------------------\\012\\012CREATE OR REPLACE FUNCTION CONTROLLED_VOCABULARY_CHECK() RETURNS trigger AS $$\\012DECLARE\\012   v_code  CODE;\\012BEGIN\\012\\012   select code into v_code from data_types where id = NEW.daty_id;\\012\\012   -- Check if the data is of type "CONTROLLEDVOCABULARY"\\012   if v_code = 'CONTROLLEDVOCABULARY' then\\012      if NEW.covo_id IS NULL then\\012         RAISE EXCEPTION 'Insert/Update of Property Type (Code: %) failed, as its Data Type is CONTROLLEDVOCABULARY, but it is not linked to a Controlled Vocabulary.', NEW.code;\\012      end if;\\012   end if;\\012\\012   RETURN NEW;\\012\\012END;\\012$$ LANGUAGE 'plpgsql';\\012\\012CREATE TRIGGER CONTROLLED_VOCABULARY_CHECK BEFORE INSERT OR UPDATE ON PROPERTY_TYPES\\012    FOR EACH ROW EXECUTE PROCEDURE CONTROLLED_VOCABULARY_CHECK();\\012\\012\\012------------------------------------------------------------------------------------\\012--  Purpose:  Create trigger EXTERNAL_DATA_STORAGE_FORMAT_CHECK \\012------------------------------------------------------------------------------------\\012\\012CREATE OR REPLACE FUNCTION EXTERNAL_DATA_STORAGE_FORMAT_CHECK() RETURNS trigger AS $$\\012DECLARE\\012   v_covo_code  CODE;\\012   data_code CODE;\\012BEGIN\\012\\012   select code into v_covo_code from controlled_vocabularies\\012      where is_internal_namespace = true and \\012         id = (select covo_id from controlled_vocabulary_terms where id = NEW.cvte_id_stor_fmt);\\012   -- Check if the data storage format is a term of the controlled vocabulary "STORAGE_FORMAT"\\012   if v_covo_code != 'STORAGE_FORMAT' then\\012      select code into data_code from data where id = NEW.data_id; \\012      RAISE EXCEPTION 'Insert/Update of Data (Code: %) failed, as its Storage Format is %, but is required to be STORAGE_FORMAT.', data_code, v_covo_code;\\012   end if;\\012\\012   RETURN NEW;\\012\\012END;\\012$$ LANGUAGE 'plpgsql';\\012\\012CREATE TRIGGER EXTERNAL_DATA_STORAGE_FORMAT_CHECK BEFORE INSERT OR UPDATE ON EXTERNAL_DATA\\012    FOR EACH ROW EXECUTE PROCEDURE EXTERNAL_DATA_STORAGE_FORMAT_CHECK();\\012\\012------------------------------------------------------------------------------------\\012--  Purpose:  Create trigger SAMPLE_CODE_UNIQUENESS_CHECK \\012------------------------------------------------------------------------------------\\012\\012CREATE OR REPLACE FUNCTION SAMPLE_CODE_UNIQUENESS_CHECK() RETURNS trigger AS $$\\012DECLARE\\012   counter  INTEGER;\\012BEGIN\\012\\011IF (NEW.samp_id_part_of is NULL) THEN\\012\\011\\011IF (NEW.dbin_id is not NULL) THEN\\012\\011\\011\\011SELECT count(*) into counter FROM samples \\012\\011\\011\\011\\011where id != NEW.id and code = NEW.code and samp_id_part_of is NULL and dbin_id = NEW.dbin_id;\\012\\011\\011\\011IF (counter > 0) THEN\\012\\011\\011\\011\\011RAISE EXCEPTION 'Insert/Update of Sample (Code: %) failed because database instance sample with the same code already exists.', NEW.code;\\012\\011\\011\\011END IF;\\012\\011\\011ELSIF (NEW.grou_id is not NULL) THEN\\012\\011\\011\\011SELECT count(*) into counter FROM samples \\012\\011\\011\\011\\011where id != NEW.id and code = NEW.code and samp_id_part_of is NULL and grou_id = NEW.grou_id;\\012\\011\\011\\011IF (counter > 0) THEN\\012\\011\\011\\011\\011RAISE EXCEPTION 'Insert/Update of Sample (Code: %) failed because group sample with the same code already exists.', NEW.code;\\012\\011\\011\\011END IF;\\012\\011\\011END IF;\\012        ELSE\\012\\011\\011IF (NEW.dbin_id is not NULL) THEN\\012\\011\\011\\011SELECT count(*) into counter FROM samples \\012\\011\\011\\011\\011where id != NEW.id and code = NEW.code and samp_id_part_of = NEW.samp_id_part_of and dbin_id = NEW.dbin_id;\\012\\011\\011\\011IF (counter > 0) THEN\\012\\011\\011\\011\\011RAISE EXCEPTION 'Insert/Update of Sample (Code: %) failed because database instance sample with the same code and being the part of the same parent already exists.', NEW.code;\\012\\011\\011\\011END IF;\\012\\011\\011ELSIF (NEW.grou_id is not NULL) THEN\\012\\011\\011\\011SELECT count(*) into counter FROM samples \\012\\011\\011\\011\\011where id != NEW.id and code = NEW.code and samp_id_part_of = NEW.samp_id_part_of and grou_id = NEW.grou_id;\\012\\011\\011\\011IF (counter > 0) THEN\\012\\011\\011\\011\\011RAISE EXCEPTION 'Insert/Update of Sample (Code: %) failed because group sample with the same code and being the part of the same parent already exists.', NEW.code;\\012\\011\\011\\011END IF;\\012\\011\\011END IF;\\012        END IF;   \\012   RETURN NEW;\\012END;\\012$$ LANGUAGE 'plpgsql';\\012\\012CREATE TRIGGER SAMPLE_CODE_UNIQUENESS_CHECK BEFORE INSERT OR UPDATE ON SAMPLES\\012    FOR EACH ROW EXECUTE PROCEDURE SAMPLE_CODE_UNIQUENESS_CHECK();\\012	\N
+./sourceTest/sql/postgresql/063/.svn/text-base/017=database_version_logs.tsv.svn-base:028	source/sql/postgresql/migration/migration-027-028.sql	SUCCESS	2008-11-18 13:24:17.508	-- Create EXPERIMENT_ATTACHMENT_CONTENTS.\\012CREATE TABLE EXPERIMENT_ATTACHMENT_CONTENTS (ID TECH_ID NOT NULL,VALUE FILE NOT NULL);\\012CREATE SEQUENCE EXPERIMENT_ATTACHMENT_CONTENT_ID_SEQ;\\012ALTER TABLE EXPERIMENT_ATTACHMENT_CONTENTS ADD CONSTRAINT EXAC_PK PRIMARY KEY(ID);\\012\\012-- Alter EXPERIMENT_ATTACHMENTS by adding the new column which has a NULL constraint.\\012-- The NOT NULL constraint is added later on.\\012ALTER TABLE EXPERIMENT_ATTACHMENTS ADD COLUMN EXAC_ID TECH_ID;\\012\\012-- Does the VALUE migration between EXPERIMENT_ATTACHMENTS to EXPERIMENT_ATTACHMENT_CONTENTS.\\012CREATE OR REPLACE FUNCTION move_exp_att_content() RETURNS integer AS $$\\012DECLARE\\012    rec RECORD;\\012    seq BIGINT;\\012BEGIN\\012  FOR rec IN SELECT id, value FROM EXPERIMENT_ATTACHMENTS LOOP\\012  \\011seq := nextval('EXPERIMENT_ATTACHMENT_CONTENT_ID_SEQ');\\012    INSERT INTO EXPERIMENT_ATTACHMENT_CONTENTS (id, value) VALUES (seq, rec.value);\\012    UPDATE EXPERIMENT_ATTACHMENTS SET exac_id = seq WHERE id = rec.id;\\012  END LOOP;\\012  RETURN 1;\\012END;\\012$$ LANGUAGE 'plpgsql';\\012\\012-- Call the function.\\012SELECT move_exp_att_content();\\012DROP FUNCTION move_exp_att_content();\\012\\012\\012-- Finish EXPERIMENT_ATTACHMENTS changes.\\012ALTER TABLE EXPERIMENT_ATTACHMENTS ADD CONSTRAINT EXAT_CONT_FK FOREIGN KEY (EXAC_ID) REFERENCES EXPERIMENT_ATTACHMENT_CONTENTS(ID);\\012ALTER TABLE EXPERIMENT_ATTACHMENTS DROP COLUMN VALUE;\\012ALTER TABLE EXPERIMENT_ATTACHMENTS ALTER COLUMN EXAC_ID SET NOT NULL;\\012	\N
+./sourceTest/sql/postgresql/063/.svn/text-base/017=database_version_logs.tsv.svn-base:029	source/sql/postgresql/migration/migration-028-029.sql	SUCCESS	2009-03-18 10:50:20.105	-- -------\\012-- add modification_timestamp field to allow edition with Hibernate\\012-- -------\\012\\012ALTER TABLE samples\\012\\011ADD COLUMN modification_timestamp TIME_STAMP DEFAULT CURRENT_TIMESTAMP;\\012\\012ALTER TABLE experiments\\012\\011ADD COLUMN modification_timestamp TIME_STAMP DEFAULT CURRENT_TIMESTAMP;\\012\\012ALTER TABLE materials\\012\\011ADD COLUMN modification_timestamp TIME_STAMP DEFAULT CURRENT_TIMESTAMP;\\012\\012ALTER TABLE experiment_properties\\012\\011ADD COLUMN modification_timestamp TIME_STAMP DEFAULT CURRENT_TIMESTAMP;\\012\\012ALTER TABLE material_properties\\012\\011ADD COLUMN modification_timestamp TIME_STAMP DEFAULT CURRENT_TIMESTAMP;\\012\\012ALTER TABLE sample_properties\\012\\011ADD COLUMN modification_timestamp TIME_STAMP DEFAULT CURRENT_TIMESTAMP;\\012\\012-- -------\\012-- add property data type which references materials\\012-- -------\\012\\012ALTER TABLE property_types\\012\\011ADD COLUMN maty_prop_id tech_id;\\012\\012ALTER TABLE property_types\\012\\011ADD CONSTRAINT prty_maty_fk FOREIGN KEY (maty_prop_id) REFERENCES material_types(id);\\012\\012ALTER TABLE experiment_properties\\012\\011ADD COLUMN mate_prop_id tech_id;\\012\\012ALTER TABLE material_properties\\012\\011ADD COLUMN mate_prop_id tech_id;\\012\\012ALTER TABLE sample_properties\\012\\011ADD COLUMN mate_prop_id tech_id;\\012\\012ALTER TABLE experiment_properties\\012\\011ADD CONSTRAINT expr_mapr_fk FOREIGN KEY (mate_prop_id) REFERENCES materials(id);\\012\\012ALTER TABLE material_properties\\012\\011ADD CONSTRAINT mapr_mapr_fk FOREIGN KEY (mate_prop_id) REFERENCES materials(id);\\012\\012ALTER TABLE sample_properties\\012\\011ADD CONSTRAINT sapr_mapr_fk FOREIGN KEY (mate_prop_id) REFERENCES materials(id);\\012\\012insert into data_types\\012(id\\012 ,code\\012 ,description)\\012 values \\012 (nextval('DATA_TYPE_ID_SEQ')\\012 ,'MATERIAL'\\012 ,'Reference to a material'\\012);\\012\\012ALTER TABLE MATERIAL_PROPERTIES DROP CONSTRAINT MAPR_CK;\\012ALTER TABLE MATERIAL_PROPERTIES ADD CONSTRAINT MAPR_CK CHECK \\012\\011((VALUE IS NOT NULL AND CVTE_ID IS NULL AND MATE_PROP_ID IS NULL) OR \\012\\011 (VALUE IS NULL AND CVTE_ID IS NOT NULL AND MATE_PROP_ID IS NULL) OR\\012\\011 (VALUE IS NULL AND CVTE_ID IS NULL AND MATE_PROP_ID IS NOT NULL)\\012\\011);\\012\\012ALTER TABLE EXPERIMENT_PROPERTIES DROP CONSTRAINT EXPR_CK;\\012ALTER TABLE EXPERIMENT_PROPERTIES ADD CONSTRAINT EXPR_CK CHECK \\012\\011((VALUE IS NOT NULL AND CVTE_ID IS NULL AND MATE_PROP_ID IS NULL) OR \\012\\011 (VALUE IS NULL AND CVTE_ID IS NOT NULL AND MATE_PROP_ID IS NULL) OR\\012\\011 (VALUE IS NULL AND CVTE_ID IS NULL AND MATE_PROP_ID IS NOT NULL)\\012\\011);\\012\\012ALTER TABLE SAMPLE_PROPERTIES DROP CONSTRAINT SAPR_CK;\\012ALTER TABLE SAMPLE_PROPERTIES ADD CONSTRAINT SAPR_CK CHECK \\012\\011((VALUE IS NOT NULL AND CVTE_ID IS NULL AND MATE_PROP_ID IS NULL) OR \\012\\011 (VALUE IS NULL AND CVTE_ID IS NOT NULL AND MATE_PROP_ID IS NULL) OR\\012\\011 (VALUE IS NULL AND CVTE_ID IS NULL AND MATE_PROP_ID IS NOT NULL)\\012\\011);\\012\\012------------------------------------------------------------------------------------\\012--  Purpose:  Create trigger MATERIAL/SAMPLE/EXPERIMENT _PROPERTY_WITH_MATERIAL_DATA_TYPE_CHECK\\012--            It checks that if material property value is assigned to the entity,\\012--\\011\\011\\011\\011\\011\\011then the material type is equal to the one described by property type.\\012------------------------------------------------------------------------------------\\012\\012CREATE OR REPLACE FUNCTION MATERIAL_PROPERTY_WITH_MATERIAL_DATA_TYPE_CHECK() RETURNS trigger AS $$\\012DECLARE\\012   v_type_id  CODE;\\012   v_type_id_prop  CODE;\\012BEGIN\\012   if NEW.mate_prop_id IS NOT NULL then\\012\\011\\011\\011-- find material type id of the property type \\012\\011\\011\\011select pt.maty_prop_id into v_type_id_prop \\012\\011\\011\\011  from material_type_property_types etpt, property_types pt \\012\\011\\011\\011 where NEW.mtpt_id = etpt.id AND etpt.prty_id = pt.id;\\012\\011\\011\\012\\011\\011\\011if v_type_id_prop IS NOT NULL then\\012\\011\\011\\011\\011-- find material type id of the material which consists the entity's property value\\012\\011\\011\\011\\011select entity.maty_id into v_type_id \\012\\011\\011\\011\\011  from materials entity\\012\\011\\011\\011\\011 where NEW.mate_prop_id = entity.id;\\012\\011\\011\\011\\011if v_type_id != v_type_id_prop then\\012\\011\\011\\011\\011\\011RAISE EXCEPTION 'Insert/Update of property value referencing material (id: %) failed, as referenced material type is different than expected (id %, expected id: %).', \\012\\011\\011\\011\\011\\011\\011\\011 NEW.mate_prop_id, v_type_id, v_type_id_prop;\\012\\011\\011\\011\\011end if;\\012\\011\\011\\011end if;\\012   end if;\\012   RETURN NEW;\\012END;\\012$$ LANGUAGE 'plpgsql';\\012\\012CREATE TRIGGER MATERIAL_PROPERTY_WITH_MATERIAL_DATA_TYPE_CHECK BEFORE INSERT OR UPDATE ON material_properties\\012    FOR EACH ROW EXECUTE PROCEDURE MATERIAL_PROPERTY_WITH_MATERIAL_DATA_TYPE_CHECK();\\012    \\012CREATE OR REPLACE FUNCTION SAMPLE_PROPERTY_WITH_MATERIAL_DATA_TYPE_CHECK() RETURNS trigger AS $$\\012DECLARE\\012   v_type_id  CODE;\\012   v_type_id_prop  CODE;\\012BEGIN\\012   if NEW.mate_prop_id IS NOT NULL then\\012\\011\\011\\011-- find material type id of the property type \\012\\011\\011\\011select pt.maty_prop_id into v_type_id_prop \\012\\011\\011\\011  from sample_type_property_types etpt, property_types pt \\012\\011\\011\\011 where NEW.stpt_id = etpt.id AND etpt.prty_id = pt.id;\\012\\011\\011\\012\\011\\011\\011if v_type_id_prop IS NOT NULL then\\012\\011\\011\\011\\011-- find material type id of the material which consists the entity's property value\\012\\011\\011\\011\\011select entity.maty_id into v_type_id \\012\\011\\011\\011\\011  from materials entity\\012\\011\\011\\011\\011 where NEW.mate_prop_id = entity.id;\\012\\011\\011\\011\\011if v_type_id != v_type_id_prop then\\012\\011\\011\\011\\011\\011RAISE EXCEPTION 'Insert/Update of property value referencing material (id: %) failed, as referenced material type is different than expected (id %, expected id: %).', \\012\\011\\011\\011\\011\\011\\011\\011\\011\\011\\011\\011\\011 NEW.mate_prop_id, v_type_id, v_type_id_prop;\\012\\011\\011\\011\\011end if;\\012\\011\\011\\011end if;\\012   end if;\\012   RETURN NEW;\\012END;\\012$$ LANGUAGE 'plpgsql';\\012\\012CREATE TRIGGER SAMPLE_PROPERTY_WITH_MATERIAL_DATA_TYPE_CHECK BEFORE INSERT OR UPDATE ON sample_properties\\012    FOR EACH ROW EXECUTE PROCEDURE SAMPLE_PROPERTY_WITH_MATERIAL_DATA_TYPE_CHECK();\\012    \\012CREATE OR REPLACE FUNCTION EXPERIMENT_PROPERTY_WITH_MATERIAL_DATA_TYPE_CHECK() RETURNS trigger AS $$\\012DECLARE\\012   v_type_id  CODE;\\012   v_type_id_prop  CODE;\\012BEGIN\\012   if NEW.mate_prop_id IS NOT NULL then\\012\\011\\011\\011-- find material type id of the property type \\012\\011\\011\\011select pt.maty_prop_id into v_type_id_prop \\012\\011\\011\\011  from experiment_type_property_types etpt, property_types pt \\012\\011\\011\\011 where NEW.etpt_id = etpt.id AND etpt.prty_id = pt.id;\\012\\011\\011\\012\\011\\011\\011if v_type_id_prop IS NOT NULL then\\012\\011\\011\\011\\011-- find material type id of the material which consists the entity's property value\\012\\011\\011\\011\\011select entity.maty_id into v_type_id \\012\\011\\011\\011\\011  from materials entity\\012\\011\\011\\011\\011 where NEW.mate_prop_id = entity.id;\\012\\011\\011\\011\\011if v_type_id != v_type_id_prop then\\012\\011\\011\\011\\011\\011RAISE EXCEPTION 'Insert/Update of property value referencing material (id: %) failed, as referenced material type is different than expected (id %, expected id: %).', \\012\\011\\011\\011\\011\\011\\011\\011\\011\\011\\011\\011\\011 NEW.mate_prop_id, v_type_id, v_type_id_prop;\\012\\011\\011\\011\\011end if;\\012\\011\\011\\011end if;\\012   end if;\\012   RETURN NEW;\\012END;\\012$$ LANGUAGE 'plpgsql';\\012\\012CREATE TRIGGER EXPERIMENT_PROPERTY_WITH_MATERIAL_DATA_TYPE_CHECK BEFORE INSERT OR UPDATE ON experiment_properties\\012    FOR EACH ROW EXECUTE PROCEDURE EXPERIMENT_PROPERTY_WITH_MATERIAL_DATA_TYPE_CHECK();\\012       \\012-- -------\\012-- remove the reminescents of the OBSERVABLE_TYPE\\012-- -------\\012\\012ALTER TABLE data\\012\\011DROP CONSTRAINT data_obty_fk;\\012\\012ALTER TABLE data_set_types\\012\\011DROP CONSTRAINT obty_pk;\\012\\012ALTER TABLE data_set_types\\012\\011ADD CONSTRAINT dsty_pk PRIMARY KEY (id);\\012\\012ALTER TABLE data\\012\\011ADD CONSTRAINT data_dsty_fk FOREIGN KEY (dsty_id) REFERENCES data_set_types(id);\\012\\012ALTER TABLE data_set_types\\012\\011DROP CONSTRAINT obty_bk_uk;\\012\\012ALTER TABLE data_set_types\\012\\011DROP CONSTRAINT obty_dbin_fk;\\012\\012ALTER TABLE data_set_types\\012\\011ADD CONSTRAINT dsty_bk_uk UNIQUE (code, dbin_id);\\012\\012ALTER TABLE data_set_types\\012\\011ADD CONSTRAINT dsty_dbin_fk FOREIGN KEY (dbin_id) REFERENCES database_instances(id);\\012\\012DROP INDEX data_obty_fk_i;\\012\\012CREATE INDEX data_dsty_fk_i ON data(dsty_id);\\012	\N
+./sourceTest/sql/postgresql/063/.svn/text-base/017=database_version_logs.tsv.svn-base:030	source/sql/postgresql/migration/migration-029-030.sql	SUCCESS	2009-03-23 15:34:44.72	-- -------\\012-- add modification_timestamp field to allow edition with Hibernate\\012-- -------\\012ALTER TABLE data\\012\\011ADD COLUMN modification_timestamp TIME_STAMP DEFAULT CURRENT_TIMESTAMP;\\012ALTER TABLE experiment_types\\012\\011ADD COLUMN modification_timestamp TIME_STAMP DEFAULT CURRENT_TIMESTAMP;\\012ALTER TABLE sample_types\\012\\011ADD COLUMN modification_timestamp TIME_STAMP DEFAULT CURRENT_TIMESTAMP;\\012ALTER TABLE material_types\\012\\011ADD COLUMN modification_timestamp TIME_STAMP DEFAULT CURRENT_TIMESTAMP;\\012ALTER TABLE data_set_types\\012\\011ADD COLUMN modification_timestamp TIME_STAMP DEFAULT CURRENT_TIMESTAMP;\\012ALTER TABLE controlled_vocabularies\\012\\011ADD COLUMN modification_timestamp TIME_STAMP DEFAULT CURRENT_TIMESTAMP;\\012-- -------\\012-- add properties to data sets\\012-- -------\\012CREATE TABLE DATA_SET_PROPERTIES (ID TECH_ID NOT NULL,DS_ID TECH_ID NOT NULL,DSTPT_ID TECH_ID NOT NULL,VALUE GENERIC_VALUE,CVTE_ID TECH_ID, MATE_PROP_ID TECH_ID, PERS_ID_REGISTERER TECH_ID NOT NULL,REGISTRATION_TIMESTAMP TIME_STAMP_DFL NOT NULL DEFAULT CURRENT_TIMESTAMP, MODIFICATION_TIMESTAMP TIME_STAMP DEFAULT CURRENT_TIMESTAMP);\\012CREATE TABLE DATA_SET_TYPE_PROPERTY_TYPES (ID TECH_ID NOT NULL,DSTY_ID TECH_ID NOT NULL,PRTY_ID TECH_ID NOT NULL,IS_MANDATORY BOOLEAN_CHAR NOT NULL DEFAULT 'F',IS_MANAGED_INTERNALLY BOOLEAN_CHAR NOT NULL DEFAULT 'F',PERS_ID_REGISTERER TECH_ID NOT NULL,REGISTRATION_TIMESTAMP TIME_STAMP_DFL NOT NULL DEFAULT CURRENT_TIMESTAMP);\\012\\012CREATE SEQUENCE DATA_SET_PROPERTY_ID_SEQ;\\012CREATE SEQUENCE DSTPT_ID_SEQ;\\012\\012ALTER TABLE DATA_SET_TYPE_PROPERTY_TYPES ADD CONSTRAINT DSTPT_PK PRIMARY KEY(ID);\\012ALTER TABLE DATA_SET_PROPERTIES ADD CONSTRAINT DSPR_PK PRIMARY KEY(ID);\\012\\012ALTER TABLE DATA_SET_TYPE_PROPERTY_TYPES ADD CONSTRAINT DSTPT_BK_UK UNIQUE(DSTY_ID,PRTY_ID);\\012ALTER TABLE DATA_SET_PROPERTIES ADD CONSTRAINT DSPR_BK_UK UNIQUE(DS_ID,DSTPT_ID);\\012\\012\\012ALTER TABLE DATA_SET_TYPE_PROPERTY_TYPES ADD CONSTRAINT DSTPT_DSTY_FK FOREIGN KEY (DSTY_ID) REFERENCES DATA_SET_TYPES(ID);\\012ALTER TABLE DATA_SET_TYPE_PROPERTY_TYPES ADD CONSTRAINT DSTPT_PERS_FK FOREIGN KEY (PERS_ID_REGISTERER) REFERENCES PERSONS(ID);\\012ALTER TABLE DATA_SET_TYPE_PROPERTY_TYPES ADD CONSTRAINT DSTPT_PRTY_FK FOREIGN KEY (PRTY_ID) REFERENCES PROPERTY_TYPES(ID);\\012ALTER TABLE DATA_SET_PROPERTIES ADD CONSTRAINT DSPR_CVTE_FK FOREIGN KEY (CVTE_ID) REFERENCES CONTROLLED_VOCABULARY_TERMS(ID);\\012ALTER TABLE DATA_SET_PROPERTIES ADD CONSTRAINT DSPR_DSTPT_FK FOREIGN KEY (DSTPT_ID) REFERENCES DATA_SET_TYPE_PROPERTY_TYPES(ID) ON DELETE CASCADE;\\012ALTER TABLE DATA_SET_PROPERTIES ADD CONSTRAINT DSPR_DS_FK FOREIGN KEY (DS_ID) REFERENCES DATA(ID);\\012ALTER TABLE DATA_SET_PROPERTIES ADD CONSTRAINT DSPR_PERS_FK FOREIGN KEY (PERS_ID_REGISTERER) REFERENCES PERSONS(ID);\\012ALTER TABLE DATA_SET_PROPERTIES ADD CONSTRAINT DSPR_MAPR_FK FOREIGN KEY (MATE_PROP_ID) REFERENCES MATERIALS(ID);\\012\\012ALTER TABLE DATA_SET_PROPERTIES ADD CONSTRAINT DSPR_CK CHECK \\012\\011((VALUE IS NOT NULL AND CVTE_ID IS NULL AND MATE_PROP_ID IS NULL) OR \\012\\011 (VALUE IS NULL AND CVTE_ID IS NOT NULL AND MATE_PROP_ID IS NULL) OR\\012\\011 (VALUE IS NULL AND CVTE_ID IS NULL AND MATE_PROP_ID IS NOT NULL)\\012\\011);\\012\\012CREATE INDEX DSPR_CVTE_FK_I ON DATA_SET_PROPERTIES (CVTE_ID);\\012CREATE INDEX DSPR_DSTPT_FK_I ON DATA_SET_PROPERTIES (DSTPT_ID);\\012CREATE INDEX DSPR_DS_FK_I ON DATA_SET_PROPERTIES (DS_ID);\\012CREATE INDEX DSPR_PERS_FK_I ON DATA_SET_PROPERTIES (PERS_ID_REGISTERER);\\012CREATE INDEX DSTPT_DSTY_FK_I ON DATA_SET_TYPE_PROPERTY_TYPES (DSTY_ID);\\012CREATE INDEX DSTPT_PERS_FK_I ON DATA_SET_TYPE_PROPERTY_TYPES (PERS_ID_REGISTERER);\\012CREATE INDEX DSTPT_PRTY_FK_I ON DATA_SET_TYPE_PROPERTY_TYPES (PRTY_ID);\\012\\012CREATE OR REPLACE FUNCTION DATA_SET_PROPERTY_WITH_MATERIAL_DATA_TYPE_CHECK() RETURNS trigger AS $$\\012DECLARE\\012   v_type_id  CODE;\\012   v_type_id_prop  CODE;\\012BEGIN\\012   if NEW.mate_prop_id IS NOT NULL then\\012\\011\\011\\011-- find material type id of the property type \\012\\011\\011\\011select pt.maty_prop_id into v_type_id_prop \\012\\011\\011\\011  from data_set_type_property_types dstpt, property_types pt \\012\\011\\011\\011 where NEW.dstpt_id = dstpt.id AND dstpt.prty_id = pt.id;\\012\\011\\011\\012\\011\\011\\011if v_type_id_prop IS NOT NULL then\\012\\011\\011\\011\\011-- find material type id of the material which consists the entity's property value\\012\\011\\011\\011\\011select entity.maty_id into v_type_id \\012\\011\\011\\011\\011  from materials entity\\012\\011\\011\\011\\011 where NEW.mate_prop_id = entity.id;\\012\\011\\011\\011\\011if v_type_id != v_type_id_prop then\\012\\011\\011\\011\\011\\011RAISE EXCEPTION 'Insert/Update of property value referencing material (id: %) failed, as referenced material type is different than expected (id %, expected id: %).', \\012\\011\\011\\011\\011\\011\\011\\011\\011\\011\\011\\011\\011 NEW.mate_prop_id, v_type_id, v_type_id_prop;\\012\\011\\011\\011\\011end if;\\012\\011\\011\\011end if;\\012   end if;\\012   RETURN NEW;\\012END;\\012$$ LANGUAGE 'plpgsql';\\012\\012CREATE TRIGGER DATA_SET_PROPERTY_WITH_MATERIAL_DATA_TYPE_CHECK BEFORE INSERT OR UPDATE ON data_set_properties\\012    FOR EACH ROW EXECUTE PROCEDURE DATA_SET_PROPERTY_WITH_MATERIAL_DATA_TYPE_CHECK();   \\012	\N
+./sourceTest/sql/postgresql/063/.svn/text-base/017=database_version_logs.tsv.svn-base:032	source/sql/postgresql/migration/migration-031-032.sql	SUCCESS	2009-04-09 09:36:36.2	-- -------\\012-- Modify MATERIAL_BATCHES\\012-- -------\\012\\012ALTER TABLE material_batches\\012    DROP COLUMN proc_id;\\012\\012-- -------\\012-- Modify SAMPLES\\012-- -------\\012\\012ALTER TABLE samples\\012    ADD COLUMN expe_id tech_id;\\012\\012ALTER TABLE samples\\012    ADD CONSTRAINT samp_expe_fk FOREIGN KEY (expe_id) REFERENCES experiments(id);\\012\\012CREATE INDEX samp_expe_fk_i ON samples USING btree (expe_id);\\012\\012-- relink samples directly to experiments\\012\\012UPDATE samples\\012SET expe_id = (SELECT e.id FROM experiments e, procedures p, sample_inputs si \\012               WHERE si.samp_id = samples.id AND si.proc_id = p.id AND p.expe_id = e.id AND e.inva_id IS NULL);\\012\\012\\012-- -------\\012-- Modify DATA\\012-- -------\\012\\012ALTER TABLE data\\012    ADD COLUMN expe_id tech_id;\\012\\012ALTER TABLE data\\012    ADD CONSTRAINT data_expe_fk FOREIGN KEY (expe_id) REFERENCES experiments(id);\\012\\012CREATE INDEX data_expe_fk_i ON data USING btree (expe_id);\\012\\012UPDATE data\\012SET expe_id = (SELECT e.id FROM experiments e, procedures p \\012               WHERE data.proc_id_produced_by = p.id AND p.expe_id = e.id);\\012\\012ALTER TABLE data\\012    ALTER COLUMN expe_id SET NOT NULL;\\012\\012ALTER TABLE data\\012    DROP COLUMN proc_id_produced_by;\\012\\012-- -------\\012-- Drop PROCEDURES, PROCEDURE_TYPES, and SAMPLE_INPUTS\\012-- -------\\012\\012DROP TABLE sample_inputs;\\012DROP TABLE procedures;\\012DROP TABLE procedure_types;\\012\\012DROP SEQUENCE procedure_id_seq;\\012DROP SEQUENCE procedure_type_id_seq;\\012\\012-- -------\\012-- Add CODE_SEQ\\012-- -------\\012\\012CREATE SEQUENCE CODE_SEQ;\\012\\012-- -------\\012-- Add new columns to DATA_STORES\\012-- -------\\012\\012ALTER TABLE data_stores\\012    ADD COLUMN remote_url character varying(250),\\012    ADD COLUMN session_token character varying(50),\\012    ADD COLUMN modification_timestamp time_stamp DEFAULT now();\\012\\012UPDATE data_stores\\012SET remote_url = '', session_token='';\\012\\012ALTER TABLE data_stores\\012    ALTER COLUMN remote_url SET NOT NULL,\\012    ALTER COLUMN session_token SET NOT NULL;\\012\\012-- -------\\012-- Drop foreign keys onto DATA_STORES\\012-- -------\\012\\012ALTER TABLE database_instances\\012    DROP COLUMN dast_id;\\012\\012ALTER TABLE groups\\012    DROP COLUMN dast_id;\\012\\012ALTER TABLE projects\\012    DROP COLUMN dast_id;\\012\\012ALTER TABLE experiments\\012    DROP COLUMN dast_id;\\012\\012-- -------\\012-- Add foreign key from DATA onto DATA_STORES\\012-- -------\\012\\012ALTER TABLE data\\012    ADD COLUMN dast_id tech_id;\\012\\012ALTER TABLE data\\012    ADD CONSTRAINT data_dast_fk FOREIGN KEY (dast_id) REFERENCES data_stores(id);\\012\\012UPDATE data\\012SET dast_id = (select id from data_stores where code = 'STANDARD');\\012\\012ALTER TABLE data\\012    ALTER COLUMN dast_id SET NOT NULL;\\012\\012\\012------------------------------------------------------------------------------------\\012--  Purpose:  Replace trigger SAMPLE_CODE_UNIQUENESS_CHECK \\012------------------------------------------------------------------------------------\\012\\012CREATE OR REPLACE FUNCTION SAMPLE_CODE_UNIQUENESS_CHECK() RETURNS trigger AS $$\\012DECLARE\\012   counter  INTEGER;\\012BEGIN\\012    LOCK TABLE samples IN EXCLUSIVE MODE;\\012    IF (NEW.samp_id_part_of is NULL) THEN\\012        IF (NEW.dbin_id is not NULL) THEN\\012            SELECT count(*) into counter FROM samples \\012                where id != NEW.id and code = NEW.code and samp_id_part_of is NULL and dbin_id = NEW.dbin_id;\\012            IF (counter > 0) THEN\\012                RAISE EXCEPTION 'Insert/Update of Sample (Code: %) failed because database instance sample with the same code already exists.', NEW.code;\\012            END IF;\\012        ELSIF (NEW.grou_id is not NULL) THEN\\012            SELECT count(*) into counter FROM samples \\012                where id != NEW.id and code = NEW.code and samp_id_part_of is NULL and grou_id = NEW.grou_id;\\012            IF (counter > 0) THEN\\012                RAISE EXCEPTION 'Insert/Update of Sample (Code: %) failed because group sample with the same code already exists.', NEW.code;\\012            END IF;\\012        END IF;\\012        ELSE\\012        IF (NEW.dbin_id is not NULL) THEN\\012            SELECT count(*) into counter FROM samples \\012                where id != NEW.id and code = NEW.code and samp_id_part_of = NEW.samp_id_part_of and dbin_id = NEW.dbin_id;\\012            IF (counter > 0) THEN\\012                RAISE EXCEPTION 'Insert/Update of Sample (Code: %) failed because database instance sample with the same code and being the part of the same parent already exists.', NEW.code;\\012            END IF;\\012        ELSIF (NEW.grou_id is not NULL) THEN\\012            SELECT count(*) into counter FROM samples \\012                where id != NEW.id and code = NEW.code and samp_id_part_of = NEW.samp_id_part_of and grou_id = NEW.grou_id;\\012            IF (counter > 0) THEN\\012                RAISE EXCEPTION 'Insert/Update of Sample (Code: %) failed because group sample with the same code and being the part of the same parent already exists.', NEW.code;\\012            END IF;\\012        END IF;\\012        END IF;   \\012   RETURN NEW;\\012END;\\012$$ LANGUAGE 'plpgsql';\\012\\012\\012\\012	\N
+./sourceTest/sql/postgresql/063/.svn/text-base/017=database_version_logs.tsv.svn-base:034	source/sql/postgresql/migration/migration-033-034.sql	SUCCESS	2009-05-26 08:32:49.935	------------------------------------------------------------------------------------\\012-- Create sequence for generating permanent identifiers starting with nextval of existing dataset sequence.\\012------------------------------------------------------------------------------------\\012CREATE FUNCTION CREATE_SEQUENCE(EXISTING_SEQUENCE VARCHAR, NEW_SEQUENCE VARCHAR) RETURNS VOID AS $$\\012DECLARE\\012  CURR_SEQ_VAL   INTEGER;\\012BEGIN\\012  SELECT INTO CURR_SEQ_VAL NEXTVAL(EXISTING_SEQUENCE);\\012  EXECUTE 'CREATE SEQUENCE ' || NEW_SEQUENCE || ' START WITH ' || CURR_SEQ_VAL;\\012  RETURN;\\012END;\\012$$ LANGUAGE 'plpgsql';\\012\\012SELECT CREATE_SEQUENCE('DATA_ID_SEQ', 'PERM_ID_SEQ');\\012DROP FUNCTION CREATE_SEQUENCE(VARCHAR, VARCHAR);\\012\\012------------------------------------------------------------------------------------\\012-- Add perm_id columns to samples and experiments.\\012------------------------------------------------------------------------------------\\012ALTER TABLE SAMPLES ADD COLUMN PERM_ID CODE;\\012ALTER TABLE EXPERIMENTS ADD COLUMN PERM_ID CODE;\\012\\012UPDATE SAMPLES SET PERM_ID = to_char(registration_timestamp,'YYYYMMDDHHSSMS') || '-' || NEXTVAL('PERM_ID_SEQ');\\012UPDATE EXPERIMENTS SET PERM_ID = to_char(registration_timestamp,'YYYYMMDDHHSSMS') || '-' || NEXTVAL('PERM_ID_SEQ');\\012ALTER TABLE SAMPLES ALTER COLUMN PERM_ID SET NOT NULL;\\012ALTER TABLE EXPERIMENTS ALTER COLUMN PERM_ID SET NOT NULL;\\012ALTER TABLE SAMPLES ADD CONSTRAINT SAMP_PI_UK UNIQUE(PERM_ID);\\012ALTER TABLE EXPERIMENTS ADD CONSTRAINT EXPE_PI_UK UNIQUE(PERM_ID);\\012\\012\\012------------------------------------------------------------------------------------\\012-- Add column is_chosen_from_list to controlled_vocabularies.\\012------------------------------------------------------------------------------------\\012ALTER TABLE controlled_vocabularies ADD COLUMN is_chosen_from_list BOOLEAN_CHAR NOT NULL DEFAULT TRUE;\\012ALTER TABLE controlled_vocabularies ADD COLUMN source_uri CHARACTER VARYING(250);\\012------------------------------------------------------------------------------------\\012-- Modify Data table - remove arc connection between Sample and Data table, use a flag instead\\012------------------------------------------------------------------------------------\\012\\012-- add new columns\\012\\012ALTER TABLE data\\012    ADD COLUMN is_derived boolean_char;\\012ALTER TABLE data\\012    ADD COLUMN samp_id tech_id;\\012\\012-- update values in new columns\\012\\012UPDATE data\\012    SET is_derived = (samp_id_derived_from IS NOT NULL); \\012UPDATE data\\012    SET samp_id = samp_id_derived_from \\012    WHERE is_derived = 'TRUE';\\012UPDATE data\\012    SET samp_id = samp_id_acquired_from \\012    WHERE is_derived = 'FALSE';\\012\\012-- add constraints and indexes to new columns\\012\\012ALTER TABLE data\\012    ALTER COLUMN is_derived SET NOT NULL;\\012ALTER TABLE data\\012    ALTER COLUMN samp_id SET NOT NULL;   \\012ALTER TABLE data\\012    ADD CONSTRAINT data_samp_fk FOREIGN KEY (samp_id) REFERENCES samples (id);\\012CREATE INDEX data_samp_fk_i ON data USING btree (samp_id);\\012\\012-- remove old columns\\012\\012ALTER TABLE data\\012    DROP COLUMN samp_id_acquired_from;\\012ALTER TABLE data\\012    DROP COLUMN samp_id_derived_from;\\012    \\012------------------------------------------------------------------------------------\\012-- Granting SELECT privilege to group openbis_readonly\\012------------------------------------------------------------------------------------\\012\\012GRANT SELECT ON SEQUENCE attachment_content_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE attachment_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE code_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE controlled_vocabulary_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE cvte_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE data_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE data_set_property_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE data_set_relationship_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE data_set_type_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE data_store_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE data_type_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE database_instance_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE dstpt_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE etpt_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE event_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE experiment_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE experiment_property_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE experiment_type_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE file_format_type_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE group_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE invalidation_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE locator_type_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE material_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE material_property_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE material_type_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE mtpt_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE perm_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE person_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE project_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE property_type_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE role_assignment_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE sample_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE sample_property_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE sample_type_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE stpt_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE attachment_contents TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE attachments TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE controlled_vocabularies TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE controlled_vocabulary_terms TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE data TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE data_set_properties TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE data_set_relationships TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE data_set_type_property_types TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE data_set_types TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE data_stores TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE data_types TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE database_instances TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE database_version_logs TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE events TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE experiment_properties TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE experiment_type_property_types TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE experiment_types TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE experiments TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE external_data TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE file_format_types TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE groups TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE invalidations TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE locator_types TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE material_properties TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE material_type_property_types TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE material_types TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE materials TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE persons TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE projects TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE property_types TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE role_assignments TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE sample_properties TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE sample_type_property_types TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE sample_types TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE samples TO GROUP OPENBIS_READONLY;\\012\\012------------------------------------------------------------------------------------\\012-- Delete MATERIAL_BATCHES table\\012------------------------------------------------------------------------------------\\012\\012-- WARNING: Potential data lost!!!\\012-- WARNING: Potential data lost!!!\\012-- WARNING: Potential data lost!!!\\012\\012DROP TABLE SAMPLE_MATERIAL_BATCHES;\\012DROP TABLE MATERIAL_BATCHES;\\012DROP SEQUENCE MATERIAL_BATCH_ID_SEQ;\\012\\012------------------------------------------------------------------------------------\\012-- Delete MATE_ID_INHIBITOR_OF from table MATERIALS\\012------------------------------------------------------------------------------------\\012\\012-- WARNING: Potential data lost!!!\\012-- WARNING: Potential data lost!!!\\012-- WARNING: Potential data lost!!!\\012\\012ALTER TABLE MATERIALS DROP COLUMN MATE_ID_INHIBITOR_OF;\\012	\N
+./sourceTest/sql/postgresql/063/.svn/text-base/017=database_version_logs.tsv.svn-base:041	source/sql/postgresql/migration/migration-040-041.sql	SUCCESS	2009-09-14 13:48:57.539	-- Create FILTERS table\\012\\012CREATE TABLE FILTERS (ID TECH_ID NOT NULL, DBIN_ID TECH_ID NOT NULL, NAME VARCHAR(200) NOT NULL, DESCRIPTION DESCRIPTION_1000,REGISTRATION_TIMESTAMP TIME_STAMP_DFL NOT NULL DEFAULT CURRENT_TIMESTAMP, PERS_ID_REGISTERER TECH_ID NOT NULL, MODIFICATION_TIMESTAMP TIME_STAMP DEFAULT CURRENT_TIMESTAMP, EXPRESSION VARCHAR(2000) NOT NULL, IS_PUBLIC BOOLEAN NOT NULL, GRID_ID VARCHAR(200) NOT NULL);\\012CREATE SEQUENCE FILTER_ID_SEQ;\\012ALTER TABLE FILTERS ADD CONSTRAINT FILT_PK PRIMARY KEY(ID);\\012ALTER TABLE FILTERS ADD CONSTRAINT FILT_BK_UK UNIQUE(NAME, DBIN_ID, GRID_ID);\\012ALTER TABLE FILTERS ADD CONSTRAINT FILT_PERS_FK FOREIGN KEY (PERS_ID_REGISTERER) REFERENCES PERSONS(ID);\\012ALTER TABLE FILTERS ADD CONSTRAINT FILT_DBIN_FK FOREIGN KEY (DBIN_ID) REFERENCES DATABASE_INSTANCES(ID);\\012CREATE INDEX FILT_PERS_FK_I ON FILTERS (PERS_ID_REGISTERER);\\012CREATE INDEX FILT_DBIN_FK_I ON FILTERS (DBIN_ID);\\012GRANT SELECT ON SEQUENCE filter_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE filters TO GROUP OPENBIS_READONLY;\\012\\012-- Add missing foreign key to role assignments authorization group\\012ALTER TABLE ROLE_ASSIGNMENTS ADD CONSTRAINT ROAS_AG_FK_GRANTEE FOREIGN KEY (AG_ID_GRANTEE) REFERENCES AUTHORIZATION_GROUPS(ID);\\012\\012--------------------------------------------------------------------------------------------------\\012-- Modify dataset connections:\\012-- 1. connection with sample shouldn't be mandatory any more\\012-- 2. introduce an arc condition that dataset cannot be connected with a sample and a parent dataset at the same time\\012--------------------------------------------------------------------------------------------------\\012\\012-- Weaken data-sample connection constraint - allow dataset to have no connection with sample\\012ALTER TABLE data ALTER COLUMN samp_id DROP NOT NULL;\\012\\012-- Remove data-sample connection for datasets that have a parent\\012\\012UPDATE data \\012   SET samp_id = NULL \\012 WHERE id IN (SELECT DISTINCT data_id_child FROM data_set_relationships);\\012\\012-- With PostgreSQL 8.4 one can check that before migration there were no cycles in dataset relationships:\\012--\\012-- WITH RECURSIVE data_set_parents(id, parent_ids, cycle) AS (\\012--         SELECT  r.data_id_child AS id, \\012--                 ARRAY[CAST (r.data_id_parent AS bigint)] AS parent_ids, \\012--                 false AS cycle \\012--         FROM data_set_relationships r\\012--     UNION ALL\\012--         SELECT  r.data_id_child,\\012--                 CAST (r.data_id_parent AS bigint) || p.parent_ids,\\012--                 r.data_id_child = ANY(p.parent_ids)\\012--         FROM data_set_relationships r, data_set_parents p\\012--         WHERE r.data_id_parent = p.id AND NOT cycle\\012-- )\\012-- SELECT count(*) AS cycles FROM data_set_parents WHERE cycle = true;\\012\\012---------------------------------------------------------------------------------------------------\\012--  Purpose:  Create DEFERRED triggers:\\012--            * check_dataset_relationships_on_data_table_modification,\\012--            * check_dataset_relationships_on_relationships_table_modification.\\012--            They check that after all modifications of database (just before commit) \\012--            if 'data'/'data_set_relationships' tables are among modified tables \\012--            dataset is not connected with a sample and a parent dataset at the same time.\\012--            This connections are held in two different tables so simple immediate trigger \\012--            with arc check cannot be used and we need two deferred triggers.\\012----------------------------------------------------------------------------------------------------\\012\\012-- trigger for 'data' table\\012\\012CREATE OR REPLACE FUNCTION check_dataset_relationships_on_data_table_modification() RETURNS trigger AS $$\\012DECLARE\\012\\011counter\\011INTEGER;\\012BEGIN\\012\\011-- if there is a connection with a Sample there should not be any connection with a parent Data Set\\012\\011IF (NEW.samp_id IS NOT NULL) THEN\\012\\011\\011-- count number of parents\\012\\011\\011SELECT count(*) INTO counter \\012\\011\\011\\011FROM data_set_relationships \\012\\011\\011\\011WHERE data_id_child = OLD.id;\\012\\011\\011IF (counter > 0) THEN\\012\\011\\011\\011RAISE EXCEPTION 'Insert/Update of Data Set (Code: %) failed because it cannot be connected with a Sample and a parent Data Set at the same time.', OLD.code;\\012\\011\\011END IF;\\012\\011END IF;\\012  RETURN NEW;\\012END;\\012$$ LANGUAGE 'plpgsql';\\012\\012CREATE CONSTRAINT TRIGGER check_dataset_relationships_on_data_table_modification \\012  AFTER INSERT OR UPDATE ON data\\012\\011DEFERRABLE INITIALLY DEFERRED\\012\\011FOR EACH ROW \\012\\011EXECUTE PROCEDURE check_dataset_relationships_on_data_table_modification();\\012\\012-- trigger for 'data_set_relationships'\\012\\012CREATE OR REPLACE FUNCTION check_dataset_relationships_on_relationships_table_modification() RETURNS trigger AS $$\\012DECLARE\\012\\011counter\\011INTEGER;\\012\\011sample_id\\011TECH_ID;\\012\\011data_code\\011CODE;\\012BEGIN\\012\\011-- child will have a parent added so it should not be connected with any sample\\012\\011SELECT samp_id, code INTO sample_id, data_code \\012\\011\\011FROM data \\012\\011\\011WHERE id = NEW.data_id_child;\\012\\011IF (sample_id IS NOT NULL) THEN\\012\\011\\011RAISE EXCEPTION 'Insert/Update of Data Set (Code: %) failed because it cannot be connected to a Sample and to a parent Data Set at the same time.', data_code;\\012\\011END IF;\\012\\011RETURN NEW;\\012END;\\012$$ LANGUAGE 'plpgsql';\\012  \\012CREATE CONSTRAINT TRIGGER check_dataset_relationships_on_relationships_table_modification \\012  AFTER INSERT OR UPDATE ON data_set_relationships\\012\\011DEFERRABLE INITIALLY DEFERRED\\012\\011FOR EACH ROW \\012\\011EXECUTE PROCEDURE check_dataset_relationships_on_relationships_table_modification();\\012	\N
+./sourceTest/sql/postgresql/063/.svn/text-base/017=database_version_logs.tsv.svn-base:053	source/sql/postgresql/migration/migration-052-053.sql	SUCCESS	2010-06-08 15:27:55.032	-- Migration from 052 to 053\\012\\012-- Change code uniqueness check for samples of specific type.\\012-- If sample_types.is_subcode_unique flag is set to 'true', additional check is performed \\012-- on codes of samples of the type. Subcodes will have to be unique as well.\\012\\012ALTER TABLE sample_types ADD COLUMN is_subcode_unique boolean_char NOT NULL DEFAULT false;\\012\\012CREATE OR REPLACE FUNCTION SAMPLE_SUBCODE_UNIQUENESS_CHECK() RETURNS trigger AS $$\\012DECLARE\\012   counter  INTEGER;\\012   unique_subcode  BOOLEAN_CHAR;\\012BEGIN\\012  LOCK TABLE samples IN EXCLUSIVE MODE;\\012  \\012  SELECT is_subcode_unique into unique_subcode FROM sample_types WHERE id = NEW.saty_id;\\012  \\012  IF (unique_subcode) THEN\\012    IF (NEW.dbin_id is not NULL) THEN\\012\\011\\011\\011SELECT count(*) into counter FROM samples \\012\\011\\011\\011\\011where id != NEW.id and code = NEW.code and saty_id = NEW.saty_id and dbin_id = NEW.dbin_id;\\012\\011\\011\\011IF (counter > 0) THEN\\012\\011\\011\\011\\011RAISE EXCEPTION 'Insert/Update of Sample (Code: %) failed because database instance sample of the same type with the same subcode already exists.', NEW.code;\\012\\011\\011\\011END IF;\\012\\011\\011ELSIF (NEW.grou_id is not NULL) THEN\\012\\011\\011\\011SELECT count(*) into counter FROM samples \\012\\011\\011\\011\\011where id != NEW.id and code = NEW.code and saty_id = NEW.saty_id and grou_id = NEW.grou_id;\\012\\011\\011\\011IF (counter > 0) THEN\\012\\011\\011\\011\\011RAISE EXCEPTION 'Insert/Update of Sample (Code: %) failed because space sample of the same type with the same subcode already exists.', NEW.code;\\012\\011\\011\\011END IF;\\012\\011\\011END IF;\\012  END IF;\\012  \\012  RETURN NEW;\\012END;\\012$$ LANGUAGE 'plpgsql';\\012\\012CREATE TRIGGER SAMPLE_SUBCODE_UNIQUENESS_CHECK BEFORE INSERT OR UPDATE ON SAMPLES\\012    FOR EACH ROW EXECUTE PROCEDURE SAMPLE_SUBCODE_UNIQUENESS_CHECK();\\012    \\012-- Fixing error messages in old trigger\\012\\012CREATE OR REPLACE FUNCTION SAMPLE_CODE_UNIQUENESS_CHECK() RETURNS trigger AS $$\\012DECLARE\\012   counter  INTEGER;\\012BEGIN\\012  LOCK TABLE samples IN EXCLUSIVE MODE;\\012  \\012\\011  IF (NEW.samp_id_part_of is NULL) THEN\\012\\011\\011  IF (NEW.dbin_id is not NULL) THEN\\012\\011\\011\\011  SELECT count(*) into counter FROM samples \\012\\011\\011      where id != NEW.id and code = NEW.code and samp_id_part_of is NULL and dbin_id = NEW.dbin_id;\\012        IF (counter > 0) THEN\\012\\011\\011\\011\\011  RAISE EXCEPTION 'Insert/Update of Sample (Code: %) failed because database instance sample with the same code already exists.', NEW.code;\\012        END IF;\\012\\011\\011  ELSIF (NEW.grou_id is not NULL) THEN\\012\\011\\011\\011  SELECT count(*) into counter FROM samples \\012\\011\\011\\011\\011  where id != NEW.id and code = NEW.code and samp_id_part_of is NULL and grou_id = NEW.grou_id;\\012\\011\\011\\011  IF (counter > 0) THEN\\012\\011\\011\\011\\011  RAISE EXCEPTION 'Insert/Update of Sample (Code: %) failed because space sample with the same code already exists.', NEW.code;\\012\\011\\011\\011  END IF;\\012      END IF;\\012    ELSE\\012\\011\\011  IF (NEW.dbin_id is not NULL) THEN\\012\\011\\011\\011  SELECT count(*) into counter FROM samples \\012\\011\\011\\011\\011  where id != NEW.id and code = NEW.code and samp_id_part_of = NEW.samp_id_part_of and dbin_id = NEW.dbin_id;\\012\\011\\011\\011  IF (counter > 0) THEN\\012\\011\\011\\011\\011  RAISE EXCEPTION 'Insert/Update of Sample (Code: %) failed because database instance sample with the same code and being the part of the same container already exists.', NEW.code;\\012\\011\\011\\011  END IF;\\012\\011\\011  ELSIF (NEW.grou_id is not NULL) THEN\\012\\011\\011\\011  SELECT count(*) into counter FROM samples \\012\\011\\011\\011\\011  where id != NEW.id and code = NEW.code and samp_id_part_of = NEW.samp_id_part_of and grou_id = NEW.grou_id;\\012\\011\\011\\011  IF (counter > 0) THEN\\012\\011\\011\\011\\011  RAISE EXCEPTION 'Insert/Update of Sample (Code: %) failed because space sample with the same code and being the part of the same container already exists.', NEW.code;\\012\\011\\011\\011  END IF;\\012\\011\\011  END IF;\\012     END IF;   \\012  \\012  RETURN NEW;\\012END;\\012$$ LANGUAGE 'plpgsql';\\012	\N
+./sourceTest/sql/postgresql/063/.svn/text-base/017=database_version_logs.tsv.svn-base:054	source/sql/postgresql/migration/migration-053-054.sql	SUCCESS	2010-07-27 11:30:46.766	-- Migration from 053 to 054\\012\\012\\012-- Add RELATIONSHIP_TYPES table\\012CREATE TABLE relationship_types (id TECH_ID NOT NULL, code CODE NOT NULL, label COLUMN_LABEL, parent_label COLUMN_LABEL, child_label COLUMN_LABEL, description DESCRIPTION_2000, registration_timestamp TIME_STAMP_DFL NOT NULL DEFAULT CURRENT_TIMESTAMP, pers_id_registerer TECH_ID NOT NULL, is_managed_internally BOOLEAN_CHAR NOT NULL DEFAULT 'F', is_internal_namespace BOOLEAN_CHAR NOT NULL DEFAULT 'F', dbin_id TECH_ID NOT NULL);\\012\\012-- Add SAMPLE_RELATIONSHIPS table\\012CREATE TABLE sample_relationships (id TECH_ID NOT NULL, sample_id_parent TECH_ID NOT NULL, relationship_id TECH_ID NOT NULL, sample_id_child TECH_ID NOT NULL);\\012\\012-- Add/update constraints\\012ALTER TABLE relationship_types ADD CONSTRAINT rety_pk PRIMARY KEY (id);\\012ALTER TABLE relationship_types ADD CONSTRAINT rety_uk UNIQUE(code,dbin_id);\\012ALTER TABLE sample_relationships ADD CONSTRAINT sare_pk PRIMARY KEY (id);\\012ALTER TABLE sample_relationships ADD CONSTRAINT sare_bk_uk UNIQUE(sample_id_child,sample_id_parent,relationship_id);\\012ALTER TABLE sample_relationships ADD CONSTRAINT sare_data_fk_child FOREIGN KEY (sample_id_child) REFERENCES samples(id) ON DELETE CASCADE;\\012ALTER TABLE sample_relationships ADD CONSTRAINT sare_data_fk_parent FOREIGN KEY (sample_id_parent) REFERENCES samples(id) ON DELETE CASCADE;\\012ALTER TABLE sample_relationships ADD CONSTRAINT sare_data_fk_relationship FOREIGN KEY (relationship_id) REFERENCES relationship_types(id);\\012\\012-- Create index\\012CREATE INDEX sare_data_fk_i_child ON sample_relationships (sample_id_child);\\012CREATE INDEX sare_data_fk_i_parent ON sample_relationships (sample_id_parent);\\012CREATE INDEX sare_data_fk_i_relationship ON sample_relationships (relationship_id);\\012\\012-- Create sequence for RELATIONSHIP_TYPES\\012CREATE SEQUENCE RELATIONSHIP_TYPE_ID_SEQ;\\012CREATE SEQUENCE SAMPLE_RELATIONSHIP_ID_SEQ;\\012\\012-- Create initial relationships\\012insert into relationship_types\\012(id, \\012code, \\012label, \\012parent_label, \\012child_label, \\012description, \\012pers_id_registerer, \\012is_managed_internally, \\012is_internal_namespace, \\012dbin_id) \\012values\\012(\\012nextval('RELATIONSHIP_TYPE_ID_SEQ'),\\012'PARENT_CHILD',\\012'Parent - Child', \\012'Parent', \\012'Child', \\012'Parent - Child relationship', \\012(select id from persons where user_id ='system'), \\012'T', \\012'T', \\012(select id from database_instances where is_original_source = 'T')\\012);\\012\\012insert into relationship_types\\012(id, \\012code, \\012label, \\012parent_label, \\012child_label, \\012description, \\012pers_id_registerer, \\012is_managed_internally, \\012is_internal_namespace, \\012dbin_id) \\012values\\012(\\012nextval('RELATIONSHIP_TYPE_ID_SEQ'),\\012'PLATE_CONTROL_LAYOUT',\\012'Plate - Control Layout', \\012'Plate', \\012'Control Layout', \\012'Plate - Control Layout relationship', \\012(select id from persons where user_id ='system'), \\012'T', \\012'T', \\012(select id from database_instances where is_original_source = 'T')\\012); \\012\\012\\012-- Migrate sample relationships to new schema\\012INSERT INTO sample_relationships (id, sample_id_parent,sample_id_child,relationship_id) (select distinct nextval('SAMPLE_RELATIONSHIP_ID_SEQ') as id, s.SAMP_ID_GENERATED_FROM as parent_id, s.ID as child_id, rt.id as relationship_id from samples s, relationship_types rt  WHERE rt.code = 'PARENT_CHILD' and s.SAMP_ID_GENERATED_FROM is not null); \\012INSERT INTO sample_relationships (id, sample_id_parent,sample_id_child,relationship_id) (select distinct nextval('SAMPLE_RELATIONSHIP_ID_SEQ') as id, s.SAMP_ID_CONTROL_LAYOUT as parent_id, s.ID as child_id, rt.id as relationship_id from samples s, relationship_types rt  WHERE rt.code = 'PLATE_CONTROL_LAYOUT' and s.SAMP_ID_CONTROL_LAYOUT is not null);\\012\\012-- Drop old sample relations\\012ALTER TABLE SAMPLES DROP COLUMN SAMP_ID_TOP;\\012ALTER TABLE SAMPLES DROP COLUMN SAMP_ID_GENERATED_FROM;\\012ALTER TABLE SAMPLES DROP COLUMN SAMP_ID_CONTROL_LAYOUT;\\012\\012--------------------------------------------------------------------------------------\\012--------------------------------------------------------------------------------------\\012-- This is a screening specific migration. Nothing will be performed on openBIS databases \\012-- which are not screening specific.\\012-- \\012-- This migration for each existing connection between oligo well, oligo material and gene material\\012-- creates a direct connection between the well and the gene. \\012--------------------------------------------------------------------------------------\\012--------------------------------------------------------------------------------------\\012 \\012\\011\\012CREATE OR REPLACE FUNCTION CONNECT_WELLS_WITH_GENES() RETURNS void AS $$\\012DECLARE\\012\\011counter  int;\\012\\011oligo_well_exists bool;\\012BEGIN\\012\\011--------------------------------------------------\\012\\011-- create a gene property and assign it to oligo well\\012\\011--------------------------------------------------\\012\\011\\012\\011select true \\012\\011into oligo_well_exists\\012\\011from sample_types \\012\\011where code = 'OLIGO_WELL';\\012\\011\\012\\011if oligo_well_exists IS NULL then \\012\\011\\011-- skip migration if there are no oligo wells\\012\\011\\011return;\\012\\011end if;   \\012\\011\\012\\011insert into property_types(\\012\\011\\011id, \\012\\011\\011code, description, label, \\012\\011\\011daty_id,\\012\\011\\011pers_id_registerer,\\012\\011\\011dbin_id,\\012\\011\\011maty_prop_id) \\012\\011values(\\012\\011\\011\\011nextval('PROPERTY_TYPE_ID_SEQ'), \\012\\011\\011\\011'GENE','Inhibited gene','Gene',\\012\\011\\011\\011(select id from data_types where code = 'MATERIAL'), \\012\\011\\011\\011(select id from persons where user_id ='system'), \\012\\011\\011\\011(select id from database_instances where is_original_source = 'T'), \\012\\011\\011\\011(select id from material_types where code = 'GENE')\\012\\011\\011);\\012\\011\\011\\012\\011insert into sample_type_property_types( \\012\\011  id,\\012\\011  saty_id,\\012\\011  prty_id,\\012\\011  is_mandatory,\\012\\011  pers_id_registerer,\\012\\011  ordinal\\012\\011) values(\\012\\011\\011\\011nextval('stpt_id_seq'), \\012\\011\\011\\011(select id from sample_types where code = 'OLIGO_WELL'),\\012\\011\\011\\011(select id from property_types where code = 'GENE'),\\012\\011\\011\\011false,\\012\\011\\011\\011(select id from persons where user_id ='system'),\\012\\011\\011\\011(select max(ordinal)+1 from sample_type_property_types \\012\\011\\011\\011\\011where saty_id = (select id from sample_types where code = 'OLIGO_WELL'))\\012\\011\\011);\\012\\012\\011--------------------------------------------------\\012\\011-- create a gene material property for each oligo well\\012\\011--------------------------------------------------\\012\\011\\011\\012\\011select \\011count(*)\\012\\011into counter\\012\\011from\\012\\011\\011samples well, sample_types well_type, sample_properties well_props, \\012\\011\\011materials well_material, material_properties well_material_props,\\012\\011\\011materials nested_well_material\\012\\011where\\012\\011\\011well_type.code = 'OLIGO_WELL' and\\012\\011\\011-- find 'well_material' assigned to the well\\012\\011\\011well_props.samp_id = well.id and well_material.id = well_props.mate_prop_id and \\012\\011\\011-- additional joins to entity type tables\\012\\011\\011well_type.id = well.saty_id and\\012\\011\\011-- well content material property\\012\\011\\011well_material_props.mate_id = well_material.id and \\012\\011\\011-- material connected to the material in the well (e.g. gene)\\012\\011\\011well_material_props.mate_prop_id = nested_well_material.id and\\012\\011\\011nested_well_material.maty_id = (select id from material_types where code = 'GENE');\\012\\011\\012\\011if counter = 0 then \\012\\011\\011-- skip migration if there are no genes indirectly connected to oligo wells\\012\\011\\011return;\\012\\011end if;   \\012\\012\\011insert into sample_properties(id, samp_id, stpt_id, mate_prop_id, pers_id_registerer) (\\012\\011\\011select \\011nextval('sample_property_id_seq') id, \\012\\011\\011\\011well.id samp_id, \\012\\011\\011\\011(select stpt.id from sample_type_property_types stpt, property_types props where stpt.prty_id = props.id and props.code='GENE') stpt_id,\\012\\011\\011\\011nested_well_material.id mate_prop_id,\\012\\011\\011\\011(select id from persons where user_id ='system') pers_id_registerer \\012\\011\\011from\\012\\011\\011\\011samples well, sample_types well_type, sample_properties well_props, \\012\\011\\011\\011materials well_material, material_properties well_material_props,\\012\\011\\011\\011materials nested_well_material\\012\\011\\011where\\012\\011\\011\\011well_type.code = 'OLIGO_WELL' and\\012\\011\\011\\011-- find 'well_material' assigned to the well\\012\\011\\011\\011well_props.samp_id = well.id and well_material.id = well_props.mate_prop_id and \\012\\011\\011\\011-- additional joins to entity type tables\\012\\011\\011\\011well_type.id = well.saty_id and\\012\\011\\011\\011-- well content material property\\012\\011\\011\\011well_material_props.mate_id = well_material.id and \\012\\011\\011\\011-- material connected to the material in the well (e.g. gene)\\012\\011\\011\\011well_material_props.mate_prop_id = nested_well_material.id and\\012\\011\\011\\011nested_well_material.maty_id = (select id from material_types where code = 'GENE')\\012\\011);\\012\\012END;\\012$$ LANGUAGE 'plpgsql';\\012\\012select CONNECT_WELLS_WITH_GENES();\\012drop function CONNECT_WELLS_WITH_GENES();\\012\\012--------------------------------------------------------------------------------------\\012--------------------------------------------------------------------------------------\\012\\012-- drop dataset triggers\\012\\012DROP TRIGGER check_dataset_relationships_on_data_table_modification ON data;\\012DROP FUNCTION check_dataset_relationships_on_data_table_modification();\\012DROP TRIGGER check_dataset_relationships_on_relationships_table_modification ON data_set_relationships;\\012DROP FUNCTION check_dataset_relationships_on_relationships_table_modification();\\012 \\012\\012\\012\\012\\012\\012\\012\\012	\N
+./sourceTest/sql/postgresql/063/.svn/text-base/017=database_version_logs.tsv.svn-base:056	source/sql/postgresql/migration/migration-055-056.sql	SUCCESS	2010-09-10 09:06:20.278	-- Migration from 055 to 056\\012\\012--------------------------------------------------------------------------------------\\012--------------------------------------------------------------------------------------\\012-- Screening specific migration. Nothing will be performed on openBIS databases \\012-- which are not screening specific.\\012--------------------------------------------------------------------------------------\\012--------------------------------------------------------------------------------------\\012\\012CREATE OR REPLACE FUNCTION merge_words(text, text) RETURNS text AS $$\\012DECLARE\\012  BEGIN\\012    IF  character_length($1) > 0 THEN\\012      RETURN $1 || ' ' || $2;\\012    ELSE\\012      RETURN $2;\\012    END IF;\\012  END;\\012$$ LANGUAGE plpgsql;\\012\\012CREATE AGGREGATE merge_words(text)\\012(\\012  SFUNC = merge_words,\\012  STYPE = text\\012);\\012\\012\\012CREATE OR REPLACE FUNCTION REPLACE_GENE_SYMBOL_BY_GENE_ID() RETURNS void AS $$\\012DECLARE\\012\\011counter  int;\\012\\011library_id_assigned_to_gene bool;\\012BEGIN\\012\\011--------------------------------------------------\\012\\011-- create a GENE_SYMBOL property and assign it to GENE\\012\\011--------------------------------------------------\\012\\011\\012\\011select true  \\012\\011into library_id_assigned_to_gene \\012\\011from material_type_property_types mtpt, material_types mt, property_types pt  \\012\\011where mtpt.maty_id = mt.id and mtpt.prty_id = pt.id \\012\\011\\011and mt.code = 'GENE' and pt.code = 'LIBRARY_ID';\\012\\011\\012\\011if library_id_assigned_to_gene IS NULL then \\012\\011\\011-- skip migration if gene has no library_id property\\012\\011\\011return;\\012\\011end if; \\012\\011\\012\\011\\012\\011select count(*)\\012\\011into counter \\012\\011from  \\012\\011\\011(select m.id, count(mp.id) as c \\012\\011\\011\\011from materials m, material_types mt, material_properties mp, material_type_property_types mtpt, property_types pt \\012\\011\\011\\011where m.maty_id = mt.id and mp.mate_id = m.id and mp.mtpt_id = mtpt.id and mtpt.maty_id = mt.id and pt.id = mtpt.prty_id\\012\\011\\011\\011\\011and mt.code = 'GENE' and pt.code = 'LIBRARY_ID' \\012\\011\\011\\011group by m.id) as counter_table \\012\\011where c < 1; \\012\\011\\012\\011if counter > 0 then \\012\\011\\011-- skip migration if there is at least one gene without library_id\\012\\011\\011return;\\012\\011end if;\\012\\011\\012\\011\\012\\011insert into property_types\\012\\011\\011(id\\012\\011\\011,code\\012\\011\\011,description\\012\\011\\011,label\\012\\011\\011,daty_id\\012\\011\\011,pers_id_registerer\\012\\011\\011,dbin_id)\\012\\011values \\012\\011\\011(nextval('PROPERTY_TYPE_ID_SEQ')\\012\\011\\011,'GENE_SYMBOLS'\\012\\011\\011,'Gene symbols'\\012\\011\\011,'Gene symbols'\\012\\011\\011,(select id from data_types where code ='VARCHAR')\\012\\011\\011,(select id from persons where user_id ='system')\\012\\011\\011,(select id from database_instances where is_original_source = 'T')\\012\\011);\\012\\011\\011\\012\\011insert into material_type_property_types( \\012\\011  id,\\012\\011  maty_id,\\012\\011  prty_id,\\012\\011  is_mandatory,\\012\\011  pers_id_registerer,\\012\\011  ordinal\\012\\011) values(\\012\\011\\011\\011nextval('mtpt_id_seq'), \\012\\011\\011\\011(select id from material_types where code = 'GENE'),\\012\\011\\011\\011(select id from property_types where code = 'GENE_SYMBOLS'),\\012\\011\\011\\011false,\\012\\011\\011\\011(select id from persons where user_id ='system'),\\012\\011\\011\\011(select max(ordinal)+1 from material_type_property_types \\012\\011\\011\\011\\011where maty_id = (select id from material_types where code = 'GENE'))\\012\\011\\011);\\012\\012\\011--------------------------------------------------\\012\\011-- create temporary table with all gene migration information\\012\\011--------------------------------------------------\\012\\012\\011create temp table genes \\012\\011(\\012\\011\\011id tech_id,\\012\\011\\011code code,\\012\\011\\011library_id generic_value,\\012\\011\\011gene_codes generic_value,\\012\\011\\011new_id tech_id,\\012\\011\\011library_tech_id tech_id\\011\\011\\012\\011);\\012\\011\\012\\011insert into genes (id, code, library_id, library_tech_id)\\012\\011\\011(select m.id, m.code, mp.value as library_id, mp.id as library_tech_id from materials m, material_properties mp, material_type_property_types mtpt, property_types pt, material_types mt\\012\\011\\011where mp.mate_id = m.id and  mp.mtpt_id = mtpt.id and pt.id = mtpt.prty_id and pt.code = 'LIBRARY_ID' and mt.id = m.maty_id and mt.id = mtpt.maty_id and mt.code = 'GENE');\\012\\011\\012\\011update genes set new_id = map.to_id from (select g_from.id as from_id, min(g_to.id) as to_id  from genes g_from, genes g_to where g_from.library_id = g_to.library_id group by g_from.id) as map where map.from_id = id;\\011\\012\\011\\012\\011update genes set gene_codes = map.gene_codes from (select g_from.library_id as lib_id, merge_words(distinct g_to.code) as gene_codes from genes g_from, genes g_to where g_from.library_id = g_to.library_id group by g_from.library_id) as map where map.lib_id = library_id;\\011\\012\\012\\011--------------------------------------------------\\012\\011-- update gene references\\012\\011--------------------------------------------------\\012\\012\\011update EXPERIMENTS set MATE_ID_STUDY_OBJECT = genes.new_id from genes where genes.id = MATE_ID_STUDY_OBJECT and not genes.id = genes.new_id;\\012\\011update EXPERIMENT_PROPERTIES set  MATE_PROP_ID = genes.new_id from genes where genes.id = MATE_PROP_ID and not genes.id = genes.new_id;\\012\\011update MATERIAL_PROPERTIES set  MATE_PROP_ID = genes.new_id from genes where genes.id = MATE_PROP_ID and not genes.id = genes.new_id;\\012\\011update SAMPLE_PROPERTIES set  MATE_PROP_ID = genes.new_id from genes where genes.id = MATE_PROP_ID and not genes.id = genes.new_id;\\012\\011update DATA_SET_PROPERTIES set  MATE_PROP_ID = genes.new_id from genes where genes.id = MATE_PROP_ID and not genes.id = genes.new_id;\\012\\011\\012\\011delete from  material_properties where mate_id in (select id from genes where not genes.id = genes.new_id);\\012\\011delete from MATERIALS where id in (select id from genes where not genes.id = genes.new_id);\\012\\012\\011delete from genes where id in (select id from genes where not genes.id = genes.new_id);\\012\\012\\012\\011--------------------------------------------------\\012\\011-- replace gene code with library_id\\012\\011--------------------------------------------------\\012\\011\\012\\011update materials set code = genes.library_id from genes where materials.id = genes.id ;\\012\\011delete from material_properties where id in (select library_tech_id from genes);\\012\\011\\012\\011--------------------------------------------------\\012\\011-- create a gene symbols property for each gene\\012\\011--------------------------------------------------\\012\\011\\012\\011insert into material_properties\\012\\011\\011(id\\012\\011  , mate_id\\012\\011  , mtpt_id\\012\\011  , "value"\\012\\011  , pers_id_registerer)\\012\\011\\011(select nextval('material_property_id_seq') id\\012\\011  \\011, genes.id  mate_id\\012\\011    , (select mtpt.id\\012\\011    \\011\\011from   material_type_property_types mtpt, material_types mt, property_types pt\\012\\011    \\011\\011where  pt.code = 'GENE_SYMBOLS' and mt.code = 'GENE' and mtpt.prty_id = pt.id\\012\\011        \\011and mtpt.maty_id = mt.id) mtpt_id\\012\\011    , genes.gene_codes "value"\\012\\011    , (select id from persons where user_id = 'system') pers_id_registerer\\012\\011 \\011from genes); \\012\\012\\011--------------------------------------------------\\012\\011-- delete temporary table\\012\\011--------------------------------------------------\\012\\011\\012\\011drop table genes;\\012\\011\\012END;\\012$$ LANGUAGE 'plpgsql';\\012\\012select REPLACE_GENE_SYMBOL_BY_GENE_ID();\\012drop function REPLACE_GENE_SYMBOL_BY_GENE_ID();\\012DROP AGGREGATE merge_words(text);\\012drop function merge_words(text,text);\\012\\012\\012--------------------------------------------------------------------------------------\\012--------------------------------------------------------------------------------------\\012\\012UPDATE sample_types SET code = 'SIRNA_WELL' WHERE code = 'OLIGO_WELL';\\012UPDATE material_types SET code = 'SIRNA' WHERE code = 'OLIGO';\\012UPDATE property_types SET code = 'SIRNA', label = 'siRNA' WHERE code = 'OLIGO';\\012\\012\\012\\012\\012\\012\\012\\012\\012\\012\\012\\012\\012\\012\\012\\012\\012\\012\\012\\012	\N
+./sourceTest/sql/postgresql/063/.svn/text-base/017=database_version_logs.tsv.svn-base:059	source/sql/postgresql/migration/migration-058-059.sql	SUCCESS	2010-09-29 13:37:07.231	-- Migration from 058 to 059\\012\\012-- Add ENTITY_TYPE_CODE column to QUERIES\\012ALTER TABLE queries ADD COLUMN entity_type_code CODE;\\012\\012------------------------------------------------------------------------------------\\012--  Purpose:  Create trigger that checks if entity_type_code specified in a query\\012--            matches a code of an entity of type specified in query_type.\\012------------------------------------------------------------------------------------\\012\\012CREATE OR REPLACE FUNCTION query_entity_type_code_check() RETURNS trigger AS $$\\012DECLARE\\012   counter  INTEGER;\\012BEGIN\\012   if (NEW.entity_type_code IS NOT NULL) then\\012     if (NEW.query_type = 'GENERIC') then\\012       RAISE EXCEPTION 'Insert/Update of query (Name: %) failed, as entity_type has to be null for GENERIC queries.', NEW.name;\\012     elsif (NEW.query_type = 'EXPERIMENT') then\\012       SELECT count(*) INTO counter FROM experiment_types WHERE code = NEW.entity_type_code;\\012\\011\\011 elsif (NEW.query_type = 'DATA_SET') then\\012       SELECT count(*) INTO counter FROM data_set_types WHERE code = NEW.entity_type_code;\\012\\011\\011 elsif (NEW.query_type = 'MATERIAL') then\\012       SELECT count(*) INTO counter FROM material_types WHERE code = NEW.entity_type_code;\\012\\011\\011 elsif (NEW.query_type = 'SAMPLE') then\\012       SELECT count(*) INTO counter FROM sample_types WHERE code = NEW.entity_type_code;\\012\\011\\011 end if;\\012\\011\\011 if (counter = 0) then\\012\\011\\011\\011 RAISE EXCEPTION 'Insert/Update of query (Name: %) failed because % type (Code: %) does not exist.', NEW.name, NEW.query_type, NEW.entity_type_code;\\012\\011\\011 end if;\\011\\011\\011\\012   end if;\\012   RETURN NEW;\\012END;\\012$$ LANGUAGE 'plpgsql';\\012\\012CREATE TRIGGER query_entity_type_code_check BEFORE INSERT OR UPDATE ON queries\\012    FOR EACH ROW EXECUTE PROCEDURE query_entity_type_code_check();\\012	\N
+./sourceTest/sql/postgresql/063/.svn/text-base/017=database_version_logs.tsv.svn-base:062	source/sql/postgresql/migration/migration-061-062.sql	SUCCESS	2010-11-25 16:02:07.224	\\012CREATE OR REPLACE FUNCTION sample_code_uniqueness_check() RETURNS trigger\\012    LANGUAGE plpgsql\\012    AS $$\\012DECLARE\\012   counter  INTEGER;\\012BEGIN\\012  LOCK TABLE samples IN EXCLUSIVE MODE;\\012  \\012\\011  IF (NEW.samp_id_part_of is NULL) THEN\\012\\011\\011  IF (NEW.dbin_id is not NULL) THEN\\012\\011\\011\\011  SELECT count(*) into counter FROM samples \\012\\011\\011      where id != NEW.id and code = NEW.code and samp_id_part_of is NULL and dbin_id = NEW.dbin_id;\\012        IF (counter > 0) THEN\\012\\011\\011\\011\\011  RAISE EXCEPTION 'Insert/Update of Sample (Code: %) failed because database instance sample with the same code already exists.', NEW.code;\\012        END IF;\\012\\011\\011  ELSIF (NEW.space_id is not NULL) THEN\\012\\011\\011\\011  SELECT count(*) into counter FROM samples \\012\\011\\011\\011\\011  where id != NEW.id and code = NEW.code and samp_id_part_of is NULL and space_id = NEW.grou_id;\\012\\011\\011\\011  IF (counter > 0) THEN\\012\\011\\011\\011\\011  RAISE EXCEPTION 'Insert/Update of Sample (Code: %) failed because space sample with the same code already exists.', NEW.code;\\012\\011\\011\\011  END IF;\\012      END IF;\\012    ELSE\\012\\011\\011  IF (NEW.dbin_id is not NULL) THEN\\012\\011\\011\\011  SELECT count(*) into counter FROM samples \\012\\011\\011\\011\\011  where id != NEW.id and code = NEW.code and samp_id_part_of = NEW.samp_id_part_of and dbin_id = NEW.dbin_id;\\012\\011\\011\\011  IF (counter > 0) THEN\\012\\011\\011\\011\\011  RAISE EXCEPTION 'Insert/Update of Sample (Code: %) failed because database instance sample with the same code and being the part of the same container already exists.', NEW.code;\\012\\011\\011\\011  END IF;\\012\\011\\011  ELSIF (NEW.space_id is not NULL) THEN\\012\\011\\011\\011  SELECT count(*) into counter FROM samples \\012\\011\\011\\011\\011  where id != NEW.id and code = NEW.code and samp_id_part_of = NEW.samp_id_part_of and space_id = NEW.space_id;\\012\\011\\011\\011  IF (counter > 0) THEN\\012\\011\\011\\011\\011  RAISE EXCEPTION 'Insert/Update of Sample (Code: %) failed because space sample with the same code and being the part of the same container already exists.', NEW.code;\\012\\011\\011\\011  END IF;\\012\\011\\011  END IF;\\012     END IF;   \\012  \\012  RETURN NEW;\\012END;\\012$$;\\012\\012\\012CREATE OR REPLACE FUNCTION sample_subcode_uniqueness_check() RETURNS trigger\\012    LANGUAGE plpgsql\\012    AS $$\\012DECLARE\\012   counter  INTEGER;\\012   unique_subcode  BOOLEAN_CHAR;\\012BEGIN\\012  LOCK TABLE samples IN EXCLUSIVE MODE;\\012  \\012  SELECT is_subcode_unique into unique_subcode FROM sample_types WHERE id = NEW.saty_id;\\012  \\012  IF (unique_subcode) THEN\\012    IF (NEW.dbin_id is not NULL) THEN\\012\\011\\011\\011SELECT count(*) into counter FROM samples \\012\\011\\011\\011\\011where id != NEW.id and code = NEW.code and saty_id = NEW.saty_id and dbin_id = NEW.dbin_id;\\012\\011\\011\\011IF (counter > 0) THEN\\012\\011\\011\\011\\011RAISE EXCEPTION 'Insert/Update of Sample (Code: %) failed because database instance sample of the same type with the same subcode already exists.', NEW.code;\\012\\011\\011\\011END IF;\\012\\011\\011ELSIF (NEW.space_id is not NULL) THEN\\012\\011\\011\\011SELECT count(*) into counter FROM samples \\012\\011\\011\\011\\011where id != NEW.id and code = NEW.code and saty_id = NEW.saty_id and space_id = NEW.space_id;\\012\\011\\011\\011IF (counter > 0) THEN\\012\\011\\011\\011\\011RAISE EXCEPTION 'Insert/Update of Sample (Code: %) failed because space sample of the same type with the same subcode already exists.', NEW.code;\\012\\011\\011\\011END IF;\\012\\011\\011END IF;\\012  END IF;\\012  \\012  RETURN NEW;\\012END;\\012$$;\\012\\012ALTER TABLE groups RENAME TO spaces;\\012\\012ALTER SEQUENCE group_id_seq RENAME TO space_id_seq;\\012\\012ALTER TABLE persons\\011RENAME grou_id TO space_id;\\012ALTER TABLE projects RENAME grou_id TO space_id;\\012ALTER TABLE role_assignments RENAME grou_id TO space_id;\\012ALTER TABLE samples\\011RENAME grou_id TO space_id;\\012\\012-- migrate EVENTS table\\012\\012ALTER TABLE events\\012\\011DROP CONSTRAINT evnt_et_enum_ck;\\012\\012update events set entity_type = 'SPACE' where entity_type = 'GROUP';\\012\\012ALTER TABLE events ADD CONSTRAINT evnt_et_enum_ck CHECK \\012\\011(entity_type IN ('ATTACHMENT', 'DATASET', 'EXPERIMENT', 'SPACE', 'MATERIAL', 'PROJECT', 'PROPERTY_TYPE', 'SAMPLE', 'VOCABULARY', 'AUTHORIZATION_GROUP')); \\012\\012ALTER TABLE persons\\012\\011DROP CONSTRAINT pers_grou_fk;\\012\\012ALTER TABLE persons\\012\\011ADD CONSTRAINT pers_space_fk FOREIGN KEY (space_id) REFERENCES spaces(id);\\012\\012ALTER TABLE projects\\012\\011DROP CONSTRAINT proj_bk_uk;\\012\\012ALTER TABLE projects\\012\\011DROP CONSTRAINT proj_grou_fk;\\012\\012ALTER TABLE projects\\012\\011ADD CONSTRAINT proj_bk_uk UNIQUE (code, space_id);\\012\\012ALTER TABLE projects\\012\\011ADD CONSTRAINT proj_space_fk FOREIGN KEY (space_id) REFERENCES spaces(id);\\012\\012ALTER TABLE role_assignments\\012\\011DROP CONSTRAINT roas_dbin_grou_arc_ck;\\012\\012ALTER TABLE role_assignments\\012\\011DROP CONSTRAINT roas_ag_group_bk_uk;\\012\\012ALTER TABLE role_assignments\\012\\011DROP CONSTRAINT roas_pe_group_bk_uk;\\012\\012ALTER TABLE role_assignments\\012\\011DROP CONSTRAINT roas_grou_fk;\\012\\012ALTER TABLE role_assignments\\012\\011ADD CONSTRAINT roas_dbin_space_arc_ck CHECK ((((dbin_id IS NOT NULL) AND (space_id IS NULL)) OR ((dbin_id IS NULL) AND (space_id IS NOT NULL))));\\012\\012ALTER TABLE role_assignments\\012\\011ADD CONSTRAINT roas_ag_space_bk_uk UNIQUE (ag_id_grantee, role_code, space_id);\\012\\012ALTER TABLE role_assignments\\012\\011ADD CONSTRAINT roas_pe_space_bk_uk UNIQUE (pers_id_grantee, role_code, space_id);\\012\\012ALTER TABLE role_assignments\\012\\011ADD CONSTRAINT roas_space_fk FOREIGN KEY (space_id) REFERENCES spaces(id);\\012\\012ALTER TABLE samples\\012\\011DROP CONSTRAINT samp_dbin_grou_arc_ck;\\012\\012ALTER TABLE samples\\012\\011DROP CONSTRAINT samp_grou_fk;\\012\\012ALTER TABLE samples\\012\\011ADD CONSTRAINT samp_dbin_space_arc_ck CHECK ((((dbin_id IS NOT NULL) AND (space_id IS NULL)) OR ((dbin_id IS NULL) AND (space_id IS NOT NULL))));\\012\\012ALTER TABLE samples\\012\\011ADD CONSTRAINT samp_space_fk FOREIGN KEY (space_id) REFERENCES spaces(id);\\012\\012ALTER TABLE spaces\\012  DROP CONSTRAINT grou_bk_uk,\\012  ADD CONSTRAINT space_bk_uk UNIQUE (code, dbin_id);\\012\\012ALTER TABLE spaces\\012  DROP CONSTRAINT grou_dbin_fk,\\012  ADD CONSTRAINT space_dbin_fk FOREIGN KEY (dbin_id) REFERENCES database_instances(id);\\012\\012ALTER TABLE spaces\\012  DROP CONSTRAINT grou_pers_fk_registerer,\\012  ADD CONSTRAINT space_pers_fk_registerer FOREIGN KEY (pers_id_registerer) REFERENCES persons(id);\\012\\012ALTER INDEX pers_grou_fk_i RENAME TO pers_space_fk_i;\\012\\012ALTER INDEX proj_grou_fk_i RENAME TO proj_space_fk_i;\\012\\012ALTER INDEX roas_grou_fk_i RENAME TO roas_space_fk_i;\\012\\012ALTER INDEX grou_pk RENAME TO space_pk;\\012\\012ALTER INDEX grou_dbin_fk_i RENAME TO space_dbin_fk_i;\\012\\012ALTER INDEX grou_pers_registered_by_fk_i RENAME TO space_pers_registered_by_fk_i;\\012\\012	\N
+./sourceTest/sql/postgresql/063/.svn/text-base/schema-063.sql.svn-base:    LANGUAGE plpgsql
+./sourceTest/sql/postgresql/063/.svn/text-base/schema-063.sql.svn-base:    LANGUAGE plpgsql
+./sourceTest/sql/postgresql/063/.svn/text-base/schema-063.sql.svn-base:    LANGUAGE plpgsql
+./sourceTest/sql/postgresql/063/.svn/text-base/schema-063.sql.svn-base:    LANGUAGE plpgsql
+./sourceTest/sql/postgresql/063/.svn/text-base/schema-063.sql.svn-base:    LANGUAGE plpgsql
+./sourceTest/sql/postgresql/063/.svn/text-base/schema-063.sql.svn-base:    LANGUAGE plpgsql
+./sourceTest/sql/postgresql/063/.svn/text-base/schema-063.sql.svn-base:    LANGUAGE plpgsql
+./sourceTest/sql/postgresql/063/.svn/text-base/schema-063.sql.svn-base:    LANGUAGE plpgsql
+./sourceTest/sql/postgresql/063/.svn/text-base/schema-063.sql.svn-base:    LANGUAGE plpgsql
+./sourceTest/sql/postgresql/063/017=database_version_logs.tsv:027	D:\\User\\felmer\\dev-workspace\\openbis/source/sql/postgresql/027/function-027.sql	SUCCESS	2008-11-05 09:18:00.403	-- Creating Functions\\012\\012------------------------------------------------------------------------------------\\012--  Purpose:  Create function RENAME_SEQUENCE() that is required for renaming the sequences belonging to tables\\012------------------------------------------------------------------------------------\\012CREATE FUNCTION RENAME_SEQUENCE(OLD_NAME VARCHAR, NEW_NAME VARCHAR) RETURNS INTEGER AS $$\\012DECLARE\\012  CURR_SEQ_VAL   INTEGER;\\012BEGIN\\012  SELECT INTO CURR_SEQ_VAL NEXTVAL(OLD_NAME);\\012  EXECUTE 'CREATE SEQUENCE ' || NEW_NAME || ' START WITH ' || CURR_SEQ_VAL;\\012  EXECUTE 'DROP SEQUENCE ' || OLD_NAME;\\012  RETURN CURR_SEQ_VAL;\\012END;\\012$$ LANGUAGE 'plpgsql';\\012\\012\\012------------------------------------------------------------------------------------\\012--  Purpose:  Create trigger CONTROLLED_VOCABULARY_CHECK \\012------------------------------------------------------------------------------------\\012\\012CREATE OR REPLACE FUNCTION CONTROLLED_VOCABULARY_CHECK() RETURNS trigger AS $$\\012DECLARE\\012   v_code  CODE;\\012BEGIN\\012\\012   select code into v_code from data_types where id = NEW.daty_id;\\012\\012   -- Check if the data is of type "CONTROLLEDVOCABULARY"\\012   if v_code = 'CONTROLLEDVOCABULARY' then\\012      if NEW.covo_id IS NULL then\\012         RAISE EXCEPTION 'Insert/Update of Property Type (Code: %) failed, as its Data Type is CONTROLLEDVOCABULARY, but it is not linked to a Controlled Vocabulary.', NEW.code;\\012      end if;\\012   end if;\\012\\012   RETURN NEW;\\012\\012END;\\012$$ LANGUAGE 'plpgsql';\\012\\012CREATE TRIGGER CONTROLLED_VOCABULARY_CHECK BEFORE INSERT OR UPDATE ON PROPERTY_TYPES\\012    FOR EACH ROW EXECUTE PROCEDURE CONTROLLED_VOCABULARY_CHECK();\\012\\012\\012------------------------------------------------------------------------------------\\012--  Purpose:  Create trigger EXTERNAL_DATA_STORAGE_FORMAT_CHECK \\012------------------------------------------------------------------------------------\\012\\012CREATE OR REPLACE FUNCTION EXTERNAL_DATA_STORAGE_FORMAT_CHECK() RETURNS trigger AS $$\\012DECLARE\\012   v_covo_code  CODE;\\012   data_code CODE;\\012BEGIN\\012\\012   select code into v_covo_code from controlled_vocabularies\\012      where is_internal_namespace = true and \\012         id = (select covo_id from controlled_vocabulary_terms where id = NEW.cvte_id_stor_fmt);\\012   -- Check if the data storage format is a term of the controlled vocabulary "STORAGE_FORMAT"\\012   if v_covo_code != 'STORAGE_FORMAT' then\\012      select code into data_code from data where id = NEW.data_id; \\012      RAISE EXCEPTION 'Insert/Update of Data (Code: %) failed, as its Storage Format is %, but is required to be STORAGE_FORMAT.', data_code, v_covo_code;\\012   end if;\\012\\012   RETURN NEW;\\012\\012END;\\012$$ LANGUAGE 'plpgsql';\\012\\012CREATE TRIGGER EXTERNAL_DATA_STORAGE_FORMAT_CHECK BEFORE INSERT OR UPDATE ON EXTERNAL_DATA\\012    FOR EACH ROW EXECUTE PROCEDURE EXTERNAL_DATA_STORAGE_FORMAT_CHECK();\\012\\012------------------------------------------------------------------------------------\\012--  Purpose:  Create trigger SAMPLE_CODE_UNIQUENESS_CHECK \\012------------------------------------------------------------------------------------\\012\\012CREATE OR REPLACE FUNCTION SAMPLE_CODE_UNIQUENESS_CHECK() RETURNS trigger AS $$\\012DECLARE\\012   counter  INTEGER;\\012BEGIN\\012\\011IF (NEW.samp_id_part_of is NULL) THEN\\012\\011\\011IF (NEW.dbin_id is not NULL) THEN\\012\\011\\011\\011SELECT count(*) into counter FROM samples \\012\\011\\011\\011\\011where id != NEW.id and code = NEW.code and samp_id_part_of is NULL and dbin_id = NEW.dbin_id;\\012\\011\\011\\011IF (counter > 0) THEN\\012\\011\\011\\011\\011RAISE EXCEPTION 'Insert/Update of Sample (Code: %) failed because database instance sample with the same code already exists.', NEW.code;\\012\\011\\011\\011END IF;\\012\\011\\011ELSIF (NEW.grou_id is not NULL) THEN\\012\\011\\011\\011SELECT count(*) into counter FROM samples \\012\\011\\011\\011\\011where id != NEW.id and code = NEW.code and samp_id_part_of is NULL and grou_id = NEW.grou_id;\\012\\011\\011\\011IF (counter > 0) THEN\\012\\011\\011\\011\\011RAISE EXCEPTION 'Insert/Update of Sample (Code: %) failed because group sample with the same code already exists.', NEW.code;\\012\\011\\011\\011END IF;\\012\\011\\011END IF;\\012        ELSE\\012\\011\\011IF (NEW.dbin_id is not NULL) THEN\\012\\011\\011\\011SELECT count(*) into counter FROM samples \\012\\011\\011\\011\\011where id != NEW.id and code = NEW.code and samp_id_part_of = NEW.samp_id_part_of and dbin_id = NEW.dbin_id;\\012\\011\\011\\011IF (counter > 0) THEN\\012\\011\\011\\011\\011RAISE EXCEPTION 'Insert/Update of Sample (Code: %) failed because database instance sample with the same code and being the part of the same parent already exists.', NEW.code;\\012\\011\\011\\011END IF;\\012\\011\\011ELSIF (NEW.grou_id is not NULL) THEN\\012\\011\\011\\011SELECT count(*) into counter FROM samples \\012\\011\\011\\011\\011where id != NEW.id and code = NEW.code and samp_id_part_of = NEW.samp_id_part_of and grou_id = NEW.grou_id;\\012\\011\\011\\011IF (counter > 0) THEN\\012\\011\\011\\011\\011RAISE EXCEPTION 'Insert/Update of Sample (Code: %) failed because group sample with the same code and being the part of the same parent already exists.', NEW.code;\\012\\011\\011\\011END IF;\\012\\011\\011END IF;\\012        END IF;   \\012   RETURN NEW;\\012END;\\012$$ LANGUAGE 'plpgsql';\\012\\012CREATE TRIGGER SAMPLE_CODE_UNIQUENESS_CHECK BEFORE INSERT OR UPDATE ON SAMPLES\\012    FOR EACH ROW EXECUTE PROCEDURE SAMPLE_CODE_UNIQUENESS_CHECK();\\012	\N
+./sourceTest/sql/postgresql/063/017=database_version_logs.tsv:028	source/sql/postgresql/migration/migration-027-028.sql	SUCCESS	2008-11-18 13:24:17.508	-- Create EXPERIMENT_ATTACHMENT_CONTENTS.\\012CREATE TABLE EXPERIMENT_ATTACHMENT_CONTENTS (ID TECH_ID NOT NULL,VALUE FILE NOT NULL);\\012CREATE SEQUENCE EXPERIMENT_ATTACHMENT_CONTENT_ID_SEQ;\\012ALTER TABLE EXPERIMENT_ATTACHMENT_CONTENTS ADD CONSTRAINT EXAC_PK PRIMARY KEY(ID);\\012\\012-- Alter EXPERIMENT_ATTACHMENTS by adding the new column which has a NULL constraint.\\012-- The NOT NULL constraint is added later on.\\012ALTER TABLE EXPERIMENT_ATTACHMENTS ADD COLUMN EXAC_ID TECH_ID;\\012\\012-- Does the VALUE migration between EXPERIMENT_ATTACHMENTS to EXPERIMENT_ATTACHMENT_CONTENTS.\\012CREATE OR REPLACE FUNCTION move_exp_att_content() RETURNS integer AS $$\\012DECLARE\\012    rec RECORD;\\012    seq BIGINT;\\012BEGIN\\012  FOR rec IN SELECT id, value FROM EXPERIMENT_ATTACHMENTS LOOP\\012  \\011seq := nextval('EXPERIMENT_ATTACHMENT_CONTENT_ID_SEQ');\\012    INSERT INTO EXPERIMENT_ATTACHMENT_CONTENTS (id, value) VALUES (seq, rec.value);\\012    UPDATE EXPERIMENT_ATTACHMENTS SET exac_id = seq WHERE id = rec.id;\\012  END LOOP;\\012  RETURN 1;\\012END;\\012$$ LANGUAGE 'plpgsql';\\012\\012-- Call the function.\\012SELECT move_exp_att_content();\\012DROP FUNCTION move_exp_att_content();\\012\\012\\012-- Finish EXPERIMENT_ATTACHMENTS changes.\\012ALTER TABLE EXPERIMENT_ATTACHMENTS ADD CONSTRAINT EXAT_CONT_FK FOREIGN KEY (EXAC_ID) REFERENCES EXPERIMENT_ATTACHMENT_CONTENTS(ID);\\012ALTER TABLE EXPERIMENT_ATTACHMENTS DROP COLUMN VALUE;\\012ALTER TABLE EXPERIMENT_ATTACHMENTS ALTER COLUMN EXAC_ID SET NOT NULL;\\012	\N
+./sourceTest/sql/postgresql/063/017=database_version_logs.tsv:029	source/sql/postgresql/migration/migration-028-029.sql	SUCCESS	2009-03-18 10:50:20.105	-- -------\\012-- add modification_timestamp field to allow edition with Hibernate\\012-- -------\\012\\012ALTER TABLE samples\\012\\011ADD COLUMN modification_timestamp TIME_STAMP DEFAULT CURRENT_TIMESTAMP;\\012\\012ALTER TABLE experiments\\012\\011ADD COLUMN modification_timestamp TIME_STAMP DEFAULT CURRENT_TIMESTAMP;\\012\\012ALTER TABLE materials\\012\\011ADD COLUMN modification_timestamp TIME_STAMP DEFAULT CURRENT_TIMESTAMP;\\012\\012ALTER TABLE experiment_properties\\012\\011ADD COLUMN modification_timestamp TIME_STAMP DEFAULT CURRENT_TIMESTAMP;\\012\\012ALTER TABLE material_properties\\012\\011ADD COLUMN modification_timestamp TIME_STAMP DEFAULT CURRENT_TIMESTAMP;\\012\\012ALTER TABLE sample_properties\\012\\011ADD COLUMN modification_timestamp TIME_STAMP DEFAULT CURRENT_TIMESTAMP;\\012\\012-- -------\\012-- add property data type which references materials\\012-- -------\\012\\012ALTER TABLE property_types\\012\\011ADD COLUMN maty_prop_id tech_id;\\012\\012ALTER TABLE property_types\\012\\011ADD CONSTRAINT prty_maty_fk FOREIGN KEY (maty_prop_id) REFERENCES material_types(id);\\012\\012ALTER TABLE experiment_properties\\012\\011ADD COLUMN mate_prop_id tech_id;\\012\\012ALTER TABLE material_properties\\012\\011ADD COLUMN mate_prop_id tech_id;\\012\\012ALTER TABLE sample_properties\\012\\011ADD COLUMN mate_prop_id tech_id;\\012\\012ALTER TABLE experiment_properties\\012\\011ADD CONSTRAINT expr_mapr_fk FOREIGN KEY (mate_prop_id) REFERENCES materials(id);\\012\\012ALTER TABLE material_properties\\012\\011ADD CONSTRAINT mapr_mapr_fk FOREIGN KEY (mate_prop_id) REFERENCES materials(id);\\012\\012ALTER TABLE sample_properties\\012\\011ADD CONSTRAINT sapr_mapr_fk FOREIGN KEY (mate_prop_id) REFERENCES materials(id);\\012\\012insert into data_types\\012(id\\012 ,code\\012 ,description)\\012 values \\012 (nextval('DATA_TYPE_ID_SEQ')\\012 ,'MATERIAL'\\012 ,'Reference to a material'\\012);\\012\\012ALTER TABLE MATERIAL_PROPERTIES DROP CONSTRAINT MAPR_CK;\\012ALTER TABLE MATERIAL_PROPERTIES ADD CONSTRAINT MAPR_CK CHECK \\012\\011((VALUE IS NOT NULL AND CVTE_ID IS NULL AND MATE_PROP_ID IS NULL) OR \\012\\011 (VALUE IS NULL AND CVTE_ID IS NOT NULL AND MATE_PROP_ID IS NULL) OR\\012\\011 (VALUE IS NULL AND CVTE_ID IS NULL AND MATE_PROP_ID IS NOT NULL)\\012\\011);\\012\\012ALTER TABLE EXPERIMENT_PROPERTIES DROP CONSTRAINT EXPR_CK;\\012ALTER TABLE EXPERIMENT_PROPERTIES ADD CONSTRAINT EXPR_CK CHECK \\012\\011((VALUE IS NOT NULL AND CVTE_ID IS NULL AND MATE_PROP_ID IS NULL) OR \\012\\011 (VALUE IS NULL AND CVTE_ID IS NOT NULL AND MATE_PROP_ID IS NULL) OR\\012\\011 (VALUE IS NULL AND CVTE_ID IS NULL AND MATE_PROP_ID IS NOT NULL)\\012\\011);\\012\\012ALTER TABLE SAMPLE_PROPERTIES DROP CONSTRAINT SAPR_CK;\\012ALTER TABLE SAMPLE_PROPERTIES ADD CONSTRAINT SAPR_CK CHECK \\012\\011((VALUE IS NOT NULL AND CVTE_ID IS NULL AND MATE_PROP_ID IS NULL) OR \\012\\011 (VALUE IS NULL AND CVTE_ID IS NOT NULL AND MATE_PROP_ID IS NULL) OR\\012\\011 (VALUE IS NULL AND CVTE_ID IS NULL AND MATE_PROP_ID IS NOT NULL)\\012\\011);\\012\\012------------------------------------------------------------------------------------\\012--  Purpose:  Create trigger MATERIAL/SAMPLE/EXPERIMENT _PROPERTY_WITH_MATERIAL_DATA_TYPE_CHECK\\012--            It checks that if material property value is assigned to the entity,\\012--\\011\\011\\011\\011\\011\\011then the material type is equal to the one described by property type.\\012------------------------------------------------------------------------------------\\012\\012CREATE OR REPLACE FUNCTION MATERIAL_PROPERTY_WITH_MATERIAL_DATA_TYPE_CHECK() RETURNS trigger AS $$\\012DECLARE\\012   v_type_id  CODE;\\012   v_type_id_prop  CODE;\\012BEGIN\\012   if NEW.mate_prop_id IS NOT NULL then\\012\\011\\011\\011-- find material type id of the property type \\012\\011\\011\\011select pt.maty_prop_id into v_type_id_prop \\012\\011\\011\\011  from material_type_property_types etpt, property_types pt \\012\\011\\011\\011 where NEW.mtpt_id = etpt.id AND etpt.prty_id = pt.id;\\012\\011\\011\\012\\011\\011\\011if v_type_id_prop IS NOT NULL then\\012\\011\\011\\011\\011-- find material type id of the material which consists the entity's property value\\012\\011\\011\\011\\011select entity.maty_id into v_type_id \\012\\011\\011\\011\\011  from materials entity\\012\\011\\011\\011\\011 where NEW.mate_prop_id = entity.id;\\012\\011\\011\\011\\011if v_type_id != v_type_id_prop then\\012\\011\\011\\011\\011\\011RAISE EXCEPTION 'Insert/Update of property value referencing material (id: %) failed, as referenced material type is different than expected (id %, expected id: %).', \\012\\011\\011\\011\\011\\011\\011\\011 NEW.mate_prop_id, v_type_id, v_type_id_prop;\\012\\011\\011\\011\\011end if;\\012\\011\\011\\011end if;\\012   end if;\\012   RETURN NEW;\\012END;\\012$$ LANGUAGE 'plpgsql';\\012\\012CREATE TRIGGER MATERIAL_PROPERTY_WITH_MATERIAL_DATA_TYPE_CHECK BEFORE INSERT OR UPDATE ON material_properties\\012    FOR EACH ROW EXECUTE PROCEDURE MATERIAL_PROPERTY_WITH_MATERIAL_DATA_TYPE_CHECK();\\012    \\012CREATE OR REPLACE FUNCTION SAMPLE_PROPERTY_WITH_MATERIAL_DATA_TYPE_CHECK() RETURNS trigger AS $$\\012DECLARE\\012   v_type_id  CODE;\\012   v_type_id_prop  CODE;\\012BEGIN\\012   if NEW.mate_prop_id IS NOT NULL then\\012\\011\\011\\011-- find material type id of the property type \\012\\011\\011\\011select pt.maty_prop_id into v_type_id_prop \\012\\011\\011\\011  from sample_type_property_types etpt, property_types pt \\012\\011\\011\\011 where NEW.stpt_id = etpt.id AND etpt.prty_id = pt.id;\\012\\011\\011\\012\\011\\011\\011if v_type_id_prop IS NOT NULL then\\012\\011\\011\\011\\011-- find material type id of the material which consists the entity's property value\\012\\011\\011\\011\\011select entity.maty_id into v_type_id \\012\\011\\011\\011\\011  from materials entity\\012\\011\\011\\011\\011 where NEW.mate_prop_id = entity.id;\\012\\011\\011\\011\\011if v_type_id != v_type_id_prop then\\012\\011\\011\\011\\011\\011RAISE EXCEPTION 'Insert/Update of property value referencing material (id: %) failed, as referenced material type is different than expected (id %, expected id: %).', \\012\\011\\011\\011\\011\\011\\011\\011\\011\\011\\011\\011\\011 NEW.mate_prop_id, v_type_id, v_type_id_prop;\\012\\011\\011\\011\\011end if;\\012\\011\\011\\011end if;\\012   end if;\\012   RETURN NEW;\\012END;\\012$$ LANGUAGE 'plpgsql';\\012\\012CREATE TRIGGER SAMPLE_PROPERTY_WITH_MATERIAL_DATA_TYPE_CHECK BEFORE INSERT OR UPDATE ON sample_properties\\012    FOR EACH ROW EXECUTE PROCEDURE SAMPLE_PROPERTY_WITH_MATERIAL_DATA_TYPE_CHECK();\\012    \\012CREATE OR REPLACE FUNCTION EXPERIMENT_PROPERTY_WITH_MATERIAL_DATA_TYPE_CHECK() RETURNS trigger AS $$\\012DECLARE\\012   v_type_id  CODE;\\012   v_type_id_prop  CODE;\\012BEGIN\\012   if NEW.mate_prop_id IS NOT NULL then\\012\\011\\011\\011-- find material type id of the property type \\012\\011\\011\\011select pt.maty_prop_id into v_type_id_prop \\012\\011\\011\\011  from experiment_type_property_types etpt, property_types pt \\012\\011\\011\\011 where NEW.etpt_id = etpt.id AND etpt.prty_id = pt.id;\\012\\011\\011\\012\\011\\011\\011if v_type_id_prop IS NOT NULL then\\012\\011\\011\\011\\011-- find material type id of the material which consists the entity's property value\\012\\011\\011\\011\\011select entity.maty_id into v_type_id \\012\\011\\011\\011\\011  from materials entity\\012\\011\\011\\011\\011 where NEW.mate_prop_id = entity.id;\\012\\011\\011\\011\\011if v_type_id != v_type_id_prop then\\012\\011\\011\\011\\011\\011RAISE EXCEPTION 'Insert/Update of property value referencing material (id: %) failed, as referenced material type is different than expected (id %, expected id: %).', \\012\\011\\011\\011\\011\\011\\011\\011\\011\\011\\011\\011\\011 NEW.mate_prop_id, v_type_id, v_type_id_prop;\\012\\011\\011\\011\\011end if;\\012\\011\\011\\011end if;\\012   end if;\\012   RETURN NEW;\\012END;\\012$$ LANGUAGE 'plpgsql';\\012\\012CREATE TRIGGER EXPERIMENT_PROPERTY_WITH_MATERIAL_DATA_TYPE_CHECK BEFORE INSERT OR UPDATE ON experiment_properties\\012    FOR EACH ROW EXECUTE PROCEDURE EXPERIMENT_PROPERTY_WITH_MATERIAL_DATA_TYPE_CHECK();\\012       \\012-- -------\\012-- remove the reminescents of the OBSERVABLE_TYPE\\012-- -------\\012\\012ALTER TABLE data\\012\\011DROP CONSTRAINT data_obty_fk;\\012\\012ALTER TABLE data_set_types\\012\\011DROP CONSTRAINT obty_pk;\\012\\012ALTER TABLE data_set_types\\012\\011ADD CONSTRAINT dsty_pk PRIMARY KEY (id);\\012\\012ALTER TABLE data\\012\\011ADD CONSTRAINT data_dsty_fk FOREIGN KEY (dsty_id) REFERENCES data_set_types(id);\\012\\012ALTER TABLE data_set_types\\012\\011DROP CONSTRAINT obty_bk_uk;\\012\\012ALTER TABLE data_set_types\\012\\011DROP CONSTRAINT obty_dbin_fk;\\012\\012ALTER TABLE data_set_types\\012\\011ADD CONSTRAINT dsty_bk_uk UNIQUE (code, dbin_id);\\012\\012ALTER TABLE data_set_types\\012\\011ADD CONSTRAINT dsty_dbin_fk FOREIGN KEY (dbin_id) REFERENCES database_instances(id);\\012\\012DROP INDEX data_obty_fk_i;\\012\\012CREATE INDEX data_dsty_fk_i ON data(dsty_id);\\012	\N
+./sourceTest/sql/postgresql/063/017=database_version_logs.tsv:030	source/sql/postgresql/migration/migration-029-030.sql	SUCCESS	2009-03-23 15:34:44.72	-- -------\\012-- add modification_timestamp field to allow edition with Hibernate\\012-- -------\\012ALTER TABLE data\\012\\011ADD COLUMN modification_timestamp TIME_STAMP DEFAULT CURRENT_TIMESTAMP;\\012ALTER TABLE experiment_types\\012\\011ADD COLUMN modification_timestamp TIME_STAMP DEFAULT CURRENT_TIMESTAMP;\\012ALTER TABLE sample_types\\012\\011ADD COLUMN modification_timestamp TIME_STAMP DEFAULT CURRENT_TIMESTAMP;\\012ALTER TABLE material_types\\012\\011ADD COLUMN modification_timestamp TIME_STAMP DEFAULT CURRENT_TIMESTAMP;\\012ALTER TABLE data_set_types\\012\\011ADD COLUMN modification_timestamp TIME_STAMP DEFAULT CURRENT_TIMESTAMP;\\012ALTER TABLE controlled_vocabularies\\012\\011ADD COLUMN modification_timestamp TIME_STAMP DEFAULT CURRENT_TIMESTAMP;\\012-- -------\\012-- add properties to data sets\\012-- -------\\012CREATE TABLE DATA_SET_PROPERTIES (ID TECH_ID NOT NULL,DS_ID TECH_ID NOT NULL,DSTPT_ID TECH_ID NOT NULL,VALUE GENERIC_VALUE,CVTE_ID TECH_ID, MATE_PROP_ID TECH_ID, PERS_ID_REGISTERER TECH_ID NOT NULL,REGISTRATION_TIMESTAMP TIME_STAMP_DFL NOT NULL DEFAULT CURRENT_TIMESTAMP, MODIFICATION_TIMESTAMP TIME_STAMP DEFAULT CURRENT_TIMESTAMP);\\012CREATE TABLE DATA_SET_TYPE_PROPERTY_TYPES (ID TECH_ID NOT NULL,DSTY_ID TECH_ID NOT NULL,PRTY_ID TECH_ID NOT NULL,IS_MANDATORY BOOLEAN_CHAR NOT NULL DEFAULT 'F',IS_MANAGED_INTERNALLY BOOLEAN_CHAR NOT NULL DEFAULT 'F',PERS_ID_REGISTERER TECH_ID NOT NULL,REGISTRATION_TIMESTAMP TIME_STAMP_DFL NOT NULL DEFAULT CURRENT_TIMESTAMP);\\012\\012CREATE SEQUENCE DATA_SET_PROPERTY_ID_SEQ;\\012CREATE SEQUENCE DSTPT_ID_SEQ;\\012\\012ALTER TABLE DATA_SET_TYPE_PROPERTY_TYPES ADD CONSTRAINT DSTPT_PK PRIMARY KEY(ID);\\012ALTER TABLE DATA_SET_PROPERTIES ADD CONSTRAINT DSPR_PK PRIMARY KEY(ID);\\012\\012ALTER TABLE DATA_SET_TYPE_PROPERTY_TYPES ADD CONSTRAINT DSTPT_BK_UK UNIQUE(DSTY_ID,PRTY_ID);\\012ALTER TABLE DATA_SET_PROPERTIES ADD CONSTRAINT DSPR_BK_UK UNIQUE(DS_ID,DSTPT_ID);\\012\\012\\012ALTER TABLE DATA_SET_TYPE_PROPERTY_TYPES ADD CONSTRAINT DSTPT_DSTY_FK FOREIGN KEY (DSTY_ID) REFERENCES DATA_SET_TYPES(ID);\\012ALTER TABLE DATA_SET_TYPE_PROPERTY_TYPES ADD CONSTRAINT DSTPT_PERS_FK FOREIGN KEY (PERS_ID_REGISTERER) REFERENCES PERSONS(ID);\\012ALTER TABLE DATA_SET_TYPE_PROPERTY_TYPES ADD CONSTRAINT DSTPT_PRTY_FK FOREIGN KEY (PRTY_ID) REFERENCES PROPERTY_TYPES(ID);\\012ALTER TABLE DATA_SET_PROPERTIES ADD CONSTRAINT DSPR_CVTE_FK FOREIGN KEY (CVTE_ID) REFERENCES CONTROLLED_VOCABULARY_TERMS(ID);\\012ALTER TABLE DATA_SET_PROPERTIES ADD CONSTRAINT DSPR_DSTPT_FK FOREIGN KEY (DSTPT_ID) REFERENCES DATA_SET_TYPE_PROPERTY_TYPES(ID) ON DELETE CASCADE;\\012ALTER TABLE DATA_SET_PROPERTIES ADD CONSTRAINT DSPR_DS_FK FOREIGN KEY (DS_ID) REFERENCES DATA(ID);\\012ALTER TABLE DATA_SET_PROPERTIES ADD CONSTRAINT DSPR_PERS_FK FOREIGN KEY (PERS_ID_REGISTERER) REFERENCES PERSONS(ID);\\012ALTER TABLE DATA_SET_PROPERTIES ADD CONSTRAINT DSPR_MAPR_FK FOREIGN KEY (MATE_PROP_ID) REFERENCES MATERIALS(ID);\\012\\012ALTER TABLE DATA_SET_PROPERTIES ADD CONSTRAINT DSPR_CK CHECK \\012\\011((VALUE IS NOT NULL AND CVTE_ID IS NULL AND MATE_PROP_ID IS NULL) OR \\012\\011 (VALUE IS NULL AND CVTE_ID IS NOT NULL AND MATE_PROP_ID IS NULL) OR\\012\\011 (VALUE IS NULL AND CVTE_ID IS NULL AND MATE_PROP_ID IS NOT NULL)\\012\\011);\\012\\012CREATE INDEX DSPR_CVTE_FK_I ON DATA_SET_PROPERTIES (CVTE_ID);\\012CREATE INDEX DSPR_DSTPT_FK_I ON DATA_SET_PROPERTIES (DSTPT_ID);\\012CREATE INDEX DSPR_DS_FK_I ON DATA_SET_PROPERTIES (DS_ID);\\012CREATE INDEX DSPR_PERS_FK_I ON DATA_SET_PROPERTIES (PERS_ID_REGISTERER);\\012CREATE INDEX DSTPT_DSTY_FK_I ON DATA_SET_TYPE_PROPERTY_TYPES (DSTY_ID);\\012CREATE INDEX DSTPT_PERS_FK_I ON DATA_SET_TYPE_PROPERTY_TYPES (PERS_ID_REGISTERER);\\012CREATE INDEX DSTPT_PRTY_FK_I ON DATA_SET_TYPE_PROPERTY_TYPES (PRTY_ID);\\012\\012CREATE OR REPLACE FUNCTION DATA_SET_PROPERTY_WITH_MATERIAL_DATA_TYPE_CHECK() RETURNS trigger AS $$\\012DECLARE\\012   v_type_id  CODE;\\012   v_type_id_prop  CODE;\\012BEGIN\\012   if NEW.mate_prop_id IS NOT NULL then\\012\\011\\011\\011-- find material type id of the property type \\012\\011\\011\\011select pt.maty_prop_id into v_type_id_prop \\012\\011\\011\\011  from data_set_type_property_types dstpt, property_types pt \\012\\011\\011\\011 where NEW.dstpt_id = dstpt.id AND dstpt.prty_id = pt.id;\\012\\011\\011\\012\\011\\011\\011if v_type_id_prop IS NOT NULL then\\012\\011\\011\\011\\011-- find material type id of the material which consists the entity's property value\\012\\011\\011\\011\\011select entity.maty_id into v_type_id \\012\\011\\011\\011\\011  from materials entity\\012\\011\\011\\011\\011 where NEW.mate_prop_id = entity.id;\\012\\011\\011\\011\\011if v_type_id != v_type_id_prop then\\012\\011\\011\\011\\011\\011RAISE EXCEPTION 'Insert/Update of property value referencing material (id: %) failed, as referenced material type is different than expected (id %, expected id: %).', \\012\\011\\011\\011\\011\\011\\011\\011\\011\\011\\011\\011\\011 NEW.mate_prop_id, v_type_id, v_type_id_prop;\\012\\011\\011\\011\\011end if;\\012\\011\\011\\011end if;\\012   end if;\\012   RETURN NEW;\\012END;\\012$$ LANGUAGE 'plpgsql';\\012\\012CREATE TRIGGER DATA_SET_PROPERTY_WITH_MATERIAL_DATA_TYPE_CHECK BEFORE INSERT OR UPDATE ON data_set_properties\\012    FOR EACH ROW EXECUTE PROCEDURE DATA_SET_PROPERTY_WITH_MATERIAL_DATA_TYPE_CHECK();   \\012	\N
+./sourceTest/sql/postgresql/063/017=database_version_logs.tsv:032	source/sql/postgresql/migration/migration-031-032.sql	SUCCESS	2009-04-09 09:36:36.2	-- -------\\012-- Modify MATERIAL_BATCHES\\012-- -------\\012\\012ALTER TABLE material_batches\\012    DROP COLUMN proc_id;\\012\\012-- -------\\012-- Modify SAMPLES\\012-- -------\\012\\012ALTER TABLE samples\\012    ADD COLUMN expe_id tech_id;\\012\\012ALTER TABLE samples\\012    ADD CONSTRAINT samp_expe_fk FOREIGN KEY (expe_id) REFERENCES experiments(id);\\012\\012CREATE INDEX samp_expe_fk_i ON samples USING btree (expe_id);\\012\\012-- relink samples directly to experiments\\012\\012UPDATE samples\\012SET expe_id = (SELECT e.id FROM experiments e, procedures p, sample_inputs si \\012               WHERE si.samp_id = samples.id AND si.proc_id = p.id AND p.expe_id = e.id AND e.inva_id IS NULL);\\012\\012\\012-- -------\\012-- Modify DATA\\012-- -------\\012\\012ALTER TABLE data\\012    ADD COLUMN expe_id tech_id;\\012\\012ALTER TABLE data\\012    ADD CONSTRAINT data_expe_fk FOREIGN KEY (expe_id) REFERENCES experiments(id);\\012\\012CREATE INDEX data_expe_fk_i ON data USING btree (expe_id);\\012\\012UPDATE data\\012SET expe_id = (SELECT e.id FROM experiments e, procedures p \\012               WHERE data.proc_id_produced_by = p.id AND p.expe_id = e.id);\\012\\012ALTER TABLE data\\012    ALTER COLUMN expe_id SET NOT NULL;\\012\\012ALTER TABLE data\\012    DROP COLUMN proc_id_produced_by;\\012\\012-- -------\\012-- Drop PROCEDURES, PROCEDURE_TYPES, and SAMPLE_INPUTS\\012-- -------\\012\\012DROP TABLE sample_inputs;\\012DROP TABLE procedures;\\012DROP TABLE procedure_types;\\012\\012DROP SEQUENCE procedure_id_seq;\\012DROP SEQUENCE procedure_type_id_seq;\\012\\012-- -------\\012-- Add CODE_SEQ\\012-- -------\\012\\012CREATE SEQUENCE CODE_SEQ;\\012\\012-- -------\\012-- Add new columns to DATA_STORES\\012-- -------\\012\\012ALTER TABLE data_stores\\012    ADD COLUMN remote_url character varying(250),\\012    ADD COLUMN session_token character varying(50),\\012    ADD COLUMN modification_timestamp time_stamp DEFAULT now();\\012\\012UPDATE data_stores\\012SET remote_url = '', session_token='';\\012\\012ALTER TABLE data_stores\\012    ALTER COLUMN remote_url SET NOT NULL,\\012    ALTER COLUMN session_token SET NOT NULL;\\012\\012-- -------\\012-- Drop foreign keys onto DATA_STORES\\012-- -------\\012\\012ALTER TABLE database_instances\\012    DROP COLUMN dast_id;\\012\\012ALTER TABLE groups\\012    DROP COLUMN dast_id;\\012\\012ALTER TABLE projects\\012    DROP COLUMN dast_id;\\012\\012ALTER TABLE experiments\\012    DROP COLUMN dast_id;\\012\\012-- -------\\012-- Add foreign key from DATA onto DATA_STORES\\012-- -------\\012\\012ALTER TABLE data\\012    ADD COLUMN dast_id tech_id;\\012\\012ALTER TABLE data\\012    ADD CONSTRAINT data_dast_fk FOREIGN KEY (dast_id) REFERENCES data_stores(id);\\012\\012UPDATE data\\012SET dast_id = (select id from data_stores where code = 'STANDARD');\\012\\012ALTER TABLE data\\012    ALTER COLUMN dast_id SET NOT NULL;\\012\\012\\012------------------------------------------------------------------------------------\\012--  Purpose:  Replace trigger SAMPLE_CODE_UNIQUENESS_CHECK \\012------------------------------------------------------------------------------------\\012\\012CREATE OR REPLACE FUNCTION SAMPLE_CODE_UNIQUENESS_CHECK() RETURNS trigger AS $$\\012DECLARE\\012   counter  INTEGER;\\012BEGIN\\012    LOCK TABLE samples IN EXCLUSIVE MODE;\\012    IF (NEW.samp_id_part_of is NULL) THEN\\012        IF (NEW.dbin_id is not NULL) THEN\\012            SELECT count(*) into counter FROM samples \\012                where id != NEW.id and code = NEW.code and samp_id_part_of is NULL and dbin_id = NEW.dbin_id;\\012            IF (counter > 0) THEN\\012                RAISE EXCEPTION 'Insert/Update of Sample (Code: %) failed because database instance sample with the same code already exists.', NEW.code;\\012            END IF;\\012        ELSIF (NEW.grou_id is not NULL) THEN\\012            SELECT count(*) into counter FROM samples \\012                where id != NEW.id and code = NEW.code and samp_id_part_of is NULL and grou_id = NEW.grou_id;\\012            IF (counter > 0) THEN\\012                RAISE EXCEPTION 'Insert/Update of Sample (Code: %) failed because group sample with the same code already exists.', NEW.code;\\012            END IF;\\012        END IF;\\012        ELSE\\012        IF (NEW.dbin_id is not NULL) THEN\\012            SELECT count(*) into counter FROM samples \\012                where id != NEW.id and code = NEW.code and samp_id_part_of = NEW.samp_id_part_of and dbin_id = NEW.dbin_id;\\012            IF (counter > 0) THEN\\012                RAISE EXCEPTION 'Insert/Update of Sample (Code: %) failed because database instance sample with the same code and being the part of the same parent already exists.', NEW.code;\\012            END IF;\\012        ELSIF (NEW.grou_id is not NULL) THEN\\012            SELECT count(*) into counter FROM samples \\012                where id != NEW.id and code = NEW.code and samp_id_part_of = NEW.samp_id_part_of and grou_id = NEW.grou_id;\\012            IF (counter > 0) THEN\\012                RAISE EXCEPTION 'Insert/Update of Sample (Code: %) failed because group sample with the same code and being the part of the same parent already exists.', NEW.code;\\012            END IF;\\012        END IF;\\012        END IF;   \\012   RETURN NEW;\\012END;\\012$$ LANGUAGE 'plpgsql';\\012\\012\\012\\012	\N
+./sourceTest/sql/postgresql/063/017=database_version_logs.tsv:034	source/sql/postgresql/migration/migration-033-034.sql	SUCCESS	2009-05-26 08:32:49.935	------------------------------------------------------------------------------------\\012-- Create sequence for generating permanent identifiers starting with nextval of existing dataset sequence.\\012------------------------------------------------------------------------------------\\012CREATE FUNCTION CREATE_SEQUENCE(EXISTING_SEQUENCE VARCHAR, NEW_SEQUENCE VARCHAR) RETURNS VOID AS $$\\012DECLARE\\012  CURR_SEQ_VAL   INTEGER;\\012BEGIN\\012  SELECT INTO CURR_SEQ_VAL NEXTVAL(EXISTING_SEQUENCE);\\012  EXECUTE 'CREATE SEQUENCE ' || NEW_SEQUENCE || ' START WITH ' || CURR_SEQ_VAL;\\012  RETURN;\\012END;\\012$$ LANGUAGE 'plpgsql';\\012\\012SELECT CREATE_SEQUENCE('DATA_ID_SEQ', 'PERM_ID_SEQ');\\012DROP FUNCTION CREATE_SEQUENCE(VARCHAR, VARCHAR);\\012\\012------------------------------------------------------------------------------------\\012-- Add perm_id columns to samples and experiments.\\012------------------------------------------------------------------------------------\\012ALTER TABLE SAMPLES ADD COLUMN PERM_ID CODE;\\012ALTER TABLE EXPERIMENTS ADD COLUMN PERM_ID CODE;\\012\\012UPDATE SAMPLES SET PERM_ID = to_char(registration_timestamp,'YYYYMMDDHHSSMS') || '-' || NEXTVAL('PERM_ID_SEQ');\\012UPDATE EXPERIMENTS SET PERM_ID = to_char(registration_timestamp,'YYYYMMDDHHSSMS') || '-' || NEXTVAL('PERM_ID_SEQ');\\012ALTER TABLE SAMPLES ALTER COLUMN PERM_ID SET NOT NULL;\\012ALTER TABLE EXPERIMENTS ALTER COLUMN PERM_ID SET NOT NULL;\\012ALTER TABLE SAMPLES ADD CONSTRAINT SAMP_PI_UK UNIQUE(PERM_ID);\\012ALTER TABLE EXPERIMENTS ADD CONSTRAINT EXPE_PI_UK UNIQUE(PERM_ID);\\012\\012\\012------------------------------------------------------------------------------------\\012-- Add column is_chosen_from_list to controlled_vocabularies.\\012------------------------------------------------------------------------------------\\012ALTER TABLE controlled_vocabularies ADD COLUMN is_chosen_from_list BOOLEAN_CHAR NOT NULL DEFAULT TRUE;\\012ALTER TABLE controlled_vocabularies ADD COLUMN source_uri CHARACTER VARYING(250);\\012------------------------------------------------------------------------------------\\012-- Modify Data table - remove arc connection between Sample and Data table, use a flag instead\\012------------------------------------------------------------------------------------\\012\\012-- add new columns\\012\\012ALTER TABLE data\\012    ADD COLUMN is_derived boolean_char;\\012ALTER TABLE data\\012    ADD COLUMN samp_id tech_id;\\012\\012-- update values in new columns\\012\\012UPDATE data\\012    SET is_derived = (samp_id_derived_from IS NOT NULL); \\012UPDATE data\\012    SET samp_id = samp_id_derived_from \\012    WHERE is_derived = 'TRUE';\\012UPDATE data\\012    SET samp_id = samp_id_acquired_from \\012    WHERE is_derived = 'FALSE';\\012\\012-- add constraints and indexes to new columns\\012\\012ALTER TABLE data\\012    ALTER COLUMN is_derived SET NOT NULL;\\012ALTER TABLE data\\012    ALTER COLUMN samp_id SET NOT NULL;   \\012ALTER TABLE data\\012    ADD CONSTRAINT data_samp_fk FOREIGN KEY (samp_id) REFERENCES samples (id);\\012CREATE INDEX data_samp_fk_i ON data USING btree (samp_id);\\012\\012-- remove old columns\\012\\012ALTER TABLE data\\012    DROP COLUMN samp_id_acquired_from;\\012ALTER TABLE data\\012    DROP COLUMN samp_id_derived_from;\\012    \\012------------------------------------------------------------------------------------\\012-- Granting SELECT privilege to group openbis_readonly\\012------------------------------------------------------------------------------------\\012\\012GRANT SELECT ON SEQUENCE attachment_content_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE attachment_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE code_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE controlled_vocabulary_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE cvte_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE data_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE data_set_property_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE data_set_relationship_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE data_set_type_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE data_store_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE data_type_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE database_instance_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE dstpt_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE etpt_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE event_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE experiment_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE experiment_property_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE experiment_type_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE file_format_type_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE group_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE invalidation_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE locator_type_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE material_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE material_property_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE material_type_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE mtpt_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE perm_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE person_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE project_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE property_type_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE role_assignment_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE sample_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE sample_property_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE sample_type_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE stpt_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE attachment_contents TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE attachments TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE controlled_vocabularies TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE controlled_vocabulary_terms TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE data TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE data_set_properties TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE data_set_relationships TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE data_set_type_property_types TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE data_set_types TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE data_stores TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE data_types TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE database_instances TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE database_version_logs TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE events TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE experiment_properties TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE experiment_type_property_types TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE experiment_types TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE experiments TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE external_data TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE file_format_types TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE groups TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE invalidations TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE locator_types TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE material_properties TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE material_type_property_types TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE material_types TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE materials TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE persons TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE projects TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE property_types TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE role_assignments TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE sample_properties TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE sample_type_property_types TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE sample_types TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE samples TO GROUP OPENBIS_READONLY;\\012\\012------------------------------------------------------------------------------------\\012-- Delete MATERIAL_BATCHES table\\012------------------------------------------------------------------------------------\\012\\012-- WARNING: Potential data lost!!!\\012-- WARNING: Potential data lost!!!\\012-- WARNING: Potential data lost!!!\\012\\012DROP TABLE SAMPLE_MATERIAL_BATCHES;\\012DROP TABLE MATERIAL_BATCHES;\\012DROP SEQUENCE MATERIAL_BATCH_ID_SEQ;\\012\\012------------------------------------------------------------------------------------\\012-- Delete MATE_ID_INHIBITOR_OF from table MATERIALS\\012------------------------------------------------------------------------------------\\012\\012-- WARNING: Potential data lost!!!\\012-- WARNING: Potential data lost!!!\\012-- WARNING: Potential data lost!!!\\012\\012ALTER TABLE MATERIALS DROP COLUMN MATE_ID_INHIBITOR_OF;\\012	\N
+./sourceTest/sql/postgresql/063/017=database_version_logs.tsv:041	source/sql/postgresql/migration/migration-040-041.sql	SUCCESS	2009-09-14 13:48:57.539	-- Create FILTERS table\\012\\012CREATE TABLE FILTERS (ID TECH_ID NOT NULL, DBIN_ID TECH_ID NOT NULL, NAME VARCHAR(200) NOT NULL, DESCRIPTION DESCRIPTION_1000,REGISTRATION_TIMESTAMP TIME_STAMP_DFL NOT NULL DEFAULT CURRENT_TIMESTAMP, PERS_ID_REGISTERER TECH_ID NOT NULL, MODIFICATION_TIMESTAMP TIME_STAMP DEFAULT CURRENT_TIMESTAMP, EXPRESSION VARCHAR(2000) NOT NULL, IS_PUBLIC BOOLEAN NOT NULL, GRID_ID VARCHAR(200) NOT NULL);\\012CREATE SEQUENCE FILTER_ID_SEQ;\\012ALTER TABLE FILTERS ADD CONSTRAINT FILT_PK PRIMARY KEY(ID);\\012ALTER TABLE FILTERS ADD CONSTRAINT FILT_BK_UK UNIQUE(NAME, DBIN_ID, GRID_ID);\\012ALTER TABLE FILTERS ADD CONSTRAINT FILT_PERS_FK FOREIGN KEY (PERS_ID_REGISTERER) REFERENCES PERSONS(ID);\\012ALTER TABLE FILTERS ADD CONSTRAINT FILT_DBIN_FK FOREIGN KEY (DBIN_ID) REFERENCES DATABASE_INSTANCES(ID);\\012CREATE INDEX FILT_PERS_FK_I ON FILTERS (PERS_ID_REGISTERER);\\012CREATE INDEX FILT_DBIN_FK_I ON FILTERS (DBIN_ID);\\012GRANT SELECT ON SEQUENCE filter_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE filters TO GROUP OPENBIS_READONLY;\\012\\012-- Add missing foreign key to role assignments authorization group\\012ALTER TABLE ROLE_ASSIGNMENTS ADD CONSTRAINT ROAS_AG_FK_GRANTEE FOREIGN KEY (AG_ID_GRANTEE) REFERENCES AUTHORIZATION_GROUPS(ID);\\012\\012--------------------------------------------------------------------------------------------------\\012-- Modify dataset connections:\\012-- 1. connection with sample shouldn't be mandatory any more\\012-- 2. introduce an arc condition that dataset cannot be connected with a sample and a parent dataset at the same time\\012--------------------------------------------------------------------------------------------------\\012\\012-- Weaken data-sample connection constraint - allow dataset to have no connection with sample\\012ALTER TABLE data ALTER COLUMN samp_id DROP NOT NULL;\\012\\012-- Remove data-sample connection for datasets that have a parent\\012\\012UPDATE data \\012   SET samp_id = NULL \\012 WHERE id IN (SELECT DISTINCT data_id_child FROM data_set_relationships);\\012\\012-- With PostgreSQL 8.4 one can check that before migration there were no cycles in dataset relationships:\\012--\\012-- WITH RECURSIVE data_set_parents(id, parent_ids, cycle) AS (\\012--         SELECT  r.data_id_child AS id, \\012--                 ARRAY[CAST (r.data_id_parent AS bigint)] AS parent_ids, \\012--                 false AS cycle \\012--         FROM data_set_relationships r\\012--     UNION ALL\\012--         SELECT  r.data_id_child,\\012--                 CAST (r.data_id_parent AS bigint) || p.parent_ids,\\012--                 r.data_id_child = ANY(p.parent_ids)\\012--         FROM data_set_relationships r, data_set_parents p\\012--         WHERE r.data_id_parent = p.id AND NOT cycle\\012-- )\\012-- SELECT count(*) AS cycles FROM data_set_parents WHERE cycle = true;\\012\\012---------------------------------------------------------------------------------------------------\\012--  Purpose:  Create DEFERRED triggers:\\012--            * check_dataset_relationships_on_data_table_modification,\\012--            * check_dataset_relationships_on_relationships_table_modification.\\012--            They check that after all modifications of database (just before commit) \\012--            if 'data'/'data_set_relationships' tables are among modified tables \\012--            dataset is not connected with a sample and a parent dataset at the same time.\\012--            This connections are held in two different tables so simple immediate trigger \\012--            with arc check cannot be used and we need two deferred triggers.\\012----------------------------------------------------------------------------------------------------\\012\\012-- trigger for 'data' table\\012\\012CREATE OR REPLACE FUNCTION check_dataset_relationships_on_data_table_modification() RETURNS trigger AS $$\\012DECLARE\\012\\011counter\\011INTEGER;\\012BEGIN\\012\\011-- if there is a connection with a Sample there should not be any connection with a parent Data Set\\012\\011IF (NEW.samp_id IS NOT NULL) THEN\\012\\011\\011-- count number of parents\\012\\011\\011SELECT count(*) INTO counter \\012\\011\\011\\011FROM data_set_relationships \\012\\011\\011\\011WHERE data_id_child = OLD.id;\\012\\011\\011IF (counter > 0) THEN\\012\\011\\011\\011RAISE EXCEPTION 'Insert/Update of Data Set (Code: %) failed because it cannot be connected with a Sample and a parent Data Set at the same time.', OLD.code;\\012\\011\\011END IF;\\012\\011END IF;\\012  RETURN NEW;\\012END;\\012$$ LANGUAGE 'plpgsql';\\012\\012CREATE CONSTRAINT TRIGGER check_dataset_relationships_on_data_table_modification \\012  AFTER INSERT OR UPDATE ON data\\012\\011DEFERRABLE INITIALLY DEFERRED\\012\\011FOR EACH ROW \\012\\011EXECUTE PROCEDURE check_dataset_relationships_on_data_table_modification();\\012\\012-- trigger for 'data_set_relationships'\\012\\012CREATE OR REPLACE FUNCTION check_dataset_relationships_on_relationships_table_modification() RETURNS trigger AS $$\\012DECLARE\\012\\011counter\\011INTEGER;\\012\\011sample_id\\011TECH_ID;\\012\\011data_code\\011CODE;\\012BEGIN\\012\\011-- child will have a parent added so it should not be connected with any sample\\012\\011SELECT samp_id, code INTO sample_id, data_code \\012\\011\\011FROM data \\012\\011\\011WHERE id = NEW.data_id_child;\\012\\011IF (sample_id IS NOT NULL) THEN\\012\\011\\011RAISE EXCEPTION 'Insert/Update of Data Set (Code: %) failed because it cannot be connected to a Sample and to a parent Data Set at the same time.', data_code;\\012\\011END IF;\\012\\011RETURN NEW;\\012END;\\012$$ LANGUAGE 'plpgsql';\\012  \\012CREATE CONSTRAINT TRIGGER check_dataset_relationships_on_relationships_table_modification \\012  AFTER INSERT OR UPDATE ON data_set_relationships\\012\\011DEFERRABLE INITIALLY DEFERRED\\012\\011FOR EACH ROW \\012\\011EXECUTE PROCEDURE check_dataset_relationships_on_relationships_table_modification();\\012	\N
+./sourceTest/sql/postgresql/063/017=database_version_logs.tsv:053	source/sql/postgresql/migration/migration-052-053.sql	SUCCESS	2010-06-08 15:27:55.032	-- Migration from 052 to 053\\012\\012-- Change code uniqueness check for samples of specific type.\\012-- If sample_types.is_subcode_unique flag is set to 'true', additional check is performed \\012-- on codes of samples of the type. Subcodes will have to be unique as well.\\012\\012ALTER TABLE sample_types ADD COLUMN is_subcode_unique boolean_char NOT NULL DEFAULT false;\\012\\012CREATE OR REPLACE FUNCTION SAMPLE_SUBCODE_UNIQUENESS_CHECK() RETURNS trigger AS $$\\012DECLARE\\012   counter  INTEGER;\\012   unique_subcode  BOOLEAN_CHAR;\\012BEGIN\\012  LOCK TABLE samples IN EXCLUSIVE MODE;\\012  \\012  SELECT is_subcode_unique into unique_subcode FROM sample_types WHERE id = NEW.saty_id;\\012  \\012  IF (unique_subcode) THEN\\012    IF (NEW.dbin_id is not NULL) THEN\\012\\011\\011\\011SELECT count(*) into counter FROM samples \\012\\011\\011\\011\\011where id != NEW.id and code = NEW.code and saty_id = NEW.saty_id and dbin_id = NEW.dbin_id;\\012\\011\\011\\011IF (counter > 0) THEN\\012\\011\\011\\011\\011RAISE EXCEPTION 'Insert/Update of Sample (Code: %) failed because database instance sample of the same type with the same subcode already exists.', NEW.code;\\012\\011\\011\\011END IF;\\012\\011\\011ELSIF (NEW.grou_id is not NULL) THEN\\012\\011\\011\\011SELECT count(*) into counter FROM samples \\012\\011\\011\\011\\011where id != NEW.id and code = NEW.code and saty_id = NEW.saty_id and grou_id = NEW.grou_id;\\012\\011\\011\\011IF (counter > 0) THEN\\012\\011\\011\\011\\011RAISE EXCEPTION 'Insert/Update of Sample (Code: %) failed because space sample of the same type with the same subcode already exists.', NEW.code;\\012\\011\\011\\011END IF;\\012\\011\\011END IF;\\012  END IF;\\012  \\012  RETURN NEW;\\012END;\\012$$ LANGUAGE 'plpgsql';\\012\\012CREATE TRIGGER SAMPLE_SUBCODE_UNIQUENESS_CHECK BEFORE INSERT OR UPDATE ON SAMPLES\\012    FOR EACH ROW EXECUTE PROCEDURE SAMPLE_SUBCODE_UNIQUENESS_CHECK();\\012    \\012-- Fixing error messages in old trigger\\012\\012CREATE OR REPLACE FUNCTION SAMPLE_CODE_UNIQUENESS_CHECK() RETURNS trigger AS $$\\012DECLARE\\012   counter  INTEGER;\\012BEGIN\\012  LOCK TABLE samples IN EXCLUSIVE MODE;\\012  \\012\\011  IF (NEW.samp_id_part_of is NULL) THEN\\012\\011\\011  IF (NEW.dbin_id is not NULL) THEN\\012\\011\\011\\011  SELECT count(*) into counter FROM samples \\012\\011\\011      where id != NEW.id and code = NEW.code and samp_id_part_of is NULL and dbin_id = NEW.dbin_id;\\012        IF (counter > 0) THEN\\012\\011\\011\\011\\011  RAISE EXCEPTION 'Insert/Update of Sample (Code: %) failed because database instance sample with the same code already exists.', NEW.code;\\012        END IF;\\012\\011\\011  ELSIF (NEW.grou_id is not NULL) THEN\\012\\011\\011\\011  SELECT count(*) into counter FROM samples \\012\\011\\011\\011\\011  where id != NEW.id and code = NEW.code and samp_id_part_of is NULL and grou_id = NEW.grou_id;\\012\\011\\011\\011  IF (counter > 0) THEN\\012\\011\\011\\011\\011  RAISE EXCEPTION 'Insert/Update of Sample (Code: %) failed because space sample with the same code already exists.', NEW.code;\\012\\011\\011\\011  END IF;\\012      END IF;\\012    ELSE\\012\\011\\011  IF (NEW.dbin_id is not NULL) THEN\\012\\011\\011\\011  SELECT count(*) into counter FROM samples \\012\\011\\011\\011\\011  where id != NEW.id and code = NEW.code and samp_id_part_of = NEW.samp_id_part_of and dbin_id = NEW.dbin_id;\\012\\011\\011\\011  IF (counter > 0) THEN\\012\\011\\011\\011\\011  RAISE EXCEPTION 'Insert/Update of Sample (Code: %) failed because database instance sample with the same code and being the part of the same container already exists.', NEW.code;\\012\\011\\011\\011  END IF;\\012\\011\\011  ELSIF (NEW.grou_id is not NULL) THEN\\012\\011\\011\\011  SELECT count(*) into counter FROM samples \\012\\011\\011\\011\\011  where id != NEW.id and code = NEW.code and samp_id_part_of = NEW.samp_id_part_of and grou_id = NEW.grou_id;\\012\\011\\011\\011  IF (counter > 0) THEN\\012\\011\\011\\011\\011  RAISE EXCEPTION 'Insert/Update of Sample (Code: %) failed because space sample with the same code and being the part of the same container already exists.', NEW.code;\\012\\011\\011\\011  END IF;\\012\\011\\011  END IF;\\012     END IF;   \\012  \\012  RETURN NEW;\\012END;\\012$$ LANGUAGE 'plpgsql';\\012	\N
+./sourceTest/sql/postgresql/063/017=database_version_logs.tsv:054	source/sql/postgresql/migration/migration-053-054.sql	SUCCESS	2010-07-27 11:30:46.766	-- Migration from 053 to 054\\012\\012\\012-- Add RELATIONSHIP_TYPES table\\012CREATE TABLE relationship_types (id TECH_ID NOT NULL, code CODE NOT NULL, label COLUMN_LABEL, parent_label COLUMN_LABEL, child_label COLUMN_LABEL, description DESCRIPTION_2000, registration_timestamp TIME_STAMP_DFL NOT NULL DEFAULT CURRENT_TIMESTAMP, pers_id_registerer TECH_ID NOT NULL, is_managed_internally BOOLEAN_CHAR NOT NULL DEFAULT 'F', is_internal_namespace BOOLEAN_CHAR NOT NULL DEFAULT 'F', dbin_id TECH_ID NOT NULL);\\012\\012-- Add SAMPLE_RELATIONSHIPS table\\012CREATE TABLE sample_relationships (id TECH_ID NOT NULL, sample_id_parent TECH_ID NOT NULL, relationship_id TECH_ID NOT NULL, sample_id_child TECH_ID NOT NULL);\\012\\012-- Add/update constraints\\012ALTER TABLE relationship_types ADD CONSTRAINT rety_pk PRIMARY KEY (id);\\012ALTER TABLE relationship_types ADD CONSTRAINT rety_uk UNIQUE(code,dbin_id);\\012ALTER TABLE sample_relationships ADD CONSTRAINT sare_pk PRIMARY KEY (id);\\012ALTER TABLE sample_relationships ADD CONSTRAINT sare_bk_uk UNIQUE(sample_id_child,sample_id_parent,relationship_id);\\012ALTER TABLE sample_relationships ADD CONSTRAINT sare_data_fk_child FOREIGN KEY (sample_id_child) REFERENCES samples(id) ON DELETE CASCADE;\\012ALTER TABLE sample_relationships ADD CONSTRAINT sare_data_fk_parent FOREIGN KEY (sample_id_parent) REFERENCES samples(id) ON DELETE CASCADE;\\012ALTER TABLE sample_relationships ADD CONSTRAINT sare_data_fk_relationship FOREIGN KEY (relationship_id) REFERENCES relationship_types(id);\\012\\012-- Create index\\012CREATE INDEX sare_data_fk_i_child ON sample_relationships (sample_id_child);\\012CREATE INDEX sare_data_fk_i_parent ON sample_relationships (sample_id_parent);\\012CREATE INDEX sare_data_fk_i_relationship ON sample_relationships (relationship_id);\\012\\012-- Create sequence for RELATIONSHIP_TYPES\\012CREATE SEQUENCE RELATIONSHIP_TYPE_ID_SEQ;\\012CREATE SEQUENCE SAMPLE_RELATIONSHIP_ID_SEQ;\\012\\012-- Create initial relationships\\012insert into relationship_types\\012(id, \\012code, \\012label, \\012parent_label, \\012child_label, \\012description, \\012pers_id_registerer, \\012is_managed_internally, \\012is_internal_namespace, \\012dbin_id) \\012values\\012(\\012nextval('RELATIONSHIP_TYPE_ID_SEQ'),\\012'PARENT_CHILD',\\012'Parent - Child', \\012'Parent', \\012'Child', \\012'Parent - Child relationship', \\012(select id from persons where user_id ='system'), \\012'T', \\012'T', \\012(select id from database_instances where is_original_source = 'T')\\012);\\012\\012insert into relationship_types\\012(id, \\012code, \\012label, \\012parent_label, \\012child_label, \\012description, \\012pers_id_registerer, \\012is_managed_internally, \\012is_internal_namespace, \\012dbin_id) \\012values\\012(\\012nextval('RELATIONSHIP_TYPE_ID_SEQ'),\\012'PLATE_CONTROL_LAYOUT',\\012'Plate - Control Layout', \\012'Plate', \\012'Control Layout', \\012'Plate - Control Layout relationship', \\012(select id from persons where user_id ='system'), \\012'T', \\012'T', \\012(select id from database_instances where is_original_source = 'T')\\012); \\012\\012\\012-- Migrate sample relationships to new schema\\012INSERT INTO sample_relationships (id, sample_id_parent,sample_id_child,relationship_id) (select distinct nextval('SAMPLE_RELATIONSHIP_ID_SEQ') as id, s.SAMP_ID_GENERATED_FROM as parent_id, s.ID as child_id, rt.id as relationship_id from samples s, relationship_types rt  WHERE rt.code = 'PARENT_CHILD' and s.SAMP_ID_GENERATED_FROM is not null); \\012INSERT INTO sample_relationships (id, sample_id_parent,sample_id_child,relationship_id) (select distinct nextval('SAMPLE_RELATIONSHIP_ID_SEQ') as id, s.SAMP_ID_CONTROL_LAYOUT as parent_id, s.ID as child_id, rt.id as relationship_id from samples s, relationship_types rt  WHERE rt.code = 'PLATE_CONTROL_LAYOUT' and s.SAMP_ID_CONTROL_LAYOUT is not null);\\012\\012-- Drop old sample relations\\012ALTER TABLE SAMPLES DROP COLUMN SAMP_ID_TOP;\\012ALTER TABLE SAMPLES DROP COLUMN SAMP_ID_GENERATED_FROM;\\012ALTER TABLE SAMPLES DROP COLUMN SAMP_ID_CONTROL_LAYOUT;\\012\\012--------------------------------------------------------------------------------------\\012--------------------------------------------------------------------------------------\\012-- This is a screening specific migration. Nothing will be performed on openBIS databases \\012-- which are not screening specific.\\012-- \\012-- This migration for each existing connection between oligo well, oligo material and gene material\\012-- creates a direct connection between the well and the gene. \\012--------------------------------------------------------------------------------------\\012--------------------------------------------------------------------------------------\\012 \\012\\011\\012CREATE OR REPLACE FUNCTION CONNECT_WELLS_WITH_GENES() RETURNS void AS $$\\012DECLARE\\012\\011counter  int;\\012\\011oligo_well_exists bool;\\012BEGIN\\012\\011--------------------------------------------------\\012\\011-- create a gene property and assign it to oligo well\\012\\011--------------------------------------------------\\012\\011\\012\\011select true \\012\\011into oligo_well_exists\\012\\011from sample_types \\012\\011where code = 'OLIGO_WELL';\\012\\011\\012\\011if oligo_well_exists IS NULL then \\012\\011\\011-- skip migration if there are no oligo wells\\012\\011\\011return;\\012\\011end if;   \\012\\011\\012\\011insert into property_types(\\012\\011\\011id, \\012\\011\\011code, description, label, \\012\\011\\011daty_id,\\012\\011\\011pers_id_registerer,\\012\\011\\011dbin_id,\\012\\011\\011maty_prop_id) \\012\\011values(\\012\\011\\011\\011nextval('PROPERTY_TYPE_ID_SEQ'), \\012\\011\\011\\011'GENE','Inhibited gene','Gene',\\012\\011\\011\\011(select id from data_types where code = 'MATERIAL'), \\012\\011\\011\\011(select id from persons where user_id ='system'), \\012\\011\\011\\011(select id from database_instances where is_original_source = 'T'), \\012\\011\\011\\011(select id from material_types where code = 'GENE')\\012\\011\\011);\\012\\011\\011\\012\\011insert into sample_type_property_types( \\012\\011  id,\\012\\011  saty_id,\\012\\011  prty_id,\\012\\011  is_mandatory,\\012\\011  pers_id_registerer,\\012\\011  ordinal\\012\\011) values(\\012\\011\\011\\011nextval('stpt_id_seq'), \\012\\011\\011\\011(select id from sample_types where code = 'OLIGO_WELL'),\\012\\011\\011\\011(select id from property_types where code = 'GENE'),\\012\\011\\011\\011false,\\012\\011\\011\\011(select id from persons where user_id ='system'),\\012\\011\\011\\011(select max(ordinal)+1 from sample_type_property_types \\012\\011\\011\\011\\011where saty_id = (select id from sample_types where code = 'OLIGO_WELL'))\\012\\011\\011);\\012\\012\\011--------------------------------------------------\\012\\011-- create a gene material property for each oligo well\\012\\011--------------------------------------------------\\012\\011\\011\\012\\011select \\011count(*)\\012\\011into counter\\012\\011from\\012\\011\\011samples well, sample_types well_type, sample_properties well_props, \\012\\011\\011materials well_material, material_properties well_material_props,\\012\\011\\011materials nested_well_material\\012\\011where\\012\\011\\011well_type.code = 'OLIGO_WELL' and\\012\\011\\011-- find 'well_material' assigned to the well\\012\\011\\011well_props.samp_id = well.id and well_material.id = well_props.mate_prop_id and \\012\\011\\011-- additional joins to entity type tables\\012\\011\\011well_type.id = well.saty_id and\\012\\011\\011-- well content material property\\012\\011\\011well_material_props.mate_id = well_material.id and \\012\\011\\011-- material connected to the material in the well (e.g. gene)\\012\\011\\011well_material_props.mate_prop_id = nested_well_material.id and\\012\\011\\011nested_well_material.maty_id = (select id from material_types where code = 'GENE');\\012\\011\\012\\011if counter = 0 then \\012\\011\\011-- skip migration if there are no genes indirectly connected to oligo wells\\012\\011\\011return;\\012\\011end if;   \\012\\012\\011insert into sample_properties(id, samp_id, stpt_id, mate_prop_id, pers_id_registerer) (\\012\\011\\011select \\011nextval('sample_property_id_seq') id, \\012\\011\\011\\011well.id samp_id, \\012\\011\\011\\011(select stpt.id from sample_type_property_types stpt, property_types props where stpt.prty_id = props.id and props.code='GENE') stpt_id,\\012\\011\\011\\011nested_well_material.id mate_prop_id,\\012\\011\\011\\011(select id from persons where user_id ='system') pers_id_registerer \\012\\011\\011from\\012\\011\\011\\011samples well, sample_types well_type, sample_properties well_props, \\012\\011\\011\\011materials well_material, material_properties well_material_props,\\012\\011\\011\\011materials nested_well_material\\012\\011\\011where\\012\\011\\011\\011well_type.code = 'OLIGO_WELL' and\\012\\011\\011\\011-- find 'well_material' assigned to the well\\012\\011\\011\\011well_props.samp_id = well.id and well_material.id = well_props.mate_prop_id and \\012\\011\\011\\011-- additional joins to entity type tables\\012\\011\\011\\011well_type.id = well.saty_id and\\012\\011\\011\\011-- well content material property\\012\\011\\011\\011well_material_props.mate_id = well_material.id and \\012\\011\\011\\011-- material connected to the material in the well (e.g. gene)\\012\\011\\011\\011well_material_props.mate_prop_id = nested_well_material.id and\\012\\011\\011\\011nested_well_material.maty_id = (select id from material_types where code = 'GENE')\\012\\011);\\012\\012END;\\012$$ LANGUAGE 'plpgsql';\\012\\012select CONNECT_WELLS_WITH_GENES();\\012drop function CONNECT_WELLS_WITH_GENES();\\012\\012--------------------------------------------------------------------------------------\\012--------------------------------------------------------------------------------------\\012\\012-- drop dataset triggers\\012\\012DROP TRIGGER check_dataset_relationships_on_data_table_modification ON data;\\012DROP FUNCTION check_dataset_relationships_on_data_table_modification();\\012DROP TRIGGER check_dataset_relationships_on_relationships_table_modification ON data_set_relationships;\\012DROP FUNCTION check_dataset_relationships_on_relationships_table_modification();\\012 \\012\\012\\012\\012\\012\\012\\012\\012	\N
+./sourceTest/sql/postgresql/063/017=database_version_logs.tsv:056	source/sql/postgresql/migration/migration-055-056.sql	SUCCESS	2010-09-10 09:06:20.278	-- Migration from 055 to 056\\012\\012--------------------------------------------------------------------------------------\\012--------------------------------------------------------------------------------------\\012-- Screening specific migration. Nothing will be performed on openBIS databases \\012-- which are not screening specific.\\012--------------------------------------------------------------------------------------\\012--------------------------------------------------------------------------------------\\012\\012CREATE OR REPLACE FUNCTION merge_words(text, text) RETURNS text AS $$\\012DECLARE\\012  BEGIN\\012    IF  character_length($1) > 0 THEN\\012      RETURN $1 || ' ' || $2;\\012    ELSE\\012      RETURN $2;\\012    END IF;\\012  END;\\012$$ LANGUAGE plpgsql;\\012\\012CREATE AGGREGATE merge_words(text)\\012(\\012  SFUNC = merge_words,\\012  STYPE = text\\012);\\012\\012\\012CREATE OR REPLACE FUNCTION REPLACE_GENE_SYMBOL_BY_GENE_ID() RETURNS void AS $$\\012DECLARE\\012\\011counter  int;\\012\\011library_id_assigned_to_gene bool;\\012BEGIN\\012\\011--------------------------------------------------\\012\\011-- create a GENE_SYMBOL property and assign it to GENE\\012\\011--------------------------------------------------\\012\\011\\012\\011select true  \\012\\011into library_id_assigned_to_gene \\012\\011from material_type_property_types mtpt, material_types mt, property_types pt  \\012\\011where mtpt.maty_id = mt.id and mtpt.prty_id = pt.id \\012\\011\\011and mt.code = 'GENE' and pt.code = 'LIBRARY_ID';\\012\\011\\012\\011if library_id_assigned_to_gene IS NULL then \\012\\011\\011-- skip migration if gene has no library_id property\\012\\011\\011return;\\012\\011end if; \\012\\011\\012\\011\\012\\011select count(*)\\012\\011into counter \\012\\011from  \\012\\011\\011(select m.id, count(mp.id) as c \\012\\011\\011\\011from materials m, material_types mt, material_properties mp, material_type_property_types mtpt, property_types pt \\012\\011\\011\\011where m.maty_id = mt.id and mp.mate_id = m.id and mp.mtpt_id = mtpt.id and mtpt.maty_id = mt.id and pt.id = mtpt.prty_id\\012\\011\\011\\011\\011and mt.code = 'GENE' and pt.code = 'LIBRARY_ID' \\012\\011\\011\\011group by m.id) as counter_table \\012\\011where c < 1; \\012\\011\\012\\011if counter > 0 then \\012\\011\\011-- skip migration if there is at least one gene without library_id\\012\\011\\011return;\\012\\011end if;\\012\\011\\012\\011\\012\\011insert into property_types\\012\\011\\011(id\\012\\011\\011,code\\012\\011\\011,description\\012\\011\\011,label\\012\\011\\011,daty_id\\012\\011\\011,pers_id_registerer\\012\\011\\011,dbin_id)\\012\\011values \\012\\011\\011(nextval('PROPERTY_TYPE_ID_SEQ')\\012\\011\\011,'GENE_SYMBOLS'\\012\\011\\011,'Gene symbols'\\012\\011\\011,'Gene symbols'\\012\\011\\011,(select id from data_types where code ='VARCHAR')\\012\\011\\011,(select id from persons where user_id ='system')\\012\\011\\011,(select id from database_instances where is_original_source = 'T')\\012\\011);\\012\\011\\011\\012\\011insert into material_type_property_types( \\012\\011  id,\\012\\011  maty_id,\\012\\011  prty_id,\\012\\011  is_mandatory,\\012\\011  pers_id_registerer,\\012\\011  ordinal\\012\\011) values(\\012\\011\\011\\011nextval('mtpt_id_seq'), \\012\\011\\011\\011(select id from material_types where code = 'GENE'),\\012\\011\\011\\011(select id from property_types where code = 'GENE_SYMBOLS'),\\012\\011\\011\\011false,\\012\\011\\011\\011(select id from persons where user_id ='system'),\\012\\011\\011\\011(select max(ordinal)+1 from material_type_property_types \\012\\011\\011\\011\\011where maty_id = (select id from material_types where code = 'GENE'))\\012\\011\\011);\\012\\012\\011--------------------------------------------------\\012\\011-- create temporary table with all gene migration information\\012\\011--------------------------------------------------\\012\\012\\011create temp table genes \\012\\011(\\012\\011\\011id tech_id,\\012\\011\\011code code,\\012\\011\\011library_id generic_value,\\012\\011\\011gene_codes generic_value,\\012\\011\\011new_id tech_id,\\012\\011\\011library_tech_id tech_id\\011\\011\\012\\011);\\012\\011\\012\\011insert into genes (id, code, library_id, library_tech_id)\\012\\011\\011(select m.id, m.code, mp.value as library_id, mp.id as library_tech_id from materials m, material_properties mp, material_type_property_types mtpt, property_types pt, material_types mt\\012\\011\\011where mp.mate_id = m.id and  mp.mtpt_id = mtpt.id and pt.id = mtpt.prty_id and pt.code = 'LIBRARY_ID' and mt.id = m.maty_id and mt.id = mtpt.maty_id and mt.code = 'GENE');\\012\\011\\012\\011update genes set new_id = map.to_id from (select g_from.id as from_id, min(g_to.id) as to_id  from genes g_from, genes g_to where g_from.library_id = g_to.library_id group by g_from.id) as map where map.from_id = id;\\011\\012\\011\\012\\011update genes set gene_codes = map.gene_codes from (select g_from.library_id as lib_id, merge_words(distinct g_to.code) as gene_codes from genes g_from, genes g_to where g_from.library_id = g_to.library_id group by g_from.library_id) as map where map.lib_id = library_id;\\011\\012\\012\\011--------------------------------------------------\\012\\011-- update gene references\\012\\011--------------------------------------------------\\012\\012\\011update EXPERIMENTS set MATE_ID_STUDY_OBJECT = genes.new_id from genes where genes.id = MATE_ID_STUDY_OBJECT and not genes.id = genes.new_id;\\012\\011update EXPERIMENT_PROPERTIES set  MATE_PROP_ID = genes.new_id from genes where genes.id = MATE_PROP_ID and not genes.id = genes.new_id;\\012\\011update MATERIAL_PROPERTIES set  MATE_PROP_ID = genes.new_id from genes where genes.id = MATE_PROP_ID and not genes.id = genes.new_id;\\012\\011update SAMPLE_PROPERTIES set  MATE_PROP_ID = genes.new_id from genes where genes.id = MATE_PROP_ID and not genes.id = genes.new_id;\\012\\011update DATA_SET_PROPERTIES set  MATE_PROP_ID = genes.new_id from genes where genes.id = MATE_PROP_ID and not genes.id = genes.new_id;\\012\\011\\012\\011delete from  material_properties where mate_id in (select id from genes where not genes.id = genes.new_id);\\012\\011delete from MATERIALS where id in (select id from genes where not genes.id = genes.new_id);\\012\\012\\011delete from genes where id in (select id from genes where not genes.id = genes.new_id);\\012\\012\\012\\011--------------------------------------------------\\012\\011-- replace gene code with library_id\\012\\011--------------------------------------------------\\012\\011\\012\\011update materials set code = genes.library_id from genes where materials.id = genes.id ;\\012\\011delete from material_properties where id in (select library_tech_id from genes);\\012\\011\\012\\011--------------------------------------------------\\012\\011-- create a gene symbols property for each gene\\012\\011--------------------------------------------------\\012\\011\\012\\011insert into material_properties\\012\\011\\011(id\\012\\011  , mate_id\\012\\011  , mtpt_id\\012\\011  , "value"\\012\\011  , pers_id_registerer)\\012\\011\\011(select nextval('material_property_id_seq') id\\012\\011  \\011, genes.id  mate_id\\012\\011    , (select mtpt.id\\012\\011    \\011\\011from   material_type_property_types mtpt, material_types mt, property_types pt\\012\\011    \\011\\011where  pt.code = 'GENE_SYMBOLS' and mt.code = 'GENE' and mtpt.prty_id = pt.id\\012\\011        \\011and mtpt.maty_id = mt.id) mtpt_id\\012\\011    , genes.gene_codes "value"\\012\\011    , (select id from persons where user_id = 'system') pers_id_registerer\\012\\011 \\011from genes); \\012\\012\\011--------------------------------------------------\\012\\011-- delete temporary table\\012\\011--------------------------------------------------\\012\\011\\012\\011drop table genes;\\012\\011\\012END;\\012$$ LANGUAGE 'plpgsql';\\012\\012select REPLACE_GENE_SYMBOL_BY_GENE_ID();\\012drop function REPLACE_GENE_SYMBOL_BY_GENE_ID();\\012DROP AGGREGATE merge_words(text);\\012drop function merge_words(text,text);\\012\\012\\012--------------------------------------------------------------------------------------\\012--------------------------------------------------------------------------------------\\012\\012UPDATE sample_types SET code = 'SIRNA_WELL' WHERE code = 'OLIGO_WELL';\\012UPDATE material_types SET code = 'SIRNA' WHERE code = 'OLIGO';\\012UPDATE property_types SET code = 'SIRNA', label = 'siRNA' WHERE code = 'OLIGO';\\012\\012\\012\\012\\012\\012\\012\\012\\012\\012\\012\\012\\012\\012\\012\\012\\012\\012\\012\\012	\N
+./sourceTest/sql/postgresql/063/017=database_version_logs.tsv:059	source/sql/postgresql/migration/migration-058-059.sql	SUCCESS	2010-09-29 13:37:07.231	-- Migration from 058 to 059\\012\\012-- Add ENTITY_TYPE_CODE column to QUERIES\\012ALTER TABLE queries ADD COLUMN entity_type_code CODE;\\012\\012------------------------------------------------------------------------------------\\012--  Purpose:  Create trigger that checks if entity_type_code specified in a query\\012--            matches a code of an entity of type specified in query_type.\\012------------------------------------------------------------------------------------\\012\\012CREATE OR REPLACE FUNCTION query_entity_type_code_check() RETURNS trigger AS $$\\012DECLARE\\012   counter  INTEGER;\\012BEGIN\\012   if (NEW.entity_type_code IS NOT NULL) then\\012     if (NEW.query_type = 'GENERIC') then\\012       RAISE EXCEPTION 'Insert/Update of query (Name: %) failed, as entity_type has to be null for GENERIC queries.', NEW.name;\\012     elsif (NEW.query_type = 'EXPERIMENT') then\\012       SELECT count(*) INTO counter FROM experiment_types WHERE code = NEW.entity_type_code;\\012\\011\\011 elsif (NEW.query_type = 'DATA_SET') then\\012       SELECT count(*) INTO counter FROM data_set_types WHERE code = NEW.entity_type_code;\\012\\011\\011 elsif (NEW.query_type = 'MATERIAL') then\\012       SELECT count(*) INTO counter FROM material_types WHERE code = NEW.entity_type_code;\\012\\011\\011 elsif (NEW.query_type = 'SAMPLE') then\\012       SELECT count(*) INTO counter FROM sample_types WHERE code = NEW.entity_type_code;\\012\\011\\011 end if;\\012\\011\\011 if (counter = 0) then\\012\\011\\011\\011 RAISE EXCEPTION 'Insert/Update of query (Name: %) failed because % type (Code: %) does not exist.', NEW.name, NEW.query_type, NEW.entity_type_code;\\012\\011\\011 end if;\\011\\011\\011\\012   end if;\\012   RETURN NEW;\\012END;\\012$$ LANGUAGE 'plpgsql';\\012\\012CREATE TRIGGER query_entity_type_code_check BEFORE INSERT OR UPDATE ON queries\\012    FOR EACH ROW EXECUTE PROCEDURE query_entity_type_code_check();\\012	\N
+./sourceTest/sql/postgresql/063/017=database_version_logs.tsv:062	source/sql/postgresql/migration/migration-061-062.sql	SUCCESS	2010-11-25 16:02:07.224	\\012CREATE OR REPLACE FUNCTION sample_code_uniqueness_check() RETURNS trigger\\012    LANGUAGE plpgsql\\012    AS $$\\012DECLARE\\012   counter  INTEGER;\\012BEGIN\\012  LOCK TABLE samples IN EXCLUSIVE MODE;\\012  \\012\\011  IF (NEW.samp_id_part_of is NULL) THEN\\012\\011\\011  IF (NEW.dbin_id is not NULL) THEN\\012\\011\\011\\011  SELECT count(*) into counter FROM samples \\012\\011\\011      where id != NEW.id and code = NEW.code and samp_id_part_of is NULL and dbin_id = NEW.dbin_id;\\012        IF (counter > 0) THEN\\012\\011\\011\\011\\011  RAISE EXCEPTION 'Insert/Update of Sample (Code: %) failed because database instance sample with the same code already exists.', NEW.code;\\012        END IF;\\012\\011\\011  ELSIF (NEW.space_id is not NULL) THEN\\012\\011\\011\\011  SELECT count(*) into counter FROM samples \\012\\011\\011\\011\\011  where id != NEW.id and code = NEW.code and samp_id_part_of is NULL and space_id = NEW.grou_id;\\012\\011\\011\\011  IF (counter > 0) THEN\\012\\011\\011\\011\\011  RAISE EXCEPTION 'Insert/Update of Sample (Code: %) failed because space sample with the same code already exists.', NEW.code;\\012\\011\\011\\011  END IF;\\012      END IF;\\012    ELSE\\012\\011\\011  IF (NEW.dbin_id is not NULL) THEN\\012\\011\\011\\011  SELECT count(*) into counter FROM samples \\012\\011\\011\\011\\011  where id != NEW.id and code = NEW.code and samp_id_part_of = NEW.samp_id_part_of and dbin_id = NEW.dbin_id;\\012\\011\\011\\011  IF (counter > 0) THEN\\012\\011\\011\\011\\011  RAISE EXCEPTION 'Insert/Update of Sample (Code: %) failed because database instance sample with the same code and being the part of the same container already exists.', NEW.code;\\012\\011\\011\\011  END IF;\\012\\011\\011  ELSIF (NEW.space_id is not NULL) THEN\\012\\011\\011\\011  SELECT count(*) into counter FROM samples \\012\\011\\011\\011\\011  where id != NEW.id and code = NEW.code and samp_id_part_of = NEW.samp_id_part_of and space_id = NEW.space_id;\\012\\011\\011\\011  IF (counter > 0) THEN\\012\\011\\011\\011\\011  RAISE EXCEPTION 'Insert/Update of Sample (Code: %) failed because space sample with the same code and being the part of the same container already exists.', NEW.code;\\012\\011\\011\\011  END IF;\\012\\011\\011  END IF;\\012     END IF;   \\012  \\012  RETURN NEW;\\012END;\\012$$;\\012\\012\\012CREATE OR REPLACE FUNCTION sample_subcode_uniqueness_check() RETURNS trigger\\012    LANGUAGE plpgsql\\012    AS $$\\012DECLARE\\012   counter  INTEGER;\\012   unique_subcode  BOOLEAN_CHAR;\\012BEGIN\\012  LOCK TABLE samples IN EXCLUSIVE MODE;\\012  \\012  SELECT is_subcode_unique into unique_subcode FROM sample_types WHERE id = NEW.saty_id;\\012  \\012  IF (unique_subcode) THEN\\012    IF (NEW.dbin_id is not NULL) THEN\\012\\011\\011\\011SELECT count(*) into counter FROM samples \\012\\011\\011\\011\\011where id != NEW.id and code = NEW.code and saty_id = NEW.saty_id and dbin_id = NEW.dbin_id;\\012\\011\\011\\011IF (counter > 0) THEN\\012\\011\\011\\011\\011RAISE EXCEPTION 'Insert/Update of Sample (Code: %) failed because database instance sample of the same type with the same subcode already exists.', NEW.code;\\012\\011\\011\\011END IF;\\012\\011\\011ELSIF (NEW.space_id is not NULL) THEN\\012\\011\\011\\011SELECT count(*) into counter FROM samples \\012\\011\\011\\011\\011where id != NEW.id and code = NEW.code and saty_id = NEW.saty_id and space_id = NEW.space_id;\\012\\011\\011\\011IF (counter > 0) THEN\\012\\011\\011\\011\\011RAISE EXCEPTION 'Insert/Update of Sample (Code: %) failed because space sample of the same type with the same subcode already exists.', NEW.code;\\012\\011\\011\\011END IF;\\012\\011\\011END IF;\\012  END IF;\\012  \\012  RETURN NEW;\\012END;\\012$$;\\012\\012ALTER TABLE groups RENAME TO spaces;\\012\\012ALTER SEQUENCE group_id_seq RENAME TO space_id_seq;\\012\\012ALTER TABLE persons\\011RENAME grou_id TO space_id;\\012ALTER TABLE projects RENAME grou_id TO space_id;\\012ALTER TABLE role_assignments RENAME grou_id TO space_id;\\012ALTER TABLE samples\\011RENAME grou_id TO space_id;\\012\\012-- migrate EVENTS table\\012\\012ALTER TABLE events\\012\\011DROP CONSTRAINT evnt_et_enum_ck;\\012\\012update events set entity_type = 'SPACE' where entity_type = 'GROUP';\\012\\012ALTER TABLE events ADD CONSTRAINT evnt_et_enum_ck CHECK \\012\\011(entity_type IN ('ATTACHMENT', 'DATASET', 'EXPERIMENT', 'SPACE', 'MATERIAL', 'PROJECT', 'PROPERTY_TYPE', 'SAMPLE', 'VOCABULARY', 'AUTHORIZATION_GROUP')); \\012\\012ALTER TABLE persons\\012\\011DROP CONSTRAINT pers_grou_fk;\\012\\012ALTER TABLE persons\\012\\011ADD CONSTRAINT pers_space_fk FOREIGN KEY (space_id) REFERENCES spaces(id);\\012\\012ALTER TABLE projects\\012\\011DROP CONSTRAINT proj_bk_uk;\\012\\012ALTER TABLE projects\\012\\011DROP CONSTRAINT proj_grou_fk;\\012\\012ALTER TABLE projects\\012\\011ADD CONSTRAINT proj_bk_uk UNIQUE (code, space_id);\\012\\012ALTER TABLE projects\\012\\011ADD CONSTRAINT proj_space_fk FOREIGN KEY (space_id) REFERENCES spaces(id);\\012\\012ALTER TABLE role_assignments\\012\\011DROP CONSTRAINT roas_dbin_grou_arc_ck;\\012\\012ALTER TABLE role_assignments\\012\\011DROP CONSTRAINT roas_ag_group_bk_uk;\\012\\012ALTER TABLE role_assignments\\012\\011DROP CONSTRAINT roas_pe_group_bk_uk;\\012\\012ALTER TABLE role_assignments\\012\\011DROP CONSTRAINT roas_grou_fk;\\012\\012ALTER TABLE role_assignments\\012\\011ADD CONSTRAINT roas_dbin_space_arc_ck CHECK ((((dbin_id IS NOT NULL) AND (space_id IS NULL)) OR ((dbin_id IS NULL) AND (space_id IS NOT NULL))));\\012\\012ALTER TABLE role_assignments\\012\\011ADD CONSTRAINT roas_ag_space_bk_uk UNIQUE (ag_id_grantee, role_code, space_id);\\012\\012ALTER TABLE role_assignments\\012\\011ADD CONSTRAINT roas_pe_space_bk_uk UNIQUE (pers_id_grantee, role_code, space_id);\\012\\012ALTER TABLE role_assignments\\012\\011ADD CONSTRAINT roas_space_fk FOREIGN KEY (space_id) REFERENCES spaces(id);\\012\\012ALTER TABLE samples\\012\\011DROP CONSTRAINT samp_dbin_grou_arc_ck;\\012\\012ALTER TABLE samples\\012\\011DROP CONSTRAINT samp_grou_fk;\\012\\012ALTER TABLE samples\\012\\011ADD CONSTRAINT samp_dbin_space_arc_ck CHECK ((((dbin_id IS NOT NULL) AND (space_id IS NULL)) OR ((dbin_id IS NULL) AND (space_id IS NOT NULL))));\\012\\012ALTER TABLE samples\\012\\011ADD CONSTRAINT samp_space_fk FOREIGN KEY (space_id) REFERENCES spaces(id);\\012\\012ALTER TABLE spaces\\012  DROP CONSTRAINT grou_bk_uk,\\012  ADD CONSTRAINT space_bk_uk UNIQUE (code, dbin_id);\\012\\012ALTER TABLE spaces\\012  DROP CONSTRAINT grou_dbin_fk,\\012  ADD CONSTRAINT space_dbin_fk FOREIGN KEY (dbin_id) REFERENCES database_instances(id);\\012\\012ALTER TABLE spaces\\012  DROP CONSTRAINT grou_pers_fk_registerer,\\012  ADD CONSTRAINT space_pers_fk_registerer FOREIGN KEY (pers_id_registerer) REFERENCES persons(id);\\012\\012ALTER INDEX pers_grou_fk_i RENAME TO pers_space_fk_i;\\012\\012ALTER INDEX proj_grou_fk_i RENAME TO proj_space_fk_i;\\012\\012ALTER INDEX roas_grou_fk_i RENAME TO roas_space_fk_i;\\012\\012ALTER INDEX grou_pk RENAME TO space_pk;\\012\\012ALTER INDEX grou_dbin_fk_i RENAME TO space_dbin_fk_i;\\012\\012ALTER INDEX grou_pers_registered_by_fk_i RENAME TO space_pers_registered_by_fk_i;\\012\\012	\N
+./sourceTest/sql/postgresql/063/schema-063.sql:    LANGUAGE plpgsql
+./sourceTest/sql/postgresql/063/schema-063.sql:    LANGUAGE plpgsql
+./sourceTest/sql/postgresql/063/schema-063.sql:    LANGUAGE plpgsql
+./sourceTest/sql/postgresql/063/schema-063.sql:    LANGUAGE plpgsql
+./sourceTest/sql/postgresql/063/schema-063.sql:    LANGUAGE plpgsql
+./sourceTest/sql/postgresql/063/schema-063.sql:    LANGUAGE plpgsql
+./sourceTest/sql/postgresql/063/schema-063.sql:    LANGUAGE plpgsql
+./sourceTest/sql/postgresql/063/schema-063.sql:    LANGUAGE plpgsql
+./sourceTest/sql/postgresql/063/schema-063.sql:    LANGUAGE plpgsql
+./sourceTest/sql/postgresql/064/.svn/text-base/017=database_version_logs.tsv.svn-base:027	D:\\User\\felmer\\dev-workspace\\openbis/source/sql/postgresql/027/function-027.sql	SUCCESS	2008-11-05 09:18:00.403	-- Creating Functions\\012\\012------------------------------------------------------------------------------------\\012--  Purpose:  Create function RENAME_SEQUENCE() that is required for renaming the sequences belonging to tables\\012------------------------------------------------------------------------------------\\012CREATE FUNCTION RENAME_SEQUENCE(OLD_NAME VARCHAR, NEW_NAME VARCHAR) RETURNS INTEGER AS $$\\012DECLARE\\012  CURR_SEQ_VAL   INTEGER;\\012BEGIN\\012  SELECT INTO CURR_SEQ_VAL NEXTVAL(OLD_NAME);\\012  EXECUTE 'CREATE SEQUENCE ' || NEW_NAME || ' START WITH ' || CURR_SEQ_VAL;\\012  EXECUTE 'DROP SEQUENCE ' || OLD_NAME;\\012  RETURN CURR_SEQ_VAL;\\012END;\\012$$ LANGUAGE 'plpgsql';\\012\\012\\012------------------------------------------------------------------------------------\\012--  Purpose:  Create trigger CONTROLLED_VOCABULARY_CHECK \\012------------------------------------------------------------------------------------\\012\\012CREATE OR REPLACE FUNCTION CONTROLLED_VOCABULARY_CHECK() RETURNS trigger AS $$\\012DECLARE\\012   v_code  CODE;\\012BEGIN\\012\\012   select code into v_code from data_types where id = NEW.daty_id;\\012\\012   -- Check if the data is of type "CONTROLLEDVOCABULARY"\\012   if v_code = 'CONTROLLEDVOCABULARY' then\\012      if NEW.covo_id IS NULL then\\012         RAISE EXCEPTION 'Insert/Update of Property Type (Code: %) failed, as its Data Type is CONTROLLEDVOCABULARY, but it is not linked to a Controlled Vocabulary.', NEW.code;\\012      end if;\\012   end if;\\012\\012   RETURN NEW;\\012\\012END;\\012$$ LANGUAGE 'plpgsql';\\012\\012CREATE TRIGGER CONTROLLED_VOCABULARY_CHECK BEFORE INSERT OR UPDATE ON PROPERTY_TYPES\\012    FOR EACH ROW EXECUTE PROCEDURE CONTROLLED_VOCABULARY_CHECK();\\012\\012\\012------------------------------------------------------------------------------------\\012--  Purpose:  Create trigger EXTERNAL_DATA_STORAGE_FORMAT_CHECK \\012------------------------------------------------------------------------------------\\012\\012CREATE OR REPLACE FUNCTION EXTERNAL_DATA_STORAGE_FORMAT_CHECK() RETURNS trigger AS $$\\012DECLARE\\012   v_covo_code  CODE;\\012   data_code CODE;\\012BEGIN\\012\\012   select code into v_covo_code from controlled_vocabularies\\012      where is_internal_namespace = true and \\012         id = (select covo_id from controlled_vocabulary_terms where id = NEW.cvte_id_stor_fmt);\\012   -- Check if the data storage format is a term of the controlled vocabulary "STORAGE_FORMAT"\\012   if v_covo_code != 'STORAGE_FORMAT' then\\012      select code into data_code from data where id = NEW.data_id; \\012      RAISE EXCEPTION 'Insert/Update of Data (Code: %) failed, as its Storage Format is %, but is required to be STORAGE_FORMAT.', data_code, v_covo_code;\\012   end if;\\012\\012   RETURN NEW;\\012\\012END;\\012$$ LANGUAGE 'plpgsql';\\012\\012CREATE TRIGGER EXTERNAL_DATA_STORAGE_FORMAT_CHECK BEFORE INSERT OR UPDATE ON EXTERNAL_DATA\\012    FOR EACH ROW EXECUTE PROCEDURE EXTERNAL_DATA_STORAGE_FORMAT_CHECK();\\012\\012------------------------------------------------------------------------------------\\012--  Purpose:  Create trigger SAMPLE_CODE_UNIQUENESS_CHECK \\012------------------------------------------------------------------------------------\\012\\012CREATE OR REPLACE FUNCTION SAMPLE_CODE_UNIQUENESS_CHECK() RETURNS trigger AS $$\\012DECLARE\\012   counter  INTEGER;\\012BEGIN\\012\\011IF (NEW.samp_id_part_of is NULL) THEN\\012\\011\\011IF (NEW.dbin_id is not NULL) THEN\\012\\011\\011\\011SELECT count(*) into counter FROM samples \\012\\011\\011\\011\\011where id != NEW.id and code = NEW.code and samp_id_part_of is NULL and dbin_id = NEW.dbin_id;\\012\\011\\011\\011IF (counter > 0) THEN\\012\\011\\011\\011\\011RAISE EXCEPTION 'Insert/Update of Sample (Code: %) failed because database instance sample with the same code already exists.', NEW.code;\\012\\011\\011\\011END IF;\\012\\011\\011ELSIF (NEW.grou_id is not NULL) THEN\\012\\011\\011\\011SELECT count(*) into counter FROM samples \\012\\011\\011\\011\\011where id != NEW.id and code = NEW.code and samp_id_part_of is NULL and grou_id = NEW.grou_id;\\012\\011\\011\\011IF (counter > 0) THEN\\012\\011\\011\\011\\011RAISE EXCEPTION 'Insert/Update of Sample (Code: %) failed because group sample with the same code already exists.', NEW.code;\\012\\011\\011\\011END IF;\\012\\011\\011END IF;\\012        ELSE\\012\\011\\011IF (NEW.dbin_id is not NULL) THEN\\012\\011\\011\\011SELECT count(*) into counter FROM samples \\012\\011\\011\\011\\011where id != NEW.id and code = NEW.code and samp_id_part_of = NEW.samp_id_part_of and dbin_id = NEW.dbin_id;\\012\\011\\011\\011IF (counter > 0) THEN\\012\\011\\011\\011\\011RAISE EXCEPTION 'Insert/Update of Sample (Code: %) failed because database instance sample with the same code and being the part of the same parent already exists.', NEW.code;\\012\\011\\011\\011END IF;\\012\\011\\011ELSIF (NEW.grou_id is not NULL) THEN\\012\\011\\011\\011SELECT count(*) into counter FROM samples \\012\\011\\011\\011\\011where id != NEW.id and code = NEW.code and samp_id_part_of = NEW.samp_id_part_of and grou_id = NEW.grou_id;\\012\\011\\011\\011IF (counter > 0) THEN\\012\\011\\011\\011\\011RAISE EXCEPTION 'Insert/Update of Sample (Code: %) failed because group sample with the same code and being the part of the same parent already exists.', NEW.code;\\012\\011\\011\\011END IF;\\012\\011\\011END IF;\\012        END IF;   \\012   RETURN NEW;\\012END;\\012$$ LANGUAGE 'plpgsql';\\012\\012CREATE TRIGGER SAMPLE_CODE_UNIQUENESS_CHECK BEFORE INSERT OR UPDATE ON SAMPLES\\012    FOR EACH ROW EXECUTE PROCEDURE SAMPLE_CODE_UNIQUENESS_CHECK();\\012	\N
+./sourceTest/sql/postgresql/064/.svn/text-base/017=database_version_logs.tsv.svn-base:028	source/sql/postgresql/migration/migration-027-028.sql	SUCCESS	2008-11-18 13:24:17.508	-- Create EXPERIMENT_ATTACHMENT_CONTENTS.\\012CREATE TABLE EXPERIMENT_ATTACHMENT_CONTENTS (ID TECH_ID NOT NULL,VALUE FILE NOT NULL);\\012CREATE SEQUENCE EXPERIMENT_ATTACHMENT_CONTENT_ID_SEQ;\\012ALTER TABLE EXPERIMENT_ATTACHMENT_CONTENTS ADD CONSTRAINT EXAC_PK PRIMARY KEY(ID);\\012\\012-- Alter EXPERIMENT_ATTACHMENTS by adding the new column which has a NULL constraint.\\012-- The NOT NULL constraint is added later on.\\012ALTER TABLE EXPERIMENT_ATTACHMENTS ADD COLUMN EXAC_ID TECH_ID;\\012\\012-- Does the VALUE migration between EXPERIMENT_ATTACHMENTS to EXPERIMENT_ATTACHMENT_CONTENTS.\\012CREATE OR REPLACE FUNCTION move_exp_att_content() RETURNS integer AS $$\\012DECLARE\\012    rec RECORD;\\012    seq BIGINT;\\012BEGIN\\012  FOR rec IN SELECT id, value FROM EXPERIMENT_ATTACHMENTS LOOP\\012  \\011seq := nextval('EXPERIMENT_ATTACHMENT_CONTENT_ID_SEQ');\\012    INSERT INTO EXPERIMENT_ATTACHMENT_CONTENTS (id, value) VALUES (seq, rec.value);\\012    UPDATE EXPERIMENT_ATTACHMENTS SET exac_id = seq WHERE id = rec.id;\\012  END LOOP;\\012  RETURN 1;\\012END;\\012$$ LANGUAGE 'plpgsql';\\012\\012-- Call the function.\\012SELECT move_exp_att_content();\\012DROP FUNCTION move_exp_att_content();\\012\\012\\012-- Finish EXPERIMENT_ATTACHMENTS changes.\\012ALTER TABLE EXPERIMENT_ATTACHMENTS ADD CONSTRAINT EXAT_CONT_FK FOREIGN KEY (EXAC_ID) REFERENCES EXPERIMENT_ATTACHMENT_CONTENTS(ID);\\012ALTER TABLE EXPERIMENT_ATTACHMENTS DROP COLUMN VALUE;\\012ALTER TABLE EXPERIMENT_ATTACHMENTS ALTER COLUMN EXAC_ID SET NOT NULL;\\012	\N
+./sourceTest/sql/postgresql/064/.svn/text-base/017=database_version_logs.tsv.svn-base:029	source/sql/postgresql/migration/migration-028-029.sql	SUCCESS	2009-03-18 10:50:20.105	-- -------\\012-- add modification_timestamp field to allow edition with Hibernate\\012-- -------\\012\\012ALTER TABLE samples\\012\\011ADD COLUMN modification_timestamp TIME_STAMP DEFAULT CURRENT_TIMESTAMP;\\012\\012ALTER TABLE experiments\\012\\011ADD COLUMN modification_timestamp TIME_STAMP DEFAULT CURRENT_TIMESTAMP;\\012\\012ALTER TABLE materials\\012\\011ADD COLUMN modification_timestamp TIME_STAMP DEFAULT CURRENT_TIMESTAMP;\\012\\012ALTER TABLE experiment_properties\\012\\011ADD COLUMN modification_timestamp TIME_STAMP DEFAULT CURRENT_TIMESTAMP;\\012\\012ALTER TABLE material_properties\\012\\011ADD COLUMN modification_timestamp TIME_STAMP DEFAULT CURRENT_TIMESTAMP;\\012\\012ALTER TABLE sample_properties\\012\\011ADD COLUMN modification_timestamp TIME_STAMP DEFAULT CURRENT_TIMESTAMP;\\012\\012-- -------\\012-- add property data type which references materials\\012-- -------\\012\\012ALTER TABLE property_types\\012\\011ADD COLUMN maty_prop_id tech_id;\\012\\012ALTER TABLE property_types\\012\\011ADD CONSTRAINT prty_maty_fk FOREIGN KEY (maty_prop_id) REFERENCES material_types(id);\\012\\012ALTER TABLE experiment_properties\\012\\011ADD COLUMN mate_prop_id tech_id;\\012\\012ALTER TABLE material_properties\\012\\011ADD COLUMN mate_prop_id tech_id;\\012\\012ALTER TABLE sample_properties\\012\\011ADD COLUMN mate_prop_id tech_id;\\012\\012ALTER TABLE experiment_properties\\012\\011ADD CONSTRAINT expr_mapr_fk FOREIGN KEY (mate_prop_id) REFERENCES materials(id);\\012\\012ALTER TABLE material_properties\\012\\011ADD CONSTRAINT mapr_mapr_fk FOREIGN KEY (mate_prop_id) REFERENCES materials(id);\\012\\012ALTER TABLE sample_properties\\012\\011ADD CONSTRAINT sapr_mapr_fk FOREIGN KEY (mate_prop_id) REFERENCES materials(id);\\012\\012insert into data_types\\012(id\\012 ,code\\012 ,description)\\012 values \\012 (nextval('DATA_TYPE_ID_SEQ')\\012 ,'MATERIAL'\\012 ,'Reference to a material'\\012);\\012\\012ALTER TABLE MATERIAL_PROPERTIES DROP CONSTRAINT MAPR_CK;\\012ALTER TABLE MATERIAL_PROPERTIES ADD CONSTRAINT MAPR_CK CHECK \\012\\011((VALUE IS NOT NULL AND CVTE_ID IS NULL AND MATE_PROP_ID IS NULL) OR \\012\\011 (VALUE IS NULL AND CVTE_ID IS NOT NULL AND MATE_PROP_ID IS NULL) OR\\012\\011 (VALUE IS NULL AND CVTE_ID IS NULL AND MATE_PROP_ID IS NOT NULL)\\012\\011);\\012\\012ALTER TABLE EXPERIMENT_PROPERTIES DROP CONSTRAINT EXPR_CK;\\012ALTER TABLE EXPERIMENT_PROPERTIES ADD CONSTRAINT EXPR_CK CHECK \\012\\011((VALUE IS NOT NULL AND CVTE_ID IS NULL AND MATE_PROP_ID IS NULL) OR \\012\\011 (VALUE IS NULL AND CVTE_ID IS NOT NULL AND MATE_PROP_ID IS NULL) OR\\012\\011 (VALUE IS NULL AND CVTE_ID IS NULL AND MATE_PROP_ID IS NOT NULL)\\012\\011);\\012\\012ALTER TABLE SAMPLE_PROPERTIES DROP CONSTRAINT SAPR_CK;\\012ALTER TABLE SAMPLE_PROPERTIES ADD CONSTRAINT SAPR_CK CHECK \\012\\011((VALUE IS NOT NULL AND CVTE_ID IS NULL AND MATE_PROP_ID IS NULL) OR \\012\\011 (VALUE IS NULL AND CVTE_ID IS NOT NULL AND MATE_PROP_ID IS NULL) OR\\012\\011 (VALUE IS NULL AND CVTE_ID IS NULL AND MATE_PROP_ID IS NOT NULL)\\012\\011);\\012\\012------------------------------------------------------------------------------------\\012--  Purpose:  Create trigger MATERIAL/SAMPLE/EXPERIMENT _PROPERTY_WITH_MATERIAL_DATA_TYPE_CHECK\\012--            It checks that if material property value is assigned to the entity,\\012--\\011\\011\\011\\011\\011\\011then the material type is equal to the one described by property type.\\012------------------------------------------------------------------------------------\\012\\012CREATE OR REPLACE FUNCTION MATERIAL_PROPERTY_WITH_MATERIAL_DATA_TYPE_CHECK() RETURNS trigger AS $$\\012DECLARE\\012   v_type_id  CODE;\\012   v_type_id_prop  CODE;\\012BEGIN\\012   if NEW.mate_prop_id IS NOT NULL then\\012\\011\\011\\011-- find material type id of the property type \\012\\011\\011\\011select pt.maty_prop_id into v_type_id_prop \\012\\011\\011\\011  from material_type_property_types etpt, property_types pt \\012\\011\\011\\011 where NEW.mtpt_id = etpt.id AND etpt.prty_id = pt.id;\\012\\011\\011\\012\\011\\011\\011if v_type_id_prop IS NOT NULL then\\012\\011\\011\\011\\011-- find material type id of the material which consists the entity's property value\\012\\011\\011\\011\\011select entity.maty_id into v_type_id \\012\\011\\011\\011\\011  from materials entity\\012\\011\\011\\011\\011 where NEW.mate_prop_id = entity.id;\\012\\011\\011\\011\\011if v_type_id != v_type_id_prop then\\012\\011\\011\\011\\011\\011RAISE EXCEPTION 'Insert/Update of property value referencing material (id: %) failed, as referenced material type is different than expected (id %, expected id: %).', \\012\\011\\011\\011\\011\\011\\011\\011 NEW.mate_prop_id, v_type_id, v_type_id_prop;\\012\\011\\011\\011\\011end if;\\012\\011\\011\\011end if;\\012   end if;\\012   RETURN NEW;\\012END;\\012$$ LANGUAGE 'plpgsql';\\012\\012CREATE TRIGGER MATERIAL_PROPERTY_WITH_MATERIAL_DATA_TYPE_CHECK BEFORE INSERT OR UPDATE ON material_properties\\012    FOR EACH ROW EXECUTE PROCEDURE MATERIAL_PROPERTY_WITH_MATERIAL_DATA_TYPE_CHECK();\\012    \\012CREATE OR REPLACE FUNCTION SAMPLE_PROPERTY_WITH_MATERIAL_DATA_TYPE_CHECK() RETURNS trigger AS $$\\012DECLARE\\012   v_type_id  CODE;\\012   v_type_id_prop  CODE;\\012BEGIN\\012   if NEW.mate_prop_id IS NOT NULL then\\012\\011\\011\\011-- find material type id of the property type \\012\\011\\011\\011select pt.maty_prop_id into v_type_id_prop \\012\\011\\011\\011  from sample_type_property_types etpt, property_types pt \\012\\011\\011\\011 where NEW.stpt_id = etpt.id AND etpt.prty_id = pt.id;\\012\\011\\011\\012\\011\\011\\011if v_type_id_prop IS NOT NULL then\\012\\011\\011\\011\\011-- find material type id of the material which consists the entity's property value\\012\\011\\011\\011\\011select entity.maty_id into v_type_id \\012\\011\\011\\011\\011  from materials entity\\012\\011\\011\\011\\011 where NEW.mate_prop_id = entity.id;\\012\\011\\011\\011\\011if v_type_id != v_type_id_prop then\\012\\011\\011\\011\\011\\011RAISE EXCEPTION 'Insert/Update of property value referencing material (id: %) failed, as referenced material type is different than expected (id %, expected id: %).', \\012\\011\\011\\011\\011\\011\\011\\011\\011\\011\\011\\011\\011 NEW.mate_prop_id, v_type_id, v_type_id_prop;\\012\\011\\011\\011\\011end if;\\012\\011\\011\\011end if;\\012   end if;\\012   RETURN NEW;\\012END;\\012$$ LANGUAGE 'plpgsql';\\012\\012CREATE TRIGGER SAMPLE_PROPERTY_WITH_MATERIAL_DATA_TYPE_CHECK BEFORE INSERT OR UPDATE ON sample_properties\\012    FOR EACH ROW EXECUTE PROCEDURE SAMPLE_PROPERTY_WITH_MATERIAL_DATA_TYPE_CHECK();\\012    \\012CREATE OR REPLACE FUNCTION EXPERIMENT_PROPERTY_WITH_MATERIAL_DATA_TYPE_CHECK() RETURNS trigger AS $$\\012DECLARE\\012   v_type_id  CODE;\\012   v_type_id_prop  CODE;\\012BEGIN\\012   if NEW.mate_prop_id IS NOT NULL then\\012\\011\\011\\011-- find material type id of the property type \\012\\011\\011\\011select pt.maty_prop_id into v_type_id_prop \\012\\011\\011\\011  from experiment_type_property_types etpt, property_types pt \\012\\011\\011\\011 where NEW.etpt_id = etpt.id AND etpt.prty_id = pt.id;\\012\\011\\011\\012\\011\\011\\011if v_type_id_prop IS NOT NULL then\\012\\011\\011\\011\\011-- find material type id of the material which consists the entity's property value\\012\\011\\011\\011\\011select entity.maty_id into v_type_id \\012\\011\\011\\011\\011  from materials entity\\012\\011\\011\\011\\011 where NEW.mate_prop_id = entity.id;\\012\\011\\011\\011\\011if v_type_id != v_type_id_prop then\\012\\011\\011\\011\\011\\011RAISE EXCEPTION 'Insert/Update of property value referencing material (id: %) failed, as referenced material type is different than expected (id %, expected id: %).', \\012\\011\\011\\011\\011\\011\\011\\011\\011\\011\\011\\011\\011 NEW.mate_prop_id, v_type_id, v_type_id_prop;\\012\\011\\011\\011\\011end if;\\012\\011\\011\\011end if;\\012   end if;\\012   RETURN NEW;\\012END;\\012$$ LANGUAGE 'plpgsql';\\012\\012CREATE TRIGGER EXPERIMENT_PROPERTY_WITH_MATERIAL_DATA_TYPE_CHECK BEFORE INSERT OR UPDATE ON experiment_properties\\012    FOR EACH ROW EXECUTE PROCEDURE EXPERIMENT_PROPERTY_WITH_MATERIAL_DATA_TYPE_CHECK();\\012       \\012-- -------\\012-- remove the reminescents of the OBSERVABLE_TYPE\\012-- -------\\012\\012ALTER TABLE data\\012\\011DROP CONSTRAINT data_obty_fk;\\012\\012ALTER TABLE data_set_types\\012\\011DROP CONSTRAINT obty_pk;\\012\\012ALTER TABLE data_set_types\\012\\011ADD CONSTRAINT dsty_pk PRIMARY KEY (id);\\012\\012ALTER TABLE data\\012\\011ADD CONSTRAINT data_dsty_fk FOREIGN KEY (dsty_id) REFERENCES data_set_types(id);\\012\\012ALTER TABLE data_set_types\\012\\011DROP CONSTRAINT obty_bk_uk;\\012\\012ALTER TABLE data_set_types\\012\\011DROP CONSTRAINT obty_dbin_fk;\\012\\012ALTER TABLE data_set_types\\012\\011ADD CONSTRAINT dsty_bk_uk UNIQUE (code, dbin_id);\\012\\012ALTER TABLE data_set_types\\012\\011ADD CONSTRAINT dsty_dbin_fk FOREIGN KEY (dbin_id) REFERENCES database_instances(id);\\012\\012DROP INDEX data_obty_fk_i;\\012\\012CREATE INDEX data_dsty_fk_i ON data(dsty_id);\\012	\N
+./sourceTest/sql/postgresql/064/.svn/text-base/017=database_version_logs.tsv.svn-base:030	source/sql/postgresql/migration/migration-029-030.sql	SUCCESS	2009-03-23 15:34:44.72	-- -------\\012-- add modification_timestamp field to allow edition with Hibernate\\012-- -------\\012ALTER TABLE data\\012\\011ADD COLUMN modification_timestamp TIME_STAMP DEFAULT CURRENT_TIMESTAMP;\\012ALTER TABLE experiment_types\\012\\011ADD COLUMN modification_timestamp TIME_STAMP DEFAULT CURRENT_TIMESTAMP;\\012ALTER TABLE sample_types\\012\\011ADD COLUMN modification_timestamp TIME_STAMP DEFAULT CURRENT_TIMESTAMP;\\012ALTER TABLE material_types\\012\\011ADD COLUMN modification_timestamp TIME_STAMP DEFAULT CURRENT_TIMESTAMP;\\012ALTER TABLE data_set_types\\012\\011ADD COLUMN modification_timestamp TIME_STAMP DEFAULT CURRENT_TIMESTAMP;\\012ALTER TABLE controlled_vocabularies\\012\\011ADD COLUMN modification_timestamp TIME_STAMP DEFAULT CURRENT_TIMESTAMP;\\012-- -------\\012-- add properties to data sets\\012-- -------\\012CREATE TABLE DATA_SET_PROPERTIES (ID TECH_ID NOT NULL,DS_ID TECH_ID NOT NULL,DSTPT_ID TECH_ID NOT NULL,VALUE GENERIC_VALUE,CVTE_ID TECH_ID, MATE_PROP_ID TECH_ID, PERS_ID_REGISTERER TECH_ID NOT NULL,REGISTRATION_TIMESTAMP TIME_STAMP_DFL NOT NULL DEFAULT CURRENT_TIMESTAMP, MODIFICATION_TIMESTAMP TIME_STAMP DEFAULT CURRENT_TIMESTAMP);\\012CREATE TABLE DATA_SET_TYPE_PROPERTY_TYPES (ID TECH_ID NOT NULL,DSTY_ID TECH_ID NOT NULL,PRTY_ID TECH_ID NOT NULL,IS_MANDATORY BOOLEAN_CHAR NOT NULL DEFAULT 'F',IS_MANAGED_INTERNALLY BOOLEAN_CHAR NOT NULL DEFAULT 'F',PERS_ID_REGISTERER TECH_ID NOT NULL,REGISTRATION_TIMESTAMP TIME_STAMP_DFL NOT NULL DEFAULT CURRENT_TIMESTAMP);\\012\\012CREATE SEQUENCE DATA_SET_PROPERTY_ID_SEQ;\\012CREATE SEQUENCE DSTPT_ID_SEQ;\\012\\012ALTER TABLE DATA_SET_TYPE_PROPERTY_TYPES ADD CONSTRAINT DSTPT_PK PRIMARY KEY(ID);\\012ALTER TABLE DATA_SET_PROPERTIES ADD CONSTRAINT DSPR_PK PRIMARY KEY(ID);\\012\\012ALTER TABLE DATA_SET_TYPE_PROPERTY_TYPES ADD CONSTRAINT DSTPT_BK_UK UNIQUE(DSTY_ID,PRTY_ID);\\012ALTER TABLE DATA_SET_PROPERTIES ADD CONSTRAINT DSPR_BK_UK UNIQUE(DS_ID,DSTPT_ID);\\012\\012\\012ALTER TABLE DATA_SET_TYPE_PROPERTY_TYPES ADD CONSTRAINT DSTPT_DSTY_FK FOREIGN KEY (DSTY_ID) REFERENCES DATA_SET_TYPES(ID);\\012ALTER TABLE DATA_SET_TYPE_PROPERTY_TYPES ADD CONSTRAINT DSTPT_PERS_FK FOREIGN KEY (PERS_ID_REGISTERER) REFERENCES PERSONS(ID);\\012ALTER TABLE DATA_SET_TYPE_PROPERTY_TYPES ADD CONSTRAINT DSTPT_PRTY_FK FOREIGN KEY (PRTY_ID) REFERENCES PROPERTY_TYPES(ID);\\012ALTER TABLE DATA_SET_PROPERTIES ADD CONSTRAINT DSPR_CVTE_FK FOREIGN KEY (CVTE_ID) REFERENCES CONTROLLED_VOCABULARY_TERMS(ID);\\012ALTER TABLE DATA_SET_PROPERTIES ADD CONSTRAINT DSPR_DSTPT_FK FOREIGN KEY (DSTPT_ID) REFERENCES DATA_SET_TYPE_PROPERTY_TYPES(ID) ON DELETE CASCADE;\\012ALTER TABLE DATA_SET_PROPERTIES ADD CONSTRAINT DSPR_DS_FK FOREIGN KEY (DS_ID) REFERENCES DATA(ID);\\012ALTER TABLE DATA_SET_PROPERTIES ADD CONSTRAINT DSPR_PERS_FK FOREIGN KEY (PERS_ID_REGISTERER) REFERENCES PERSONS(ID);\\012ALTER TABLE DATA_SET_PROPERTIES ADD CONSTRAINT DSPR_MAPR_FK FOREIGN KEY (MATE_PROP_ID) REFERENCES MATERIALS(ID);\\012\\012ALTER TABLE DATA_SET_PROPERTIES ADD CONSTRAINT DSPR_CK CHECK \\012\\011((VALUE IS NOT NULL AND CVTE_ID IS NULL AND MATE_PROP_ID IS NULL) OR \\012\\011 (VALUE IS NULL AND CVTE_ID IS NOT NULL AND MATE_PROP_ID IS NULL) OR\\012\\011 (VALUE IS NULL AND CVTE_ID IS NULL AND MATE_PROP_ID IS NOT NULL)\\012\\011);\\012\\012CREATE INDEX DSPR_CVTE_FK_I ON DATA_SET_PROPERTIES (CVTE_ID);\\012CREATE INDEX DSPR_DSTPT_FK_I ON DATA_SET_PROPERTIES (DSTPT_ID);\\012CREATE INDEX DSPR_DS_FK_I ON DATA_SET_PROPERTIES (DS_ID);\\012CREATE INDEX DSPR_PERS_FK_I ON DATA_SET_PROPERTIES (PERS_ID_REGISTERER);\\012CREATE INDEX DSTPT_DSTY_FK_I ON DATA_SET_TYPE_PROPERTY_TYPES (DSTY_ID);\\012CREATE INDEX DSTPT_PERS_FK_I ON DATA_SET_TYPE_PROPERTY_TYPES (PERS_ID_REGISTERER);\\012CREATE INDEX DSTPT_PRTY_FK_I ON DATA_SET_TYPE_PROPERTY_TYPES (PRTY_ID);\\012\\012CREATE OR REPLACE FUNCTION DATA_SET_PROPERTY_WITH_MATERIAL_DATA_TYPE_CHECK() RETURNS trigger AS $$\\012DECLARE\\012   v_type_id  CODE;\\012   v_type_id_prop  CODE;\\012BEGIN\\012   if NEW.mate_prop_id IS NOT NULL then\\012\\011\\011\\011-- find material type id of the property type \\012\\011\\011\\011select pt.maty_prop_id into v_type_id_prop \\012\\011\\011\\011  from data_set_type_property_types dstpt, property_types pt \\012\\011\\011\\011 where NEW.dstpt_id = dstpt.id AND dstpt.prty_id = pt.id;\\012\\011\\011\\012\\011\\011\\011if v_type_id_prop IS NOT NULL then\\012\\011\\011\\011\\011-- find material type id of the material which consists the entity's property value\\012\\011\\011\\011\\011select entity.maty_id into v_type_id \\012\\011\\011\\011\\011  from materials entity\\012\\011\\011\\011\\011 where NEW.mate_prop_id = entity.id;\\012\\011\\011\\011\\011if v_type_id != v_type_id_prop then\\012\\011\\011\\011\\011\\011RAISE EXCEPTION 'Insert/Update of property value referencing material (id: %) failed, as referenced material type is different than expected (id %, expected id: %).', \\012\\011\\011\\011\\011\\011\\011\\011\\011\\011\\011\\011\\011 NEW.mate_prop_id, v_type_id, v_type_id_prop;\\012\\011\\011\\011\\011end if;\\012\\011\\011\\011end if;\\012   end if;\\012   RETURN NEW;\\012END;\\012$$ LANGUAGE 'plpgsql';\\012\\012CREATE TRIGGER DATA_SET_PROPERTY_WITH_MATERIAL_DATA_TYPE_CHECK BEFORE INSERT OR UPDATE ON data_set_properties\\012    FOR EACH ROW EXECUTE PROCEDURE DATA_SET_PROPERTY_WITH_MATERIAL_DATA_TYPE_CHECK();   \\012	\N
+./sourceTest/sql/postgresql/064/.svn/text-base/017=database_version_logs.tsv.svn-base:032	source/sql/postgresql/migration/migration-031-032.sql	SUCCESS	2009-04-09 09:36:36.2	-- -------\\012-- Modify MATERIAL_BATCHES\\012-- -------\\012\\012ALTER TABLE material_batches\\012    DROP COLUMN proc_id;\\012\\012-- -------\\012-- Modify SAMPLES\\012-- -------\\012\\012ALTER TABLE samples\\012    ADD COLUMN expe_id tech_id;\\012\\012ALTER TABLE samples\\012    ADD CONSTRAINT samp_expe_fk FOREIGN KEY (expe_id) REFERENCES experiments(id);\\012\\012CREATE INDEX samp_expe_fk_i ON samples USING btree (expe_id);\\012\\012-- relink samples directly to experiments\\012\\012UPDATE samples\\012SET expe_id = (SELECT e.id FROM experiments e, procedures p, sample_inputs si \\012               WHERE si.samp_id = samples.id AND si.proc_id = p.id AND p.expe_id = e.id AND e.inva_id IS NULL);\\012\\012\\012-- -------\\012-- Modify DATA\\012-- -------\\012\\012ALTER TABLE data\\012    ADD COLUMN expe_id tech_id;\\012\\012ALTER TABLE data\\012    ADD CONSTRAINT data_expe_fk FOREIGN KEY (expe_id) REFERENCES experiments(id);\\012\\012CREATE INDEX data_expe_fk_i ON data USING btree (expe_id);\\012\\012UPDATE data\\012SET expe_id = (SELECT e.id FROM experiments e, procedures p \\012               WHERE data.proc_id_produced_by = p.id AND p.expe_id = e.id);\\012\\012ALTER TABLE data\\012    ALTER COLUMN expe_id SET NOT NULL;\\012\\012ALTER TABLE data\\012    DROP COLUMN proc_id_produced_by;\\012\\012-- -------\\012-- Drop PROCEDURES, PROCEDURE_TYPES, and SAMPLE_INPUTS\\012-- -------\\012\\012DROP TABLE sample_inputs;\\012DROP TABLE procedures;\\012DROP TABLE procedure_types;\\012\\012DROP SEQUENCE procedure_id_seq;\\012DROP SEQUENCE procedure_type_id_seq;\\012\\012-- -------\\012-- Add CODE_SEQ\\012-- -------\\012\\012CREATE SEQUENCE CODE_SEQ;\\012\\012-- -------\\012-- Add new columns to DATA_STORES\\012-- -------\\012\\012ALTER TABLE data_stores\\012    ADD COLUMN remote_url character varying(250),\\012    ADD COLUMN session_token character varying(50),\\012    ADD COLUMN modification_timestamp time_stamp DEFAULT now();\\012\\012UPDATE data_stores\\012SET remote_url = '', session_token='';\\012\\012ALTER TABLE data_stores\\012    ALTER COLUMN remote_url SET NOT NULL,\\012    ALTER COLUMN session_token SET NOT NULL;\\012\\012-- -------\\012-- Drop foreign keys onto DATA_STORES\\012-- -------\\012\\012ALTER TABLE database_instances\\012    DROP COLUMN dast_id;\\012\\012ALTER TABLE groups\\012    DROP COLUMN dast_id;\\012\\012ALTER TABLE projects\\012    DROP COLUMN dast_id;\\012\\012ALTER TABLE experiments\\012    DROP COLUMN dast_id;\\012\\012-- -------\\012-- Add foreign key from DATA onto DATA_STORES\\012-- -------\\012\\012ALTER TABLE data\\012    ADD COLUMN dast_id tech_id;\\012\\012ALTER TABLE data\\012    ADD CONSTRAINT data_dast_fk FOREIGN KEY (dast_id) REFERENCES data_stores(id);\\012\\012UPDATE data\\012SET dast_id = (select id from data_stores where code = 'STANDARD');\\012\\012ALTER TABLE data\\012    ALTER COLUMN dast_id SET NOT NULL;\\012\\012\\012------------------------------------------------------------------------------------\\012--  Purpose:  Replace trigger SAMPLE_CODE_UNIQUENESS_CHECK \\012------------------------------------------------------------------------------------\\012\\012CREATE OR REPLACE FUNCTION SAMPLE_CODE_UNIQUENESS_CHECK() RETURNS trigger AS $$\\012DECLARE\\012   counter  INTEGER;\\012BEGIN\\012    LOCK TABLE samples IN EXCLUSIVE MODE;\\012    IF (NEW.samp_id_part_of is NULL) THEN\\012        IF (NEW.dbin_id is not NULL) THEN\\012            SELECT count(*) into counter FROM samples \\012                where id != NEW.id and code = NEW.code and samp_id_part_of is NULL and dbin_id = NEW.dbin_id;\\012            IF (counter > 0) THEN\\012                RAISE EXCEPTION 'Insert/Update of Sample (Code: %) failed because database instance sample with the same code already exists.', NEW.code;\\012            END IF;\\012        ELSIF (NEW.grou_id is not NULL) THEN\\012            SELECT count(*) into counter FROM samples \\012                where id != NEW.id and code = NEW.code and samp_id_part_of is NULL and grou_id = NEW.grou_id;\\012            IF (counter > 0) THEN\\012                RAISE EXCEPTION 'Insert/Update of Sample (Code: %) failed because group sample with the same code already exists.', NEW.code;\\012            END IF;\\012        END IF;\\012        ELSE\\012        IF (NEW.dbin_id is not NULL) THEN\\012            SELECT count(*) into counter FROM samples \\012                where id != NEW.id and code = NEW.code and samp_id_part_of = NEW.samp_id_part_of and dbin_id = NEW.dbin_id;\\012            IF (counter > 0) THEN\\012                RAISE EXCEPTION 'Insert/Update of Sample (Code: %) failed because database instance sample with the same code and being the part of the same parent already exists.', NEW.code;\\012            END IF;\\012        ELSIF (NEW.grou_id is not NULL) THEN\\012            SELECT count(*) into counter FROM samples \\012                where id != NEW.id and code = NEW.code and samp_id_part_of = NEW.samp_id_part_of and grou_id = NEW.grou_id;\\012            IF (counter > 0) THEN\\012                RAISE EXCEPTION 'Insert/Update of Sample (Code: %) failed because group sample with the same code and being the part of the same parent already exists.', NEW.code;\\012            END IF;\\012        END IF;\\012        END IF;   \\012   RETURN NEW;\\012END;\\012$$ LANGUAGE 'plpgsql';\\012\\012\\012\\012	\N
+./sourceTest/sql/postgresql/064/.svn/text-base/017=database_version_logs.tsv.svn-base:034	source/sql/postgresql/migration/migration-033-034.sql	SUCCESS	2009-05-26 08:32:49.935	------------------------------------------------------------------------------------\\012-- Create sequence for generating permanent identifiers starting with nextval of existing dataset sequence.\\012------------------------------------------------------------------------------------\\012CREATE FUNCTION CREATE_SEQUENCE(EXISTING_SEQUENCE VARCHAR, NEW_SEQUENCE VARCHAR) RETURNS VOID AS $$\\012DECLARE\\012  CURR_SEQ_VAL   INTEGER;\\012BEGIN\\012  SELECT INTO CURR_SEQ_VAL NEXTVAL(EXISTING_SEQUENCE);\\012  EXECUTE 'CREATE SEQUENCE ' || NEW_SEQUENCE || ' START WITH ' || CURR_SEQ_VAL;\\012  RETURN;\\012END;\\012$$ LANGUAGE 'plpgsql';\\012\\012SELECT CREATE_SEQUENCE('DATA_ID_SEQ', 'PERM_ID_SEQ');\\012DROP FUNCTION CREATE_SEQUENCE(VARCHAR, VARCHAR);\\012\\012------------------------------------------------------------------------------------\\012-- Add perm_id columns to samples and experiments.\\012------------------------------------------------------------------------------------\\012ALTER TABLE SAMPLES ADD COLUMN PERM_ID CODE;\\012ALTER TABLE EXPERIMENTS ADD COLUMN PERM_ID CODE;\\012\\012UPDATE SAMPLES SET PERM_ID = to_char(registration_timestamp,'YYYYMMDDHHSSMS') || '-' || NEXTVAL('PERM_ID_SEQ');\\012UPDATE EXPERIMENTS SET PERM_ID = to_char(registration_timestamp,'YYYYMMDDHHSSMS') || '-' || NEXTVAL('PERM_ID_SEQ');\\012ALTER TABLE SAMPLES ALTER COLUMN PERM_ID SET NOT NULL;\\012ALTER TABLE EXPERIMENTS ALTER COLUMN PERM_ID SET NOT NULL;\\012ALTER TABLE SAMPLES ADD CONSTRAINT SAMP_PI_UK UNIQUE(PERM_ID);\\012ALTER TABLE EXPERIMENTS ADD CONSTRAINT EXPE_PI_UK UNIQUE(PERM_ID);\\012\\012\\012------------------------------------------------------------------------------------\\012-- Add column is_chosen_from_list to controlled_vocabularies.\\012------------------------------------------------------------------------------------\\012ALTER TABLE controlled_vocabularies ADD COLUMN is_chosen_from_list BOOLEAN_CHAR NOT NULL DEFAULT TRUE;\\012ALTER TABLE controlled_vocabularies ADD COLUMN source_uri CHARACTER VARYING(250);\\012------------------------------------------------------------------------------------\\012-- Modify Data table - remove arc connection between Sample and Data table, use a flag instead\\012------------------------------------------------------------------------------------\\012\\012-- add new columns\\012\\012ALTER TABLE data\\012    ADD COLUMN is_derived boolean_char;\\012ALTER TABLE data\\012    ADD COLUMN samp_id tech_id;\\012\\012-- update values in new columns\\012\\012UPDATE data\\012    SET is_derived = (samp_id_derived_from IS NOT NULL); \\012UPDATE data\\012    SET samp_id = samp_id_derived_from \\012    WHERE is_derived = 'TRUE';\\012UPDATE data\\012    SET samp_id = samp_id_acquired_from \\012    WHERE is_derived = 'FALSE';\\012\\012-- add constraints and indexes to new columns\\012\\012ALTER TABLE data\\012    ALTER COLUMN is_derived SET NOT NULL;\\012ALTER TABLE data\\012    ALTER COLUMN samp_id SET NOT NULL;   \\012ALTER TABLE data\\012    ADD CONSTRAINT data_samp_fk FOREIGN KEY (samp_id) REFERENCES samples (id);\\012CREATE INDEX data_samp_fk_i ON data USING btree (samp_id);\\012\\012-- remove old columns\\012\\012ALTER TABLE data\\012    DROP COLUMN samp_id_acquired_from;\\012ALTER TABLE data\\012    DROP COLUMN samp_id_derived_from;\\012    \\012------------------------------------------------------------------------------------\\012-- Granting SELECT privilege to group openbis_readonly\\012------------------------------------------------------------------------------------\\012\\012GRANT SELECT ON SEQUENCE attachment_content_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE attachment_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE code_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE controlled_vocabulary_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE cvte_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE data_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE data_set_property_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE data_set_relationship_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE data_set_type_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE data_store_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE data_type_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE database_instance_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE dstpt_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE etpt_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE event_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE experiment_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE experiment_property_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE experiment_type_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE file_format_type_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE group_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE invalidation_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE locator_type_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE material_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE material_property_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE material_type_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE mtpt_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE perm_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE person_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE project_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE property_type_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE role_assignment_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE sample_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE sample_property_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE sample_type_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE stpt_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE attachment_contents TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE attachments TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE controlled_vocabularies TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE controlled_vocabulary_terms TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE data TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE data_set_properties TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE data_set_relationships TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE data_set_type_property_types TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE data_set_types TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE data_stores TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE data_types TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE database_instances TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE database_version_logs TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE events TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE experiment_properties TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE experiment_type_property_types TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE experiment_types TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE experiments TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE external_data TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE file_format_types TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE groups TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE invalidations TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE locator_types TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE material_properties TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE material_type_property_types TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE material_types TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE materials TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE persons TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE projects TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE property_types TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE role_assignments TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE sample_properties TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE sample_type_property_types TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE sample_types TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE samples TO GROUP OPENBIS_READONLY;\\012\\012------------------------------------------------------------------------------------\\012-- Delete MATERIAL_BATCHES table\\012------------------------------------------------------------------------------------\\012\\012-- WARNING: Potential data lost!!!\\012-- WARNING: Potential data lost!!!\\012-- WARNING: Potential data lost!!!\\012\\012DROP TABLE SAMPLE_MATERIAL_BATCHES;\\012DROP TABLE MATERIAL_BATCHES;\\012DROP SEQUENCE MATERIAL_BATCH_ID_SEQ;\\012\\012------------------------------------------------------------------------------------\\012-- Delete MATE_ID_INHIBITOR_OF from table MATERIALS\\012------------------------------------------------------------------------------------\\012\\012-- WARNING: Potential data lost!!!\\012-- WARNING: Potential data lost!!!\\012-- WARNING: Potential data lost!!!\\012\\012ALTER TABLE MATERIALS DROP COLUMN MATE_ID_INHIBITOR_OF;\\012	\N
+./sourceTest/sql/postgresql/064/.svn/text-base/017=database_version_logs.tsv.svn-base:041	source/sql/postgresql/migration/migration-040-041.sql	SUCCESS	2009-09-14 13:48:57.539	-- Create FILTERS table\\012\\012CREATE TABLE FILTERS (ID TECH_ID NOT NULL, DBIN_ID TECH_ID NOT NULL, NAME VARCHAR(200) NOT NULL, DESCRIPTION DESCRIPTION_1000,REGISTRATION_TIMESTAMP TIME_STAMP_DFL NOT NULL DEFAULT CURRENT_TIMESTAMP, PERS_ID_REGISTERER TECH_ID NOT NULL, MODIFICATION_TIMESTAMP TIME_STAMP DEFAULT CURRENT_TIMESTAMP, EXPRESSION VARCHAR(2000) NOT NULL, IS_PUBLIC BOOLEAN NOT NULL, GRID_ID VARCHAR(200) NOT NULL);\\012CREATE SEQUENCE FILTER_ID_SEQ;\\012ALTER TABLE FILTERS ADD CONSTRAINT FILT_PK PRIMARY KEY(ID);\\012ALTER TABLE FILTERS ADD CONSTRAINT FILT_BK_UK UNIQUE(NAME, DBIN_ID, GRID_ID);\\012ALTER TABLE FILTERS ADD CONSTRAINT FILT_PERS_FK FOREIGN KEY (PERS_ID_REGISTERER) REFERENCES PERSONS(ID);\\012ALTER TABLE FILTERS ADD CONSTRAINT FILT_DBIN_FK FOREIGN KEY (DBIN_ID) REFERENCES DATABASE_INSTANCES(ID);\\012CREATE INDEX FILT_PERS_FK_I ON FILTERS (PERS_ID_REGISTERER);\\012CREATE INDEX FILT_DBIN_FK_I ON FILTERS (DBIN_ID);\\012GRANT SELECT ON SEQUENCE filter_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE filters TO GROUP OPENBIS_READONLY;\\012\\012-- Add missing foreign key to role assignments authorization group\\012ALTER TABLE ROLE_ASSIGNMENTS ADD CONSTRAINT ROAS_AG_FK_GRANTEE FOREIGN KEY (AG_ID_GRANTEE) REFERENCES AUTHORIZATION_GROUPS(ID);\\012\\012--------------------------------------------------------------------------------------------------\\012-- Modify dataset connections:\\012-- 1. connection with sample shouldn't be mandatory any more\\012-- 2. introduce an arc condition that dataset cannot be connected with a sample and a parent dataset at the same time\\012--------------------------------------------------------------------------------------------------\\012\\012-- Weaken data-sample connection constraint - allow dataset to have no connection with sample\\012ALTER TABLE data ALTER COLUMN samp_id DROP NOT NULL;\\012\\012-- Remove data-sample connection for datasets that have a parent\\012\\012UPDATE data \\012   SET samp_id = NULL \\012 WHERE id IN (SELECT DISTINCT data_id_child FROM data_set_relationships);\\012\\012-- With PostgreSQL 8.4 one can check that before migration there were no cycles in dataset relationships:\\012--\\012-- WITH RECURSIVE data_set_parents(id, parent_ids, cycle) AS (\\012--         SELECT  r.data_id_child AS id, \\012--                 ARRAY[CAST (r.data_id_parent AS bigint)] AS parent_ids, \\012--                 false AS cycle \\012--         FROM data_set_relationships r\\012--     UNION ALL\\012--         SELECT  r.data_id_child,\\012--                 CAST (r.data_id_parent AS bigint) || p.parent_ids,\\012--                 r.data_id_child = ANY(p.parent_ids)\\012--         FROM data_set_relationships r, data_set_parents p\\012--         WHERE r.data_id_parent = p.id AND NOT cycle\\012-- )\\012-- SELECT count(*) AS cycles FROM data_set_parents WHERE cycle = true;\\012\\012---------------------------------------------------------------------------------------------------\\012--  Purpose:  Create DEFERRED triggers:\\012--            * check_dataset_relationships_on_data_table_modification,\\012--            * check_dataset_relationships_on_relationships_table_modification.\\012--            They check that after all modifications of database (just before commit) \\012--            if 'data'/'data_set_relationships' tables are among modified tables \\012--            dataset is not connected with a sample and a parent dataset at the same time.\\012--            This connections are held in two different tables so simple immediate trigger \\012--            with arc check cannot be used and we need two deferred triggers.\\012----------------------------------------------------------------------------------------------------\\012\\012-- trigger for 'data' table\\012\\012CREATE OR REPLACE FUNCTION check_dataset_relationships_on_data_table_modification() RETURNS trigger AS $$\\012DECLARE\\012\\011counter\\011INTEGER;\\012BEGIN\\012\\011-- if there is a connection with a Sample there should not be any connection with a parent Data Set\\012\\011IF (NEW.samp_id IS NOT NULL) THEN\\012\\011\\011-- count number of parents\\012\\011\\011SELECT count(*) INTO counter \\012\\011\\011\\011FROM data_set_relationships \\012\\011\\011\\011WHERE data_id_child = OLD.id;\\012\\011\\011IF (counter > 0) THEN\\012\\011\\011\\011RAISE EXCEPTION 'Insert/Update of Data Set (Code: %) failed because it cannot be connected with a Sample and a parent Data Set at the same time.', OLD.code;\\012\\011\\011END IF;\\012\\011END IF;\\012  RETURN NEW;\\012END;\\012$$ LANGUAGE 'plpgsql';\\012\\012CREATE CONSTRAINT TRIGGER check_dataset_relationships_on_data_table_modification \\012  AFTER INSERT OR UPDATE ON data\\012\\011DEFERRABLE INITIALLY DEFERRED\\012\\011FOR EACH ROW \\012\\011EXECUTE PROCEDURE check_dataset_relationships_on_data_table_modification();\\012\\012-- trigger for 'data_set_relationships'\\012\\012CREATE OR REPLACE FUNCTION check_dataset_relationships_on_relationships_table_modification() RETURNS trigger AS $$\\012DECLARE\\012\\011counter\\011INTEGER;\\012\\011sample_id\\011TECH_ID;\\012\\011data_code\\011CODE;\\012BEGIN\\012\\011-- child will have a parent added so it should not be connected with any sample\\012\\011SELECT samp_id, code INTO sample_id, data_code \\012\\011\\011FROM data \\012\\011\\011WHERE id = NEW.data_id_child;\\012\\011IF (sample_id IS NOT NULL) THEN\\012\\011\\011RAISE EXCEPTION 'Insert/Update of Data Set (Code: %) failed because it cannot be connected to a Sample and to a parent Data Set at the same time.', data_code;\\012\\011END IF;\\012\\011RETURN NEW;\\012END;\\012$$ LANGUAGE 'plpgsql';\\012  \\012CREATE CONSTRAINT TRIGGER check_dataset_relationships_on_relationships_table_modification \\012  AFTER INSERT OR UPDATE ON data_set_relationships\\012\\011DEFERRABLE INITIALLY DEFERRED\\012\\011FOR EACH ROW \\012\\011EXECUTE PROCEDURE check_dataset_relationships_on_relationships_table_modification();\\012	\N
+./sourceTest/sql/postgresql/064/.svn/text-base/017=database_version_logs.tsv.svn-base:053	source/sql/postgresql/migration/migration-052-053.sql	SUCCESS	2010-06-08 15:27:55.032	-- Migration from 052 to 053\\012\\012-- Change code uniqueness check for samples of specific type.\\012-- If sample_types.is_subcode_unique flag is set to 'true', additional check is performed \\012-- on codes of samples of the type. Subcodes will have to be unique as well.\\012\\012ALTER TABLE sample_types ADD COLUMN is_subcode_unique boolean_char NOT NULL DEFAULT false;\\012\\012CREATE OR REPLACE FUNCTION SAMPLE_SUBCODE_UNIQUENESS_CHECK() RETURNS trigger AS $$\\012DECLARE\\012   counter  INTEGER;\\012   unique_subcode  BOOLEAN_CHAR;\\012BEGIN\\012  LOCK TABLE samples IN EXCLUSIVE MODE;\\012  \\012  SELECT is_subcode_unique into unique_subcode FROM sample_types WHERE id = NEW.saty_id;\\012  \\012  IF (unique_subcode) THEN\\012    IF (NEW.dbin_id is not NULL) THEN\\012\\011\\011\\011SELECT count(*) into counter FROM samples \\012\\011\\011\\011\\011where id != NEW.id and code = NEW.code and saty_id = NEW.saty_id and dbin_id = NEW.dbin_id;\\012\\011\\011\\011IF (counter > 0) THEN\\012\\011\\011\\011\\011RAISE EXCEPTION 'Insert/Update of Sample (Code: %) failed because database instance sample of the same type with the same subcode already exists.', NEW.code;\\012\\011\\011\\011END IF;\\012\\011\\011ELSIF (NEW.grou_id is not NULL) THEN\\012\\011\\011\\011SELECT count(*) into counter FROM samples \\012\\011\\011\\011\\011where id != NEW.id and code = NEW.code and saty_id = NEW.saty_id and grou_id = NEW.grou_id;\\012\\011\\011\\011IF (counter > 0) THEN\\012\\011\\011\\011\\011RAISE EXCEPTION 'Insert/Update of Sample (Code: %) failed because space sample of the same type with the same subcode already exists.', NEW.code;\\012\\011\\011\\011END IF;\\012\\011\\011END IF;\\012  END IF;\\012  \\012  RETURN NEW;\\012END;\\012$$ LANGUAGE 'plpgsql';\\012\\012CREATE TRIGGER SAMPLE_SUBCODE_UNIQUENESS_CHECK BEFORE INSERT OR UPDATE ON SAMPLES\\012    FOR EACH ROW EXECUTE PROCEDURE SAMPLE_SUBCODE_UNIQUENESS_CHECK();\\012    \\012-- Fixing error messages in old trigger\\012\\012CREATE OR REPLACE FUNCTION SAMPLE_CODE_UNIQUENESS_CHECK() RETURNS trigger AS $$\\012DECLARE\\012   counter  INTEGER;\\012BEGIN\\012  LOCK TABLE samples IN EXCLUSIVE MODE;\\012  \\012\\011  IF (NEW.samp_id_part_of is NULL) THEN\\012\\011\\011  IF (NEW.dbin_id is not NULL) THEN\\012\\011\\011\\011  SELECT count(*) into counter FROM samples \\012\\011\\011      where id != NEW.id and code = NEW.code and samp_id_part_of is NULL and dbin_id = NEW.dbin_id;\\012        IF (counter > 0) THEN\\012\\011\\011\\011\\011  RAISE EXCEPTION 'Insert/Update of Sample (Code: %) failed because database instance sample with the same code already exists.', NEW.code;\\012        END IF;\\012\\011\\011  ELSIF (NEW.grou_id is not NULL) THEN\\012\\011\\011\\011  SELECT count(*) into counter FROM samples \\012\\011\\011\\011\\011  where id != NEW.id and code = NEW.code and samp_id_part_of is NULL and grou_id = NEW.grou_id;\\012\\011\\011\\011  IF (counter > 0) THEN\\012\\011\\011\\011\\011  RAISE EXCEPTION 'Insert/Update of Sample (Code: %) failed because space sample with the same code already exists.', NEW.code;\\012\\011\\011\\011  END IF;\\012      END IF;\\012    ELSE\\012\\011\\011  IF (NEW.dbin_id is not NULL) THEN\\012\\011\\011\\011  SELECT count(*) into counter FROM samples \\012\\011\\011\\011\\011  where id != NEW.id and code = NEW.code and samp_id_part_of = NEW.samp_id_part_of and dbin_id = NEW.dbin_id;\\012\\011\\011\\011  IF (counter > 0) THEN\\012\\011\\011\\011\\011  RAISE EXCEPTION 'Insert/Update of Sample (Code: %) failed because database instance sample with the same code and being the part of the same container already exists.', NEW.code;\\012\\011\\011\\011  END IF;\\012\\011\\011  ELSIF (NEW.grou_id is not NULL) THEN\\012\\011\\011\\011  SELECT count(*) into counter FROM samples \\012\\011\\011\\011\\011  where id != NEW.id and code = NEW.code and samp_id_part_of = NEW.samp_id_part_of and grou_id = NEW.grou_id;\\012\\011\\011\\011  IF (counter > 0) THEN\\012\\011\\011\\011\\011  RAISE EXCEPTION 'Insert/Update of Sample (Code: %) failed because space sample with the same code and being the part of the same container already exists.', NEW.code;\\012\\011\\011\\011  END IF;\\012\\011\\011  END IF;\\012     END IF;   \\012  \\012  RETURN NEW;\\012END;\\012$$ LANGUAGE 'plpgsql';\\012	\N
+./sourceTest/sql/postgresql/064/.svn/text-base/017=database_version_logs.tsv.svn-base:054	source/sql/postgresql/migration/migration-053-054.sql	SUCCESS	2010-07-27 11:30:46.766	-- Migration from 053 to 054\\012\\012\\012-- Add RELATIONSHIP_TYPES table\\012CREATE TABLE relationship_types (id TECH_ID NOT NULL, code CODE NOT NULL, label COLUMN_LABEL, parent_label COLUMN_LABEL, child_label COLUMN_LABEL, description DESCRIPTION_2000, registration_timestamp TIME_STAMP_DFL NOT NULL DEFAULT CURRENT_TIMESTAMP, pers_id_registerer TECH_ID NOT NULL, is_managed_internally BOOLEAN_CHAR NOT NULL DEFAULT 'F', is_internal_namespace BOOLEAN_CHAR NOT NULL DEFAULT 'F', dbin_id TECH_ID NOT NULL);\\012\\012-- Add SAMPLE_RELATIONSHIPS table\\012CREATE TABLE sample_relationships (id TECH_ID NOT NULL, sample_id_parent TECH_ID NOT NULL, relationship_id TECH_ID NOT NULL, sample_id_child TECH_ID NOT NULL);\\012\\012-- Add/update constraints\\012ALTER TABLE relationship_types ADD CONSTRAINT rety_pk PRIMARY KEY (id);\\012ALTER TABLE relationship_types ADD CONSTRAINT rety_uk UNIQUE(code,dbin_id);\\012ALTER TABLE sample_relationships ADD CONSTRAINT sare_pk PRIMARY KEY (id);\\012ALTER TABLE sample_relationships ADD CONSTRAINT sare_bk_uk UNIQUE(sample_id_child,sample_id_parent,relationship_id);\\012ALTER TABLE sample_relationships ADD CONSTRAINT sare_data_fk_child FOREIGN KEY (sample_id_child) REFERENCES samples(id) ON DELETE CASCADE;\\012ALTER TABLE sample_relationships ADD CONSTRAINT sare_data_fk_parent FOREIGN KEY (sample_id_parent) REFERENCES samples(id) ON DELETE CASCADE;\\012ALTER TABLE sample_relationships ADD CONSTRAINT sare_data_fk_relationship FOREIGN KEY (relationship_id) REFERENCES relationship_types(id);\\012\\012-- Create index\\012CREATE INDEX sare_data_fk_i_child ON sample_relationships (sample_id_child);\\012CREATE INDEX sare_data_fk_i_parent ON sample_relationships (sample_id_parent);\\012CREATE INDEX sare_data_fk_i_relationship ON sample_relationships (relationship_id);\\012\\012-- Create sequence for RELATIONSHIP_TYPES\\012CREATE SEQUENCE RELATIONSHIP_TYPE_ID_SEQ;\\012CREATE SEQUENCE SAMPLE_RELATIONSHIP_ID_SEQ;\\012\\012-- Create initial relationships\\012insert into relationship_types\\012(id, \\012code, \\012label, \\012parent_label, \\012child_label, \\012description, \\012pers_id_registerer, \\012is_managed_internally, \\012is_internal_namespace, \\012dbin_id) \\012values\\012(\\012nextval('RELATIONSHIP_TYPE_ID_SEQ'),\\012'PARENT_CHILD',\\012'Parent - Child', \\012'Parent', \\012'Child', \\012'Parent - Child relationship', \\012(select id from persons where user_id ='system'), \\012'T', \\012'T', \\012(select id from database_instances where is_original_source = 'T')\\012);\\012\\012insert into relationship_types\\012(id, \\012code, \\012label, \\012parent_label, \\012child_label, \\012description, \\012pers_id_registerer, \\012is_managed_internally, \\012is_internal_namespace, \\012dbin_id) \\012values\\012(\\012nextval('RELATIONSHIP_TYPE_ID_SEQ'),\\012'PLATE_CONTROL_LAYOUT',\\012'Plate - Control Layout', \\012'Plate', \\012'Control Layout', \\012'Plate - Control Layout relationship', \\012(select id from persons where user_id ='system'), \\012'T', \\012'T', \\012(select id from database_instances where is_original_source = 'T')\\012); \\012\\012\\012-- Migrate sample relationships to new schema\\012INSERT INTO sample_relationships (id, sample_id_parent,sample_id_child,relationship_id) (select distinct nextval('SAMPLE_RELATIONSHIP_ID_SEQ') as id, s.SAMP_ID_GENERATED_FROM as parent_id, s.ID as child_id, rt.id as relationship_id from samples s, relationship_types rt  WHERE rt.code = 'PARENT_CHILD' and s.SAMP_ID_GENERATED_FROM is not null); \\012INSERT INTO sample_relationships (id, sample_id_parent,sample_id_child,relationship_id) (select distinct nextval('SAMPLE_RELATIONSHIP_ID_SEQ') as id, s.SAMP_ID_CONTROL_LAYOUT as parent_id, s.ID as child_id, rt.id as relationship_id from samples s, relationship_types rt  WHERE rt.code = 'PLATE_CONTROL_LAYOUT' and s.SAMP_ID_CONTROL_LAYOUT is not null);\\012\\012-- Drop old sample relations\\012ALTER TABLE SAMPLES DROP COLUMN SAMP_ID_TOP;\\012ALTER TABLE SAMPLES DROP COLUMN SAMP_ID_GENERATED_FROM;\\012ALTER TABLE SAMPLES DROP COLUMN SAMP_ID_CONTROL_LAYOUT;\\012\\012--------------------------------------------------------------------------------------\\012--------------------------------------------------------------------------------------\\012-- This is a screening specific migration. Nothing will be performed on openBIS databases \\012-- which are not screening specific.\\012-- \\012-- This migration for each existing connection between oligo well, oligo material and gene material\\012-- creates a direct connection between the well and the gene. \\012--------------------------------------------------------------------------------------\\012--------------------------------------------------------------------------------------\\012 \\012\\011\\012CREATE OR REPLACE FUNCTION CONNECT_WELLS_WITH_GENES() RETURNS void AS $$\\012DECLARE\\012\\011counter  int;\\012\\011oligo_well_exists bool;\\012BEGIN\\012\\011--------------------------------------------------\\012\\011-- create a gene property and assign it to oligo well\\012\\011--------------------------------------------------\\012\\011\\012\\011select true \\012\\011into oligo_well_exists\\012\\011from sample_types \\012\\011where code = 'OLIGO_WELL';\\012\\011\\012\\011if oligo_well_exists IS NULL then \\012\\011\\011-- skip migration if there are no oligo wells\\012\\011\\011return;\\012\\011end if;   \\012\\011\\012\\011insert into property_types(\\012\\011\\011id, \\012\\011\\011code, description, label, \\012\\011\\011daty_id,\\012\\011\\011pers_id_registerer,\\012\\011\\011dbin_id,\\012\\011\\011maty_prop_id) \\012\\011values(\\012\\011\\011\\011nextval('PROPERTY_TYPE_ID_SEQ'), \\012\\011\\011\\011'GENE','Inhibited gene','Gene',\\012\\011\\011\\011(select id from data_types where code = 'MATERIAL'), \\012\\011\\011\\011(select id from persons where user_id ='system'), \\012\\011\\011\\011(select id from database_instances where is_original_source = 'T'), \\012\\011\\011\\011(select id from material_types where code = 'GENE')\\012\\011\\011);\\012\\011\\011\\012\\011insert into sample_type_property_types( \\012\\011  id,\\012\\011  saty_id,\\012\\011  prty_id,\\012\\011  is_mandatory,\\012\\011  pers_id_registerer,\\012\\011  ordinal\\012\\011) values(\\012\\011\\011\\011nextval('stpt_id_seq'), \\012\\011\\011\\011(select id from sample_types where code = 'OLIGO_WELL'),\\012\\011\\011\\011(select id from property_types where code = 'GENE'),\\012\\011\\011\\011false,\\012\\011\\011\\011(select id from persons where user_id ='system'),\\012\\011\\011\\011(select max(ordinal)+1 from sample_type_property_types \\012\\011\\011\\011\\011where saty_id = (select id from sample_types where code = 'OLIGO_WELL'))\\012\\011\\011);\\012\\012\\011--------------------------------------------------\\012\\011-- create a gene material property for each oligo well\\012\\011--------------------------------------------------\\012\\011\\011\\012\\011select \\011count(*)\\012\\011into counter\\012\\011from\\012\\011\\011samples well, sample_types well_type, sample_properties well_props, \\012\\011\\011materials well_material, material_properties well_material_props,\\012\\011\\011materials nested_well_material\\012\\011where\\012\\011\\011well_type.code = 'OLIGO_WELL' and\\012\\011\\011-- find 'well_material' assigned to the well\\012\\011\\011well_props.samp_id = well.id and well_material.id = well_props.mate_prop_id and \\012\\011\\011-- additional joins to entity type tables\\012\\011\\011well_type.id = well.saty_id and\\012\\011\\011-- well content material property\\012\\011\\011well_material_props.mate_id = well_material.id and \\012\\011\\011-- material connected to the material in the well (e.g. gene)\\012\\011\\011well_material_props.mate_prop_id = nested_well_material.id and\\012\\011\\011nested_well_material.maty_id = (select id from material_types where code = 'GENE');\\012\\011\\012\\011if counter = 0 then \\012\\011\\011-- skip migration if there are no genes indirectly connected to oligo wells\\012\\011\\011return;\\012\\011end if;   \\012\\012\\011insert into sample_properties(id, samp_id, stpt_id, mate_prop_id, pers_id_registerer) (\\012\\011\\011select \\011nextval('sample_property_id_seq') id, \\012\\011\\011\\011well.id samp_id, \\012\\011\\011\\011(select stpt.id from sample_type_property_types stpt, property_types props where stpt.prty_id = props.id and props.code='GENE') stpt_id,\\012\\011\\011\\011nested_well_material.id mate_prop_id,\\012\\011\\011\\011(select id from persons where user_id ='system') pers_id_registerer \\012\\011\\011from\\012\\011\\011\\011samples well, sample_types well_type, sample_properties well_props, \\012\\011\\011\\011materials well_material, material_properties well_material_props,\\012\\011\\011\\011materials nested_well_material\\012\\011\\011where\\012\\011\\011\\011well_type.code = 'OLIGO_WELL' and\\012\\011\\011\\011-- find 'well_material' assigned to the well\\012\\011\\011\\011well_props.samp_id = well.id and well_material.id = well_props.mate_prop_id and \\012\\011\\011\\011-- additional joins to entity type tables\\012\\011\\011\\011well_type.id = well.saty_id and\\012\\011\\011\\011-- well content material property\\012\\011\\011\\011well_material_props.mate_id = well_material.id and \\012\\011\\011\\011-- material connected to the material in the well (e.g. gene)\\012\\011\\011\\011well_material_props.mate_prop_id = nested_well_material.id and\\012\\011\\011\\011nested_well_material.maty_id = (select id from material_types where code = 'GENE')\\012\\011);\\012\\012END;\\012$$ LANGUAGE 'plpgsql';\\012\\012select CONNECT_WELLS_WITH_GENES();\\012drop function CONNECT_WELLS_WITH_GENES();\\012\\012--------------------------------------------------------------------------------------\\012--------------------------------------------------------------------------------------\\012\\012-- drop dataset triggers\\012\\012DROP TRIGGER check_dataset_relationships_on_data_table_modification ON data;\\012DROP FUNCTION check_dataset_relationships_on_data_table_modification();\\012DROP TRIGGER check_dataset_relationships_on_relationships_table_modification ON data_set_relationships;\\012DROP FUNCTION check_dataset_relationships_on_relationships_table_modification();\\012 \\012\\012\\012\\012\\012\\012\\012\\012	\N
+./sourceTest/sql/postgresql/064/.svn/text-base/017=database_version_logs.tsv.svn-base:056	source/sql/postgresql/migration/migration-055-056.sql	SUCCESS	2010-09-10 09:06:20.278	-- Migration from 055 to 056\\012\\012--------------------------------------------------------------------------------------\\012--------------------------------------------------------------------------------------\\012-- Screening specific migration. Nothing will be performed on openBIS databases \\012-- which are not screening specific.\\012--------------------------------------------------------------------------------------\\012--------------------------------------------------------------------------------------\\012\\012CREATE OR REPLACE FUNCTION merge_words(text, text) RETURNS text AS $$\\012DECLARE\\012  BEGIN\\012    IF  character_length($1) > 0 THEN\\012      RETURN $1 || ' ' || $2;\\012    ELSE\\012      RETURN $2;\\012    END IF;\\012  END;\\012$$ LANGUAGE plpgsql;\\012\\012CREATE AGGREGATE merge_words(text)\\012(\\012  SFUNC = merge_words,\\012  STYPE = text\\012);\\012\\012\\012CREATE OR REPLACE FUNCTION REPLACE_GENE_SYMBOL_BY_GENE_ID() RETURNS void AS $$\\012DECLARE\\012\\011counter  int;\\012\\011library_id_assigned_to_gene bool;\\012BEGIN\\012\\011--------------------------------------------------\\012\\011-- create a GENE_SYMBOL property and assign it to GENE\\012\\011--------------------------------------------------\\012\\011\\012\\011select true  \\012\\011into library_id_assigned_to_gene \\012\\011from material_type_property_types mtpt, material_types mt, property_types pt  \\012\\011where mtpt.maty_id = mt.id and mtpt.prty_id = pt.id \\012\\011\\011and mt.code = 'GENE' and pt.code = 'LIBRARY_ID';\\012\\011\\012\\011if library_id_assigned_to_gene IS NULL then \\012\\011\\011-- skip migration if gene has no library_id property\\012\\011\\011return;\\012\\011end if; \\012\\011\\012\\011\\012\\011select count(*)\\012\\011into counter \\012\\011from  \\012\\011\\011(select m.id, count(mp.id) as c \\012\\011\\011\\011from materials m, material_types mt, material_properties mp, material_type_property_types mtpt, property_types pt \\012\\011\\011\\011where m.maty_id = mt.id and mp.mate_id = m.id and mp.mtpt_id = mtpt.id and mtpt.maty_id = mt.id and pt.id = mtpt.prty_id\\012\\011\\011\\011\\011and mt.code = 'GENE' and pt.code = 'LIBRARY_ID' \\012\\011\\011\\011group by m.id) as counter_table \\012\\011where c < 1; \\012\\011\\012\\011if counter > 0 then \\012\\011\\011-- skip migration if there is at least one gene without library_id\\012\\011\\011return;\\012\\011end if;\\012\\011\\012\\011\\012\\011insert into property_types\\012\\011\\011(id\\012\\011\\011,code\\012\\011\\011,description\\012\\011\\011,label\\012\\011\\011,daty_id\\012\\011\\011,pers_id_registerer\\012\\011\\011,dbin_id)\\012\\011values \\012\\011\\011(nextval('PROPERTY_TYPE_ID_SEQ')\\012\\011\\011,'GENE_SYMBOLS'\\012\\011\\011,'Gene symbols'\\012\\011\\011,'Gene symbols'\\012\\011\\011,(select id from data_types where code ='VARCHAR')\\012\\011\\011,(select id from persons where user_id ='system')\\012\\011\\011,(select id from database_instances where is_original_source = 'T')\\012\\011);\\012\\011\\011\\012\\011insert into material_type_property_types( \\012\\011  id,\\012\\011  maty_id,\\012\\011  prty_id,\\012\\011  is_mandatory,\\012\\011  pers_id_registerer,\\012\\011  ordinal\\012\\011) values(\\012\\011\\011\\011nextval('mtpt_id_seq'), \\012\\011\\011\\011(select id from material_types where code = 'GENE'),\\012\\011\\011\\011(select id from property_types where code = 'GENE_SYMBOLS'),\\012\\011\\011\\011false,\\012\\011\\011\\011(select id from persons where user_id ='system'),\\012\\011\\011\\011(select max(ordinal)+1 from material_type_property_types \\012\\011\\011\\011\\011where maty_id = (select id from material_types where code = 'GENE'))\\012\\011\\011);\\012\\012\\011--------------------------------------------------\\012\\011-- create temporary table with all gene migration information\\012\\011--------------------------------------------------\\012\\012\\011create temp table genes \\012\\011(\\012\\011\\011id tech_id,\\012\\011\\011code code,\\012\\011\\011library_id generic_value,\\012\\011\\011gene_codes generic_value,\\012\\011\\011new_id tech_id,\\012\\011\\011library_tech_id tech_id\\011\\011\\012\\011);\\012\\011\\012\\011insert into genes (id, code, library_id, library_tech_id)\\012\\011\\011(select m.id, m.code, mp.value as library_id, mp.id as library_tech_id from materials m, material_properties mp, material_type_property_types mtpt, property_types pt, material_types mt\\012\\011\\011where mp.mate_id = m.id and  mp.mtpt_id = mtpt.id and pt.id = mtpt.prty_id and pt.code = 'LIBRARY_ID' and mt.id = m.maty_id and mt.id = mtpt.maty_id and mt.code = 'GENE');\\012\\011\\012\\011update genes set new_id = map.to_id from (select g_from.id as from_id, min(g_to.id) as to_id  from genes g_from, genes g_to where g_from.library_id = g_to.library_id group by g_from.id) as map where map.from_id = id;\\011\\012\\011\\012\\011update genes set gene_codes = map.gene_codes from (select g_from.library_id as lib_id, merge_words(distinct g_to.code) as gene_codes from genes g_from, genes g_to where g_from.library_id = g_to.library_id group by g_from.library_id) as map where map.lib_id = library_id;\\011\\012\\012\\011--------------------------------------------------\\012\\011-- update gene references\\012\\011--------------------------------------------------\\012\\012\\011update EXPERIMENTS set MATE_ID_STUDY_OBJECT = genes.new_id from genes where genes.id = MATE_ID_STUDY_OBJECT and not genes.id = genes.new_id;\\012\\011update EXPERIMENT_PROPERTIES set  MATE_PROP_ID = genes.new_id from genes where genes.id = MATE_PROP_ID and not genes.id = genes.new_id;\\012\\011update MATERIAL_PROPERTIES set  MATE_PROP_ID = genes.new_id from genes where genes.id = MATE_PROP_ID and not genes.id = genes.new_id;\\012\\011update SAMPLE_PROPERTIES set  MATE_PROP_ID = genes.new_id from genes where genes.id = MATE_PROP_ID and not genes.id = genes.new_id;\\012\\011update DATA_SET_PROPERTIES set  MATE_PROP_ID = genes.new_id from genes where genes.id = MATE_PROP_ID and not genes.id = genes.new_id;\\012\\011\\012\\011delete from  material_properties where mate_id in (select id from genes where not genes.id = genes.new_id);\\012\\011delete from MATERIALS where id in (select id from genes where not genes.id = genes.new_id);\\012\\012\\011delete from genes where id in (select id from genes where not genes.id = genes.new_id);\\012\\012\\012\\011--------------------------------------------------\\012\\011-- replace gene code with library_id\\012\\011--------------------------------------------------\\012\\011\\012\\011update materials set code = genes.library_id from genes where materials.id = genes.id ;\\012\\011delete from material_properties where id in (select library_tech_id from genes);\\012\\011\\012\\011--------------------------------------------------\\012\\011-- create a gene symbols property for each gene\\012\\011--------------------------------------------------\\012\\011\\012\\011insert into material_properties\\012\\011\\011(id\\012\\011  , mate_id\\012\\011  , mtpt_id\\012\\011  , "value"\\012\\011  , pers_id_registerer)\\012\\011\\011(select nextval('material_property_id_seq') id\\012\\011  \\011, genes.id  mate_id\\012\\011    , (select mtpt.id\\012\\011    \\011\\011from   material_type_property_types mtpt, material_types mt, property_types pt\\012\\011    \\011\\011where  pt.code = 'GENE_SYMBOLS' and mt.code = 'GENE' and mtpt.prty_id = pt.id\\012\\011        \\011and mtpt.maty_id = mt.id) mtpt_id\\012\\011    , genes.gene_codes "value"\\012\\011    , (select id from persons where user_id = 'system') pers_id_registerer\\012\\011 \\011from genes); \\012\\012\\011--------------------------------------------------\\012\\011-- delete temporary table\\012\\011--------------------------------------------------\\012\\011\\012\\011drop table genes;\\012\\011\\012END;\\012$$ LANGUAGE 'plpgsql';\\012\\012select REPLACE_GENE_SYMBOL_BY_GENE_ID();\\012drop function REPLACE_GENE_SYMBOL_BY_GENE_ID();\\012DROP AGGREGATE merge_words(text);\\012drop function merge_words(text,text);\\012\\012\\012--------------------------------------------------------------------------------------\\012--------------------------------------------------------------------------------------\\012\\012UPDATE sample_types SET code = 'SIRNA_WELL' WHERE code = 'OLIGO_WELL';\\012UPDATE material_types SET code = 'SIRNA' WHERE code = 'OLIGO';\\012UPDATE property_types SET code = 'SIRNA', label = 'siRNA' WHERE code = 'OLIGO';\\012\\012\\012\\012\\012\\012\\012\\012\\012\\012\\012\\012\\012\\012\\012\\012\\012\\012\\012\\012	\N
+./sourceTest/sql/postgresql/064/.svn/text-base/017=database_version_logs.tsv.svn-base:059	source/sql/postgresql/migration/migration-058-059.sql	SUCCESS	2010-09-29 13:37:07.231	-- Migration from 058 to 059\\012\\012-- Add ENTITY_TYPE_CODE column to QUERIES\\012ALTER TABLE queries ADD COLUMN entity_type_code CODE;\\012\\012------------------------------------------------------------------------------------\\012--  Purpose:  Create trigger that checks if entity_type_code specified in a query\\012--            matches a code of an entity of type specified in query_type.\\012------------------------------------------------------------------------------------\\012\\012CREATE OR REPLACE FUNCTION query_entity_type_code_check() RETURNS trigger AS $$\\012DECLARE\\012   counter  INTEGER;\\012BEGIN\\012   if (NEW.entity_type_code IS NOT NULL) then\\012     if (NEW.query_type = 'GENERIC') then\\012       RAISE EXCEPTION 'Insert/Update of query (Name: %) failed, as entity_type has to be null for GENERIC queries.', NEW.name;\\012     elsif (NEW.query_type = 'EXPERIMENT') then\\012       SELECT count(*) INTO counter FROM experiment_types WHERE code = NEW.entity_type_code;\\012\\011\\011 elsif (NEW.query_type = 'DATA_SET') then\\012       SELECT count(*) INTO counter FROM data_set_types WHERE code = NEW.entity_type_code;\\012\\011\\011 elsif (NEW.query_type = 'MATERIAL') then\\012       SELECT count(*) INTO counter FROM material_types WHERE code = NEW.entity_type_code;\\012\\011\\011 elsif (NEW.query_type = 'SAMPLE') then\\012       SELECT count(*) INTO counter FROM sample_types WHERE code = NEW.entity_type_code;\\012\\011\\011 end if;\\012\\011\\011 if (counter = 0) then\\012\\011\\011\\011 RAISE EXCEPTION 'Insert/Update of query (Name: %) failed because % type (Code: %) does not exist.', NEW.name, NEW.query_type, NEW.entity_type_code;\\012\\011\\011 end if;\\011\\011\\011\\012   end if;\\012   RETURN NEW;\\012END;\\012$$ LANGUAGE 'plpgsql';\\012\\012CREATE TRIGGER query_entity_type_code_check BEFORE INSERT OR UPDATE ON queries\\012    FOR EACH ROW EXECUTE PROCEDURE query_entity_type_code_check();\\012	\N
+./sourceTest/sql/postgresql/064/.svn/text-base/017=database_version_logs.tsv.svn-base:062	source/sql/postgresql/migration/migration-061-062.sql	SUCCESS	2010-11-25 16:02:07.224	\\012CREATE OR REPLACE FUNCTION sample_code_uniqueness_check() RETURNS trigger\\012    LANGUAGE plpgsql\\012    AS $$\\012DECLARE\\012   counter  INTEGER;\\012BEGIN\\012  LOCK TABLE samples IN EXCLUSIVE MODE;\\012  \\012\\011  IF (NEW.samp_id_part_of is NULL) THEN\\012\\011\\011  IF (NEW.dbin_id is not NULL) THEN\\012\\011\\011\\011  SELECT count(*) into counter FROM samples \\012\\011\\011      where id != NEW.id and code = NEW.code and samp_id_part_of is NULL and dbin_id = NEW.dbin_id;\\012        IF (counter > 0) THEN\\012\\011\\011\\011\\011  RAISE EXCEPTION 'Insert/Update of Sample (Code: %) failed because database instance sample with the same code already exists.', NEW.code;\\012        END IF;\\012\\011\\011  ELSIF (NEW.space_id is not NULL) THEN\\012\\011\\011\\011  SELECT count(*) into counter FROM samples \\012\\011\\011\\011\\011  where id != NEW.id and code = NEW.code and samp_id_part_of is NULL and space_id = NEW.grou_id;\\012\\011\\011\\011  IF (counter > 0) THEN\\012\\011\\011\\011\\011  RAISE EXCEPTION 'Insert/Update of Sample (Code: %) failed because space sample with the same code already exists.', NEW.code;\\012\\011\\011\\011  END IF;\\012      END IF;\\012    ELSE\\012\\011\\011  IF (NEW.dbin_id is not NULL) THEN\\012\\011\\011\\011  SELECT count(*) into counter FROM samples \\012\\011\\011\\011\\011  where id != NEW.id and code = NEW.code and samp_id_part_of = NEW.samp_id_part_of and dbin_id = NEW.dbin_id;\\012\\011\\011\\011  IF (counter > 0) THEN\\012\\011\\011\\011\\011  RAISE EXCEPTION 'Insert/Update of Sample (Code: %) failed because database instance sample with the same code and being the part of the same container already exists.', NEW.code;\\012\\011\\011\\011  END IF;\\012\\011\\011  ELSIF (NEW.space_id is not NULL) THEN\\012\\011\\011\\011  SELECT count(*) into counter FROM samples \\012\\011\\011\\011\\011  where id != NEW.id and code = NEW.code and samp_id_part_of = NEW.samp_id_part_of and space_id = NEW.space_id;\\012\\011\\011\\011  IF (counter > 0) THEN\\012\\011\\011\\011\\011  RAISE EXCEPTION 'Insert/Update of Sample (Code: %) failed because space sample with the same code and being the part of the same container already exists.', NEW.code;\\012\\011\\011\\011  END IF;\\012\\011\\011  END IF;\\012     END IF;   \\012  \\012  RETURN NEW;\\012END;\\012$$;\\012\\012\\012CREATE OR REPLACE FUNCTION sample_subcode_uniqueness_check() RETURNS trigger\\012    LANGUAGE plpgsql\\012    AS $$\\012DECLARE\\012   counter  INTEGER;\\012   unique_subcode  BOOLEAN_CHAR;\\012BEGIN\\012  LOCK TABLE samples IN EXCLUSIVE MODE;\\012  \\012  SELECT is_subcode_unique into unique_subcode FROM sample_types WHERE id = NEW.saty_id;\\012  \\012  IF (unique_subcode) THEN\\012    IF (NEW.dbin_id is not NULL) THEN\\012\\011\\011\\011SELECT count(*) into counter FROM samples \\012\\011\\011\\011\\011where id != NEW.id and code = NEW.code and saty_id = NEW.saty_id and dbin_id = NEW.dbin_id;\\012\\011\\011\\011IF (counter > 0) THEN\\012\\011\\011\\011\\011RAISE EXCEPTION 'Insert/Update of Sample (Code: %) failed because database instance sample of the same type with the same subcode already exists.', NEW.code;\\012\\011\\011\\011END IF;\\012\\011\\011ELSIF (NEW.space_id is not NULL) THEN\\012\\011\\011\\011SELECT count(*) into counter FROM samples \\012\\011\\011\\011\\011where id != NEW.id and code = NEW.code and saty_id = NEW.saty_id and space_id = NEW.space_id;\\012\\011\\011\\011IF (counter > 0) THEN\\012\\011\\011\\011\\011RAISE EXCEPTION 'Insert/Update of Sample (Code: %) failed because space sample of the same type with the same subcode already exists.', NEW.code;\\012\\011\\011\\011END IF;\\012\\011\\011END IF;\\012  END IF;\\012  \\012  RETURN NEW;\\012END;\\012$$;\\012\\012ALTER TABLE groups RENAME TO spaces;\\012\\012ALTER SEQUENCE group_id_seq RENAME TO space_id_seq;\\012\\012ALTER TABLE persons\\011RENAME grou_id TO space_id;\\012ALTER TABLE projects RENAME grou_id TO space_id;\\012ALTER TABLE role_assignments RENAME grou_id TO space_id;\\012ALTER TABLE samples\\011RENAME grou_id TO space_id;\\012\\012-- migrate EVENTS table\\012\\012ALTER TABLE events\\012\\011DROP CONSTRAINT evnt_et_enum_ck;\\012\\012update events set entity_type = 'SPACE' where entity_type = 'GROUP';\\012\\012ALTER TABLE events ADD CONSTRAINT evnt_et_enum_ck CHECK \\012\\011(entity_type IN ('ATTACHMENT', 'DATASET', 'EXPERIMENT', 'SPACE', 'MATERIAL', 'PROJECT', 'PROPERTY_TYPE', 'SAMPLE', 'VOCABULARY', 'AUTHORIZATION_GROUP')); \\012\\012ALTER TABLE persons\\012\\011DROP CONSTRAINT pers_grou_fk;\\012\\012ALTER TABLE persons\\012\\011ADD CONSTRAINT pers_space_fk FOREIGN KEY (space_id) REFERENCES spaces(id);\\012\\012ALTER TABLE projects\\012\\011DROP CONSTRAINT proj_bk_uk;\\012\\012ALTER TABLE projects\\012\\011DROP CONSTRAINT proj_grou_fk;\\012\\012ALTER TABLE projects\\012\\011ADD CONSTRAINT proj_bk_uk UNIQUE (code, space_id);\\012\\012ALTER TABLE projects\\012\\011ADD CONSTRAINT proj_space_fk FOREIGN KEY (space_id) REFERENCES spaces(id);\\012\\012ALTER TABLE role_assignments\\012\\011DROP CONSTRAINT roas_dbin_grou_arc_ck;\\012\\012ALTER TABLE role_assignments\\012\\011DROP CONSTRAINT roas_ag_group_bk_uk;\\012\\012ALTER TABLE role_assignments\\012\\011DROP CONSTRAINT roas_pe_group_bk_uk;\\012\\012ALTER TABLE role_assignments\\012\\011DROP CONSTRAINT roas_grou_fk;\\012\\012ALTER TABLE role_assignments\\012\\011ADD CONSTRAINT roas_dbin_space_arc_ck CHECK ((((dbin_id IS NOT NULL) AND (space_id IS NULL)) OR ((dbin_id IS NULL) AND (space_id IS NOT NULL))));\\012\\012ALTER TABLE role_assignments\\012\\011ADD CONSTRAINT roas_ag_space_bk_uk UNIQUE (ag_id_grantee, role_code, space_id);\\012\\012ALTER TABLE role_assignments\\012\\011ADD CONSTRAINT roas_pe_space_bk_uk UNIQUE (pers_id_grantee, role_code, space_id);\\012\\012ALTER TABLE role_assignments\\012\\011ADD CONSTRAINT roas_space_fk FOREIGN KEY (space_id) REFERENCES spaces(id);\\012\\012ALTER TABLE samples\\012\\011DROP CONSTRAINT samp_dbin_grou_arc_ck;\\012\\012ALTER TABLE samples\\012\\011DROP CONSTRAINT samp_grou_fk;\\012\\012ALTER TABLE samples\\012\\011ADD CONSTRAINT samp_dbin_space_arc_ck CHECK ((((dbin_id IS NOT NULL) AND (space_id IS NULL)) OR ((dbin_id IS NULL) AND (space_id IS NOT NULL))));\\012\\012ALTER TABLE samples\\012\\011ADD CONSTRAINT samp_space_fk FOREIGN KEY (space_id) REFERENCES spaces(id);\\012\\012ALTER TABLE spaces\\012  DROP CONSTRAINT grou_bk_uk,\\012  ADD CONSTRAINT space_bk_uk UNIQUE (code, dbin_id);\\012\\012ALTER TABLE spaces\\012  DROP CONSTRAINT grou_dbin_fk,\\012  ADD CONSTRAINT space_dbin_fk FOREIGN KEY (dbin_id) REFERENCES database_instances(id);\\012\\012ALTER TABLE spaces\\012  DROP CONSTRAINT grou_pers_fk_registerer,\\012  ADD CONSTRAINT space_pers_fk_registerer FOREIGN KEY (pers_id_registerer) REFERENCES persons(id);\\012\\012ALTER INDEX pers_grou_fk_i RENAME TO pers_space_fk_i;\\012\\012ALTER INDEX proj_grou_fk_i RENAME TO proj_space_fk_i;\\012\\012ALTER INDEX roas_grou_fk_i RENAME TO roas_space_fk_i;\\012\\012ALTER INDEX grou_pk RENAME TO space_pk;\\012\\012ALTER INDEX grou_dbin_fk_i RENAME TO space_dbin_fk_i;\\012\\012ALTER INDEX grou_pers_registered_by_fk_i RENAME TO space_pers_registered_by_fk_i;\\012\\012	\N
+./sourceTest/sql/postgresql/064/.svn/text-base/schema-064.sql.svn-base:    LANGUAGE plpgsql
+./sourceTest/sql/postgresql/064/.svn/text-base/schema-064.sql.svn-base:    LANGUAGE plpgsql
+./sourceTest/sql/postgresql/064/.svn/text-base/schema-064.sql.svn-base:    LANGUAGE plpgsql
+./sourceTest/sql/postgresql/064/.svn/text-base/schema-064.sql.svn-base:    LANGUAGE plpgsql
+./sourceTest/sql/postgresql/064/.svn/text-base/schema-064.sql.svn-base:    LANGUAGE plpgsql
+./sourceTest/sql/postgresql/064/.svn/text-base/schema-064.sql.svn-base:    LANGUAGE plpgsql
+./sourceTest/sql/postgresql/064/.svn/text-base/schema-064.sql.svn-base:    LANGUAGE plpgsql
+./sourceTest/sql/postgresql/064/.svn/text-base/schema-064.sql.svn-base:    LANGUAGE plpgsql
+./sourceTest/sql/postgresql/064/.svn/text-base/schema-064.sql.svn-base:    LANGUAGE plpgsql
+./sourceTest/sql/postgresql/064/017=database_version_logs.tsv:027	D:\\User\\felmer\\dev-workspace\\openbis/source/sql/postgresql/027/function-027.sql	SUCCESS	2008-11-05 09:18:00.403	-- Creating Functions\\012\\012------------------------------------------------------------------------------------\\012--  Purpose:  Create function RENAME_SEQUENCE() that is required for renaming the sequences belonging to tables\\012------------------------------------------------------------------------------------\\012CREATE FUNCTION RENAME_SEQUENCE(OLD_NAME VARCHAR, NEW_NAME VARCHAR) RETURNS INTEGER AS $$\\012DECLARE\\012  CURR_SEQ_VAL   INTEGER;\\012BEGIN\\012  SELECT INTO CURR_SEQ_VAL NEXTVAL(OLD_NAME);\\012  EXECUTE 'CREATE SEQUENCE ' || NEW_NAME || ' START WITH ' || CURR_SEQ_VAL;\\012  EXECUTE 'DROP SEQUENCE ' || OLD_NAME;\\012  RETURN CURR_SEQ_VAL;\\012END;\\012$$ LANGUAGE 'plpgsql';\\012\\012\\012------------------------------------------------------------------------------------\\012--  Purpose:  Create trigger CONTROLLED_VOCABULARY_CHECK \\012------------------------------------------------------------------------------------\\012\\012CREATE OR REPLACE FUNCTION CONTROLLED_VOCABULARY_CHECK() RETURNS trigger AS $$\\012DECLARE\\012   v_code  CODE;\\012BEGIN\\012\\012   select code into v_code from data_types where id = NEW.daty_id;\\012\\012   -- Check if the data is of type "CONTROLLEDVOCABULARY"\\012   if v_code = 'CONTROLLEDVOCABULARY' then\\012      if NEW.covo_id IS NULL then\\012         RAISE EXCEPTION 'Insert/Update of Property Type (Code: %) failed, as its Data Type is CONTROLLEDVOCABULARY, but it is not linked to a Controlled Vocabulary.', NEW.code;\\012      end if;\\012   end if;\\012\\012   RETURN NEW;\\012\\012END;\\012$$ LANGUAGE 'plpgsql';\\012\\012CREATE TRIGGER CONTROLLED_VOCABULARY_CHECK BEFORE INSERT OR UPDATE ON PROPERTY_TYPES\\012    FOR EACH ROW EXECUTE PROCEDURE CONTROLLED_VOCABULARY_CHECK();\\012\\012\\012------------------------------------------------------------------------------------\\012--  Purpose:  Create trigger EXTERNAL_DATA_STORAGE_FORMAT_CHECK \\012------------------------------------------------------------------------------------\\012\\012CREATE OR REPLACE FUNCTION EXTERNAL_DATA_STORAGE_FORMAT_CHECK() RETURNS trigger AS $$\\012DECLARE\\012   v_covo_code  CODE;\\012   data_code CODE;\\012BEGIN\\012\\012   select code into v_covo_code from controlled_vocabularies\\012      where is_internal_namespace = true and \\012         id = (select covo_id from controlled_vocabulary_terms where id = NEW.cvte_id_stor_fmt);\\012   -- Check if the data storage format is a term of the controlled vocabulary "STORAGE_FORMAT"\\012   if v_covo_code != 'STORAGE_FORMAT' then\\012      select code into data_code from data where id = NEW.data_id; \\012      RAISE EXCEPTION 'Insert/Update of Data (Code: %) failed, as its Storage Format is %, but is required to be STORAGE_FORMAT.', data_code, v_covo_code;\\012   end if;\\012\\012   RETURN NEW;\\012\\012END;\\012$$ LANGUAGE 'plpgsql';\\012\\012CREATE TRIGGER EXTERNAL_DATA_STORAGE_FORMAT_CHECK BEFORE INSERT OR UPDATE ON EXTERNAL_DATA\\012    FOR EACH ROW EXECUTE PROCEDURE EXTERNAL_DATA_STORAGE_FORMAT_CHECK();\\012\\012------------------------------------------------------------------------------------\\012--  Purpose:  Create trigger SAMPLE_CODE_UNIQUENESS_CHECK \\012------------------------------------------------------------------------------------\\012\\012CREATE OR REPLACE FUNCTION SAMPLE_CODE_UNIQUENESS_CHECK() RETURNS trigger AS $$\\012DECLARE\\012   counter  INTEGER;\\012BEGIN\\012\\011IF (NEW.samp_id_part_of is NULL) THEN\\012\\011\\011IF (NEW.dbin_id is not NULL) THEN\\012\\011\\011\\011SELECT count(*) into counter FROM samples \\012\\011\\011\\011\\011where id != NEW.id and code = NEW.code and samp_id_part_of is NULL and dbin_id = NEW.dbin_id;\\012\\011\\011\\011IF (counter > 0) THEN\\012\\011\\011\\011\\011RAISE EXCEPTION 'Insert/Update of Sample (Code: %) failed because database instance sample with the same code already exists.', NEW.code;\\012\\011\\011\\011END IF;\\012\\011\\011ELSIF (NEW.grou_id is not NULL) THEN\\012\\011\\011\\011SELECT count(*) into counter FROM samples \\012\\011\\011\\011\\011where id != NEW.id and code = NEW.code and samp_id_part_of is NULL and grou_id = NEW.grou_id;\\012\\011\\011\\011IF (counter > 0) THEN\\012\\011\\011\\011\\011RAISE EXCEPTION 'Insert/Update of Sample (Code: %) failed because group sample with the same code already exists.', NEW.code;\\012\\011\\011\\011END IF;\\012\\011\\011END IF;\\012        ELSE\\012\\011\\011IF (NEW.dbin_id is not NULL) THEN\\012\\011\\011\\011SELECT count(*) into counter FROM samples \\012\\011\\011\\011\\011where id != NEW.id and code = NEW.code and samp_id_part_of = NEW.samp_id_part_of and dbin_id = NEW.dbin_id;\\012\\011\\011\\011IF (counter > 0) THEN\\012\\011\\011\\011\\011RAISE EXCEPTION 'Insert/Update of Sample (Code: %) failed because database instance sample with the same code and being the part of the same parent already exists.', NEW.code;\\012\\011\\011\\011END IF;\\012\\011\\011ELSIF (NEW.grou_id is not NULL) THEN\\012\\011\\011\\011SELECT count(*) into counter FROM samples \\012\\011\\011\\011\\011where id != NEW.id and code = NEW.code and samp_id_part_of = NEW.samp_id_part_of and grou_id = NEW.grou_id;\\012\\011\\011\\011IF (counter > 0) THEN\\012\\011\\011\\011\\011RAISE EXCEPTION 'Insert/Update of Sample (Code: %) failed because group sample with the same code and being the part of the same parent already exists.', NEW.code;\\012\\011\\011\\011END IF;\\012\\011\\011END IF;\\012        END IF;   \\012   RETURN NEW;\\012END;\\012$$ LANGUAGE 'plpgsql';\\012\\012CREATE TRIGGER SAMPLE_CODE_UNIQUENESS_CHECK BEFORE INSERT OR UPDATE ON SAMPLES\\012    FOR EACH ROW EXECUTE PROCEDURE SAMPLE_CODE_UNIQUENESS_CHECK();\\012	\N
+./sourceTest/sql/postgresql/064/017=database_version_logs.tsv:028	source/sql/postgresql/migration/migration-027-028.sql	SUCCESS	2008-11-18 13:24:17.508	-- Create EXPERIMENT_ATTACHMENT_CONTENTS.\\012CREATE TABLE EXPERIMENT_ATTACHMENT_CONTENTS (ID TECH_ID NOT NULL,VALUE FILE NOT NULL);\\012CREATE SEQUENCE EXPERIMENT_ATTACHMENT_CONTENT_ID_SEQ;\\012ALTER TABLE EXPERIMENT_ATTACHMENT_CONTENTS ADD CONSTRAINT EXAC_PK PRIMARY KEY(ID);\\012\\012-- Alter EXPERIMENT_ATTACHMENTS by adding the new column which has a NULL constraint.\\012-- The NOT NULL constraint is added later on.\\012ALTER TABLE EXPERIMENT_ATTACHMENTS ADD COLUMN EXAC_ID TECH_ID;\\012\\012-- Does the VALUE migration between EXPERIMENT_ATTACHMENTS to EXPERIMENT_ATTACHMENT_CONTENTS.\\012CREATE OR REPLACE FUNCTION move_exp_att_content() RETURNS integer AS $$\\012DECLARE\\012    rec RECORD;\\012    seq BIGINT;\\012BEGIN\\012  FOR rec IN SELECT id, value FROM EXPERIMENT_ATTACHMENTS LOOP\\012  \\011seq := nextval('EXPERIMENT_ATTACHMENT_CONTENT_ID_SEQ');\\012    INSERT INTO EXPERIMENT_ATTACHMENT_CONTENTS (id, value) VALUES (seq, rec.value);\\012    UPDATE EXPERIMENT_ATTACHMENTS SET exac_id = seq WHERE id = rec.id;\\012  END LOOP;\\012  RETURN 1;\\012END;\\012$$ LANGUAGE 'plpgsql';\\012\\012-- Call the function.\\012SELECT move_exp_att_content();\\012DROP FUNCTION move_exp_att_content();\\012\\012\\012-- Finish EXPERIMENT_ATTACHMENTS changes.\\012ALTER TABLE EXPERIMENT_ATTACHMENTS ADD CONSTRAINT EXAT_CONT_FK FOREIGN KEY (EXAC_ID) REFERENCES EXPERIMENT_ATTACHMENT_CONTENTS(ID);\\012ALTER TABLE EXPERIMENT_ATTACHMENTS DROP COLUMN VALUE;\\012ALTER TABLE EXPERIMENT_ATTACHMENTS ALTER COLUMN EXAC_ID SET NOT NULL;\\012	\N
+./sourceTest/sql/postgresql/064/017=database_version_logs.tsv:029	source/sql/postgresql/migration/migration-028-029.sql	SUCCESS	2009-03-18 10:50:20.105	-- -------\\012-- add modification_timestamp field to allow edition with Hibernate\\012-- -------\\012\\012ALTER TABLE samples\\012\\011ADD COLUMN modification_timestamp TIME_STAMP DEFAULT CURRENT_TIMESTAMP;\\012\\012ALTER TABLE experiments\\012\\011ADD COLUMN modification_timestamp TIME_STAMP DEFAULT CURRENT_TIMESTAMP;\\012\\012ALTER TABLE materials\\012\\011ADD COLUMN modification_timestamp TIME_STAMP DEFAULT CURRENT_TIMESTAMP;\\012\\012ALTER TABLE experiment_properties\\012\\011ADD COLUMN modification_timestamp TIME_STAMP DEFAULT CURRENT_TIMESTAMP;\\012\\012ALTER TABLE material_properties\\012\\011ADD COLUMN modification_timestamp TIME_STAMP DEFAULT CURRENT_TIMESTAMP;\\012\\012ALTER TABLE sample_properties\\012\\011ADD COLUMN modification_timestamp TIME_STAMP DEFAULT CURRENT_TIMESTAMP;\\012\\012-- -------\\012-- add property data type which references materials\\012-- -------\\012\\012ALTER TABLE property_types\\012\\011ADD COLUMN maty_prop_id tech_id;\\012\\012ALTER TABLE property_types\\012\\011ADD CONSTRAINT prty_maty_fk FOREIGN KEY (maty_prop_id) REFERENCES material_types(id);\\012\\012ALTER TABLE experiment_properties\\012\\011ADD COLUMN mate_prop_id tech_id;\\012\\012ALTER TABLE material_properties\\012\\011ADD COLUMN mate_prop_id tech_id;\\012\\012ALTER TABLE sample_properties\\012\\011ADD COLUMN mate_prop_id tech_id;\\012\\012ALTER TABLE experiment_properties\\012\\011ADD CONSTRAINT expr_mapr_fk FOREIGN KEY (mate_prop_id) REFERENCES materials(id);\\012\\012ALTER TABLE material_properties\\012\\011ADD CONSTRAINT mapr_mapr_fk FOREIGN KEY (mate_prop_id) REFERENCES materials(id);\\012\\012ALTER TABLE sample_properties\\012\\011ADD CONSTRAINT sapr_mapr_fk FOREIGN KEY (mate_prop_id) REFERENCES materials(id);\\012\\012insert into data_types\\012(id\\012 ,code\\012 ,description)\\012 values \\012 (nextval('DATA_TYPE_ID_SEQ')\\012 ,'MATERIAL'\\012 ,'Reference to a material'\\012);\\012\\012ALTER TABLE MATERIAL_PROPERTIES DROP CONSTRAINT MAPR_CK;\\012ALTER TABLE MATERIAL_PROPERTIES ADD CONSTRAINT MAPR_CK CHECK \\012\\011((VALUE IS NOT NULL AND CVTE_ID IS NULL AND MATE_PROP_ID IS NULL) OR \\012\\011 (VALUE IS NULL AND CVTE_ID IS NOT NULL AND MATE_PROP_ID IS NULL) OR\\012\\011 (VALUE IS NULL AND CVTE_ID IS NULL AND MATE_PROP_ID IS NOT NULL)\\012\\011);\\012\\012ALTER TABLE EXPERIMENT_PROPERTIES DROP CONSTRAINT EXPR_CK;\\012ALTER TABLE EXPERIMENT_PROPERTIES ADD CONSTRAINT EXPR_CK CHECK \\012\\011((VALUE IS NOT NULL AND CVTE_ID IS NULL AND MATE_PROP_ID IS NULL) OR \\012\\011 (VALUE IS NULL AND CVTE_ID IS NOT NULL AND MATE_PROP_ID IS NULL) OR\\012\\011 (VALUE IS NULL AND CVTE_ID IS NULL AND MATE_PROP_ID IS NOT NULL)\\012\\011);\\012\\012ALTER TABLE SAMPLE_PROPERTIES DROP CONSTRAINT SAPR_CK;\\012ALTER TABLE SAMPLE_PROPERTIES ADD CONSTRAINT SAPR_CK CHECK \\012\\011((VALUE IS NOT NULL AND CVTE_ID IS NULL AND MATE_PROP_ID IS NULL) OR \\012\\011 (VALUE IS NULL AND CVTE_ID IS NOT NULL AND MATE_PROP_ID IS NULL) OR\\012\\011 (VALUE IS NULL AND CVTE_ID IS NULL AND MATE_PROP_ID IS NOT NULL)\\012\\011);\\012\\012------------------------------------------------------------------------------------\\012--  Purpose:  Create trigger MATERIAL/SAMPLE/EXPERIMENT _PROPERTY_WITH_MATERIAL_DATA_TYPE_CHECK\\012--            It checks that if material property value is assigned to the entity,\\012--\\011\\011\\011\\011\\011\\011then the material type is equal to the one described by property type.\\012------------------------------------------------------------------------------------\\012\\012CREATE OR REPLACE FUNCTION MATERIAL_PROPERTY_WITH_MATERIAL_DATA_TYPE_CHECK() RETURNS trigger AS $$\\012DECLARE\\012   v_type_id  CODE;\\012   v_type_id_prop  CODE;\\012BEGIN\\012   if NEW.mate_prop_id IS NOT NULL then\\012\\011\\011\\011-- find material type id of the property type \\012\\011\\011\\011select pt.maty_prop_id into v_type_id_prop \\012\\011\\011\\011  from material_type_property_types etpt, property_types pt \\012\\011\\011\\011 where NEW.mtpt_id = etpt.id AND etpt.prty_id = pt.id;\\012\\011\\011\\012\\011\\011\\011if v_type_id_prop IS NOT NULL then\\012\\011\\011\\011\\011-- find material type id of the material which consists the entity's property value\\012\\011\\011\\011\\011select entity.maty_id into v_type_id \\012\\011\\011\\011\\011  from materials entity\\012\\011\\011\\011\\011 where NEW.mate_prop_id = entity.id;\\012\\011\\011\\011\\011if v_type_id != v_type_id_prop then\\012\\011\\011\\011\\011\\011RAISE EXCEPTION 'Insert/Update of property value referencing material (id: %) failed, as referenced material type is different than expected (id %, expected id: %).', \\012\\011\\011\\011\\011\\011\\011\\011 NEW.mate_prop_id, v_type_id, v_type_id_prop;\\012\\011\\011\\011\\011end if;\\012\\011\\011\\011end if;\\012   end if;\\012   RETURN NEW;\\012END;\\012$$ LANGUAGE 'plpgsql';\\012\\012CREATE TRIGGER MATERIAL_PROPERTY_WITH_MATERIAL_DATA_TYPE_CHECK BEFORE INSERT OR UPDATE ON material_properties\\012    FOR EACH ROW EXECUTE PROCEDURE MATERIAL_PROPERTY_WITH_MATERIAL_DATA_TYPE_CHECK();\\012    \\012CREATE OR REPLACE FUNCTION SAMPLE_PROPERTY_WITH_MATERIAL_DATA_TYPE_CHECK() RETURNS trigger AS $$\\012DECLARE\\012   v_type_id  CODE;\\012   v_type_id_prop  CODE;\\012BEGIN\\012   if NEW.mate_prop_id IS NOT NULL then\\012\\011\\011\\011-- find material type id of the property type \\012\\011\\011\\011select pt.maty_prop_id into v_type_id_prop \\012\\011\\011\\011  from sample_type_property_types etpt, property_types pt \\012\\011\\011\\011 where NEW.stpt_id = etpt.id AND etpt.prty_id = pt.id;\\012\\011\\011\\012\\011\\011\\011if v_type_id_prop IS NOT NULL then\\012\\011\\011\\011\\011-- find material type id of the material which consists the entity's property value\\012\\011\\011\\011\\011select entity.maty_id into v_type_id \\012\\011\\011\\011\\011  from materials entity\\012\\011\\011\\011\\011 where NEW.mate_prop_id = entity.id;\\012\\011\\011\\011\\011if v_type_id != v_type_id_prop then\\012\\011\\011\\011\\011\\011RAISE EXCEPTION 'Insert/Update of property value referencing material (id: %) failed, as referenced material type is different than expected (id %, expected id: %).', \\012\\011\\011\\011\\011\\011\\011\\011\\011\\011\\011\\011\\011 NEW.mate_prop_id, v_type_id, v_type_id_prop;\\012\\011\\011\\011\\011end if;\\012\\011\\011\\011end if;\\012   end if;\\012   RETURN NEW;\\012END;\\012$$ LANGUAGE 'plpgsql';\\012\\012CREATE TRIGGER SAMPLE_PROPERTY_WITH_MATERIAL_DATA_TYPE_CHECK BEFORE INSERT OR UPDATE ON sample_properties\\012    FOR EACH ROW EXECUTE PROCEDURE SAMPLE_PROPERTY_WITH_MATERIAL_DATA_TYPE_CHECK();\\012    \\012CREATE OR REPLACE FUNCTION EXPERIMENT_PROPERTY_WITH_MATERIAL_DATA_TYPE_CHECK() RETURNS trigger AS $$\\012DECLARE\\012   v_type_id  CODE;\\012   v_type_id_prop  CODE;\\012BEGIN\\012   if NEW.mate_prop_id IS NOT NULL then\\012\\011\\011\\011-- find material type id of the property type \\012\\011\\011\\011select pt.maty_prop_id into v_type_id_prop \\012\\011\\011\\011  from experiment_type_property_types etpt, property_types pt \\012\\011\\011\\011 where NEW.etpt_id = etpt.id AND etpt.prty_id = pt.id;\\012\\011\\011\\012\\011\\011\\011if v_type_id_prop IS NOT NULL then\\012\\011\\011\\011\\011-- find material type id of the material which consists the entity's property value\\012\\011\\011\\011\\011select entity.maty_id into v_type_id \\012\\011\\011\\011\\011  from materials entity\\012\\011\\011\\011\\011 where NEW.mate_prop_id = entity.id;\\012\\011\\011\\011\\011if v_type_id != v_type_id_prop then\\012\\011\\011\\011\\011\\011RAISE EXCEPTION 'Insert/Update of property value referencing material (id: %) failed, as referenced material type is different than expected (id %, expected id: %).', \\012\\011\\011\\011\\011\\011\\011\\011\\011\\011\\011\\011\\011 NEW.mate_prop_id, v_type_id, v_type_id_prop;\\012\\011\\011\\011\\011end if;\\012\\011\\011\\011end if;\\012   end if;\\012   RETURN NEW;\\012END;\\012$$ LANGUAGE 'plpgsql';\\012\\012CREATE TRIGGER EXPERIMENT_PROPERTY_WITH_MATERIAL_DATA_TYPE_CHECK BEFORE INSERT OR UPDATE ON experiment_properties\\012    FOR EACH ROW EXECUTE PROCEDURE EXPERIMENT_PROPERTY_WITH_MATERIAL_DATA_TYPE_CHECK();\\012       \\012-- -------\\012-- remove the reminescents of the OBSERVABLE_TYPE\\012-- -------\\012\\012ALTER TABLE data\\012\\011DROP CONSTRAINT data_obty_fk;\\012\\012ALTER TABLE data_set_types\\012\\011DROP CONSTRAINT obty_pk;\\012\\012ALTER TABLE data_set_types\\012\\011ADD CONSTRAINT dsty_pk PRIMARY KEY (id);\\012\\012ALTER TABLE data\\012\\011ADD CONSTRAINT data_dsty_fk FOREIGN KEY (dsty_id) REFERENCES data_set_types(id);\\012\\012ALTER TABLE data_set_types\\012\\011DROP CONSTRAINT obty_bk_uk;\\012\\012ALTER TABLE data_set_types\\012\\011DROP CONSTRAINT obty_dbin_fk;\\012\\012ALTER TABLE data_set_types\\012\\011ADD CONSTRAINT dsty_bk_uk UNIQUE (code, dbin_id);\\012\\012ALTER TABLE data_set_types\\012\\011ADD CONSTRAINT dsty_dbin_fk FOREIGN KEY (dbin_id) REFERENCES database_instances(id);\\012\\012DROP INDEX data_obty_fk_i;\\012\\012CREATE INDEX data_dsty_fk_i ON data(dsty_id);\\012	\N
+./sourceTest/sql/postgresql/064/017=database_version_logs.tsv:030	source/sql/postgresql/migration/migration-029-030.sql	SUCCESS	2009-03-23 15:34:44.72	-- -------\\012-- add modification_timestamp field to allow edition with Hibernate\\012-- -------\\012ALTER TABLE data\\012\\011ADD COLUMN modification_timestamp TIME_STAMP DEFAULT CURRENT_TIMESTAMP;\\012ALTER TABLE experiment_types\\012\\011ADD COLUMN modification_timestamp TIME_STAMP DEFAULT CURRENT_TIMESTAMP;\\012ALTER TABLE sample_types\\012\\011ADD COLUMN modification_timestamp TIME_STAMP DEFAULT CURRENT_TIMESTAMP;\\012ALTER TABLE material_types\\012\\011ADD COLUMN modification_timestamp TIME_STAMP DEFAULT CURRENT_TIMESTAMP;\\012ALTER TABLE data_set_types\\012\\011ADD COLUMN modification_timestamp TIME_STAMP DEFAULT CURRENT_TIMESTAMP;\\012ALTER TABLE controlled_vocabularies\\012\\011ADD COLUMN modification_timestamp TIME_STAMP DEFAULT CURRENT_TIMESTAMP;\\012-- -------\\012-- add properties to data sets\\012-- -------\\012CREATE TABLE DATA_SET_PROPERTIES (ID TECH_ID NOT NULL,DS_ID TECH_ID NOT NULL,DSTPT_ID TECH_ID NOT NULL,VALUE GENERIC_VALUE,CVTE_ID TECH_ID, MATE_PROP_ID TECH_ID, PERS_ID_REGISTERER TECH_ID NOT NULL,REGISTRATION_TIMESTAMP TIME_STAMP_DFL NOT NULL DEFAULT CURRENT_TIMESTAMP, MODIFICATION_TIMESTAMP TIME_STAMP DEFAULT CURRENT_TIMESTAMP);\\012CREATE TABLE DATA_SET_TYPE_PROPERTY_TYPES (ID TECH_ID NOT NULL,DSTY_ID TECH_ID NOT NULL,PRTY_ID TECH_ID NOT NULL,IS_MANDATORY BOOLEAN_CHAR NOT NULL DEFAULT 'F',IS_MANAGED_INTERNALLY BOOLEAN_CHAR NOT NULL DEFAULT 'F',PERS_ID_REGISTERER TECH_ID NOT NULL,REGISTRATION_TIMESTAMP TIME_STAMP_DFL NOT NULL DEFAULT CURRENT_TIMESTAMP);\\012\\012CREATE SEQUENCE DATA_SET_PROPERTY_ID_SEQ;\\012CREATE SEQUENCE DSTPT_ID_SEQ;\\012\\012ALTER TABLE DATA_SET_TYPE_PROPERTY_TYPES ADD CONSTRAINT DSTPT_PK PRIMARY KEY(ID);\\012ALTER TABLE DATA_SET_PROPERTIES ADD CONSTRAINT DSPR_PK PRIMARY KEY(ID);\\012\\012ALTER TABLE DATA_SET_TYPE_PROPERTY_TYPES ADD CONSTRAINT DSTPT_BK_UK UNIQUE(DSTY_ID,PRTY_ID);\\012ALTER TABLE DATA_SET_PROPERTIES ADD CONSTRAINT DSPR_BK_UK UNIQUE(DS_ID,DSTPT_ID);\\012\\012\\012ALTER TABLE DATA_SET_TYPE_PROPERTY_TYPES ADD CONSTRAINT DSTPT_DSTY_FK FOREIGN KEY (DSTY_ID) REFERENCES DATA_SET_TYPES(ID);\\012ALTER TABLE DATA_SET_TYPE_PROPERTY_TYPES ADD CONSTRAINT DSTPT_PERS_FK FOREIGN KEY (PERS_ID_REGISTERER) REFERENCES PERSONS(ID);\\012ALTER TABLE DATA_SET_TYPE_PROPERTY_TYPES ADD CONSTRAINT DSTPT_PRTY_FK FOREIGN KEY (PRTY_ID) REFERENCES PROPERTY_TYPES(ID);\\012ALTER TABLE DATA_SET_PROPERTIES ADD CONSTRAINT DSPR_CVTE_FK FOREIGN KEY (CVTE_ID) REFERENCES CONTROLLED_VOCABULARY_TERMS(ID);\\012ALTER TABLE DATA_SET_PROPERTIES ADD CONSTRAINT DSPR_DSTPT_FK FOREIGN KEY (DSTPT_ID) REFERENCES DATA_SET_TYPE_PROPERTY_TYPES(ID) ON DELETE CASCADE;\\012ALTER TABLE DATA_SET_PROPERTIES ADD CONSTRAINT DSPR_DS_FK FOREIGN KEY (DS_ID) REFERENCES DATA(ID);\\012ALTER TABLE DATA_SET_PROPERTIES ADD CONSTRAINT DSPR_PERS_FK FOREIGN KEY (PERS_ID_REGISTERER) REFERENCES PERSONS(ID);\\012ALTER TABLE DATA_SET_PROPERTIES ADD CONSTRAINT DSPR_MAPR_FK FOREIGN KEY (MATE_PROP_ID) REFERENCES MATERIALS(ID);\\012\\012ALTER TABLE DATA_SET_PROPERTIES ADD CONSTRAINT DSPR_CK CHECK \\012\\011((VALUE IS NOT NULL AND CVTE_ID IS NULL AND MATE_PROP_ID IS NULL) OR \\012\\011 (VALUE IS NULL AND CVTE_ID IS NOT NULL AND MATE_PROP_ID IS NULL) OR\\012\\011 (VALUE IS NULL AND CVTE_ID IS NULL AND MATE_PROP_ID IS NOT NULL)\\012\\011);\\012\\012CREATE INDEX DSPR_CVTE_FK_I ON DATA_SET_PROPERTIES (CVTE_ID);\\012CREATE INDEX DSPR_DSTPT_FK_I ON DATA_SET_PROPERTIES (DSTPT_ID);\\012CREATE INDEX DSPR_DS_FK_I ON DATA_SET_PROPERTIES (DS_ID);\\012CREATE INDEX DSPR_PERS_FK_I ON DATA_SET_PROPERTIES (PERS_ID_REGISTERER);\\012CREATE INDEX DSTPT_DSTY_FK_I ON DATA_SET_TYPE_PROPERTY_TYPES (DSTY_ID);\\012CREATE INDEX DSTPT_PERS_FK_I ON DATA_SET_TYPE_PROPERTY_TYPES (PERS_ID_REGISTERER);\\012CREATE INDEX DSTPT_PRTY_FK_I ON DATA_SET_TYPE_PROPERTY_TYPES (PRTY_ID);\\012\\012CREATE OR REPLACE FUNCTION DATA_SET_PROPERTY_WITH_MATERIAL_DATA_TYPE_CHECK() RETURNS trigger AS $$\\012DECLARE\\012   v_type_id  CODE;\\012   v_type_id_prop  CODE;\\012BEGIN\\012   if NEW.mate_prop_id IS NOT NULL then\\012\\011\\011\\011-- find material type id of the property type \\012\\011\\011\\011select pt.maty_prop_id into v_type_id_prop \\012\\011\\011\\011  from data_set_type_property_types dstpt, property_types pt \\012\\011\\011\\011 where NEW.dstpt_id = dstpt.id AND dstpt.prty_id = pt.id;\\012\\011\\011\\012\\011\\011\\011if v_type_id_prop IS NOT NULL then\\012\\011\\011\\011\\011-- find material type id of the material which consists the entity's property value\\012\\011\\011\\011\\011select entity.maty_id into v_type_id \\012\\011\\011\\011\\011  from materials entity\\012\\011\\011\\011\\011 where NEW.mate_prop_id = entity.id;\\012\\011\\011\\011\\011if v_type_id != v_type_id_prop then\\012\\011\\011\\011\\011\\011RAISE EXCEPTION 'Insert/Update of property value referencing material (id: %) failed, as referenced material type is different than expected (id %, expected id: %).', \\012\\011\\011\\011\\011\\011\\011\\011\\011\\011\\011\\011\\011 NEW.mate_prop_id, v_type_id, v_type_id_prop;\\012\\011\\011\\011\\011end if;\\012\\011\\011\\011end if;\\012   end if;\\012   RETURN NEW;\\012END;\\012$$ LANGUAGE 'plpgsql';\\012\\012CREATE TRIGGER DATA_SET_PROPERTY_WITH_MATERIAL_DATA_TYPE_CHECK BEFORE INSERT OR UPDATE ON data_set_properties\\012    FOR EACH ROW EXECUTE PROCEDURE DATA_SET_PROPERTY_WITH_MATERIAL_DATA_TYPE_CHECK();   \\012	\N
+./sourceTest/sql/postgresql/064/017=database_version_logs.tsv:032	source/sql/postgresql/migration/migration-031-032.sql	SUCCESS	2009-04-09 09:36:36.2	-- -------\\012-- Modify MATERIAL_BATCHES\\012-- -------\\012\\012ALTER TABLE material_batches\\012    DROP COLUMN proc_id;\\012\\012-- -------\\012-- Modify SAMPLES\\012-- -------\\012\\012ALTER TABLE samples\\012    ADD COLUMN expe_id tech_id;\\012\\012ALTER TABLE samples\\012    ADD CONSTRAINT samp_expe_fk FOREIGN KEY (expe_id) REFERENCES experiments(id);\\012\\012CREATE INDEX samp_expe_fk_i ON samples USING btree (expe_id);\\012\\012-- relink samples directly to experiments\\012\\012UPDATE samples\\012SET expe_id = (SELECT e.id FROM experiments e, procedures p, sample_inputs si \\012               WHERE si.samp_id = samples.id AND si.proc_id = p.id AND p.expe_id = e.id AND e.inva_id IS NULL);\\012\\012\\012-- -------\\012-- Modify DATA\\012-- -------\\012\\012ALTER TABLE data\\012    ADD COLUMN expe_id tech_id;\\012\\012ALTER TABLE data\\012    ADD CONSTRAINT data_expe_fk FOREIGN KEY (expe_id) REFERENCES experiments(id);\\012\\012CREATE INDEX data_expe_fk_i ON data USING btree (expe_id);\\012\\012UPDATE data\\012SET expe_id = (SELECT e.id FROM experiments e, procedures p \\012               WHERE data.proc_id_produced_by = p.id AND p.expe_id = e.id);\\012\\012ALTER TABLE data\\012    ALTER COLUMN expe_id SET NOT NULL;\\012\\012ALTER TABLE data\\012    DROP COLUMN proc_id_produced_by;\\012\\012-- -------\\012-- Drop PROCEDURES, PROCEDURE_TYPES, and SAMPLE_INPUTS\\012-- -------\\012\\012DROP TABLE sample_inputs;\\012DROP TABLE procedures;\\012DROP TABLE procedure_types;\\012\\012DROP SEQUENCE procedure_id_seq;\\012DROP SEQUENCE procedure_type_id_seq;\\012\\012-- -------\\012-- Add CODE_SEQ\\012-- -------\\012\\012CREATE SEQUENCE CODE_SEQ;\\012\\012-- -------\\012-- Add new columns to DATA_STORES\\012-- -------\\012\\012ALTER TABLE data_stores\\012    ADD COLUMN remote_url character varying(250),\\012    ADD COLUMN session_token character varying(50),\\012    ADD COLUMN modification_timestamp time_stamp DEFAULT now();\\012\\012UPDATE data_stores\\012SET remote_url = '', session_token='';\\012\\012ALTER TABLE data_stores\\012    ALTER COLUMN remote_url SET NOT NULL,\\012    ALTER COLUMN session_token SET NOT NULL;\\012\\012-- -------\\012-- Drop foreign keys onto DATA_STORES\\012-- -------\\012\\012ALTER TABLE database_instances\\012    DROP COLUMN dast_id;\\012\\012ALTER TABLE groups\\012    DROP COLUMN dast_id;\\012\\012ALTER TABLE projects\\012    DROP COLUMN dast_id;\\012\\012ALTER TABLE experiments\\012    DROP COLUMN dast_id;\\012\\012-- -------\\012-- Add foreign key from DATA onto DATA_STORES\\012-- -------\\012\\012ALTER TABLE data\\012    ADD COLUMN dast_id tech_id;\\012\\012ALTER TABLE data\\012    ADD CONSTRAINT data_dast_fk FOREIGN KEY (dast_id) REFERENCES data_stores(id);\\012\\012UPDATE data\\012SET dast_id = (select id from data_stores where code = 'STANDARD');\\012\\012ALTER TABLE data\\012    ALTER COLUMN dast_id SET NOT NULL;\\012\\012\\012------------------------------------------------------------------------------------\\012--  Purpose:  Replace trigger SAMPLE_CODE_UNIQUENESS_CHECK \\012------------------------------------------------------------------------------------\\012\\012CREATE OR REPLACE FUNCTION SAMPLE_CODE_UNIQUENESS_CHECK() RETURNS trigger AS $$\\012DECLARE\\012   counter  INTEGER;\\012BEGIN\\012    LOCK TABLE samples IN EXCLUSIVE MODE;\\012    IF (NEW.samp_id_part_of is NULL) THEN\\012        IF (NEW.dbin_id is not NULL) THEN\\012            SELECT count(*) into counter FROM samples \\012                where id != NEW.id and code = NEW.code and samp_id_part_of is NULL and dbin_id = NEW.dbin_id;\\012            IF (counter > 0) THEN\\012                RAISE EXCEPTION 'Insert/Update of Sample (Code: %) failed because database instance sample with the same code already exists.', NEW.code;\\012            END IF;\\012        ELSIF (NEW.grou_id is not NULL) THEN\\012            SELECT count(*) into counter FROM samples \\012                where id != NEW.id and code = NEW.code and samp_id_part_of is NULL and grou_id = NEW.grou_id;\\012            IF (counter > 0) THEN\\012                RAISE EXCEPTION 'Insert/Update of Sample (Code: %) failed because group sample with the same code already exists.', NEW.code;\\012            END IF;\\012        END IF;\\012        ELSE\\012        IF (NEW.dbin_id is not NULL) THEN\\012            SELECT count(*) into counter FROM samples \\012                where id != NEW.id and code = NEW.code and samp_id_part_of = NEW.samp_id_part_of and dbin_id = NEW.dbin_id;\\012            IF (counter > 0) THEN\\012                RAISE EXCEPTION 'Insert/Update of Sample (Code: %) failed because database instance sample with the same code and being the part of the same parent already exists.', NEW.code;\\012            END IF;\\012        ELSIF (NEW.grou_id is not NULL) THEN\\012            SELECT count(*) into counter FROM samples \\012                where id != NEW.id and code = NEW.code and samp_id_part_of = NEW.samp_id_part_of and grou_id = NEW.grou_id;\\012            IF (counter > 0) THEN\\012                RAISE EXCEPTION 'Insert/Update of Sample (Code: %) failed because group sample with the same code and being the part of the same parent already exists.', NEW.code;\\012            END IF;\\012        END IF;\\012        END IF;   \\012   RETURN NEW;\\012END;\\012$$ LANGUAGE 'plpgsql';\\012\\012\\012\\012	\N
+./sourceTest/sql/postgresql/064/017=database_version_logs.tsv:034	source/sql/postgresql/migration/migration-033-034.sql	SUCCESS	2009-05-26 08:32:49.935	------------------------------------------------------------------------------------\\012-- Create sequence for generating permanent identifiers starting with nextval of existing dataset sequence.\\012------------------------------------------------------------------------------------\\012CREATE FUNCTION CREATE_SEQUENCE(EXISTING_SEQUENCE VARCHAR, NEW_SEQUENCE VARCHAR) RETURNS VOID AS $$\\012DECLARE\\012  CURR_SEQ_VAL   INTEGER;\\012BEGIN\\012  SELECT INTO CURR_SEQ_VAL NEXTVAL(EXISTING_SEQUENCE);\\012  EXECUTE 'CREATE SEQUENCE ' || NEW_SEQUENCE || ' START WITH ' || CURR_SEQ_VAL;\\012  RETURN;\\012END;\\012$$ LANGUAGE 'plpgsql';\\012\\012SELECT CREATE_SEQUENCE('DATA_ID_SEQ', 'PERM_ID_SEQ');\\012DROP FUNCTION CREATE_SEQUENCE(VARCHAR, VARCHAR);\\012\\012------------------------------------------------------------------------------------\\012-- Add perm_id columns to samples and experiments.\\012------------------------------------------------------------------------------------\\012ALTER TABLE SAMPLES ADD COLUMN PERM_ID CODE;\\012ALTER TABLE EXPERIMENTS ADD COLUMN PERM_ID CODE;\\012\\012UPDATE SAMPLES SET PERM_ID = to_char(registration_timestamp,'YYYYMMDDHHSSMS') || '-' || NEXTVAL('PERM_ID_SEQ');\\012UPDATE EXPERIMENTS SET PERM_ID = to_char(registration_timestamp,'YYYYMMDDHHSSMS') || '-' || NEXTVAL('PERM_ID_SEQ');\\012ALTER TABLE SAMPLES ALTER COLUMN PERM_ID SET NOT NULL;\\012ALTER TABLE EXPERIMENTS ALTER COLUMN PERM_ID SET NOT NULL;\\012ALTER TABLE SAMPLES ADD CONSTRAINT SAMP_PI_UK UNIQUE(PERM_ID);\\012ALTER TABLE EXPERIMENTS ADD CONSTRAINT EXPE_PI_UK UNIQUE(PERM_ID);\\012\\012\\012------------------------------------------------------------------------------------\\012-- Add column is_chosen_from_list to controlled_vocabularies.\\012------------------------------------------------------------------------------------\\012ALTER TABLE controlled_vocabularies ADD COLUMN is_chosen_from_list BOOLEAN_CHAR NOT NULL DEFAULT TRUE;\\012ALTER TABLE controlled_vocabularies ADD COLUMN source_uri CHARACTER VARYING(250);\\012------------------------------------------------------------------------------------\\012-- Modify Data table - remove arc connection between Sample and Data table, use a flag instead\\012------------------------------------------------------------------------------------\\012\\012-- add new columns\\012\\012ALTER TABLE data\\012    ADD COLUMN is_derived boolean_char;\\012ALTER TABLE data\\012    ADD COLUMN samp_id tech_id;\\012\\012-- update values in new columns\\012\\012UPDATE data\\012    SET is_derived = (samp_id_derived_from IS NOT NULL); \\012UPDATE data\\012    SET samp_id = samp_id_derived_from \\012    WHERE is_derived = 'TRUE';\\012UPDATE data\\012    SET samp_id = samp_id_acquired_from \\012    WHERE is_derived = 'FALSE';\\012\\012-- add constraints and indexes to new columns\\012\\012ALTER TABLE data\\012    ALTER COLUMN is_derived SET NOT NULL;\\012ALTER TABLE data\\012    ALTER COLUMN samp_id SET NOT NULL;   \\012ALTER TABLE data\\012    ADD CONSTRAINT data_samp_fk FOREIGN KEY (samp_id) REFERENCES samples (id);\\012CREATE INDEX data_samp_fk_i ON data USING btree (samp_id);\\012\\012-- remove old columns\\012\\012ALTER TABLE data\\012    DROP COLUMN samp_id_acquired_from;\\012ALTER TABLE data\\012    DROP COLUMN samp_id_derived_from;\\012    \\012------------------------------------------------------------------------------------\\012-- Granting SELECT privilege to group openbis_readonly\\012------------------------------------------------------------------------------------\\012\\012GRANT SELECT ON SEQUENCE attachment_content_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE attachment_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE code_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE controlled_vocabulary_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE cvte_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE data_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE data_set_property_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE data_set_relationship_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE data_set_type_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE data_store_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE data_type_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE database_instance_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE dstpt_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE etpt_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE event_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE experiment_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE experiment_property_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE experiment_type_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE file_format_type_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE group_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE invalidation_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE locator_type_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE material_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE material_property_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE material_type_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE mtpt_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE perm_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE person_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE project_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE property_type_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE role_assignment_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE sample_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE sample_property_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE sample_type_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON SEQUENCE stpt_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE attachment_contents TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE attachments TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE controlled_vocabularies TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE controlled_vocabulary_terms TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE data TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE data_set_properties TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE data_set_relationships TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE data_set_type_property_types TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE data_set_types TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE data_stores TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE data_types TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE database_instances TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE database_version_logs TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE events TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE experiment_properties TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE experiment_type_property_types TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE experiment_types TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE experiments TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE external_data TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE file_format_types TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE groups TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE invalidations TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE locator_types TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE material_properties TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE material_type_property_types TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE material_types TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE materials TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE persons TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE projects TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE property_types TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE role_assignments TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE sample_properties TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE sample_type_property_types TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE sample_types TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE samples TO GROUP OPENBIS_READONLY;\\012\\012------------------------------------------------------------------------------------\\012-- Delete MATERIAL_BATCHES table\\012------------------------------------------------------------------------------------\\012\\012-- WARNING: Potential data lost!!!\\012-- WARNING: Potential data lost!!!\\012-- WARNING: Potential data lost!!!\\012\\012DROP TABLE SAMPLE_MATERIAL_BATCHES;\\012DROP TABLE MATERIAL_BATCHES;\\012DROP SEQUENCE MATERIAL_BATCH_ID_SEQ;\\012\\012------------------------------------------------------------------------------------\\012-- Delete MATE_ID_INHIBITOR_OF from table MATERIALS\\012------------------------------------------------------------------------------------\\012\\012-- WARNING: Potential data lost!!!\\012-- WARNING: Potential data lost!!!\\012-- WARNING: Potential data lost!!!\\012\\012ALTER TABLE MATERIALS DROP COLUMN MATE_ID_INHIBITOR_OF;\\012	\N
+./sourceTest/sql/postgresql/064/017=database_version_logs.tsv:041	source/sql/postgresql/migration/migration-040-041.sql	SUCCESS	2009-09-14 13:48:57.539	-- Create FILTERS table\\012\\012CREATE TABLE FILTERS (ID TECH_ID NOT NULL, DBIN_ID TECH_ID NOT NULL, NAME VARCHAR(200) NOT NULL, DESCRIPTION DESCRIPTION_1000,REGISTRATION_TIMESTAMP TIME_STAMP_DFL NOT NULL DEFAULT CURRENT_TIMESTAMP, PERS_ID_REGISTERER TECH_ID NOT NULL, MODIFICATION_TIMESTAMP TIME_STAMP DEFAULT CURRENT_TIMESTAMP, EXPRESSION VARCHAR(2000) NOT NULL, IS_PUBLIC BOOLEAN NOT NULL, GRID_ID VARCHAR(200) NOT NULL);\\012CREATE SEQUENCE FILTER_ID_SEQ;\\012ALTER TABLE FILTERS ADD CONSTRAINT FILT_PK PRIMARY KEY(ID);\\012ALTER TABLE FILTERS ADD CONSTRAINT FILT_BK_UK UNIQUE(NAME, DBIN_ID, GRID_ID);\\012ALTER TABLE FILTERS ADD CONSTRAINT FILT_PERS_FK FOREIGN KEY (PERS_ID_REGISTERER) REFERENCES PERSONS(ID);\\012ALTER TABLE FILTERS ADD CONSTRAINT FILT_DBIN_FK FOREIGN KEY (DBIN_ID) REFERENCES DATABASE_INSTANCES(ID);\\012CREATE INDEX FILT_PERS_FK_I ON FILTERS (PERS_ID_REGISTERER);\\012CREATE INDEX FILT_DBIN_FK_I ON FILTERS (DBIN_ID);\\012GRANT SELECT ON SEQUENCE filter_id_seq TO GROUP OPENBIS_READONLY;\\012GRANT SELECT ON TABLE filters TO GROUP OPENBIS_READONLY;\\012\\012-- Add missing foreign key to role assignments authorization group\\012ALTER TABLE ROLE_ASSIGNMENTS ADD CONSTRAINT ROAS_AG_FK_GRANTEE FOREIGN KEY (AG_ID_GRANTEE) REFERENCES AUTHORIZATION_GROUPS(ID);\\012\\012--------------------------------------------------------------------------------------------------\\012-- Modify dataset connections:\\012-- 1. connection with sample shouldn't be mandatory any more\\012-- 2. introduce an arc condition that dataset cannot be connected with a sample and a parent dataset at the same time\\012--------------------------------------------------------------------------------------------------\\012\\012-- Weaken data-sample connection constraint - allow dataset to have no connection with sample\\012ALTER TABLE data ALTER COLUMN samp_id DROP NOT NULL;\\012\\012-- Remove data-sample connection for datasets that have a parent\\012\\012UPDATE data \\012   SET samp_id = NULL \\012 WHERE id IN (SELECT DISTINCT data_id_child FROM data_set_relationships);\\012\\012-- With PostgreSQL 8.4 one can check that before migration there were no cycles in dataset relationships:\\012--\\012-- WITH RECURSIVE data_set_parents(id, parent_ids, cycle) AS (\\012--         SELECT  r.data_id_child AS id, \\012--                 ARRAY[CAST (r.data_id_parent AS bigint)] AS parent_ids, \\012--                 false AS cycle \\012--         FROM data_set_relationships r\\012--     UNION ALL\\012--         SELECT  r.data_id_child,\\012--                 CAST (r.data_id_parent AS bigint) || p.parent_ids,\\012--                 r.data_id_child = ANY(p.parent_ids)\\012--         FROM data_set_relationships r, data_set_parents p\\012--         WHERE r.data_id_parent = p.id AND NOT cycle\\012-- )\\012-- SELECT count(*) AS cycles FROM data_set_parents WHERE cycle = true;\\012\\012---------------------------------------------------------------------------------------------------\\012--  Purpose:  Create DEFERRED triggers:\\012--            * check_dataset_relationships_on_data_table_modification,\\012--            * check_dataset_relationships_on_relationships_table_modification.\\012--            They check that after all modifications of database (just before commit) \\012--            if 'data'/'data_set_relationships' tables are among modified tables \\012--            dataset is not connected with a sample and a parent dataset at the same time.\\012--            This connections are held in two different tables so simple immediate trigger \\012--            with arc check cannot be used and we need two deferred triggers.\\012----------------------------------------------------------------------------------------------------\\012\\012-- trigger for 'data' table\\012\\012CREATE OR REPLACE FUNCTION check_dataset_relationships_on_data_table_modification() RETURNS trigger AS $$\\012DECLARE\\012\\011counter\\011INTEGER;\\012BEGIN\\012\\011-- if there is a connection with a Sample there should not be any connection with a parent Data Set\\012\\011IF (NEW.samp_id IS NOT NULL) THEN\\012\\011\\011-- count number of parents\\012\\011\\011SELECT count(*) INTO counter \\012\\011\\011\\011FROM data_set_relationships \\012\\011\\011\\011WHERE data_id_child = OLD.id;\\012\\011\\011IF (counter > 0) THEN\\012\\011\\011\\011RAISE EXCEPTION 'Insert/Update of Data Set (Code: %) failed because it cannot be connected with a Sample and a parent Data Set at the same time.', OLD.code;\\012\\011\\011END IF;\\012\\011END IF;\\012  RETURN NEW;\\012END;\\012$$ LANGUAGE 'plpgsql';\\012\\012CREATE CONSTRAINT TRIGGER check_dataset_relationships_on_data_table_modification \\012  AFTER INSERT OR UPDATE ON data\\012\\011DEFERRABLE INITIALLY DEFERRED\\012\\011FOR EACH ROW \\012\\011EXECUTE PROCEDURE check_dataset_relationships_on_data_table_modification();\\012\\012-- trigger for 'data_set_relationships'\\012\\012CREATE OR REPLACE FUNCTION check_dataset_relationships_on_relationships_table_modification() RETURNS trigger AS $$\\012DECLARE\\012\\011counter\\011INTEGER;\\012\\011sample_id\\011TECH_ID;\\012\\011data_code\\011CODE;\\012BEGIN\\012\\011-- child will have a parent added so it should not be connected with any sample\\012\\011SELECT samp_id, code INTO sample_id, data_code \\012\\011\\011FROM data \\012\\011\\011WHERE id = NEW.data_id_child;\\012\\011IF (sample_id IS NOT NULL) THEN\\012\\011\\011RAISE EXCEPTION 'Insert/Update of Data Set (Code: %) failed because it cannot be connected to a Sample and to a parent Data Set at the same time.', data_code;\\012\\011END IF;\\012\\011RETURN NEW;\\012END;\\012$$ LANGUAGE 'plpgsql';\\012  \\012CREATE CONSTRAINT TRIGGER check_dataset_relationships_on_relationships_table_modification \\012  AFTER INSERT OR UPDATE ON data_set_relationships\\012\\011DEFERRABLE INITIALLY DEFERRED\\012\\011FOR EACH ROW \\012\\011EXECUTE PROCEDURE check_dataset_relationships_on_relationships_table_modification();\\012	\N
+./sourceTest/sql/postgresql/064/017=database_version_logs.tsv:053	source/sql/postgresql/migration/migration-052-053.sql	SUCCESS	2010-06-08 15:27:55.032	-- Migration from 052 to 053\\012\\012-- Change code uniqueness check for samples of specific type.\\012-- If sample_types.is_subcode_unique flag is set to 'true', additional check is performed \\012-- on codes of samples of the type. Subcodes will have to be unique as well.\\012\\012ALTER TABLE sample_types ADD COLUMN is_subcode_unique boolean_char NOT NULL DEFAULT false;\\012\\012CREATE OR REPLACE FUNCTION SAMPLE_SUBCODE_UNIQUENESS_CHECK() RETURNS trigger AS $$\\012DECLARE\\012   counter  INTEGER;\\012   unique_subcode  BOOLEAN_CHAR;\\012BEGIN\\012  LOCK TABLE samples IN EXCLUSIVE MODE;\\012  \\012  SELECT is_subcode_unique into unique_subcode FROM sample_types WHERE id = NEW.saty_id;\\012  \\012  IF (unique_subcode) THEN\\012    IF (NEW.dbin_id is not NULL) THEN\\012\\011\\011\\011SELECT count(*) into counter FROM samples \\012\\011\\011\\011\\011where id != NEW.id and code = NEW.code and saty_id = NEW.saty_id and dbin_id = NEW.dbin_id;\\012\\011\\011\\011IF (counter > 0) THEN\\012\\011\\011\\011\\011RAISE EXCEPTION 'Insert/Update of Sample (Code: %) failed because database instance sample of the same type with the same subcode already exists.', NEW.code;\\012\\011\\011\\011END IF;\\012\\011\\011ELSIF (NEW.grou_id is not NULL) THEN\\012\\011\\011\\011SELECT count(*) into counter FROM samples \\012\\011\\011\\011\\011where id != NEW.id and code = NEW.code and saty_id = NEW.saty_id and grou_id = NEW.grou_id;\\012\\011\\011\\011IF (counter > 0) THEN\\012\\011\\011\\011\\011RAISE EXCEPTION 'Insert/Update of Sample (Code: %) failed because space sample of the same type with the same subcode already exists.', NEW.code;\\012\\011\\011\\011END IF;\\012\\011\\011END IF;\\012  END IF;\\012  \\012  RETURN NEW;\\012END;\\012$$ LANGUAGE 'plpgsql';\\012\\012CREATE TRIGGER SAMPLE_SUBCODE_UNIQUENESS_CHECK BEFORE INSERT OR UPDATE ON SAMPLES\\012    FOR EACH ROW EXECUTE PROCEDURE SAMPLE_SUBCODE_UNIQUENESS_CHECK();\\012    \\012-- Fixing error messages in old trigger\\012\\012CREATE OR REPLACE FUNCTION SAMPLE_CODE_UNIQUENESS_CHECK() RETURNS trigger AS $$\\012DECLARE\\012   counter  INTEGER;\\012BEGIN\\012  LOCK TABLE samples IN EXCLUSIVE MODE;\\012  \\012\\011  IF (NEW.samp_id_part_of is NULL) THEN\\012\\011\\011  IF (NEW.dbin_id is not NULL) THEN\\012\\011\\011\\011  SELECT count(*) into counter FROM samples \\012\\011\\011      where id != NEW.id and code = NEW.code and samp_id_part_of is NULL and dbin_id = NEW.dbin_id;\\012        IF (counter > 0) THEN\\012\\011\\011\\011\\011  RAISE EXCEPTION 'Insert/Update of Sample (Code: %) failed because database instance sample with the same code already exists.', NEW.code;\\012        END IF;\\012\\011\\011  ELSIF (NEW.grou_id is not NULL) THEN\\012\\011\\011\\011  SELECT count(*) into counter FROM samples \\012\\011\\011\\011\\011  where id != NEW.id and code = NEW.code and samp_id_part_of is NULL and grou_id = NEW.grou_id;\\012\\011\\011\\011  IF (counter > 0) THEN\\012\\011\\011\\011\\011  RAISE EXCEPTION 'Insert/Update of Sample (Code: %) failed because space sample with the same code already exists.', NEW.code;\\012\\011\\011\\011  END IF;\\012      END IF;\\012    ELSE\\012\\011\\011  IF (NEW.dbin_id is not NULL) THEN\\012\\011\\011\\011  SELECT count(*) into counter FROM samples \\012\\011\\011\\011\\011  where id != NEW.id and code = NEW.code and samp_id_part_of = NEW.samp_id_part_of and dbin_id = NEW.dbin_id;\\012\\011\\011\\011  IF (counter > 0) THEN\\012\\011\\011\\011\\011  RAISE EXCEPTION 'Insert/Update of Sample (Code: %) failed because database instance sample with the same code and being the part of the same container already exists.', NEW.code;\\012\\011\\011\\011  END IF;\\012\\011\\011  ELSIF (NEW.grou_id is not NULL) THEN\\012\\011\\011\\011  SELECT count(*) into counter FROM samples \\012\\011\\011\\011\\011  where id != NEW.id and code = NEW.code and samp_id_part_of = NEW.samp_id_part_of and grou_id = NEW.grou_id;\\012\\011\\011\\011  IF (counter > 0) THEN\\012\\011\\011\\011\\011  RAISE EXCEPTION 'Insert/Update of Sample (Code: %) failed because space sample with the same code and being the part of the same container already exists.', NEW.code;\\012\\011\\011\\011  END IF;\\012\\011\\011  END IF;\\012     END IF;   \\012  \\012  RETURN NEW;\\012END;\\012$$ LANGUAGE 'plpgsql';\\012	\N
+./sourceTest/sql/postgresql/064/017=database_version_logs.tsv:054	source/sql/postgresql/migration/migration-053-054.sql	SUCCESS	2010-07-27 11:30:46.766	-- Migration from 053 to 054\\012\\012\\012-- Add RELATIONSHIP_TYPES table\\012CREATE TABLE relationship_types (id TECH_ID NOT NULL, code CODE NOT NULL, label COLUMN_LABEL, parent_label COLUMN_LABEL, child_label COLUMN_LABEL, description DESCRIPTION_2000, registration_timestamp TIME_STAMP_DFL NOT NULL DEFAULT CURRENT_TIMESTAMP, pers_id_registerer TECH_ID NOT NULL, is_managed_internally BOOLEAN_CHAR NOT NULL DEFAULT 'F', is_internal_namespace BOOLEAN_CHAR NOT NULL DEFAULT 'F', dbin_id TECH_ID NOT NULL);\\012\\012-- Add SAMPLE_RELATIONSHIPS table\\012CREATE TABLE sample_relationships (id TECH_ID NOT NULL, sample_id_parent TECH_ID NOT NULL, relationship_id TECH_ID NOT NULL, sample_id_child TECH_ID NOT NULL);\\012\\012-- Add/update constraints\\012ALTER TABLE relationship_types ADD CONSTRAINT rety_pk PRIMARY KEY (id);\\012ALTER TABLE relationship_types ADD CONSTRAINT rety_uk UNIQUE(code,dbin_id);\\012ALTER TABLE sample_relationships ADD CONSTRAINT sare_pk PRIMARY KEY (id);\\012ALTER TABLE sample_relationships ADD CONSTRAINT sare_bk_uk UNIQUE(sample_id_child,sample_id_parent,relationship_id);\\012ALTER TABLE sample_relationships ADD CONSTRAINT sare_data_fk_child FOREIGN KEY (sample_id_child) REFERENCES samples(id) ON DELETE CASCADE;\\012ALTER TABLE sample_relationships ADD CONSTRAINT sare_data_fk_parent FOREIGN KEY (sample_id_parent) REFERENCES samples(id) ON DELETE CASCADE;\\012ALTER TABLE sample_relationships ADD CONSTRAINT sare_data_fk_relationship FOREIGN KEY (relationship_id) REFERENCES relationship_types(id);\\012\\012-- Create index\\012CREATE INDEX sare_data_fk_i_child ON sample_relationships (sample_id_child);\\012CREATE INDEX sare_data_fk_i_parent ON sample_relationships (sample_id_parent);\\012CREATE INDEX sare_data_fk_i_relationship ON sample_relationships (relationship_id);\\012\\012-- Create sequence for RELATIONSHIP_TYPES\\012CREATE SEQUENCE RELATIONSHIP_TYPE_ID_SEQ;\\012CREATE SEQUENCE SAMPLE_RELATIONSHIP_ID_SEQ;\\012\\012-- Create initial relationships\\012insert into relationship_types\\012(id, \\012code, \\012label, \\012parent_label, \\012child_label, \\012description, \\012pers_id_registerer, \\012is_managed_internally, \\012is_internal_namespace, \\012dbin_id) \\012values\\012(\\012nextval('RELATIONSHIP_TYPE_ID_SEQ'),\\012'PARENT_CHILD',\\012'Parent - Child', \\012'Parent', \\012'Child', \\012'Parent - Child relationship', \\012(select id from persons where user_id ='system'), \\012'T', \\012'T', \\012(select id from database_instances where is_original_source = 'T')\\012);\\012\\012insert into relationship_types\\012(id, \\012code, \\012label, \\012parent_label, \\012child_label, \\012description, \\012pers_id_registerer, \\012is_managed_internally, \\012is_internal_namespace, \\012dbin_id) \\012values\\012(\\012nextval('RELATIONSHIP_TYPE_ID_SEQ'),\\012'PLATE_CONTROL_LAYOUT',\\012'Plate - Control Layout', \\012'Plate', \\012'Control Layout', \\012'Plate - Control Layout relationship', \\012(select id from persons where user_id ='system'), \\012'T', \\012'T', \\012(select id from database_instances where is_original_source = 'T')\\012); \\012\\012\\012-- Migrate sample relationships to new schema\\012INSERT INTO sample_relationships (id, sample_id_parent,sample_id_child,relationship_id) (select distinct nextval('SAMPLE_RELATIONSHIP_ID_SEQ') as id, s.SAMP_ID_GENERATED_FROM as parent_id, s.ID as child_id, rt.id as relationship_id from samples s, relationship_types rt  WHERE rt.code = 'PARENT_CHILD' and s.SAMP_ID_GENERATED_FROM is not null); \\012INSERT INTO sample_relationships (id, sample_id_parent,sample_id_child,relationship_id) (select distinct nextval('SAMPLE_RELATIONSHIP_ID_SEQ') as id, s.SAMP_ID_CONTROL_LAYOUT as parent_id, s.ID as child_id, rt.id as relationship_id from samples s, relationship_types rt  WHERE rt.code = 'PLATE_CONTROL_LAYOUT' and s.SAMP_ID_CONTROL_LAYOUT is not null);\\012\\012-- Drop old sample relations\\012ALTER TABLE SAMPLES DROP COLUMN SAMP_ID_TOP;\\012ALTER TABLE SAMPLES DROP COLUMN SAMP_ID_GENERATED_FROM;\\012ALTER TABLE SAMPLES DROP COLUMN SAMP_ID_CONTROL_LAYOUT;\\012\\012--------------------------------------------------------------------------------------\\012--------------------------------------------------------------------------------------\\012-- This is a screening specific migration. Nothing will be performed on openBIS databases \\012-- which are not screening specific.\\012-- \\012-- This migration for each existing connection between oligo well, oligo material and gene material\\012-- creates a direct connection between the well and the gene. \\012--------------------------------------------------------------------------------------\\012--------------------------------------------------------------------------------------\\012 \\012\\011\\012CREATE OR REPLACE FUNCTION CONNECT_WELLS_WITH_GENES() RETURNS void AS $$\\012DECLARE\\012\\011counter  int;\\012\\011oligo_well_exists bool;\\012BEGIN\\012\\011--------------------------------------------------\\012\\011-- create a gene property and assign it to oligo well\\012\\011--------------------------------------------------\\012\\011\\012\\011select true \\012\\011into oligo_well_exists\\012\\011from sample_types \\012\\011where code = 'OLIGO_WELL';\\012\\011\\012\\011if oligo_well_exists IS NULL then \\012\\011\\011-- skip migration if there are no oligo wells\\012\\011\\011return;\\012\\011end if;   \\012\\011\\012\\011insert into property_types(\\012\\011\\011id, \\012\\011\\011code, description, label, \\012\\011\\011daty_id,\\012\\011\\011pers_id_registerer,\\012\\011\\011dbin_id,\\012\\011\\011maty_prop_id) \\012\\011values(\\012\\011\\011\\011nextval('PROPERTY_TYPE_ID_SEQ'), \\012\\011\\011\\011'GENE','Inhibited gene','Gene',\\012\\011\\011\\011(select id from data_types where code = 'MATERIAL'), \\012\\011\\011\\011(select id from persons where user_id ='system'), \\012\\011\\011\\011(select id from database_instances where is_original_source = 'T'), \\012\\011\\011\\011(select id from material_types where code = 'GENE')\\012\\011\\011);\\012\\011\\011\\012\\011insert into sample_type_property_types( \\012\\011  id,\\012\\011  saty_id,\\012\\011  prty_id,\\012\\011  is_mandatory,\\012\\011  pers_id_registerer,\\012\\011  ordinal\\012\\011) values(\\012\\011\\011\\011nextval('stpt_id_seq'), \\012\\011\\011\\011(select id from sample_types where code = 'OLIGO_WELL'),\\012\\011\\011\\011(select id from property_types where code = 'GENE'),\\012\\011\\011\\011false,\\012\\011\\011\\011(select id from persons where user_id ='system'),\\012\\011\\011\\011(select max(ordinal)+1 from sample_type_property_types \\012\\011\\011\\011\\011where saty_id = (select id from sample_types where code = 'OLIGO_WELL'))\\012\\011\\011);\\012\\012\\011--------------------------------------------------\\012\\011-- create a gene material property for each oligo well\\012\\011--------------------------------------------------\\012\\011\\011\\012\\011select \\011count(*)\\012\\011into counter\\012\\011from\\012\\011\\011samples well, sample_types well_type, sample_properties well_props, \\012\\011\\011materials well_material, material_properties well_material_props,\\012\\011\\011materials nested_well_material\\012\\011where\\012\\011\\011well_type.code = 'OLIGO_WELL' and\\012\\011\\011-- find 'well_material' assigned to the well\\012\\011\\011well_props.samp_id = well.id and well_material.id = well_props.mate_prop_id and \\012\\011\\011-- additional joins to entity type tables\\012\\011\\011well_type.id = well.saty_id and\\012\\011\\011-- well content material property\\012\\011\\011well_material_props.mate_id = well_material.id and \\012\\011\\011-- material connected to the material in the well (e.g. gene)\\012\\011\\011well_material_props.mate_prop_id = nested_well_material.id and\\012\\011\\011nested_well_material.maty_id = (select id from material_types where code = 'GENE');\\012\\011\\012\\011if counter = 0 then \\012\\011\\011-- skip migration if there are no genes indirectly connected to oligo wells\\012\\011\\011return;\\012\\011end if;   \\012\\012\\011insert into sample_properties(id, samp_id, stpt_id, mate_prop_id, pers_id_registerer) (\\012\\011\\011select \\011nextval('sample_property_id_seq') id, \\012\\011\\011\\011well.id samp_id, \\012\\011\\011\\011(select stpt.id from sample_type_property_types stpt, property_types props where stpt.prty_id = props.id and props.code='GENE') stpt_id,\\012\\011\\011\\011nested_well_material.id mate_prop_id,\\012\\011\\011\\011(select id from persons where user_id ='system') pers_id_registerer \\012\\011\\011from\\012\\011\\011\\011samples well, sample_types well_type, sample_properties well_props, \\012\\011\\011\\011materials well_material, material_properties well_material_props,\\012\\011\\011\\011materials nested_well_material\\012\\011\\011where\\012\\011\\011\\011well_type.code = 'OLIGO_WELL' and\\012\\011\\011\\011-- find 'well_material' assigned to the well\\012\\011\\011\\011well_props.samp_id = well.id and well_material.id = well_props.mate_prop_id and \\012\\011\\011\\011-- additional joins to entity type tables\\012\\011\\011\\011well_type.id = well.saty_id and\\012\\011\\011\\011-- well content material property\\012\\011\\011\\011well_material_props.mate_id = well_material.id and \\012\\011\\011\\011-- material connected to the material in the well (e.g. gene)\\012\\011\\011\\011well_material_props.mate_prop_id = nested_well_material.id and\\012\\011\\011\\011nested_well_material.maty_id = (select id from material_types where code = 'GENE')\\012\\011);\\012\\012END;\\012$$ LANGUAGE 'plpgsql';\\012\\012select CONNECT_WELLS_WITH_GENES();\\012drop function CONNECT_WELLS_WITH_GENES();\\012\\012--------------------------------------------------------------------------------------\\012--------------------------------------------------------------------------------------\\012\\012-- drop dataset triggers\\012\\012DROP TRIGGER check_dataset_relationships_on_data_table_modification ON data;\\012DROP FUNCTION check_dataset_relationships_on_data_table_modification();\\012DROP TRIGGER check_dataset_relationships_on_relationships_table_modification ON data_set_relationships;\\012DROP FUNCTION check_dataset_relationships_on_relationships_table_modification();\\012 \\012\\012\\012\\012\\012\\012\\012\\012	\N
+./sourceTest/sql/postgresql/064/017=database_version_logs.tsv:056	source/sql/postgresql/migration/migration-055-056.sql	SUCCESS	2010-09-10 09:06:20.278	-- Migration from 055 to 056\\012\\012--------------------------------------------------------------------------------------\\012--------------------------------------------------------------------------------------\\012-- Screening specific migration. Nothing will be performed on openBIS databases \\012-- which are not screening specific.\\012--------------------------------------------------------------------------------------\\012--------------------------------------------------------------------------------------\\012\\012CREATE OR REPLACE FUNCTION merge_words(text, text) RETURNS text AS $$\\012DECLARE\\012  BEGIN\\012    IF  character_length($1) > 0 THEN\\012      RETURN $1 || ' ' || $2;\\012    ELSE\\012      RETURN $2;\\012    END IF;\\012  END;\\012$$ LANGUAGE plpgsql;\\012\\012CREATE AGGREGATE merge_words(text)\\012(\\012  SFUNC = merge_words,\\012  STYPE = text\\012);\\012\\012\\012CREATE OR REPLACE FUNCTION REPLACE_GENE_SYMBOL_BY_GENE_ID() RETURNS void AS $$\\012DECLARE\\012\\011counter  int;\\012\\011library_id_assigned_to_gene bool;\\012BEGIN\\012\\011--------------------------------------------------\\012\\011-- create a GENE_SYMBOL property and assign it to GENE\\012\\011--------------------------------------------------\\012\\011\\012\\011select true  \\012\\011into library_id_assigned_to_gene \\012\\011from material_type_property_types mtpt, material_types mt, property_types pt  \\012\\011where mtpt.maty_id = mt.id and mtpt.prty_id = pt.id \\012\\011\\011and mt.code = 'GENE' and pt.code = 'LIBRARY_ID';\\012\\011\\012\\011if library_id_assigned_to_gene IS NULL then \\012\\011\\011-- skip migration if gene has no library_id property\\012\\011\\011return;\\012\\011end if; \\012\\011\\012\\011\\012\\011select count(*)\\012\\011into counter \\012\\011from  \\012\\011\\011(select m.id, count(mp.id) as c \\012\\011\\011\\011from materials m, material_types mt, material_properties mp, material_type_property_types mtpt, property_types pt \\012\\011\\011\\011where m.maty_id = mt.id and mp.mate_id = m.id and mp.mtpt_id = mtpt.id and mtpt.maty_id = mt.id and pt.id = mtpt.prty_id\\012\\011\\011\\011\\011and mt.code = 'GENE' and pt.code = 'LIBRARY_ID' \\012\\011\\011\\011group by m.id) as counter_table \\012\\011where c < 1; \\012\\011\\012\\011if counter > 0 then \\012\\011\\011-- skip migration if there is at least one gene without library_id\\012\\011\\011return;\\012\\011end if;\\012\\011\\012\\011\\012\\011insert into property_types\\012\\011\\011(id\\012\\011\\011,code\\012\\011\\011,description\\012\\011\\011,label\\012\\011\\011,daty_id\\012\\011\\011,pers_id_registerer\\012\\011\\011,dbin_id)\\012\\011values \\012\\011\\011(nextval('PROPERTY_TYPE_ID_SEQ')\\012\\011\\011,'GENE_SYMBOLS'\\012\\011\\011,'Gene symbols'\\012\\011\\011,'Gene symbols'\\012\\011\\011,(select id from data_types where code ='VARCHAR')\\012\\011\\011,(select id from persons where user_id ='system')\\012\\011\\011,(select id from database_instances where is_original_source = 'T')\\012\\011);\\012\\011\\011\\012\\011insert into material_type_property_types( \\012\\011  id,\\012\\011  maty_id,\\012\\011  prty_id,\\012\\011  is_mandatory,\\012\\011  pers_id_registerer,\\012\\011  ordinal\\012\\011) values(\\012\\011\\011\\011nextval('mtpt_id_seq'), \\012\\011\\011\\011(select id from material_types where code = 'GENE'),\\012\\011\\011\\011(select id from property_types where code = 'GENE_SYMBOLS'),\\012\\011\\011\\011false,\\012\\011\\011\\011(select id from persons where user_id ='system'),\\012\\011\\011\\011(select max(ordinal)+1 from material_type_property_types \\012\\011\\011\\011\\011where maty_id = (select id from material_types where code = 'GENE'))\\012\\011\\011);\\012\\012\\011--------------------------------------------------\\012\\011-- create temporary table with all gene migration information\\012\\011--------------------------------------------------\\012\\012\\011create temp table genes \\012\\011(\\012\\011\\011id tech_id,\\012\\011\\011code code,\\012\\011\\011library_id generic_value,\\012\\011\\011gene_codes generic_value,\\012\\011\\011new_id tech_id,\\012\\011\\011library_tech_id tech_id\\011\\011\\012\\011);\\012\\011\\012\\011insert into genes (id, code, library_id, library_tech_id)\\012\\011\\011(select m.id, m.code, mp.value as library_id, mp.id as library_tech_id from materials m, material_properties mp, material_type_property_types mtpt, property_types pt, material_types mt\\012\\011\\011where mp.mate_id = m.id and  mp.mtpt_id = mtpt.id and pt.id = mtpt.prty_id and pt.code = 'LIBRARY_ID' and mt.id = m.maty_id and mt.id = mtpt.maty_id and mt.code = 'GENE');\\012\\011\\012\\011update genes set new_id = map.to_id from (select g_from.id as from_id, min(g_to.id) as to_id  from genes g_from, genes g_to where g_from.library_id = g_to.library_id group by g_from.id) as map where map.from_id = id;\\011\\012\\011\\012\\011update genes set gene_codes = map.gene_codes from (select g_from.library_id as lib_id, merge_words(distinct g_to.code) as gene_codes from genes g_from, genes g_to where g_from.library_id = g_to.library_id group by g_from.library_id) as map where map.lib_id = library_id;\\011\\012\\012\\011--------------------------------------------------\\012\\011-- update gene references\\012\\011--------------------------------------------------\\012\\012\\011update EXPERIMENTS set MATE_ID_STUDY_OBJECT = genes.new_id from genes where genes.id = MATE_ID_STUDY_OBJECT and not genes.id = genes.new_id;\\012\\011update EXPERIMENT_PROPERTIES set  MATE_PROP_ID = genes.new_id from genes where genes.id = MATE_PROP_ID and not genes.id = genes.new_id;\\012\\011update MATERIAL_PROPERTIES set  MATE_PROP_ID = genes.new_id from genes where genes.id = MATE_PROP_ID and not genes.id = genes.new_id;\\012\\011update SAMPLE_PROPERTIES set  MATE_PROP_ID = genes.new_id from genes where genes.id = MATE_PROP_ID and not genes.id = genes.new_id;\\012\\011update DATA_SET_PROPERTIES set  MATE_PROP_ID = genes.new_id from genes where genes.id = MATE_PROP_ID and not genes.id = genes.new_id;\\012\\011\\012\\011delete from  material_properties where mate_id in (select id from genes where not genes.id = genes.new_id);\\012\\011delete from MATERIALS where id in (select id from genes where not genes.id = genes.new_id);\\012\\012\\011delete from genes where id in (select id from genes where not genes.id = genes.new_id);\\012\\012\\012\\011--------------------------------------------------\\012\\011-- replace gene code with library_id\\012\\011--------------------------------------------------\\012\\011\\012\\011update materials set code = genes.library_id from genes where materials.id = genes.id ;\\012\\011delete from material_properties where id in (select library_tech_id from genes);\\012\\011\\012\\011--------------------------------------------------\\012\\011-- create a gene symbols property for each gene\\012\\011--------------------------------------------------\\012\\011\\012\\011insert into material_properties\\012\\011\\011(id\\012\\011  , mate_id\\012\\011  , mtpt_id\\012\\011  , "value"\\012\\011  , pers_id_registerer)\\012\\011\\011(select nextval('material_property_id_seq') id\\012\\011  \\011, genes.id  mate_id\\012\\011    , (select mtpt.id\\012\\011    \\011\\011from   material_type_property_types mtpt, material_types mt, property_types pt\\012\\011    \\011\\011where  pt.code = 'GENE_SYMBOLS' and mt.code = 'GENE' and mtpt.prty_id = pt.id\\012\\011        \\011and mtpt.maty_id = mt.id) mtpt_id\\012\\011    , genes.gene_codes "value"\\012\\011    , (select id from persons where user_id = 'system') pers_id_registerer\\012\\011 \\011from genes); \\012\\012\\011--------------------------------------------------\\012\\011-- delete temporary table\\012\\011--------------------------------------------------\\012\\011\\012\\011drop table genes;\\012\\011\\012END;\\012$$ LANGUAGE 'plpgsql';\\012\\012select REPLACE_GENE_SYMBOL_BY_GENE_ID();\\012drop function REPLACE_GENE_SYMBOL_BY_GENE_ID();\\012DROP AGGREGATE merge_words(text);\\012drop function merge_words(text,text);\\012\\012\\012--------------------------------------------------------------------------------------\\012--------------------------------------------------------------------------------------\\012\\012UPDATE sample_types SET code = 'SIRNA_WELL' WHERE code = 'OLIGO_WELL';\\012UPDATE material_types SET code = 'SIRNA' WHERE code = 'OLIGO';\\012UPDATE property_types SET code = 'SIRNA', label = 'siRNA' WHERE code = 'OLIGO';\\012\\012\\012\\012\\012\\012\\012\\012\\012\\012\\012\\012\\012\\012\\012\\012\\012\\012\\012\\012	\N
+./sourceTest/sql/postgresql/064/017=database_version_logs.tsv:059	source/sql/postgresql/migration/migration-058-059.sql	SUCCESS	2010-09-29 13:37:07.231	-- Migration from 058 to 059\\012\\012-- Add ENTITY_TYPE_CODE column to QUERIES\\012ALTER TABLE queries ADD COLUMN entity_type_code CODE;\\012\\012------------------------------------------------------------------------------------\\012--  Purpose:  Create trigger that checks if entity_type_code specified in a query\\012--            matches a code of an entity of type specified in query_type.\\012------------------------------------------------------------------------------------\\012\\012CREATE OR REPLACE FUNCTION query_entity_type_code_check() RETURNS trigger AS $$\\012DECLARE\\012   counter  INTEGER;\\012BEGIN\\012   if (NEW.entity_type_code IS NOT NULL) then\\012     if (NEW.query_type = 'GENERIC') then\\012       RAISE EXCEPTION 'Insert/Update of query (Name: %) failed, as entity_type has to be null for GENERIC queries.', NEW.name;\\012     elsif (NEW.query_type = 'EXPERIMENT') then\\012       SELECT count(*) INTO counter FROM experiment_types WHERE code = NEW.entity_type_code;\\012\\011\\011 elsif (NEW.query_type = 'DATA_SET') then\\012       SELECT count(*) INTO counter FROM data_set_types WHERE code = NEW.entity_type_code;\\012\\011\\011 elsif (NEW.query_type = 'MATERIAL') then\\012       SELECT count(*) INTO counter FROM material_types WHERE code = NEW.entity_type_code;\\012\\011\\011 elsif (NEW.query_type = 'SAMPLE') then\\012       SELECT count(*) INTO counter FROM sample_types WHERE code = NEW.entity_type_code;\\012\\011\\011 end if;\\012\\011\\011 if (counter = 0) then\\012\\011\\011\\011 RAISE EXCEPTION 'Insert/Update of query (Name: %) failed because % type (Code: %) does not exist.', NEW.name, NEW.query_type, NEW.entity_type_code;\\012\\011\\011 end if;\\011\\011\\011\\012   end if;\\012   RETURN NEW;\\012END;\\012$$ LANGUAGE 'plpgsql';\\012\\012CREATE TRIGGER query_entity_type_code_check BEFORE INSERT OR UPDATE ON queries\\012    FOR EACH ROW EXECUTE PROCEDURE query_entity_type_code_check();\\012	\N
+./sourceTest/sql/postgresql/064/017=database_version_logs.tsv:062	source/sql/postgresql/migration/migration-061-062.sql	SUCCESS	2010-11-25 16:02:07.224	\\012CREATE OR REPLACE FUNCTION sample_code_uniqueness_check() RETURNS trigger\\012    LANGUAGE plpgsql\\012    AS $$\\012DECLARE\\012   counter  INTEGER;\\012BEGIN\\012  LOCK TABLE samples IN EXCLUSIVE MODE;\\012  \\012\\011  IF (NEW.samp_id_part_of is NULL) THEN\\012\\011\\011  IF (NEW.dbin_id is not NULL) THEN\\012\\011\\011\\011  SELECT count(*) into counter FROM samples \\012\\011\\011      where id != NEW.id and code = NEW.code and samp_id_part_of is NULL and dbin_id = NEW.dbin_id;\\012        IF (counter > 0) THEN\\012\\011\\011\\011\\011  RAISE EXCEPTION 'Insert/Update of Sample (Code: %) failed because database instance sample with the same code already exists.', NEW.code;\\012        END IF;\\012\\011\\011  ELSIF (NEW.space_id is not NULL) THEN\\012\\011\\011\\011  SELECT count(*) into counter FROM samples \\012\\011\\011\\011\\011  where id != NEW.id and code = NEW.code and samp_id_part_of is NULL and space_id = NEW.grou_id;\\012\\011\\011\\011  IF (counter > 0) THEN\\012\\011\\011\\011\\011  RAISE EXCEPTION 'Insert/Update of Sample (Code: %) failed because space sample with the same code already exists.', NEW.code;\\012\\011\\011\\011  END IF;\\012      END IF;\\012    ELSE\\012\\011\\011  IF (NEW.dbin_id is not NULL) THEN\\012\\011\\011\\011  SELECT count(*) into counter FROM samples \\012\\011\\011\\011\\011  where id != NEW.id and code = NEW.code and samp_id_part_of = NEW.samp_id_part_of and dbin_id = NEW.dbin_id;\\012\\011\\011\\011  IF (counter > 0) THEN\\012\\011\\011\\011\\011  RAISE EXCEPTION 'Insert/Update of Sample (Code: %) failed because database instance sample with the same code and being the part of the same container already exists.', NEW.code;\\012\\011\\011\\011  END IF;\\012\\011\\011  ELSIF (NEW.space_id is not NULL) THEN\\012\\011\\011\\011  SELECT count(*) into counter FROM samples \\012\\011\\011\\011\\011  where id != NEW.id and code = NEW.code and samp_id_part_of = NEW.samp_id_part_of and space_id = NEW.space_id;\\012\\011\\011\\011  IF (counter > 0) THEN\\012\\011\\011\\011\\011  RAISE EXCEPTION 'Insert/Update of Sample (Code: %) failed because space sample with the same code and being the part of the same container already exists.', NEW.code;\\012\\011\\011\\011  END IF;\\012\\011\\011  END IF;\\012     END IF;   \\012  \\012  RETURN NEW;\\012END;\\012$$;\\012\\012\\012CREATE OR REPLACE FUNCTION sample_subcode_uniqueness_check() RETURNS trigger\\012    LANGUAGE plpgsql\\012    AS $$\\012DECLARE\\012   counter  INTEGER;\\012   unique_subcode  BOOLEAN_CHAR;\\012BEGIN\\012  LOCK TABLE samples IN EXCLUSIVE MODE;\\012  \\012  SELECT is_subcode_unique into unique_subcode FROM sample_types WHERE id = NEW.saty_id;\\012  \\012  IF (unique_subcode) THEN\\012    IF (NEW.dbin_id is not NULL) THEN\\012\\011\\011\\011SELECT count(*) into counter FROM samples \\012\\011\\011\\011\\011where id != NEW.id and code = NEW.code and saty_id = NEW.saty_id and dbin_id = NEW.dbin_id;\\012\\011\\011\\011IF (counter > 0) THEN\\012\\011\\011\\011\\011RAISE EXCEPTION 'Insert/Update of Sample (Code: %) failed because database instance sample of the same type with the same subcode already exists.', NEW.code;\\012\\011\\011\\011END IF;\\012\\011\\011ELSIF (NEW.space_id is not NULL) THEN\\012\\011\\011\\011SELECT count(*) into counter FROM samples \\012\\011\\011\\011\\011where id != NEW.id and code = NEW.code and saty_id = NEW.saty_id and space_id = NEW.space_id;\\012\\011\\011\\011IF (counter > 0) THEN\\012\\011\\011\\011\\011RAISE EXCEPTION 'Insert/Update of Sample (Code: %) failed because space sample of the same type with the same subcode already exists.', NEW.code;\\012\\011\\011\\011END IF;\\012\\011\\011END IF;\\012  END IF;\\012  \\012  RETURN NEW;\\012END;\\012$$;\\012\\012ALTER TABLE groups RENAME TO spaces;\\012\\012ALTER SEQUENCE group_id_seq RENAME TO space_id_seq;\\012\\012ALTER TABLE persons\\011RENAME grou_id TO space_id;\\012ALTER TABLE projects RENAME grou_id TO space_id;\\012ALTER TABLE role_assignments RENAME grou_id TO space_id;\\012ALTER TABLE samples\\011RENAME grou_id TO space_id;\\012\\012-- migrate EVENTS table\\012\\012ALTER TABLE events\\012\\011DROP CONSTRAINT evnt_et_enum_ck;\\012\\012update events set entity_type = 'SPACE' where entity_type = 'GROUP';\\012\\012ALTER TABLE events ADD CONSTRAINT evnt_et_enum_ck CHECK \\012\\011(entity_type IN ('ATTACHMENT', 'DATASET', 'EXPERIMENT', 'SPACE', 'MATERIAL', 'PROJECT', 'PROPERTY_TYPE', 'SAMPLE', 'VOCABULARY', 'AUTHORIZATION_GROUP')); \\012\\012ALTER TABLE persons\\012\\011DROP CONSTRAINT pers_grou_fk;\\012\\012ALTER TABLE persons\\012\\011ADD CONSTRAINT pers_space_fk FOREIGN KEY (space_id) REFERENCES spaces(id);\\012\\012ALTER TABLE projects\\012\\011DROP CONSTRAINT proj_bk_uk;\\012\\012ALTER TABLE projects\\012\\011DROP CONSTRAINT proj_grou_fk;\\012\\012ALTER TABLE projects\\012\\011ADD CONSTRAINT proj_bk_uk UNIQUE (code, space_id);\\012\\012ALTER TABLE projects\\012\\011ADD CONSTRAINT proj_space_fk FOREIGN KEY (space_id) REFERENCES spaces(id);\\012\\012ALTER TABLE role_assignments\\012\\011DROP CONSTRAINT roas_dbin_grou_arc_ck;\\012\\012ALTER TABLE role_assignments\\012\\011DROP CONSTRAINT roas_ag_group_bk_uk;\\012\\012ALTER TABLE role_assignments\\012\\011DROP CONSTRAINT roas_pe_group_bk_uk;\\012\\012ALTER TABLE role_assignments\\012\\011DROP CONSTRAINT roas_grou_fk;\\012\\012ALTER TABLE role_assignments\\012\\011ADD CONSTRAINT roas_dbin_space_arc_ck CHECK ((((dbin_id IS NOT NULL) AND (space_id IS NULL)) OR ((dbin_id IS NULL) AND (space_id IS NOT NULL))));\\012\\012ALTER TABLE role_assignments\\012\\011ADD CONSTRAINT roas_ag_space_bk_uk UNIQUE (ag_id_grantee, role_code, space_id);\\012\\012ALTER TABLE role_assignments\\012\\011ADD CONSTRAINT roas_pe_space_bk_uk UNIQUE (pers_id_grantee, role_code, space_id);\\012\\012ALTER TABLE role_assignments\\012\\011ADD CONSTRAINT roas_space_fk FOREIGN KEY (space_id) REFERENCES spaces(id);\\012\\012ALTER TABLE samples\\012\\011DROP CONSTRAINT samp_dbin_grou_arc_ck;\\012\\012ALTER TABLE samples\\012\\011DROP CONSTRAINT samp_grou_fk;\\012\\012ALTER TABLE samples\\012\\011ADD CONSTRAINT samp_dbin_space_arc_ck CHECK ((((dbin_id IS NOT NULL) AND (space_id IS NULL)) OR ((dbin_id IS NULL) AND (space_id IS NOT NULL))));\\012\\012ALTER TABLE samples\\012\\011ADD CONSTRAINT samp_space_fk FOREIGN KEY (space_id) REFERENCES spaces(id);\\012\\012ALTER TABLE spaces\\012  DROP CONSTRAINT grou_bk_uk,\\012  ADD CONSTRAINT space_bk_uk UNIQUE (code, dbin_id);\\012\\012ALTER TABLE spaces\\012  DROP CONSTRAINT grou_dbin_fk,\\012  ADD CONSTRAINT space_dbin_fk FOREIGN KEY (dbin_id) REFERENCES database_instances(id);\\012\\012ALTER TABLE spaces\\012  DROP CONSTRAINT grou_pers_fk_registerer,\\012  ADD CONSTRAINT space_pers_fk_registerer FOREIGN KEY (pers_id_registerer) REFERENCES persons(id);\\012\\012ALTER INDEX pers_grou_fk_i RENAME TO pers_space_fk_i;\\012\\012ALTER INDEX proj_grou_fk_i RENAME TO proj_space_fk_i;\\012\\012ALTER INDEX roas_grou_fk_i RENAME TO roas_space_fk_i;\\012\\012ALTER INDEX grou_pk RENAME TO space_pk;\\012\\012ALTER INDEX grou_dbin_fk_i RENAME TO space_dbin_fk_i;\\012\\012ALTER INDEX grou_pers_registered_by_fk_i RENAME TO space_pers_registered_by_fk_i;\\012\\012	\N
+./sourceTest/sql/postgresql/064/schema-064.sql:    LANGUAGE plpgsql
+./sourceTest/sql/postgresql/064/schema-064.sql:    LANGUAGE plpgsql
+./sourceTest/sql/postgresql/064/schema-064.sql:    LANGUAGE plpgsql
+./sourceTest/sql/postgresql/064/schema-064.sql:    LANGUAGE plpgsql
+./sourceTest/sql/postgresql/064/schema-064.sql:    LANGUAGE plpgsql
+./sourceTest/sql/postgresql/064/schema-064.sql:    LANGUAGE plpgsql
+./sourceTest/sql/postgresql/064/schema-064.sql:    LANGUAGE plpgsql
+./sourceTest/sql/postgresql/064/schema-064.sql:    LANGUAGE plpgsql
+./sourceTest/sql/postgresql/064/schema-064.sql:    LANGUAGE plpgsql
+./sourceTest/sql/postgresql/065/.svn/text-base/schema-065.sql.svn-base:    LANGUAGE plpgsql
+./sourceTest/sql/postgresql/065/.svn/text-base/schema-065.sql.svn-base:    LANGUAGE plpgsql
+./sourceTest/sql/postgresql/065/.svn/text-base/schema-065.sql.svn-base:    LANGUAGE plpgsql
+./sourceTest/sql/postgresql/065/.svn/text-base/schema-065.sql.svn-base:    LANGUAGE plpgsql
+./sourceTest/sql/postgresql/065/.svn/text-base/schema-065.sql.svn-base:    LANGUAGE plpgsql
+./sourceTest/sql/postgresql/065/.svn/text-base/schema-065.sql.svn-base:    LANGUAGE plpgsql
+./sourceTest/sql/postgresql/065/.svn/text-base/schema-065.sql.svn-base:    LANGUAGE plpgsql
+./sourceTest/sql/postgresql/065/.svn/text-base/schema-065.sql.svn-base:    LANGUAGE plpgsql
+./sourceTest/sql/postgresql/065/.svn/text-base/schema-065.sql.svn-base:    LANGUAGE plpgsql
+./sourceTest/sql/postgresql/065/schema-065.sql:    LANGUAGE plpgsql
+./sourceTest/sql/postgresql/065/schema-065.sql:    LANGUAGE plpgsql
+./sourceTest/sql/postgresql/065/schema-065.sql:    LANGUAGE plpgsql
+./sourceTest/sql/postgresql/065/schema-065.sql:    LANGUAGE plpgsql
+./sourceTest/sql/postgresql/065/schema-065.sql:    LANGUAGE plpgsql
+./sourceTest/sql/postgresql/065/schema-065.sql:    LANGUAGE plpgsql
+./sourceTest/sql/postgresql/065/schema-065.sql:    LANGUAGE plpgsql
+./sourceTest/sql/postgresql/065/schema-065.sql:    LANGUAGE plpgsql
+./sourceTest/sql/postgresql/065/schema-065.sql:    LANGUAGE plpgsql
+./sourceTest/sql/postgresql/066/.svn/text-base/schema-066.sql.svn-base:    LANGUAGE plpgsql
+./sourceTest/sql/postgresql/066/.svn/text-base/schema-066.sql.svn-base:    LANGUAGE plpgsql
+./sourceTest/sql/postgresql/066/.svn/text-base/schema-066.sql.svn-base:    LANGUAGE plpgsql
+./sourceTest/sql/postgresql/066/.svn/text-base/schema-066.sql.svn-base:    LANGUAGE plpgsql
+./sourceTest/sql/postgresql/066/.svn/text-base/schema-066.sql.svn-base:    LANGUAGE plpgsql
+./sourceTest/sql/postgresql/066/.svn/text-base/schema-066.sql.svn-base:    LANGUAGE plpgsql
+./sourceTest/sql/postgresql/066/.svn/text-base/schema-066.sql.svn-base:    LANGUAGE plpgsql
+./sourceTest/sql/postgresql/066/.svn/text-base/schema-066.sql.svn-base:    LANGUAGE plpgsql
+./sourceTest/sql/postgresql/066/.svn/text-base/schema-066.sql.svn-base:    LANGUAGE plpgsql
+./sourceTest/sql/postgresql/066/schema-066.sql:    LANGUAGE plpgsql
+./sourceTest/sql/postgresql/066/schema-066.sql:    LANGUAGE plpgsql
+./sourceTest/sql/postgresql/066/schema-066.sql:    LANGUAGE plpgsql
+./sourceTest/sql/postgresql/066/schema-066.sql:    LANGUAGE plpgsql
+./sourceTest/sql/postgresql/066/schema-066.sql:    LANGUAGE plpgsql
+./sourceTest/sql/postgresql/066/schema-066.sql:    LANGUAGE plpgsql
+./sourceTest/sql/postgresql/066/schema-066.sql:    LANGUAGE plpgsql
+./sourceTest/sql/postgresql/066/schema-066.sql:    LANGUAGE plpgsql
+./sourceTest/sql/postgresql/066/schema-066.sql:    LANGUAGE plpgsql
+./sourceTest/sql/postgresql/067/.svn/text-base/schema-067.sql.svn-base:    LANGUAGE plpgsql
+./sourceTest/sql/postgresql/067/.svn/text-base/schema-067.sql.svn-base:    LANGUAGE plpgsql
+./sourceTest/sql/postgresql/067/.svn/text-base/schema-067.sql.svn-base:    LANGUAGE plpgsql
+./sourceTest/sql/postgresql/067/.svn/text-base/schema-067.sql.svn-base:    LANGUAGE plpgsql
+./sourceTest/sql/postgresql/067/.svn/text-base/schema-067.sql.svn-base:    LANGUAGE plpgsql
+./sourceTest/sql/postgresql/067/.svn/text-base/schema-067.sql.svn-base:    LANGUAGE plpgsql
+./sourceTest/sql/postgresql/067/.svn/text-base/schema-067.sql.svn-base:    LANGUAGE plpgsql
+./sourceTest/sql/postgresql/067/.svn/text-base/schema-067.sql.svn-base:    LANGUAGE plpgsql
+./sourceTest/sql/postgresql/067/.svn/text-base/schema-067.sql.svn-base:    LANGUAGE plpgsql
+./sourceTest/sql/postgresql/067/schema-067.sql:    LANGUAGE plpgsql
+./sourceTest/sql/postgresql/067/schema-067.sql:    LANGUAGE plpgsql
+./sourceTest/sql/postgresql/067/schema-067.sql:    LANGUAGE plpgsql
+./sourceTest/sql/postgresql/067/schema-067.sql:    LANGUAGE plpgsql
+./sourceTest/sql/postgresql/067/schema-067.sql:    LANGUAGE plpgsql
+./sourceTest/sql/postgresql/067/schema-067.sql:    LANGUAGE plpgsql
+./sourceTest/sql/postgresql/067/schema-067.sql:    LANGUAGE plpgsql
+./sourceTest/sql/postgresql/067/schema-067.sql:    LANGUAGE plpgsql
+./sourceTest/sql/postgresql/067/schema-067.sql:    LANGUAGE plpgsql
+./sourceTest/sql/postgresql/068/.svn/text-base/schema-068.sql.svn-base:    LANGUAGE plpgsql
+./sourceTest/sql/postgresql/068/.svn/text-base/schema-068.sql.svn-base:    LANGUAGE plpgsql
+./sourceTest/sql/postgresql/068/.svn/text-base/schema-068.sql.svn-base:    LANGUAGE plpgsql
+./sourceTest/sql/postgresql/068/.svn/text-base/schema-068.sql.svn-base:    LANGUAGE plpgsql
+./sourceTest/sql/postgresql/068/.svn/text-base/schema-068.sql.svn-base:    LANGUAGE plpgsql
+./sourceTest/sql/postgresql/068/.svn/text-base/schema-068.sql.svn-base:    LANGUAGE plpgsql
+./sourceTest/sql/postgresql/068/.svn/text-base/schema-068.sql.svn-base:    LANGUAGE plpgsql
+./sourceTest/sql/postgresql/068/.svn/text-base/schema-068.sql.svn-base:    LANGUAGE plpgsql
+./sourceTest/sql/postgresql/068/.svn/text-base/schema-068.sql.svn-base:    LANGUAGE plpgsql
+./sourceTest/sql/postgresql/068/schema-068.sql:    LANGUAGE plpgsql
+./sourceTest/sql/postgresql/068/schema-068.sql:    LANGUAGE plpgsql
+./sourceTest/sql/postgresql/068/schema-068.sql:    LANGUAGE plpgsql
+./sourceTest/sql/postgresql/068/schema-068.sql:    LANGUAGE plpgsql
+./sourceTest/sql/postgresql/068/schema-068.sql:    LANGUAGE plpgsql
+./sourceTest/sql/postgresql/068/schema-068.sql:    LANGUAGE plpgsql
+./sourceTest/sql/postgresql/068/schema-068.sql:    LANGUAGE plpgsql
+./sourceTest/sql/postgresql/068/schema-068.sql:    LANGUAGE plpgsql
+./sourceTest/sql/postgresql/068/schema-068.sql:    LANGUAGE plpgsql
+./sourceTest/sql/postgresql/069/.svn/text-base/schema-069.sql.svn-base:    LANGUAGE plpgsql
+./sourceTest/sql/postgresql/069/.svn/text-base/schema-069.sql.svn-base:    LANGUAGE plpgsql
+./sourceTest/sql/postgresql/069/.svn/text-base/schema-069.sql.svn-base:    LANGUAGE plpgsql
+./sourceTest/sql/postgresql/069/.svn/text-base/schema-069.sql.svn-base:    LANGUAGE plpgsql
+./sourceTest/sql/postgresql/069/.svn/text-base/schema-069.sql.svn-base:    LANGUAGE plpgsql
+./sourceTest/sql/postgresql/069/.svn/text-base/schema-069.sql.svn-base:    LANGUAGE plpgsql
+./sourceTest/sql/postgresql/069/.svn/text-base/schema-069.sql.svn-base:    LANGUAGE plpgsql
+./sourceTest/sql/postgresql/069/.svn/text-base/schema-069.sql.svn-base:    LANGUAGE plpgsql
+./sourceTest/sql/postgresql/069/.svn/text-base/schema-069.sql.svn-base:    LANGUAGE plpgsql
+./sourceTest/sql/postgresql/069/schema-069.sql:    LANGUAGE plpgsql
+./sourceTest/sql/postgresql/069/schema-069.sql:    LANGUAGE plpgsql
+./sourceTest/sql/postgresql/069/schema-069.sql:    LANGUAGE plpgsql
+./sourceTest/sql/postgresql/069/schema-069.sql:    LANGUAGE plpgsql
+./sourceTest/sql/postgresql/069/schema-069.sql:    LANGUAGE plpgsql
+./sourceTest/sql/postgresql/069/schema-069.sql:    LANGUAGE plpgsql
+./sourceTest/sql/postgresql/069/schema-069.sql:    LANGUAGE plpgsql
+./sourceTest/sql/postgresql/069/schema-069.sql:    LANGUAGE plpgsql
+./sourceTest/sql/postgresql/069/schema-069.sql:    LANGUAGE plpgsql
+./sourceTest/sql/postgresql/070/.svn/text-base/schema-070.sql.svn-base:    LANGUAGE plpgsql
+./sourceTest/sql/postgresql/070/.svn/text-base/schema-070.sql.svn-base:    LANGUAGE plpgsql
+./sourceTest/sql/postgresql/070/.svn/text-base/schema-070.sql.svn-base:    LANGUAGE plpgsql
+./sourceTest/sql/postgresql/070/.svn/text-base/schema-070.sql.svn-base:    LANGUAGE plpgsql
+./sourceTest/sql/postgresql/070/.svn/text-base/schema-070.sql.svn-base:    LANGUAGE plpgsql
+./sourceTest/sql/postgresql/070/.svn/text-base/schema-070.sql.svn-base:    LANGUAGE plpgsql
+./sourceTest/sql/postgresql/070/.svn/text-base/schema-070.sql.svn-base:    LANGUAGE plpgsql
+./sourceTest/sql/postgresql/070/.svn/text-base/schema-070.sql.svn-base:    LANGUAGE plpgsql
+./sourceTest/sql/postgresql/070/.svn/text-base/schema-070.sql.svn-base:    LANGUAGE plpgsql
+./sourceTest/sql/postgresql/070/schema-070.sql:    LANGUAGE plpgsql
+./sourceTest/sql/postgresql/070/schema-070.sql:    LANGUAGE plpgsql
+./sourceTest/sql/postgresql/070/schema-070.sql:    LANGUAGE plpgsql
+./sourceTest/sql/postgresql/070/schema-070.sql:    LANGUAGE plpgsql
+./sourceTest/sql/postgresql/070/schema-070.sql:    LANGUAGE plpgsql
+./sourceTest/sql/postgresql/070/schema-070.sql:    LANGUAGE plpgsql
+./sourceTest/sql/postgresql/070/schema-070.sql:    LANGUAGE plpgsql
+./sourceTest/sql/postgresql/070/schema-070.sql:    LANGUAGE plpgsql
+./sourceTest/sql/postgresql/070/schema-070.sql:    LANGUAGE plpgsql
+./sourceTest/sql/postgresql/071/.svn/text-base/schema-071.sql.svn-base:    LANGUAGE plpgsql
+./sourceTest/sql/postgresql/071/.svn/text-base/schema-071.sql.svn-base:    LANGUAGE plpgsql
+./sourceTest/sql/postgresql/071/.svn/text-base/schema-071.sql.svn-base:    LANGUAGE plpgsql
+./sourceTest/sql/postgresql/071/.svn/text-base/schema-071.sql.svn-base:    LANGUAGE plpgsql
+./sourceTest/sql/postgresql/071/.svn/text-base/schema-071.sql.svn-base:    LANGUAGE plpgsql
+./sourceTest/sql/postgresql/071/.svn/text-base/schema-071.sql.svn-base:    LANGUAGE plpgsql
+./sourceTest/sql/postgresql/071/.svn/text-base/schema-071.sql.svn-base:    LANGUAGE plpgsql
+./sourceTest/sql/postgresql/071/.svn/text-base/schema-071.sql.svn-base:    LANGUAGE plpgsql
+./sourceTest/sql/postgresql/071/.svn/text-base/schema-071.sql.svn-base:    LANGUAGE plpgsql
+./sourceTest/sql/postgresql/071/schema-071.sql:    LANGUAGE plpgsql
+./sourceTest/sql/postgresql/071/schema-071.sql:    LANGUAGE plpgsql
+./sourceTest/sql/postgresql/071/schema-071.sql:    LANGUAGE plpgsql
+./sourceTest/sql/postgresql/071/schema-071.sql:    LANGUAGE plpgsql
+./sourceTest/sql/postgresql/071/schema-071.sql:    LANGUAGE plpgsql
+./sourceTest/sql/postgresql/071/schema-071.sql:    LANGUAGE plpgsql
+./sourceTest/sql/postgresql/071/schema-071.sql:    LANGUAGE plpgsql
+./sourceTest/sql/postgresql/071/schema-071.sql:    LANGUAGE plpgsql
+./sourceTest/sql/postgresql/071/schema-071.sql:    LANGUAGE plpgsql
+./sourceTest/sql/postgresql/072/.svn/text-base/schema-072.sql.svn-base:    LANGUAGE plpgsql
+./sourceTest/sql/postgresql/072/.svn/text-base/schema-072.sql.svn-base:    LANGUAGE plpgsql
+./sourceTest/sql/postgresql/072/.svn/text-base/schema-072.sql.svn-base:    LANGUAGE plpgsql
+./sourceTest/sql/postgresql/072/.svn/text-base/schema-072.sql.svn-base:    LANGUAGE plpgsql
+./sourceTest/sql/postgresql/072/.svn/text-base/schema-072.sql.svn-base:    LANGUAGE plpgsql
+./sourceTest/sql/postgresql/072/.svn/text-base/schema-072.sql.svn-base:    LANGUAGE plpgsql
+./sourceTest/sql/postgresql/072/.svn/text-base/schema-072.sql.svn-base:    LANGUAGE plpgsql
+./sourceTest/sql/postgresql/072/.svn/text-base/schema-072.sql.svn-base:    LANGUAGE plpgsql
+./sourceTest/sql/postgresql/072/.svn/text-base/schema-072.sql.svn-base:    LANGUAGE plpgsql
+./sourceTest/sql/postgresql/072/schema-072.sql:    LANGUAGE plpgsql
+./sourceTest/sql/postgresql/072/schema-072.sql:    LANGUAGE plpgsql
+./sourceTest/sql/postgresql/072/schema-072.sql:    LANGUAGE plpgsql
+./sourceTest/sql/postgresql/072/schema-072.sql:    LANGUAGE plpgsql
+./sourceTest/sql/postgresql/072/schema-072.sql:    LANGUAGE plpgsql
+./sourceTest/sql/postgresql/072/schema-072.sql:    LANGUAGE plpgsql
+./sourceTest/sql/postgresql/072/schema-072.sql:    LANGUAGE plpgsql
+./sourceTest/sql/postgresql/072/schema-072.sql:    LANGUAGE plpgsql
+./sourceTest/sql/postgresql/072/schema-072.sql:    LANGUAGE plpgsql
+./sourceTest/sql/postgresql/073/.svn/text-base/schema-073.sql.svn-base:    LANGUAGE plpgsql
+./sourceTest/sql/postgresql/073/.svn/text-base/schema-073.sql.svn-base:    LANGUAGE plpgsql
+./sourceTest/sql/postgresql/073/.svn/text-base/schema-073.sql.svn-base:    LANGUAGE plpgsql
+./sourceTest/sql/postgresql/073/.svn/text-base/schema-073.sql.svn-base:    LANGUAGE plpgsql
+./sourceTest/sql/postgresql/073/.svn/text-base/schema-073.sql.svn-base:    LANGUAGE plpgsql
+./sourceTest/sql/postgresql/073/.svn/text-base/schema-073.sql.svn-base:    LANGUAGE plpgsql
+./sourceTest/sql/postgresql/073/.svn/text-base/schema-073.sql.svn-base:    LANGUAGE plpgsql
+./sourceTest/sql/postgresql/073/.svn/text-base/schema-073.sql.svn-base:    LANGUAGE plpgsql
+./sourceTest/sql/postgresql/073/.svn/text-base/schema-073.sql.svn-base:    LANGUAGE plpgsql
+./sourceTest/sql/postgresql/073/schema-073.sql:    LANGUAGE plpgsql
+./sourceTest/sql/postgresql/073/schema-073.sql:    LANGUAGE plpgsql
+./sourceTest/sql/postgresql/073/schema-073.sql:    LANGUAGE plpgsql
+./sourceTest/sql/postgresql/073/schema-073.sql:    LANGUAGE plpgsql
+./sourceTest/sql/postgresql/073/schema-073.sql:    LANGUAGE plpgsql
+./sourceTest/sql/postgresql/073/schema-073.sql:    LANGUAGE plpgsql
+./sourceTest/sql/postgresql/073/schema-073.sql:    LANGUAGE plpgsql
+./sourceTest/sql/postgresql/073/schema-073.sql:    LANGUAGE plpgsql
+./sourceTest/sql/postgresql/073/schema-073.sql:    LANGUAGE plpgsql
+./sourceTest/sql/postgresql/074/.svn/text-base/schema-074.sql.svn-base:    LANGUAGE plpgsql
+./sourceTest/sql/postgresql/074/.svn/text-base/schema-074.sql.svn-base:    LANGUAGE plpgsql
+./sourceTest/sql/postgresql/074/.svn/text-base/schema-074.sql.svn-base:    LANGUAGE plpgsql
+./sourceTest/sql/postgresql/074/.svn/text-base/schema-074.sql.svn-base:    LANGUAGE plpgsql
+./sourceTest/sql/postgresql/074/.svn/text-base/schema-074.sql.svn-base:    LANGUAGE plpgsql
+./sourceTest/sql/postgresql/074/.svn/text-base/schema-074.sql.svn-base:    LANGUAGE plpgsql
+./sourceTest/sql/postgresql/074/.svn/text-base/schema-074.sql.svn-base:    LANGUAGE plpgsql
+./sourceTest/sql/postgresql/074/.svn/text-base/schema-074.sql.svn-base:    LANGUAGE plpgsql
+./sourceTest/sql/postgresql/074/.svn/text-base/schema-074.sql.svn-base:    LANGUAGE plpgsql
+./sourceTest/sql/postgresql/074/schema-074.sql:    LANGUAGE plpgsql
+./sourceTest/sql/postgresql/074/schema-074.sql:    LANGUAGE plpgsql
+./sourceTest/sql/postgresql/074/schema-074.sql:    LANGUAGE plpgsql
+./sourceTest/sql/postgresql/074/schema-074.sql:    LANGUAGE plpgsql
+./sourceTest/sql/postgresql/074/schema-074.sql:    LANGUAGE plpgsql
+./sourceTest/sql/postgresql/074/schema-074.sql:    LANGUAGE plpgsql
+./sourceTest/sql/postgresql/074/schema-074.sql:    LANGUAGE plpgsql
+./sourceTest/sql/postgresql/074/schema-074.sql:    LANGUAGE plpgsql
+./sourceTest/sql/postgresql/074/schema-074.sql:    LANGUAGE plpgsql
+./sourceTest/sql/postgresql/075/.svn/text-base/schema-075.sql.svn-base:    LANGUAGE plpgsql
+./sourceTest/sql/postgresql/075/.svn/text-base/schema-075.sql.svn-base:    LANGUAGE plpgsql
+./sourceTest/sql/postgresql/075/.svn/text-base/schema-075.sql.svn-base:    LANGUAGE plpgsql
+./sourceTest/sql/postgresql/075/.svn/text-base/schema-075.sql.svn-base:    LANGUAGE plpgsql
+./sourceTest/sql/postgresql/075/.svn/text-base/schema-075.sql.svn-base:    LANGUAGE plpgsql
+./sourceTest/sql/postgresql/075/.svn/text-base/schema-075.sql.svn-base:    LANGUAGE plpgsql
+./sourceTest/sql/postgresql/075/.svn/text-base/schema-075.sql.svn-base:    LANGUAGE plpgsql
+./sourceTest/sql/postgresql/075/.svn/text-base/schema-075.sql.svn-base:    LANGUAGE plpgsql
+./sourceTest/sql/postgresql/075/.svn/text-base/schema-075.sql.svn-base:    LANGUAGE plpgsql
+./sourceTest/sql/postgresql/075/schema-075.sql:    LANGUAGE plpgsql
+./sourceTest/sql/postgresql/075/schema-075.sql:    LANGUAGE plpgsql
+./sourceTest/sql/postgresql/075/schema-075.sql:    LANGUAGE plpgsql
+./sourceTest/sql/postgresql/075/schema-075.sql:    LANGUAGE plpgsql
+./sourceTest/sql/postgresql/075/schema-075.sql:    LANGUAGE plpgsql
+./sourceTest/sql/postgresql/075/schema-075.sql:    LANGUAGE plpgsql
+./sourceTest/sql/postgresql/075/schema-075.sql:    LANGUAGE plpgsql
+./sourceTest/sql/postgresql/075/schema-075.sql:    LANGUAGE plpgsql
+./sourceTest/sql/postgresql/075/schema-075.sql:    LANGUAGE plpgsql
+./sourceTest/sql/postgresql/076/.svn/text-base/schema-076.sql.svn-base:    LANGUAGE plpgsql
+./sourceTest/sql/postgresql/076/.svn/text-base/schema-076.sql.svn-base:    LANGUAGE plpgsql
+./sourceTest/sql/postgresql/076/.svn/text-base/schema-076.sql.svn-base:    LANGUAGE plpgsql
+./sourceTest/sql/postgresql/076/.svn/text-base/schema-076.sql.svn-base:    LANGUAGE plpgsql
+./sourceTest/sql/postgresql/076/.svn/text-base/schema-076.sql.svn-base:    LANGUAGE plpgsql
+./sourceTest/sql/postgresql/076/.svn/text-base/schema-076.sql.svn-base:    LANGUAGE plpgsql
+./sourceTest/sql/postgresql/076/.svn/text-base/schema-076.sql.svn-base:    LANGUAGE plpgsql
+./sourceTest/sql/postgresql/076/.svn/text-base/schema-076.sql.svn-base:    LANGUAGE plpgsql
+./sourceTest/sql/postgresql/076/.svn/text-base/schema-076.sql.svn-base:    LANGUAGE plpgsql
+./sourceTest/sql/postgresql/076/.svn/text-base/schema-076.sql.svn-base:    LANGUAGE plpgsql
+./sourceTest/sql/postgresql/076/.svn/text-base/schema-076.sql.svn-base:    LANGUAGE plpgsql
+./sourceTest/sql/postgresql/076/.svn/text-base/schema-076.sql.svn-base:    LANGUAGE plpgsql
+./sourceTest/sql/postgresql/076/.svn/text-base/schema-076.sql.svn-base:    LANGUAGE plpgsql
+./sourceTest/sql/postgresql/076/.svn/text-base/schema-076.sql.svn-base:    LANGUAGE plpgsql
+./sourceTest/sql/postgresql/076/schema-076.sql:    LANGUAGE plpgsql
+./sourceTest/sql/postgresql/076/schema-076.sql:    LANGUAGE plpgsql
+./sourceTest/sql/postgresql/076/schema-076.sql:    LANGUAGE plpgsql
+./sourceTest/sql/postgresql/076/schema-076.sql:    LANGUAGE plpgsql
+./sourceTest/sql/postgresql/076/schema-076.sql:    LANGUAGE plpgsql
+./sourceTest/sql/postgresql/076/schema-076.sql:    LANGUAGE plpgsql
+./sourceTest/sql/postgresql/076/schema-076.sql:    LANGUAGE plpgsql
+./sourceTest/sql/postgresql/076/schema-076.sql:    LANGUAGE plpgsql
+./sourceTest/sql/postgresql/076/schema-076.sql:    LANGUAGE plpgsql
+./sourceTest/sql/postgresql/076/schema-076.sql:    LANGUAGE plpgsql
+./sourceTest/sql/postgresql/076/schema-076.sql:    LANGUAGE plpgsql
+./sourceTest/sql/postgresql/076/schema-076.sql:    LANGUAGE plpgsql
+./sourceTest/sql/postgresql/076/schema-076.sql:    LANGUAGE plpgsql
+./sourceTest/sql/postgresql/076/schema-076.sql:    LANGUAGE plpgsql
+./sourceTest/sql/postgresql/077/.svn/text-base/schema-077.sql.svn-base:    LANGUAGE plpgsql
+./sourceTest/sql/postgresql/077/.svn/text-base/schema-077.sql.svn-base:    LANGUAGE plpgsql
+./sourceTest/sql/postgresql/077/.svn/text-base/schema-077.sql.svn-base:    LANGUAGE plpgsql
+./sourceTest/sql/postgresql/077/.svn/text-base/schema-077.sql.svn-base:    LANGUAGE plpgsql
+./sourceTest/sql/postgresql/077/.svn/text-base/schema-077.sql.svn-base:    LANGUAGE plpgsql
+./sourceTest/sql/postgresql/077/.svn/text-base/schema-077.sql.svn-base:    LANGUAGE plpgsql
+./sourceTest/sql/postgresql/077/.svn/text-base/schema-077.sql.svn-base:    LANGUAGE plpgsql
+./sourceTest/sql/postgresql/077/.svn/text-base/schema-077.sql.svn-base:    LANGUAGE plpgsql
+./sourceTest/sql/postgresql/077/.svn/text-base/schema-077.sql.svn-base:    LANGUAGE plpgsql
+./sourceTest/sql/postgresql/077/.svn/text-base/schema-077.sql.svn-base:    LANGUAGE plpgsql
+./sourceTest/sql/postgresql/077/.svn/text-base/schema-077.sql.svn-base:    LANGUAGE plpgsql
+./sourceTest/sql/postgresql/077/.svn/text-base/schema-077.sql.svn-base:    LANGUAGE plpgsql
+./sourceTest/sql/postgresql/077/.svn/text-base/schema-077.sql.svn-base:    LANGUAGE plpgsql
+./sourceTest/sql/postgresql/077/.svn/text-base/schema-077.sql.svn-base:    LANGUAGE plpgsql
+./sourceTest/sql/postgresql/077/schema-077.sql:    LANGUAGE plpgsql
+./sourceTest/sql/postgresql/077/schema-077.sql:    LANGUAGE plpgsql
+./sourceTest/sql/postgresql/077/schema-077.sql:    LANGUAGE plpgsql
+./sourceTest/sql/postgresql/077/schema-077.sql:    LANGUAGE plpgsql
+./sourceTest/sql/postgresql/077/schema-077.sql:    LANGUAGE plpgsql
+./sourceTest/sql/postgresql/077/schema-077.sql:    LANGUAGE plpgsql
+./sourceTest/sql/postgresql/077/schema-077.sql:    LANGUAGE plpgsql
+./sourceTest/sql/postgresql/077/schema-077.sql:    LANGUAGE plpgsql
+./sourceTest/sql/postgresql/077/schema-077.sql:    LANGUAGE plpgsql
+./sourceTest/sql/postgresql/077/schema-077.sql:    LANGUAGE plpgsql
+./sourceTest/sql/postgresql/077/schema-077.sql:    LANGUAGE plpgsql
+./sourceTest/sql/postgresql/077/schema-077.sql:    LANGUAGE plpgsql
+./sourceTest/sql/postgresql/077/schema-077.sql:    LANGUAGE plpgsql
+./sourceTest/sql/postgresql/077/schema-077.sql:    LANGUAGE plpgsql
+./sourceTest/sql/postgresql/078/.svn/text-base/schema-078.sql.svn-base:    LANGUAGE plpgsql
+./sourceTest/sql/postgresql/078/.svn/text-base/schema-078.sql.svn-base:    LANGUAGE plpgsql
+./sourceTest/sql/postgresql/078/.svn/text-base/schema-078.sql.svn-base:    LANGUAGE plpgsql
+./sourceTest/sql/postgresql/078/.svn/text-base/schema-078.sql.svn-base:    LANGUAGE plpgsql
+./sourceTest/sql/postgresql/078/.svn/text-base/schema-078.sql.svn-base:    LANGUAGE plpgsql
+./sourceTest/sql/postgresql/078/.svn/text-base/schema-078.sql.svn-base:    LANGUAGE plpgsql
+./sourceTest/sql/postgresql/078/.svn/text-base/schema-078.sql.svn-base:    LANGUAGE plpgsql
+./sourceTest/sql/postgresql/078/.svn/text-base/schema-078.sql.svn-base:    LANGUAGE plpgsql
+./sourceTest/sql/postgresql/078/.svn/text-base/schema-078.sql.svn-base:    LANGUAGE plpgsql
+./sourceTest/sql/postgresql/078/.svn/text-base/schema-078.sql.svn-base:    LANGUAGE plpgsql
+./sourceTest/sql/postgresql/078/.svn/text-base/schema-078.sql.svn-base:    LANGUAGE plpgsql
+./sourceTest/sql/postgresql/078/.svn/text-base/schema-078.sql.svn-base:    LANGUAGE plpgsql
+./sourceTest/sql/postgresql/078/.svn/text-base/schema-078.sql.svn-base:    LANGUAGE plpgsql
+./sourceTest/sql/postgresql/078/.svn/text-base/schema-078.sql.svn-base:    LANGUAGE plpgsql
+./sourceTest/sql/postgresql/078/schema-078.sql:    LANGUAGE plpgsql
+./sourceTest/sql/postgresql/078/schema-078.sql:    LANGUAGE plpgsql
+./sourceTest/sql/postgresql/078/schema-078.sql:    LANGUAGE plpgsql
+./sourceTest/sql/postgresql/078/schema-078.sql:    LANGUAGE plpgsql
+./sourceTest/sql/postgresql/078/schema-078.sql:    LANGUAGE plpgsql
+./sourceTest/sql/postgresql/078/schema-078.sql:    LANGUAGE plpgsql
+./sourceTest/sql/postgresql/078/schema-078.sql:    LANGUAGE plpgsql
+./sourceTest/sql/postgresql/078/schema-078.sql:    LANGUAGE plpgsql
+./sourceTest/sql/postgresql/078/schema-078.sql:    LANGUAGE plpgsql
+./sourceTest/sql/postgresql/078/schema-078.sql:    LANGUAGE plpgsql
+./sourceTest/sql/postgresql/078/schema-078.sql:    LANGUAGE plpgsql
+./sourceTest/sql/postgresql/078/schema-078.sql:    LANGUAGE plpgsql
+./sourceTest/sql/postgresql/078/schema-078.sql:    LANGUAGE plpgsql
+./sourceTest/sql/postgresql/078/schema-078.sql:    LANGUAGE plpgsql
+./sourceTest/sql/postgresql/079/.svn/text-base/schema-079.sql.svn-base:    LANGUAGE plpgsql
+./sourceTest/sql/postgresql/079/.svn/text-base/schema-079.sql.svn-base:    LANGUAGE plpgsql
+./sourceTest/sql/postgresql/079/.svn/text-base/schema-079.sql.svn-base:    LANGUAGE plpgsql
+./sourceTest/sql/postgresql/079/.svn/text-base/schema-079.sql.svn-base:    LANGUAGE plpgsql
+./sourceTest/sql/postgresql/079/.svn/text-base/schema-079.sql.svn-base:    LANGUAGE plpgsql
+./sourceTest/sql/postgresql/079/.svn/text-base/schema-079.sql.svn-base:    LANGUAGE plpgsql
+./sourceTest/sql/postgresql/079/.svn/text-base/schema-079.sql.svn-base:    LANGUAGE plpgsql
+./sourceTest/sql/postgresql/079/.svn/text-base/schema-079.sql.svn-base:    LANGUAGE plpgsql
+./sourceTest/sql/postgresql/079/.svn/text-base/schema-079.sql.svn-base:    LANGUAGE plpgsql
+./sourceTest/sql/postgresql/079/.svn/text-base/schema-079.sql.svn-base:    LANGUAGE plpgsql
+./sourceTest/sql/postgresql/079/.svn/text-base/schema-079.sql.svn-base:    LANGUAGE plpgsql
+./sourceTest/sql/postgresql/079/.svn/text-base/schema-079.sql.svn-base:    LANGUAGE plpgsql
+./sourceTest/sql/postgresql/079/.svn/text-base/schema-079.sql.svn-base:    LANGUAGE plpgsql
+./sourceTest/sql/postgresql/079/.svn/text-base/schema-079.sql.svn-base:    LANGUAGE plpgsql
+./sourceTest/sql/postgresql/079/schema-079.sql:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql;
+./sourceTest/sql/postgresql/079/schema-079.sql:    LANGUAGE plpgsql
+./sourceTest/sql/postgresql/079/schema-079.sql:    LANGUAGE plpgsql
+./sourceTest/sql/postgresql/079/schema-079.sql:    LANGUAGE plpgsql
+./sourceTest/sql/postgresql/079/schema-079.sql:    LANGUAGE plpgsql
+./sourceTest/sql/postgresql/079/schema-079.sql:    LANGUAGE plpgsql
+./sourceTest/sql/postgresql/079/schema-079.sql:    LANGUAGE plpgsql
+./sourceTest/sql/postgresql/079/schema-079.sql:    LANGUAGE plpgsql
+./sourceTest/sql/postgresql/079/schema-079.sql:    LANGUAGE plpgsql
+./sourceTest/sql/postgresql/079/schema-079.sql:    LANGUAGE plpgsql
+./sourceTest/sql/postgresql/079/schema-079.sql:    LANGUAGE plpgsql
+./sourceTest/sql/postgresql/079/schema-079.sql:    LANGUAGE plpgsql
+./sourceTest/sql/postgresql/079/schema-079.sql:    LANGUAGE plpgsql
+./sourceTest/sql/postgresql/079/schema-079.sql:    LANGUAGE plpgsql
+./sourceTest/sql/postgresql/079/schema-079.sql:    LANGUAGE plpgsql
+./sourceTest/sql/postgresql/test_database_for_migration/postgresql/007/.svn/text-base/003=database_version_logs.tsv.svn-base:007	source/sql/postgresql/007/schema-007.sql	SUCCESS	2007-12-04 15:50:54.064	-- D:\\\\DDL\\\\postgresql\\\\schema-007.sql\\012--\\012-- Generated for ANSI SQL92 on Thu Aug 23  19:02:15 2007 by Server Generator 10.1.2.6.18\\012-- Post generation PostgreSQL specific Changes:\\012-- \\012--  1. change domain FILE from BIT(32000) to BYTEA\\012--  2. change domain TECH_ID from NUMERIC(20) to BIGINT\\012--  3. Put single quotes around the default value NOW in the create domain statement for the domain TIME_STAMP\\012--     i.e. change CREATE DOMAIN TIME_STAMP AS TIMESTAMP DEFAULT now; to CREATE DOMAIN TIME_STAMP AS TIMESTAMP DEFAULT 'now';\\012--  4. Temporarily not created, due to data quality issues with the master plate layout data\\012--\\012-- ALTER TABLE MOLECULES ADD CONSTRAINT MOLE_BK_UK UNIQUE(SEQUENCE);\\012\\012\\012\\012CREATE DOMAIN DESCRIPTION_80 AS VARCHAR(80);\\012CREATE DOMAIN USER_ID AS VARCHAR(20);\\012CREATE DOMAIN DOUBLE_PRECISION_VALUE AS DOUBLE PRECISION;\\012CREATE DOMAIN FILE_NAME AS VARCHAR(100);\\012CREATE DOMAIN TECH_ID AS BIGINT;\\012CREATE DOMAIN OBJECT_NAME AS VARCHAR(50);\\012CREATE DOMAIN TIME_STAMP AS TIMESTAMP DEFAULT CURRENT_TIMESTAMP;\\012CREATE DOMAIN REAL_VALUE AS REAL;\\012CREATE DOMAIN FILE AS BYTEA;\\012CREATE DOMAIN CODE AS VARCHAR(20);\\012CREATE DOMAIN DESCRIPTION_250 AS VARCHAR(250);\\012CREATE TABLE EXPERIMENT_PROPERTIES  (ID TECH_ID NOT NULL,EXPE_ID TECH_ID NOT NULL,FILE_NAME FILE_NAME NOT NULL,REGISTRATION_TIMESTAMP TIME_STAMP NOT NULL DEFAULT CURRENT_TIMESTAMP,VALUE FILE NOT NULL,VERSION INTEGER NOT NULL,PERS_ID_REGISTERER TECH_ID NOT NULL) ;\\012CREATE TABLE EXPERIMENT_TYPES  (ID TECH_ID NOT NULL,CODE CODE NOT NULL,DESCRIPTION DESCRIPTION_80) ;\\012CREATE TABLE DATA_VALUES  (ID TECH_ID NOT NULL,DATA_ID TECH_ID NOT NULL,SACO_ID TECH_ID NOT NULL,VALUE DOUBLE_PRECISION_VALUE NOT NULL) ;\\012CREATE TABLE PERSONS  (ID TECH_ID NOT NULL,FIRST_NAME VARCHAR(30),LAST_NAME VARCHAR(30),USER_ID USER_ID,EMAIL OBJECT_NAME) ;\\012CREATE TABLE FILE_FORMAT_TYPES  (ID TECH_ID NOT NULL,CODE CODE NOT NULL,DESCRIPTION DESCRIPTION_80) ;\\012CREATE TABLE SAMPLE_INPUTS  (ID TECH_ID NOT NULL,SAMP_ID TECH_ID NOT NULL,PROC_ID TECH_ID NOT NULL) ;\\012CREATE TABLE OBSERVABLE_TYPES  (ID TECH_ID NOT NULL,CODE CODE NOT NULL,DESCRIPTION DESCRIPTION_80) ;\\012CREATE TABLE LOCATOR_TYPES  (ID TECH_ID NOT NULL,CODE CODE NOT NULL,DESCRIPTION DESCRIPTION_80) ;\\012CREATE TABLE SAMPLE_COMPONENTS  (ID TECH_ID NOT NULL,CODE CODE NOT NULL,SAMP_ID TECH_ID NOT NULL) ;\\012CREATE TABLE SAMPLE_TYPES  (ID TECH_ID NOT NULL,CODE CODE NOT NULL,DESCRIPTION DESCRIPTION_80) ;\\012CREATE TABLE ORGANIZATIONS  (ID TECH_ID NOT NULL,CODE CODE NOT NULL) ;\\012CREATE TABLE PROCEDURES  (ID TECH_ID NOT NULL,REGISTRATION_TIMESTAMP TIME_STAMP NOT NULL DEFAULT CURRENT_TIMESTAMP,EXPE_ID TECH_ID NOT NULL,PCTY_ID TECH_ID NOT NULL,PERS_ID TECH_ID) ;\\012CREATE TABLE PROCEDURE_TYPES  (ID TECH_ID NOT NULL,CODE CODE NOT NULL,DESCRIPTION DESCRIPTION_80 NOT NULL) ;\\012CREATE TABLE PROJECTS  (ID TECH_ID NOT NULL,CODE CODE NOT NULL,ORGA_ID TECH_ID NOT NULL) ;\\012CREATE TABLE SAMPLE_COMPONENT_MATERIALS  (ID TECH_ID NOT NULL,SACO_ID TECH_ID NOT NULL,MABA_ID TECH_ID NOT NULL) ;\\012CREATE TABLE EXTERNAL_DATA  (DATA_ID TECH_ID NOT NULL,LOCATION VARCHAR(200) NOT NULL,LOTY_ID TECH_ID NOT NULL,FFTY_ID TECH_ID NOT NULL) ;\\012CREATE TABLE DATA  (ID TECH_ID NOT NULL,REGISTRATION_TIMESTAMP TIME_STAMP NOT NULL DEFAULT CURRENT_TIMESTAMP,OBTY_ID TECH_ID NOT NULL,PROC_ID_ACQUIRED_BY TECH_ID NOT NULL,SAMP_ID_ACQUIRED_FROM TECH_ID,SAMP_ID_DERIVED_FROM TECH_ID) ;\\012CREATE TABLE SAMPLES  (ID TECH_ID NOT NULL,CODE CODE NOT NULL,CONT_ID TECH_ID,PROC_ID TECH_ID,SAMP_ID_TOP TECH_ID,SAMP_ID_GENERATED_FROM TECH_ID,SATY_ID TECH_ID NOT NULL,REGISTRATION_TIMESTAMP TIME_STAMP NOT NULL DEFAULT CURRENT_TIMESTAMP,PERS_ID_REGISTERER TECH_ID NOT NULL) ;\\012CREATE TABLE MATERIAL_TYPES  (ID TECH_ID NOT NULL,CODE CODE NOT NULL,DESCRIPTION DESCRIPTION_80) ;\\012CREATE TABLE MATERIAL_BATCHES  (ID TECH_ID NOT NULL,CODE CODE NOT NULL,AMOUNT REAL_VALUE,MATE_ID TECH_ID NOT NULL,CONT_ID TECH_ID,PROC_ID TECH_ID,REGISTRATION_TIMESTAMP TIME_STAMP NOT NULL DEFAULT CURRENT_TIMESTAMP,PERS_ID_REGISTERER TECH_ID NOT NULL) ;\\012CREATE TABLE MATERIALS  (ID TECH_ID NOT NULL,CODE CODE NOT NULL,DESCRIPTION DESCRIPTION_250,MATY_ID TECH_ID NOT NULL,REGISTRATION_TIMESTAMP TIME_STAMP NOT NULL DEFAULT CURRENT_TIMESTAMP,PERS_ID_REGISTERER TECH_ID NOT NULL) ;\\012CREATE TABLE MOLECULES  (MATE_ID TECH_ID NOT NULL,SEQUENCE VARCHAR(100),ACCESSION_NUMBER OBJECT_NAME,OFF_SET VARCHAR(20),MOLE_ID_INHIBITOR_OF TECH_ID,GENE_SYMBOL CODE) ;\\012CREATE TABLE EXPERIMENTS  (ID TECH_ID NOT NULL,CODE CODE NOT NULL,EXTY_ID TECH_ID NOT NULL,MATE_ID_STUDY_OBJECT TECH_ID,PERS_ID_REGISTERER TECH_ID,REGISTRATION_TIMESTAMP TIME_STAMP NOT NULL DEFAULT CURRENT_TIMESTAMP,DESCRIPTION DESCRIPTION_250,PROJ_ID TECH_ID NOT NULL) ;\\012\\012ALTER TABLE EXPERIMENT_PROPERTIES ADD CONSTRAINT EXPR_PK PRIMARY KEY(ID);\\012ALTER TABLE EXPERIMENT_TYPES ADD CONSTRAINT EXTY_PK PRIMARY KEY(ID);\\012ALTER TABLE DATA_VALUES ADD CONSTRAINT DAVA_PK PRIMARY KEY(ID);\\012ALTER TABLE PERSONS ADD CONSTRAINT PERS_PK PRIMARY KEY(ID);\\012ALTER TABLE FILE_FORMAT_TYPES ADD CONSTRAINT FFTY_PK PRIMARY KEY(ID);\\012ALTER TABLE SAMPLE_INPUTS ADD CONSTRAINT SAIN_PK PRIMARY KEY(ID);\\012ALTER TABLE OBSERVABLE_TYPES ADD CONSTRAINT OBTY_PK PRIMARY KEY(ID);\\012ALTER TABLE LOCATOR_TYPES ADD CONSTRAINT LOTY_PK PRIMARY KEY(ID);\\012ALTER TABLE SAMPLE_COMPONENTS ADD CONSTRAINT SACO_PK PRIMARY KEY(ID);\\012ALTER TABLE SAMPLE_TYPES ADD CONSTRAINT SATY_PK PRIMARY KEY(ID);\\012ALTER TABLE ORGANIZATIONS ADD CONSTRAINT ORGA_PK PRIMARY KEY(ID);\\012ALTER TABLE PROCEDURES ADD CONSTRAINT PROC_PK PRIMARY KEY(ID);\\012ALTER TABLE PROCEDURE_TYPES ADD CONSTRAINT PCTY_PK PRIMARY KEY(ID);\\012ALTER TABLE PROJECTS ADD CONSTRAINT PROJ_PK PRIMARY KEY(ID);\\012ALTER TABLE SAMPLE_COMPONENT_MATERIALS ADD CONSTRAINT SCMA_PK PRIMARY KEY(ID);\\012ALTER TABLE EXTERNAL_DATA ADD CONSTRAINT EXDA_PK PRIMARY KEY(DATA_ID);\\012ALTER TABLE DATA ADD CONSTRAINT DATA_PK PRIMARY KEY(ID);\\012ALTER TABLE SAMPLES ADD CONSTRAINT SAMP_PK PRIMARY KEY(ID);\\012ALTER TABLE MATERIAL_TYPES ADD CONSTRAINT MATY_PK PRIMARY KEY(ID);\\012ALTER TABLE MATERIAL_BATCHES ADD CONSTRAINT MABA_PK PRIMARY KEY(ID);\\012ALTER TABLE MATERIALS ADD CONSTRAINT MATE_PK PRIMARY KEY(ID);\\012ALTER TABLE MOLECULES ADD CONSTRAINT MOLE_PK PRIMARY KEY(MATE_ID);\\012ALTER TABLE EXPERIMENTS ADD CONSTRAINT EXPE_PK PRIMARY KEY(ID);\\012ALTER TABLE EXPERIMENT_PROPERTIES ADD CONSTRAINT EXPR_BK_UK UNIQUE(EXPE_ID,FILE_NAME,VERSION);\\012ALTER TABLE EXPERIMENT_TYPES ADD CONSTRAINT EXTY_BK_UK UNIQUE(CODE);\\012ALTER TABLE DATA_VALUES ADD CONSTRAINT DAVA_BK_UK UNIQUE(DATA_ID,SACO_ID);\\012ALTER TABLE PERSONS ADD CONSTRAINT PERS_BK_UK UNIQUE(USER_ID);\\012ALTER TABLE FILE_FORMAT_TYPES ADD CONSTRAINT FFTY_BK_UK UNIQUE(CODE);\\012ALTER TABLE SAMPLE_INPUTS ADD CONSTRAINT SAIN_BK_UK UNIQUE(SAMP_ID,PROC_ID);\\012ALTER TABLE OBSERVABLE_TYPES ADD CONSTRAINT OBTY_BK_UK UNIQUE(CODE);\\012ALTER TABLE LOCATOR_TYPES ADD CONSTRAINT LOTY_BK_UK UNIQUE(CODE);\\012ALTER TABLE SAMPLE_COMPONENTS ADD CONSTRAINT SACO_BK_UK UNIQUE(CODE,SAMP_ID);\\012ALTER TABLE SAMPLE_TYPES ADD CONSTRAINT SATY_BK_UK UNIQUE(CODE);\\012ALTER TABLE ORGANIZATIONS ADD CONSTRAINT ORGA_BK_UK UNIQUE(CODE);\\012ALTER TABLE PROCEDURE_TYPES ADD CONSTRAINT PCTY_BK_UK UNIQUE(CODE);\\012ALTER TABLE PROJECTS ADD CONSTRAINT PROJ_BK_UK UNIQUE(CODE,ORGA_ID);\\012ALTER TABLE SAMPLE_COMPONENT_MATERIALS ADD CONSTRAINT SCMA_BK_UK UNIQUE(MABA_ID,SACO_ID);\\012ALTER TABLE EXTERNAL_DATA ADD CONSTRAINT EXDA_BK_UK UNIQUE(LOCATION);\\012ALTER TABLE SAMPLES ADD CONSTRAINT SAMP_BK_UK UNIQUE(CODE);\\012ALTER TABLE MATERIAL_TYPES ADD CONSTRAINT MATY_UK UNIQUE(CODE);\\012ALTER TABLE MATERIAL_TYPES ADD CONSTRAINT MATY_BK_UK UNIQUE(CODE);\\012ALTER TABLE MATERIALS ADD CONSTRAINT MATE_BK_UK UNIQUE(CODE);\\012--\\012--  Temporarily not created, due to data quality issues with the master plate layout data\\012--\\012-- ALTER TABLE MOLECULES ADD CONSTRAINT MOLE_BK_UK UNIQUE(SEQUENCE);\\012ALTER TABLE EXPERIMENTS ADD CONSTRAINT EXPE_BK_UK UNIQUE(CODE,PROJ_ID);\\012\\012ALTER TABLE DATA ADD CONSTRAINT DATA_SAMP_ARC_CK CHECK ((samp_id_acquired_from IS NOT NULL \\012and samp_id_derived_from IS NULL) \\012or (samp_id_acquired_from IS NULL \\012and samp_id_derived_from IS NOT NULL)) ;\\012ALTER TABLE EXPERIMENT_PROPERTIES ADD CONSTRAINT EXPR_PERS_FK FOREIGN KEY (PERS_ID_REGISTERER)REFERENCES PERSONS(ID);\\012ALTER TABLE EXPERIMENT_PROPERTIES ADD CONSTRAINT EXPR_EXPE_FK FOREIGN KEY (EXPE_ID)REFERENCES EXPERIMENTS(ID);\\012ALTER TABLE DATA_VALUES ADD CONSTRAINT DAVA_DATA_FK FOREIGN KEY (DATA_ID)REFERENCES DATA(ID);\\012ALTER TABLE DATA_VALUES ADD CONSTRAINT DAVA_SACO_FK FOREIGN KEY (SACO_ID)REFERENCES SAMPLE_COMPONENTS(ID);\\012ALTER TABLE SAMPLE_INPUTS ADD CONSTRAINT SAIN_PROC_FK FOREIGN KEY (PROC_ID)REFERENCES PROCEDURES(ID);\\012ALTER TABLE SAMPLE_INPUTS ADD CONSTRAINT SAIN_SAMP_FK FOREIGN KEY (SAMP_ID)REFERENCES SAMPLES(ID);\\012ALTER TABLE SAMPLE_COMPONENTS ADD CONSTRAINT SACO_SAMP_FK FOREIGN KEY (SAMP_ID)REFERENCES SAMPLES(ID);\\012ALTER TABLE PROCEDURES ADD CONSTRAINT PROC_PCTY_FK FOREIGN KEY (PCTY_ID)REFERENCES PROCEDURE_TYPES(ID);\\012ALTER TABLE PROCEDURES ADD CONSTRAINT PROC_PERS_FK FOREIGN KEY (PERS_ID)REFERENCES PERSONS(ID);\\012ALTER TABLE PROCEDURES ADD CONSTRAINT PROC_EXPE_FK FOREIGN KEY (EXPE_ID)REFERENCES EXPERIMENTS(ID);\\012ALTER TABLE PROJECTS ADD CONSTRAINT PROJ_ORGA_FK FOREIGN KEY (ORGA_ID)REFERENCES ORGANIZATIONS(ID);\\012ALTER TABLE SAMPLE_COMPONENT_MATERIALS ADD CONSTRAINT SCMA_MABA_FK FOREIGN KEY (MABA_ID)REFERENCES MATERIAL_BATCHES(ID);\\012ALTER TABLE SAMPLE_COMPONENT_MATERIALS ADD CONSTRAINT SCMA_SACO_FK FOREIGN KEY (SACO_ID)REFERENCES SAMPLE_COMPONENTS(ID);\\012ALTER TABLE EXTERNAL_DATA ADD CONSTRAINT EXDA_DATA_FK FOREIGN KEY (DATA_ID)REFERENCES DATA(ID);\\012ALTER TABLE EXTERNAL_DATA ADD CONSTRAINT EXDA_LOTY_FK FOREIGN KEY (LOTY_ID)REFERENCES LOCATOR_TYPES(ID);\\012ALTER TABLE EXTERNAL_DATA ADD CONSTRAINT EXDA_FFTY_FK FOREIGN KEY (FFTY_ID)REFERENCES FILE_FORMAT_TYPES(ID);\\012ALTER TABLE DATA ADD CONSTRAINT DATA_SAMP_DERIVED_FROM_FK FOREIGN KEY (SAMP_ID_DERIVED_FROM)REFERENCES SAMPLES(ID);\\012ALTER TABLE DATA ADD CONSTRAINT DATA_SAMP_FK FOREIGN KEY (SAMP_ID_ACQUIRED_FROM)REFERENCES SAMPLES(ID);\\012ALTER TABLE DATA ADD CONSTRAINT DATA_PROC_FK FOREIGN KEY (PROC_ID_ACQUIRED_BY)REFERENCES PROCEDURES(ID);\\012ALTER TABLE DATA ADD CONSTRAINT DATA_OBTY_FK FOREIGN KEY (OBTY_ID)REFERENCES OBSERVABLE_TYPES(ID);\\012ALTER TABLE SAMPLES ADD CONSTRAINT SAMP_PERS_FK FOREIGN KEY (PERS_ID_REGISTERER)REFERENCES PERSONS(ID);\\012ALTER TABLE SAMPLES ADD CONSTRAINT SAMP_PROC_FK FOREIGN KEY (PROC_ID)REFERENCES PROCEDURES(ID);\\012ALTER TABLE SAMPLES ADD CONSTRAINT SAMP_SAMP_FK_GENERATED_FROM FOREIGN KEY (SAMP_ID_GENERATED_FROM)REFERENCES SAMPLES(ID);\\012ALTER TABLE SAMPLES ADD CONSTRAINT SAMP_SAMP_FK_TOP FOREIGN KEY (SAMP_ID_TOP)REFERENCES SAMPLES(ID);\\012ALTER TABLE SAMPLES ADD CONSTRAINT SAMP_SATY_FK FOREIGN KEY (SATY_ID)REFERENCES SAMPLE_TYPES(ID);\\012ALTER TABLE MATERIAL_BATCHES ADD CONSTRAINT MABA_PERS_FK FOREIGN KEY (PERS_ID_REGISTERER)REFERENCES PERSONS(ID);\\012ALTER TABLE MATERIAL_BATCHES ADD CONSTRAINT MABA_MATE_FK FOREIGN KEY (MATE_ID)REFERENCES MATERIALS(ID);\\012ALTER TABLE MATERIAL_BATCHES ADD CONSTRAINT MABA_PROC_FK FOREIGN KEY (PROC_ID)REFERENCES PROCEDURES(ID);\\012ALTER TABLE MATERIALS ADD CONSTRAINT MATE_MATY_FK FOREIGN KEY (MATY_ID)REFERENCES MATERIAL_TYPES(ID);\\012ALTER TABLE MATERIALS ADD CONSTRAINT MATE_PERS_FK FOREIGN KEY (PERS_ID_REGISTERER)REFERENCES PERSONS(ID);\\012ALTER TABLE MOLECULES ADD CONSTRAINT MOLE_MATE_FK FOREIGN KEY (MATE_ID)REFERENCES MATERIALS(ID);\\012ALTER TABLE MOLECULES ADD CONSTRAINT MOLE_MOLE_FK FOREIGN KEY (MOLE_ID_INHIBITOR_OF)REFERENCES MOLECULES(MATE_ID);\\012ALTER TABLE EXPERIMENTS ADD CONSTRAINT EXPE_MATE_FK FOREIGN KEY (MATE_ID_STUDY_OBJECT)REFERENCES MATERIALS(ID);\\012ALTER TABLE EXPERIMENTS ADD CONSTRAINT EXPE_EXTY_FK FOREIGN KEY (EXTY_ID)REFERENCES EXPERIMENT_TYPES(ID);\\012ALTER TABLE EXPERIMENTS ADD CONSTRAINT EXPE_PERS_FK FOREIGN KEY (PERS_ID_REGISTERER)REFERENCES PERSONS(ID);\\012ALTER TABLE EXPERIMENTS ADD CONSTRAINT EXPE_PROJ_FK FOREIGN KEY (PROJ_ID)REFERENCES PROJECTS(ID);\\012\\012\\012\\012--  Creating Sequences\\012\\012CREATE SEQUENCE EXPERIMENT_PROPERTY_ID_SEQ;\\012\\012CREATE SEQUENCE PROCEDURE_TYPE_ID_SEQ;\\012\\012CREATE SEQUENCE SAMPLE_INPUT_ID_SEQ;\\012\\012CREATE SEQUENCE SAMPLE_TYPE_ID_SEQ;\\012\\012CREATE SEQUENCE LOCATOR_TYPE_ID_SEQ;\\012\\012CREATE SEQUENCE SAMPLE_ID_SEQ;\\012\\012CREATE SEQUENCE EXPERIMENT_ID_SEQ;\\012\\012CREATE SEQUENCE MATERIAL_BATCH_ID_SEQ;\\012\\012CREATE SEQUENCE OBSERVABLE_TYPE_ID_SEQ;\\012\\012CREATE SEQUENCE SAMPLE_COMPONENT_ID_SEQ;\\012\\012CREATE SEQUENCE MATERIAL_ID_SEQ;\\012\\012CREATE SEQUENCE DATA_ID_SEQ;\\012\\012--  Creating Sequence for the SAMPLE_COMPONENT_MATERIALS table (standard naming convention was too long)\\012CREATE SEQUENCE SCMA_ID_SEQ;\\012\\012CREATE SEQUENCE PROCEDURE_ID_SEQ;\\012\\012CREATE SEQUENCE FILE_FORMAT_TYPE_ID_SEQ;\\012\\012CREATE SEQUENCE MATERIAL_TYPE_ID_SEQ;\\012\\012CREATE SEQUENCE EXPERIMENT_TYPE_ID_SEQ;\\012\\012CREATE SEQUENCE PERSON_ID_SEQ;\\012\\012CREATE SEQUENCE ORGANIZATION_ID_SEQ;\\012\\012CREATE SEQUENCE PROJECT_ID_SEQ;\\012\\012CREATE SEQUENCE DATA_VALUE_ID_SEQ;\\012\\012\\012\\012/*\\012   Trigger Section\\012   ===============*/\\012\\012CREATE OR REPLACE FUNCTION br001_crtl_plate_chk() RETURNS trigger AS $br001_crtl_plate_chk$\\012DECLARE\\012   cnt           INTEGER;\\012   v_cell_plate  CODE;\\012BEGIN\\012\\012   select code into v_cell_plate from sample_types where id  = NEW.saty_id;\\012\\012   -- Check if the sample is of type "Cell Plate"\\012   if v_cell_plate = 'CELL PLATE' then\\012\\012      -- Check that a Control Plate exists before registering the Cell Plate\\012      select count(*) into cnt from samples s, sample_types st where s.saty_id = st.id and st.code = 'CONTROL LAYOUT';\\011 \\012      IF cnt = 0 THEN\\012\\011\\011 -- Doens't make sense, so comment it out\\012         -- RAISE EXCEPTION 'A Control Plate must exist before you can register Cell Plate: %', NEW.code;\\012      END IF;\\012\\012   end if;\\012\\012   RETURN NEW;\\012\\012END;\\012$br001_crtl_plate_chk$ LANGUAGE plpgsql;\\012\\012\\012CREATE TRIGGER br001_crtl_plate_chk BEFORE INSERT ON samples\\012    FOR EACH ROW EXECUTE PROCEDURE br001_crtl_plate_chk();\\012	\N
+./sourceTest/sql/postgresql/test_database_for_migration/postgresql/007/.svn/text-base/schema-007.sql.svn-base:    LANGUAGE plpgsql;
+./sourceTest/sql/postgresql/test_database_for_migration/postgresql/007/003=database_version_logs.tsv:007	source/sql/postgresql/007/schema-007.sql	SUCCESS	2007-12-04 15:50:54.064	-- D:\\\\DDL\\\\postgresql\\\\schema-007.sql\\012--\\012-- Generated for ANSI SQL92 on Thu Aug 23  19:02:15 2007 by Server Generator 10.1.2.6.18\\012-- Post generation PostgreSQL specific Changes:\\012-- \\012--  1. change domain FILE from BIT(32000) to BYTEA\\012--  2. change domain TECH_ID from NUMERIC(20) to BIGINT\\012--  3. Put single quotes around the default value NOW in the create domain statement for the domain TIME_STAMP\\012--     i.e. change CREATE DOMAIN TIME_STAMP AS TIMESTAMP DEFAULT now; to CREATE DOMAIN TIME_STAMP AS TIMESTAMP DEFAULT 'now';\\012--  4. Temporarily not created, due to data quality issues with the master plate layout data\\012--\\012-- ALTER TABLE MOLECULES ADD CONSTRAINT MOLE_BK_UK UNIQUE(SEQUENCE);\\012\\012\\012\\012CREATE DOMAIN DESCRIPTION_80 AS VARCHAR(80);\\012CREATE DOMAIN USER_ID AS VARCHAR(20);\\012CREATE DOMAIN DOUBLE_PRECISION_VALUE AS DOUBLE PRECISION;\\012CREATE DOMAIN FILE_NAME AS VARCHAR(100);\\012CREATE DOMAIN TECH_ID AS BIGINT;\\012CREATE DOMAIN OBJECT_NAME AS VARCHAR(50);\\012CREATE DOMAIN TIME_STAMP AS TIMESTAMP DEFAULT CURRENT_TIMESTAMP;\\012CREATE DOMAIN REAL_VALUE AS REAL;\\012CREATE DOMAIN FILE AS BYTEA;\\012CREATE DOMAIN CODE AS VARCHAR(20);\\012CREATE DOMAIN DESCRIPTION_250 AS VARCHAR(250);\\012CREATE TABLE EXPERIMENT_PROPERTIES  (ID TECH_ID NOT NULL,EXPE_ID TECH_ID NOT NULL,FILE_NAME FILE_NAME NOT NULL,REGISTRATION_TIMESTAMP TIME_STAMP NOT NULL DEFAULT CURRENT_TIMESTAMP,VALUE FILE NOT NULL,VERSION INTEGER NOT NULL,PERS_ID_REGISTERER TECH_ID NOT NULL) ;\\012CREATE TABLE EXPERIMENT_TYPES  (ID TECH_ID NOT NULL,CODE CODE NOT NULL,DESCRIPTION DESCRIPTION_80) ;\\012CREATE TABLE DATA_VALUES  (ID TECH_ID NOT NULL,DATA_ID TECH_ID NOT NULL,SACO_ID TECH_ID NOT NULL,VALUE DOUBLE_PRECISION_VALUE NOT NULL) ;\\012CREATE TABLE PERSONS  (ID TECH_ID NOT NULL,FIRST_NAME VARCHAR(30),LAST_NAME VARCHAR(30),USER_ID USER_ID,EMAIL OBJECT_NAME) ;\\012CREATE TABLE FILE_FORMAT_TYPES  (ID TECH_ID NOT NULL,CODE CODE NOT NULL,DESCRIPTION DESCRIPTION_80) ;\\012CREATE TABLE SAMPLE_INPUTS  (ID TECH_ID NOT NULL,SAMP_ID TECH_ID NOT NULL,PROC_ID TECH_ID NOT NULL) ;\\012CREATE TABLE OBSERVABLE_TYPES  (ID TECH_ID NOT NULL,CODE CODE NOT NULL,DESCRIPTION DESCRIPTION_80) ;\\012CREATE TABLE LOCATOR_TYPES  (ID TECH_ID NOT NULL,CODE CODE NOT NULL,DESCRIPTION DESCRIPTION_80) ;\\012CREATE TABLE SAMPLE_COMPONENTS  (ID TECH_ID NOT NULL,CODE CODE NOT NULL,SAMP_ID TECH_ID NOT NULL) ;\\012CREATE TABLE SAMPLE_TYPES  (ID TECH_ID NOT NULL,CODE CODE NOT NULL,DESCRIPTION DESCRIPTION_80) ;\\012CREATE TABLE ORGANIZATIONS  (ID TECH_ID NOT NULL,CODE CODE NOT NULL) ;\\012CREATE TABLE PROCEDURES  (ID TECH_ID NOT NULL,REGISTRATION_TIMESTAMP TIME_STAMP NOT NULL DEFAULT CURRENT_TIMESTAMP,EXPE_ID TECH_ID NOT NULL,PCTY_ID TECH_ID NOT NULL,PERS_ID TECH_ID) ;\\012CREATE TABLE PROCEDURE_TYPES  (ID TECH_ID NOT NULL,CODE CODE NOT NULL,DESCRIPTION DESCRIPTION_80 NOT NULL) ;\\012CREATE TABLE PROJECTS  (ID TECH_ID NOT NULL,CODE CODE NOT NULL,ORGA_ID TECH_ID NOT NULL) ;\\012CREATE TABLE SAMPLE_COMPONENT_MATERIALS  (ID TECH_ID NOT NULL,SACO_ID TECH_ID NOT NULL,MABA_ID TECH_ID NOT NULL) ;\\012CREATE TABLE EXTERNAL_DATA  (DATA_ID TECH_ID NOT NULL,LOCATION VARCHAR(200) NOT NULL,LOTY_ID TECH_ID NOT NULL,FFTY_ID TECH_ID NOT NULL) ;\\012CREATE TABLE DATA  (ID TECH_ID NOT NULL,REGISTRATION_TIMESTAMP TIME_STAMP NOT NULL DEFAULT CURRENT_TIMESTAMP,OBTY_ID TECH_ID NOT NULL,PROC_ID_ACQUIRED_BY TECH_ID NOT NULL,SAMP_ID_ACQUIRED_FROM TECH_ID,SAMP_ID_DERIVED_FROM TECH_ID) ;\\012CREATE TABLE SAMPLES  (ID TECH_ID NOT NULL,CODE CODE NOT NULL,CONT_ID TECH_ID,PROC_ID TECH_ID,SAMP_ID_TOP TECH_ID,SAMP_ID_GENERATED_FROM TECH_ID,SATY_ID TECH_ID NOT NULL,REGISTRATION_TIMESTAMP TIME_STAMP NOT NULL DEFAULT CURRENT_TIMESTAMP,PERS_ID_REGISTERER TECH_ID NOT NULL) ;\\012CREATE TABLE MATERIAL_TYPES  (ID TECH_ID NOT NULL,CODE CODE NOT NULL,DESCRIPTION DESCRIPTION_80) ;\\012CREATE TABLE MATERIAL_BATCHES  (ID TECH_ID NOT NULL,CODE CODE NOT NULL,AMOUNT REAL_VALUE,MATE_ID TECH_ID NOT NULL,CONT_ID TECH_ID,PROC_ID TECH_ID,REGISTRATION_TIMESTAMP TIME_STAMP NOT NULL DEFAULT CURRENT_TIMESTAMP,PERS_ID_REGISTERER TECH_ID NOT NULL) ;\\012CREATE TABLE MATERIALS  (ID TECH_ID NOT NULL,CODE CODE NOT NULL,DESCRIPTION DESCRIPTION_250,MATY_ID TECH_ID NOT NULL,REGISTRATION_TIMESTAMP TIME_STAMP NOT NULL DEFAULT CURRENT_TIMESTAMP,PERS_ID_REGISTERER TECH_ID NOT NULL) ;\\012CREATE TABLE MOLECULES  (MATE_ID TECH_ID NOT NULL,SEQUENCE VARCHAR(100),ACCESSION_NUMBER OBJECT_NAME,OFF_SET VARCHAR(20),MOLE_ID_INHIBITOR_OF TECH_ID,GENE_SYMBOL CODE) ;\\012CREATE TABLE EXPERIMENTS  (ID TECH_ID NOT NULL,CODE CODE NOT NULL,EXTY_ID TECH_ID NOT NULL,MATE_ID_STUDY_OBJECT TECH_ID,PERS_ID_REGISTERER TECH_ID,REGISTRATION_TIMESTAMP TIME_STAMP NOT NULL DEFAULT CURRENT_TIMESTAMP,DESCRIPTION DESCRIPTION_250,PROJ_ID TECH_ID NOT NULL) ;\\012\\012ALTER TABLE EXPERIMENT_PROPERTIES ADD CONSTRAINT EXPR_PK PRIMARY KEY(ID);\\012ALTER TABLE EXPERIMENT_TYPES ADD CONSTRAINT EXTY_PK PRIMARY KEY(ID);\\012ALTER TABLE DATA_VALUES ADD CONSTRAINT DAVA_PK PRIMARY KEY(ID);\\012ALTER TABLE PERSONS ADD CONSTRAINT PERS_PK PRIMARY KEY(ID);\\012ALTER TABLE FILE_FORMAT_TYPES ADD CONSTRAINT FFTY_PK PRIMARY KEY(ID);\\012ALTER TABLE SAMPLE_INPUTS ADD CONSTRAINT SAIN_PK PRIMARY KEY(ID);\\012ALTER TABLE OBSERVABLE_TYPES ADD CONSTRAINT OBTY_PK PRIMARY KEY(ID);\\012ALTER TABLE LOCATOR_TYPES ADD CONSTRAINT LOTY_PK PRIMARY KEY(ID);\\012ALTER TABLE SAMPLE_COMPONENTS ADD CONSTRAINT SACO_PK PRIMARY KEY(ID);\\012ALTER TABLE SAMPLE_TYPES ADD CONSTRAINT SATY_PK PRIMARY KEY(ID);\\012ALTER TABLE ORGANIZATIONS ADD CONSTRAINT ORGA_PK PRIMARY KEY(ID);\\012ALTER TABLE PROCEDURES ADD CONSTRAINT PROC_PK PRIMARY KEY(ID);\\012ALTER TABLE PROCEDURE_TYPES ADD CONSTRAINT PCTY_PK PRIMARY KEY(ID);\\012ALTER TABLE PROJECTS ADD CONSTRAINT PROJ_PK PRIMARY KEY(ID);\\012ALTER TABLE SAMPLE_COMPONENT_MATERIALS ADD CONSTRAINT SCMA_PK PRIMARY KEY(ID);\\012ALTER TABLE EXTERNAL_DATA ADD CONSTRAINT EXDA_PK PRIMARY KEY(DATA_ID);\\012ALTER TABLE DATA ADD CONSTRAINT DATA_PK PRIMARY KEY(ID);\\012ALTER TABLE SAMPLES ADD CONSTRAINT SAMP_PK PRIMARY KEY(ID);\\012ALTER TABLE MATERIAL_TYPES ADD CONSTRAINT MATY_PK PRIMARY KEY(ID);\\012ALTER TABLE MATERIAL_BATCHES ADD CONSTRAINT MABA_PK PRIMARY KEY(ID);\\012ALTER TABLE MATERIALS ADD CONSTRAINT MATE_PK PRIMARY KEY(ID);\\012ALTER TABLE MOLECULES ADD CONSTRAINT MOLE_PK PRIMARY KEY(MATE_ID);\\012ALTER TABLE EXPERIMENTS ADD CONSTRAINT EXPE_PK PRIMARY KEY(ID);\\012ALTER TABLE EXPERIMENT_PROPERTIES ADD CONSTRAINT EXPR_BK_UK UNIQUE(EXPE_ID,FILE_NAME,VERSION);\\012ALTER TABLE EXPERIMENT_TYPES ADD CONSTRAINT EXTY_BK_UK UNIQUE(CODE);\\012ALTER TABLE DATA_VALUES ADD CONSTRAINT DAVA_BK_UK UNIQUE(DATA_ID,SACO_ID);\\012ALTER TABLE PERSONS ADD CONSTRAINT PERS_BK_UK UNIQUE(USER_ID);\\012ALTER TABLE FILE_FORMAT_TYPES ADD CONSTRAINT FFTY_BK_UK UNIQUE(CODE);\\012ALTER TABLE SAMPLE_INPUTS ADD CONSTRAINT SAIN_BK_UK UNIQUE(SAMP_ID,PROC_ID);\\012ALTER TABLE OBSERVABLE_TYPES ADD CONSTRAINT OBTY_BK_UK UNIQUE(CODE);\\012ALTER TABLE LOCATOR_TYPES ADD CONSTRAINT LOTY_BK_UK UNIQUE(CODE);\\012ALTER TABLE SAMPLE_COMPONENTS ADD CONSTRAINT SACO_BK_UK UNIQUE(CODE,SAMP_ID);\\012ALTER TABLE SAMPLE_TYPES ADD CONSTRAINT SATY_BK_UK UNIQUE(CODE);\\012ALTER TABLE ORGANIZATIONS ADD CONSTRAINT ORGA_BK_UK UNIQUE(CODE);\\012ALTER TABLE PROCEDURE_TYPES ADD CONSTRAINT PCTY_BK_UK UNIQUE(CODE);\\012ALTER TABLE PROJECTS ADD CONSTRAINT PROJ_BK_UK UNIQUE(CODE,ORGA_ID);\\012ALTER TABLE SAMPLE_COMPONENT_MATERIALS ADD CONSTRAINT SCMA_BK_UK UNIQUE(MABA_ID,SACO_ID);\\012ALTER TABLE EXTERNAL_DATA ADD CONSTRAINT EXDA_BK_UK UNIQUE(LOCATION);\\012ALTER TABLE SAMPLES ADD CONSTRAINT SAMP_BK_UK UNIQUE(CODE);\\012ALTER TABLE MATERIAL_TYPES ADD CONSTRAINT MATY_UK UNIQUE(CODE);\\012ALTER TABLE MATERIAL_TYPES ADD CONSTRAINT MATY_BK_UK UNIQUE(CODE);\\012ALTER TABLE MATERIALS ADD CONSTRAINT MATE_BK_UK UNIQUE(CODE);\\012--\\012--  Temporarily not created, due to data quality issues with the master plate layout data\\012--\\012-- ALTER TABLE MOLECULES ADD CONSTRAINT MOLE_BK_UK UNIQUE(SEQUENCE);\\012ALTER TABLE EXPERIMENTS ADD CONSTRAINT EXPE_BK_UK UNIQUE(CODE,PROJ_ID);\\012\\012ALTER TABLE DATA ADD CONSTRAINT DATA_SAMP_ARC_CK CHECK ((samp_id_acquired_from IS NOT NULL \\012and samp_id_derived_from IS NULL) \\012or (samp_id_acquired_from IS NULL \\012and samp_id_derived_from IS NOT NULL)) ;\\012ALTER TABLE EXPERIMENT_PROPERTIES ADD CONSTRAINT EXPR_PERS_FK FOREIGN KEY (PERS_ID_REGISTERER)REFERENCES PERSONS(ID);\\012ALTER TABLE EXPERIMENT_PROPERTIES ADD CONSTRAINT EXPR_EXPE_FK FOREIGN KEY (EXPE_ID)REFERENCES EXPERIMENTS(ID);\\012ALTER TABLE DATA_VALUES ADD CONSTRAINT DAVA_DATA_FK FOREIGN KEY (DATA_ID)REFERENCES DATA(ID);\\012ALTER TABLE DATA_VALUES ADD CONSTRAINT DAVA_SACO_FK FOREIGN KEY (SACO_ID)REFERENCES SAMPLE_COMPONENTS(ID);\\012ALTER TABLE SAMPLE_INPUTS ADD CONSTRAINT SAIN_PROC_FK FOREIGN KEY (PROC_ID)REFERENCES PROCEDURES(ID);\\012ALTER TABLE SAMPLE_INPUTS ADD CONSTRAINT SAIN_SAMP_FK FOREIGN KEY (SAMP_ID)REFERENCES SAMPLES(ID);\\012ALTER TABLE SAMPLE_COMPONENTS ADD CONSTRAINT SACO_SAMP_FK FOREIGN KEY (SAMP_ID)REFERENCES SAMPLES(ID);\\012ALTER TABLE PROCEDURES ADD CONSTRAINT PROC_PCTY_FK FOREIGN KEY (PCTY_ID)REFERENCES PROCEDURE_TYPES(ID);\\012ALTER TABLE PROCEDURES ADD CONSTRAINT PROC_PERS_FK FOREIGN KEY (PERS_ID)REFERENCES PERSONS(ID);\\012ALTER TABLE PROCEDURES ADD CONSTRAINT PROC_EXPE_FK FOREIGN KEY (EXPE_ID)REFERENCES EXPERIMENTS(ID);\\012ALTER TABLE PROJECTS ADD CONSTRAINT PROJ_ORGA_FK FOREIGN KEY (ORGA_ID)REFERENCES ORGANIZATIONS(ID);\\012ALTER TABLE SAMPLE_COMPONENT_MATERIALS ADD CONSTRAINT SCMA_MABA_FK FOREIGN KEY (MABA_ID)REFERENCES MATERIAL_BATCHES(ID);\\012ALTER TABLE SAMPLE_COMPONENT_MATERIALS ADD CONSTRAINT SCMA_SACO_FK FOREIGN KEY (SACO_ID)REFERENCES SAMPLE_COMPONENTS(ID);\\012ALTER TABLE EXTERNAL_DATA ADD CONSTRAINT EXDA_DATA_FK FOREIGN KEY (DATA_ID)REFERENCES DATA(ID);\\012ALTER TABLE EXTERNAL_DATA ADD CONSTRAINT EXDA_LOTY_FK FOREIGN KEY (LOTY_ID)REFERENCES LOCATOR_TYPES(ID);\\012ALTER TABLE EXTERNAL_DATA ADD CONSTRAINT EXDA_FFTY_FK FOREIGN KEY (FFTY_ID)REFERENCES FILE_FORMAT_TYPES(ID);\\012ALTER TABLE DATA ADD CONSTRAINT DATA_SAMP_DERIVED_FROM_FK FOREIGN KEY (SAMP_ID_DERIVED_FROM)REFERENCES SAMPLES(ID);\\012ALTER TABLE DATA ADD CONSTRAINT DATA_SAMP_FK FOREIGN KEY (SAMP_ID_ACQUIRED_FROM)REFERENCES SAMPLES(ID);\\012ALTER TABLE DATA ADD CONSTRAINT DATA_PROC_FK FOREIGN KEY (PROC_ID_ACQUIRED_BY)REFERENCES PROCEDURES(ID);\\012ALTER TABLE DATA ADD CONSTRAINT DATA_OBTY_FK FOREIGN KEY (OBTY_ID)REFERENCES OBSERVABLE_TYPES(ID);\\012ALTER TABLE SAMPLES ADD CONSTRAINT SAMP_PERS_FK FOREIGN KEY (PERS_ID_REGISTERER)REFERENCES PERSONS(ID);\\012ALTER TABLE SAMPLES ADD CONSTRAINT SAMP_PROC_FK FOREIGN KEY (PROC_ID)REFERENCES PROCEDURES(ID);\\012ALTER TABLE SAMPLES ADD CONSTRAINT SAMP_SAMP_FK_GENERATED_FROM FOREIGN KEY (SAMP_ID_GENERATED_FROM)REFERENCES SAMPLES(ID);\\012ALTER TABLE SAMPLES ADD CONSTRAINT SAMP_SAMP_FK_TOP FOREIGN KEY (SAMP_ID_TOP)REFERENCES SAMPLES(ID);\\012ALTER TABLE SAMPLES ADD CONSTRAINT SAMP_SATY_FK FOREIGN KEY (SATY_ID)REFERENCES SAMPLE_TYPES(ID);\\012ALTER TABLE MATERIAL_BATCHES ADD CONSTRAINT MABA_PERS_FK FOREIGN KEY (PERS_ID_REGISTERER)REFERENCES PERSONS(ID);\\012ALTER TABLE MATERIAL_BATCHES ADD CONSTRAINT MABA_MATE_FK FOREIGN KEY (MATE_ID)REFERENCES MATERIALS(ID);\\012ALTER TABLE MATERIAL_BATCHES ADD CONSTRAINT MABA_PROC_FK FOREIGN KEY (PROC_ID)REFERENCES PROCEDURES(ID);\\012ALTER TABLE MATERIALS ADD CONSTRAINT MATE_MATY_FK FOREIGN KEY (MATY_ID)REFERENCES MATERIAL_TYPES(ID);\\012ALTER TABLE MATERIALS ADD CONSTRAINT MATE_PERS_FK FOREIGN KEY (PERS_ID_REGISTERER)REFERENCES PERSONS(ID);\\012ALTER TABLE MOLECULES ADD CONSTRAINT MOLE_MATE_FK FOREIGN KEY (MATE_ID)REFERENCES MATERIALS(ID);\\012ALTER TABLE MOLECULES ADD CONSTRAINT MOLE_MOLE_FK FOREIGN KEY (MOLE_ID_INHIBITOR_OF)REFERENCES MOLECULES(MATE_ID);\\012ALTER TABLE EXPERIMENTS ADD CONSTRAINT EXPE_MATE_FK FOREIGN KEY (MATE_ID_STUDY_OBJECT)REFERENCES MATERIALS(ID);\\012ALTER TABLE EXPERIMENTS ADD CONSTRAINT EXPE_EXTY_FK FOREIGN KEY (EXTY_ID)REFERENCES EXPERIMENT_TYPES(ID);\\012ALTER TABLE EXPERIMENTS ADD CONSTRAINT EXPE_PERS_FK FOREIGN KEY (PERS_ID_REGISTERER)REFERENCES PERSONS(ID);\\012ALTER TABLE EXPERIMENTS ADD CONSTRAINT EXPE_PROJ_FK FOREIGN KEY (PROJ_ID)REFERENCES PROJECTS(ID);\\012\\012\\012\\012--  Creating Sequences\\012\\012CREATE SEQUENCE EXPERIMENT_PROPERTY_ID_SEQ;\\012\\012CREATE SEQUENCE PROCEDURE_TYPE_ID_SEQ;\\012\\012CREATE SEQUENCE SAMPLE_INPUT_ID_SEQ;\\012\\012CREATE SEQUENCE SAMPLE_TYPE_ID_SEQ;\\012\\012CREATE SEQUENCE LOCATOR_TYPE_ID_SEQ;\\012\\012CREATE SEQUENCE SAMPLE_ID_SEQ;\\012\\012CREATE SEQUENCE EXPERIMENT_ID_SEQ;\\012\\012CREATE SEQUENCE MATERIAL_BATCH_ID_SEQ;\\012\\012CREATE SEQUENCE OBSERVABLE_TYPE_ID_SEQ;\\012\\012CREATE SEQUENCE SAMPLE_COMPONENT_ID_SEQ;\\012\\012CREATE SEQUENCE MATERIAL_ID_SEQ;\\012\\012CREATE SEQUENCE DATA_ID_SEQ;\\012\\012--  Creating Sequence for the SAMPLE_COMPONENT_MATERIALS table (standard naming convention was too long)\\012CREATE SEQUENCE SCMA_ID_SEQ;\\012\\012CREATE SEQUENCE PROCEDURE_ID_SEQ;\\012\\012CREATE SEQUENCE FILE_FORMAT_TYPE_ID_SEQ;\\012\\012CREATE SEQUENCE MATERIAL_TYPE_ID_SEQ;\\012\\012CREATE SEQUENCE EXPERIMENT_TYPE_ID_SEQ;\\012\\012CREATE SEQUENCE PERSON_ID_SEQ;\\012\\012CREATE SEQUENCE ORGANIZATION_ID_SEQ;\\012\\012CREATE SEQUENCE PROJECT_ID_SEQ;\\012\\012CREATE SEQUENCE DATA_VALUE_ID_SEQ;\\012\\012\\012\\012/*\\012   Trigger Section\\012   ===============*/\\012\\012CREATE OR REPLACE FUNCTION br001_crtl_plate_chk() RETURNS trigger AS $br001_crtl_plate_chk$\\012DECLARE\\012   cnt           INTEGER;\\012   v_cell_plate  CODE;\\012BEGIN\\012\\012   select code into v_cell_plate from sample_types where id  = NEW.saty_id;\\012\\012   -- Check if the sample is of type "Cell Plate"\\012   if v_cell_plate = 'CELL PLATE' then\\012\\012      -- Check that a Control Plate exists before registering the Cell Plate\\012      select count(*) into cnt from samples s, sample_types st where s.saty_id = st.id and st.code = 'CONTROL LAYOUT';\\011 \\012      IF cnt = 0 THEN\\012\\011\\011 -- Doens't make sense, so comment it out\\012         -- RAISE EXCEPTION 'A Control Plate must exist before you can register Cell Plate: %', NEW.code;\\012      END IF;\\012\\012   end if;\\012\\012   RETURN NEW;\\012\\012END;\\012$br001_crtl_plate_chk$ LANGUAGE plpgsql;\\012\\012\\012CREATE TRIGGER br001_crtl_plate_chk BEFORE INSERT ON samples\\012    FOR EACH ROW EXECUTE PROCEDURE br001_crtl_plate_chk();\\012	\N
+./sourceTest/sql/postgresql/test_database_for_migration/postgresql/007/schema-007.sql:    LANGUAGE plpgsql;
+./sourceTest/sql/postgresql/test_database_for_migration/postgresql/018/.svn/text-base/006=database_version_logs.tsv.svn-base:007	source/sql/postgresql/007/schema-007.sql	SUCCESS	2007-12-04 15:50:54.064	-- D:\\\\DDL\\\\postgresql\\\\schema-007.sql\\012--\\012-- Generated for ANSI SQL92 on Thu Aug 23  19:02:15 2007 by Server Generator 10.1.2.6.18\\012-- Post generation PostgreSQL specific Changes:\\012-- \\012--  1. change domain FILE from BIT(32000) to BYTEA\\012--  2. change domain TECH_ID from NUMERIC(20) to BIGINT\\012--  3. Put single quotes around the default value NOW in the create domain statement for the domain TIME_STAMP\\012--     i.e. change CREATE DOMAIN TIME_STAMP AS TIMESTAMP DEFAULT now; to CREATE DOMAIN TIME_STAMP AS TIMESTAMP DEFAULT 'now';\\012--  4. Temporarily not created, due to data quality issues with the master plate layout data\\012--\\012-- ALTER TABLE MOLECULES ADD CONSTRAINT MOLE_BK_UK UNIQUE(SEQUENCE);\\012\\012\\012\\012CREATE DOMAIN DESCRIPTION_80 AS VARCHAR(80);\\012CREATE DOMAIN USER_ID AS VARCHAR(20);\\012CREATE DOMAIN DOUBLE_PRECISION_VALUE AS DOUBLE PRECISION;\\012CREATE DOMAIN FILE_NAME AS VARCHAR(100);\\012CREATE DOMAIN TECH_ID AS BIGINT;\\012CREATE DOMAIN OBJECT_NAME AS VARCHAR(50);\\012CREATE DOMAIN TIME_STAMP AS TIMESTAMP DEFAULT CURRENT_TIMESTAMP;\\012CREATE DOMAIN REAL_VALUE AS REAL;\\012CREATE DOMAIN FILE AS BYTEA;\\012CREATE DOMAIN CODE AS VARCHAR(20);\\012CREATE DOMAIN DESCRIPTION_250 AS VARCHAR(250);\\012CREATE TABLE EXPERIMENT_PROPERTIES  (ID TECH_ID NOT NULL,EXPE_ID TECH_ID NOT NULL,FILE_NAME FILE_NAME NOT NULL,REGISTRATION_TIMESTAMP TIME_STAMP NOT NULL DEFAULT CURRENT_TIMESTAMP,VALUE FILE NOT NULL,VERSION INTEGER NOT NULL,PERS_ID_REGISTERER TECH_ID NOT NULL) ;\\012CREATE TABLE EXPERIMENT_TYPES  (ID TECH_ID NOT NULL,CODE CODE NOT NULL,DESCRIPTION DESCRIPTION_80) ;\\012CREATE TABLE DATA_VALUES  (ID TECH_ID NOT NULL,DATA_ID TECH_ID NOT NULL,SACO_ID TECH_ID NOT NULL,VALUE DOUBLE_PRECISION_VALUE NOT NULL) ;\\012CREATE TABLE PERSONS  (ID TECH_ID NOT NULL,FIRST_NAME VARCHAR(30),LAST_NAME VARCHAR(30),USER_ID USER_ID,EMAIL OBJECT_NAME) ;\\012CREATE TABLE FILE_FORMAT_TYPES  (ID TECH_ID NOT NULL,CODE CODE NOT NULL,DESCRIPTION DESCRIPTION_80) ;\\012CREATE TABLE SAMPLE_INPUTS  (ID TECH_ID NOT NULL,SAMP_ID TECH_ID NOT NULL,PROC_ID TECH_ID NOT NULL) ;\\012CREATE TABLE OBSERVABLE_TYPES  (ID TECH_ID NOT NULL,CODE CODE NOT NULL,DESCRIPTION DESCRIPTION_80) ;\\012CREATE TABLE LOCATOR_TYPES  (ID TECH_ID NOT NULL,CODE CODE NOT NULL,DESCRIPTION DESCRIPTION_80) ;\\012CREATE TABLE SAMPLE_COMPONENTS  (ID TECH_ID NOT NULL,CODE CODE NOT NULL,SAMP_ID TECH_ID NOT NULL) ;\\012CREATE TABLE SAMPLE_TYPES  (ID TECH_ID NOT NULL,CODE CODE NOT NULL,DESCRIPTION DESCRIPTION_80) ;\\012CREATE TABLE ORGANIZATIONS  (ID TECH_ID NOT NULL,CODE CODE NOT NULL) ;\\012CREATE TABLE PROCEDURES  (ID TECH_ID NOT NULL,REGISTRATION_TIMESTAMP TIME_STAMP NOT NULL DEFAULT CURRENT_TIMESTAMP,EXPE_ID TECH_ID NOT NULL,PCTY_ID TECH_ID NOT NULL,PERS_ID TECH_ID) ;\\012CREATE TABLE PROCEDURE_TYPES  (ID TECH_ID NOT NULL,CODE CODE NOT NULL,DESCRIPTION DESCRIPTION_80 NOT NULL) ;\\012CREATE TABLE PROJECTS  (ID TECH_ID NOT NULL,CODE CODE NOT NULL,ORGA_ID TECH_ID NOT NULL) ;\\012CREATE TABLE SAMPLE_COMPONENT_MATERIALS  (ID TECH_ID NOT NULL,SACO_ID TECH_ID NOT NULL,MABA_ID TECH_ID NOT NULL) ;\\012CREATE TABLE EXTERNAL_DATA  (DATA_ID TECH_ID NOT NULL,LOCATION VARCHAR(200) NOT NULL,LOTY_ID TECH_ID NOT NULL,FFTY_ID TECH_ID NOT NULL) ;\\012CREATE TABLE DATA  (ID TECH_ID NOT NULL,REGISTRATION_TIMESTAMP TIME_STAMP NOT NULL DEFAULT CURRENT_TIMESTAMP,OBTY_ID TECH_ID NOT NULL,PROC_ID_ACQUIRED_BY TECH_ID NOT NULL,SAMP_ID_ACQUIRED_FROM TECH_ID,SAMP_ID_DERIVED_FROM TECH_ID) ;\\012CREATE TABLE SAMPLES  (ID TECH_ID NOT NULL,CODE CODE NOT NULL,CONT_ID TECH_ID,PROC_ID TECH_ID,SAMP_ID_TOP TECH_ID,SAMP_ID_GENERATED_FROM TECH_ID,SATY_ID TECH_ID NOT NULL,REGISTRATION_TIMESTAMP TIME_STAMP NOT NULL DEFAULT CURRENT_TIMESTAMP,PERS_ID_REGISTERER TECH_ID NOT NULL) ;\\012CREATE TABLE MATERIAL_TYPES  (ID TECH_ID NOT NULL,CODE CODE NOT NULL,DESCRIPTION DESCRIPTION_80) ;\\012CREATE TABLE MATERIAL_BATCHES  (ID TECH_ID NOT NULL,CODE CODE NOT NULL,AMOUNT REAL_VALUE,MATE_ID TECH_ID NOT NULL,CONT_ID TECH_ID,PROC_ID TECH_ID,REGISTRATION_TIMESTAMP TIME_STAMP NOT NULL DEFAULT CURRENT_TIMESTAMP,PERS_ID_REGISTERER TECH_ID NOT NULL) ;\\012CREATE TABLE MATERIALS  (ID TECH_ID NOT NULL,CODE CODE NOT NULL,DESCRIPTION DESCRIPTION_250,MATY_ID TECH_ID NOT NULL,REGISTRATION_TIMESTAMP TIME_STAMP NOT NULL DEFAULT CURRENT_TIMESTAMP,PERS_ID_REGISTERER TECH_ID NOT NULL) ;\\012CREATE TABLE MOLECULES  (MATE_ID TECH_ID NOT NULL,SEQUENCE VARCHAR(100),ACCESSION_NUMBER OBJECT_NAME,OFF_SET VARCHAR(20),MOLE_ID_INHIBITOR_OF TECH_ID,GENE_SYMBOL CODE) ;\\012CREATE TABLE EXPERIMENTS  (ID TECH_ID NOT NULL,CODE CODE NOT NULL,EXTY_ID TECH_ID NOT NULL,MATE_ID_STUDY_OBJECT TECH_ID,PERS_ID_REGISTERER TECH_ID,REGISTRATION_TIMESTAMP TIME_STAMP NOT NULL DEFAULT CURRENT_TIMESTAMP,DESCRIPTION DESCRIPTION_250,PROJ_ID TECH_ID NOT NULL) ;\\012\\012ALTER TABLE EXPERIMENT_PROPERTIES ADD CONSTRAINT EXPR_PK PRIMARY KEY(ID);\\012ALTER TABLE EXPERIMENT_TYPES ADD CONSTRAINT EXTY_PK PRIMARY KEY(ID);\\012ALTER TABLE DATA_VALUES ADD CONSTRAINT DAVA_PK PRIMARY KEY(ID);\\012ALTER TABLE PERSONS ADD CONSTRAINT PERS_PK PRIMARY KEY(ID);\\012ALTER TABLE FILE_FORMAT_TYPES ADD CONSTRAINT FFTY_PK PRIMARY KEY(ID);\\012ALTER TABLE SAMPLE_INPUTS ADD CONSTRAINT SAIN_PK PRIMARY KEY(ID);\\012ALTER TABLE OBSERVABLE_TYPES ADD CONSTRAINT OBTY_PK PRIMARY KEY(ID);\\012ALTER TABLE LOCATOR_TYPES ADD CONSTRAINT LOTY_PK PRIMARY KEY(ID);\\012ALTER TABLE SAMPLE_COMPONENTS ADD CONSTRAINT SACO_PK PRIMARY KEY(ID);\\012ALTER TABLE SAMPLE_TYPES ADD CONSTRAINT SATY_PK PRIMARY KEY(ID);\\012ALTER TABLE ORGANIZATIONS ADD CONSTRAINT ORGA_PK PRIMARY KEY(ID);\\012ALTER TABLE PROCEDURES ADD CONSTRAINT PROC_PK PRIMARY KEY(ID);\\012ALTER TABLE PROCEDURE_TYPES ADD CONSTRAINT PCTY_PK PRIMARY KEY(ID);\\012ALTER TABLE PROJECTS ADD CONSTRAINT PROJ_PK PRIMARY KEY(ID);\\012ALTER TABLE SAMPLE_COMPONENT_MATERIALS ADD CONSTRAINT SCMA_PK PRIMARY KEY(ID);\\012ALTER TABLE EXTERNAL_DATA ADD CONSTRAINT EXDA_PK PRIMARY KEY(DATA_ID);\\012ALTER TABLE DATA ADD CONSTRAINT DATA_PK PRIMARY KEY(ID);\\012ALTER TABLE SAMPLES ADD CONSTRAINT SAMP_PK PRIMARY KEY(ID);\\012ALTER TABLE MATERIAL_TYPES ADD CONSTRAINT MATY_PK PRIMARY KEY(ID);\\012ALTER TABLE MATERIAL_BATCHES ADD CONSTRAINT MABA_PK PRIMARY KEY(ID);\\012ALTER TABLE MATERIALS ADD CONSTRAINT MATE_PK PRIMARY KEY(ID);\\012ALTER TABLE MOLECULES ADD CONSTRAINT MOLE_PK PRIMARY KEY(MATE_ID);\\012ALTER TABLE EXPERIMENTS ADD CONSTRAINT EXPE_PK PRIMARY KEY(ID);\\012ALTER TABLE EXPERIMENT_PROPERTIES ADD CONSTRAINT EXPR_BK_UK UNIQUE(EXPE_ID,FILE_NAME,VERSION);\\012ALTER TABLE EXPERIMENT_TYPES ADD CONSTRAINT EXTY_BK_UK UNIQUE(CODE);\\012ALTER TABLE DATA_VALUES ADD CONSTRAINT DAVA_BK_UK UNIQUE(DATA_ID,SACO_ID);\\012ALTER TABLE PERSONS ADD CONSTRAINT PERS_BK_UK UNIQUE(USER_ID);\\012ALTER TABLE FILE_FORMAT_TYPES ADD CONSTRAINT FFTY_BK_UK UNIQUE(CODE);\\012ALTER TABLE SAMPLE_INPUTS ADD CONSTRAINT SAIN_BK_UK UNIQUE(SAMP_ID,PROC_ID);\\012ALTER TABLE OBSERVABLE_TYPES ADD CONSTRAINT OBTY_BK_UK UNIQUE(CODE);\\012ALTER TABLE LOCATOR_TYPES ADD CONSTRAINT LOTY_BK_UK UNIQUE(CODE);\\012ALTER TABLE SAMPLE_COMPONENTS ADD CONSTRAINT SACO_BK_UK UNIQUE(CODE,SAMP_ID);\\012ALTER TABLE SAMPLE_TYPES ADD CONSTRAINT SATY_BK_UK UNIQUE(CODE);\\012ALTER TABLE ORGANIZATIONS ADD CONSTRAINT ORGA_BK_UK UNIQUE(CODE);\\012ALTER TABLE PROCEDURE_TYPES ADD CONSTRAINT PCTY_BK_UK UNIQUE(CODE);\\012ALTER TABLE PROJECTS ADD CONSTRAINT PROJ_BK_UK UNIQUE(CODE,ORGA_ID);\\012ALTER TABLE SAMPLE_COMPONENT_MATERIALS ADD CONSTRAINT SCMA_BK_UK UNIQUE(MABA_ID,SACO_ID);\\012ALTER TABLE EXTERNAL_DATA ADD CONSTRAINT EXDA_BK_UK UNIQUE(LOCATION);\\012ALTER TABLE SAMPLES ADD CONSTRAINT SAMP_BK_UK UNIQUE(CODE);\\012ALTER TABLE MATERIAL_TYPES ADD CONSTRAINT MATY_UK UNIQUE(CODE);\\012ALTER TABLE MATERIAL_TYPES ADD CONSTRAINT MATY_BK_UK UNIQUE(CODE);\\012ALTER TABLE MATERIALS ADD CONSTRAINT MATE_BK_UK UNIQUE(CODE);\\012--\\012--  Temporarily not created, due to data quality issues with the master plate layout data\\012--\\012-- ALTER TABLE MOLECULES ADD CONSTRAINT MOLE_BK_UK UNIQUE(SEQUENCE);\\012ALTER TABLE EXPERIMENTS ADD CONSTRAINT EXPE_BK_UK UNIQUE(CODE,PROJ_ID);\\012\\012ALTER TABLE DATA ADD CONSTRAINT DATA_SAMP_ARC_CK CHECK ((samp_id_acquired_from IS NOT NULL \\012and samp_id_derived_from IS NULL) \\012or (samp_id_acquired_from IS NULL \\012and samp_id_derived_from IS NOT NULL)) ;\\012ALTER TABLE EXPERIMENT_PROPERTIES ADD CONSTRAINT EXPR_PERS_FK FOREIGN KEY (PERS_ID_REGISTERER)REFERENCES PERSONS(ID);\\012ALTER TABLE EXPERIMENT_PROPERTIES ADD CONSTRAINT EXPR_EXPE_FK FOREIGN KEY (EXPE_ID)REFERENCES EXPERIMENTS(ID);\\012ALTER TABLE DATA_VALUES ADD CONSTRAINT DAVA_DATA_FK FOREIGN KEY (DATA_ID)REFERENCES DATA(ID);\\012ALTER TABLE DATA_VALUES ADD CONSTRAINT DAVA_SACO_FK FOREIGN KEY (SACO_ID)REFERENCES SAMPLE_COMPONENTS(ID);\\012ALTER TABLE SAMPLE_INPUTS ADD CONSTRAINT SAIN_PROC_FK FOREIGN KEY (PROC_ID)REFERENCES PROCEDURES(ID);\\012ALTER TABLE SAMPLE_INPUTS ADD CONSTRAINT SAIN_SAMP_FK FOREIGN KEY (SAMP_ID)REFERENCES SAMPLES(ID);\\012ALTER TABLE SAMPLE_COMPONENTS ADD CONSTRAINT SACO_SAMP_FK FOREIGN KEY (SAMP_ID)REFERENCES SAMPLES(ID);\\012ALTER TABLE PROCEDURES ADD CONSTRAINT PROC_PCTY_FK FOREIGN KEY (PCTY_ID)REFERENCES PROCEDURE_TYPES(ID);\\012ALTER TABLE PROCEDURES ADD CONSTRAINT PROC_PERS_FK FOREIGN KEY (PERS_ID)REFERENCES PERSONS(ID);\\012ALTER TABLE PROCEDURES ADD CONSTRAINT PROC_EXPE_FK FOREIGN KEY (EXPE_ID)REFERENCES EXPERIMENTS(ID);\\012ALTER TABLE PROJECTS ADD CONSTRAINT PROJ_ORGA_FK FOREIGN KEY (ORGA_ID)REFERENCES ORGANIZATIONS(ID);\\012ALTER TABLE SAMPLE_COMPONENT_MATERIALS ADD CONSTRAINT SCMA_MABA_FK FOREIGN KEY (MABA_ID)REFERENCES MATERIAL_BATCHES(ID);\\012ALTER TABLE SAMPLE_COMPONENT_MATERIALS ADD CONSTRAINT SCMA_SACO_FK FOREIGN KEY (SACO_ID)REFERENCES SAMPLE_COMPONENTS(ID);\\012ALTER TABLE EXTERNAL_DATA ADD CONSTRAINT EXDA_DATA_FK FOREIGN KEY (DATA_ID)REFERENCES DATA(ID);\\012ALTER TABLE EXTERNAL_DATA ADD CONSTRAINT EXDA_LOTY_FK FOREIGN KEY (LOTY_ID)REFERENCES LOCATOR_TYPES(ID);\\012ALTER TABLE EXTERNAL_DATA ADD CONSTRAINT EXDA_FFTY_FK FOREIGN KEY (FFTY_ID)REFERENCES FILE_FORMAT_TYPES(ID);\\012ALTER TABLE DATA ADD CONSTRAINT DATA_SAMP_DERIVED_FROM_FK FOREIGN KEY (SAMP_ID_DERIVED_FROM)REFERENCES SAMPLES(ID);\\012ALTER TABLE DATA ADD CONSTRAINT DATA_SAMP_FK FOREIGN KEY (SAMP_ID_ACQUIRED_FROM)REFERENCES SAMPLES(ID);\\012ALTER TABLE DATA ADD CONSTRAINT DATA_PROC_FK FOREIGN KEY (PROC_ID_ACQUIRED_BY)REFERENCES PROCEDURES(ID);\\012ALTER TABLE DATA ADD CONSTRAINT DATA_OBTY_FK FOREIGN KEY (OBTY_ID)REFERENCES OBSERVABLE_TYPES(ID);\\012ALTER TABLE SAMPLES ADD CONSTRAINT SAMP_PERS_FK FOREIGN KEY (PERS_ID_REGISTERER)REFERENCES PERSONS(ID);\\012ALTER TABLE SAMPLES ADD CONSTRAINT SAMP_PROC_FK FOREIGN KEY (PROC_ID)REFERENCES PROCEDURES(ID);\\012ALTER TABLE SAMPLES ADD CONSTRAINT SAMP_SAMP_FK_GENERATED_FROM FOREIGN KEY (SAMP_ID_GENERATED_FROM)REFERENCES SAMPLES(ID);\\012ALTER TABLE SAMPLES ADD CONSTRAINT SAMP_SAMP_FK_TOP FOREIGN KEY (SAMP_ID_TOP)REFERENCES SAMPLES(ID);\\012ALTER TABLE SAMPLES ADD CONSTRAINT SAMP_SATY_FK FOREIGN KEY (SATY_ID)REFERENCES SAMPLE_TYPES(ID);\\012ALTER TABLE MATERIAL_BATCHES ADD CONSTRAINT MABA_PERS_FK FOREIGN KEY (PERS_ID_REGISTERER)REFERENCES PERSONS(ID);\\012ALTER TABLE MATERIAL_BATCHES ADD CONSTRAINT MABA_MATE_FK FOREIGN KEY (MATE_ID)REFERENCES MATERIALS(ID);\\012ALTER TABLE MATERIAL_BATCHES ADD CONSTRAINT MABA_PROC_FK FOREIGN KEY (PROC_ID)REFERENCES PROCEDURES(ID);\\012ALTER TABLE MATERIALS ADD CONSTRAINT MATE_MATY_FK FOREIGN KEY (MATY_ID)REFERENCES MATERIAL_TYPES(ID);\\012ALTER TABLE MATERIALS ADD CONSTRAINT MATE_PERS_FK FOREIGN KEY (PERS_ID_REGISTERER)REFERENCES PERSONS(ID);\\012ALTER TABLE MOLECULES ADD CONSTRAINT MOLE_MATE_FK FOREIGN KEY (MATE_ID)REFERENCES MATERIALS(ID);\\012ALTER TABLE MOLECULES ADD CONSTRAINT MOLE_MOLE_FK FOREIGN KEY (MOLE_ID_INHIBITOR_OF)REFERENCES MOLECULES(MATE_ID);\\012ALTER TABLE EXPERIMENTS ADD CONSTRAINT EXPE_MATE_FK FOREIGN KEY (MATE_ID_STUDY_OBJECT)REFERENCES MATERIALS(ID);\\012ALTER TABLE EXPERIMENTS ADD CONSTRAINT EXPE_EXTY_FK FOREIGN KEY (EXTY_ID)REFERENCES EXPERIMENT_TYPES(ID);\\012ALTER TABLE EXPERIMENTS ADD CONSTRAINT EXPE_PERS_FK FOREIGN KEY (PERS_ID_REGISTERER)REFERENCES PERSONS(ID);\\012ALTER TABLE EXPERIMENTS ADD CONSTRAINT EXPE_PROJ_FK FOREIGN KEY (PROJ_ID)REFERENCES PROJECTS(ID);\\012\\012\\012\\012--  Creating Sequences\\012\\012CREATE SEQUENCE EXPERIMENT_PROPERTY_ID_SEQ;\\012\\012CREATE SEQUENCE PROCEDURE_TYPE_ID_SEQ;\\012\\012CREATE SEQUENCE SAMPLE_INPUT_ID_SEQ;\\012\\012CREATE SEQUENCE SAMPLE_TYPE_ID_SEQ;\\012\\012CREATE SEQUENCE LOCATOR_TYPE_ID_SEQ;\\012\\012CREATE SEQUENCE SAMPLE_ID_SEQ;\\012\\012CREATE SEQUENCE EXPERIMENT_ID_SEQ;\\012\\012CREATE SEQUENCE MATERIAL_BATCH_ID_SEQ;\\012\\012CREATE SEQUENCE OBSERVABLE_TYPE_ID_SEQ;\\012\\012CREATE SEQUENCE SAMPLE_COMPONENT_ID_SEQ;\\012\\012CREATE SEQUENCE MATERIAL_ID_SEQ;\\012\\012CREATE SEQUENCE DATA_ID_SEQ;\\012\\012--  Creating Sequence for the SAMPLE_COMPONENT_MATERIALS table (standard naming convention was too long)\\012CREATE SEQUENCE SCMA_ID_SEQ;\\012\\012CREATE SEQUENCE PROCEDURE_ID_SEQ;\\012\\012CREATE SEQUENCE FILE_FORMAT_TYPE_ID_SEQ;\\012\\012CREATE SEQUENCE MATERIAL_TYPE_ID_SEQ;\\012\\012CREATE SEQUENCE EXPERIMENT_TYPE_ID_SEQ;\\012\\012CREATE SEQUENCE PERSON_ID_SEQ;\\012\\012CREATE SEQUENCE ORGANIZATION_ID_SEQ;\\012\\012CREATE SEQUENCE PROJECT_ID_SEQ;\\012\\012CREATE SEQUENCE DATA_VALUE_ID_SEQ;\\012\\012\\012\\012/*\\012   Trigger Section\\012   ===============*/\\012\\012CREATE OR REPLACE FUNCTION br001_crtl_plate_chk() RETURNS trigger AS $br001_crtl_plate_chk$\\012DECLARE\\012   cnt           INTEGER;\\012   v_cell_plate  CODE;\\012BEGIN\\012\\012   select code into v_cell_plate from sample_types where id  = NEW.saty_id;\\012\\012   -- Check if the sample is of type "Cell Plate"\\012   if v_cell_plate = 'CELL PLATE' then\\012\\012      -- Check that a Control Plate exists before registering the Cell Plate\\012      select count(*) into cnt from samples s, sample_types st where s.saty_id = st.id and st.code = 'CONTROL LAYOUT';\\011 \\012      IF cnt = 0 THEN\\012\\011\\011 -- Doens't make sense, so comment it out\\012         -- RAISE EXCEPTION 'A Control Plate must exist before you can register Cell Plate: %', NEW.code;\\012      END IF;\\012\\012   end if;\\012\\012   RETURN NEW;\\012\\012END;\\012$br001_crtl_plate_chk$ LANGUAGE plpgsql;\\012\\012\\012CREATE TRIGGER br001_crtl_plate_chk BEFORE INSERT ON samples\\012    FOR EACH ROW EXECUTE PROCEDURE br001_crtl_plate_chk();\\012	\N
+./sourceTest/sql/postgresql/test_database_for_migration/postgresql/018/.svn/text-base/006=database_version_logs.tsv.svn-base:013	source/sql/postgresql/migration/migration-012-013.sql	SUCCESS	2008-08-29 08:10:55.399	----------------------------------------------------------------------------------------------\\012--  File: migration-012-013.sql\\012--\\012-- \\012--  This script enables the migration of the database schema from 012 to 013.\\012-- \\012--  Update History\\012--\\012--\\012--\\011Who\\011\\011\\011\\011\\011\\011\\011When\\011\\011\\011\\011What\\012--\\011---\\011\\011\\011\\011\\011\\011\\011----\\011\\011\\011\\011----\\012--\\011Bernd Rinn\\011\\0112008-01-04\\011Initial Version - add support for invalidations and material type BACTERIUM \\012--\\011Bernd Rinn\\011\\0112008-01-05\\011Add material type COMPOUND and material type property type entries for the new material types \\012--  \\012----------------------------------------------------------------------------------------------\\012\\012------------------------------------------------------------------------------------\\012--  Purpose:  Create function RENAME_SEQUENCE() that is required for renaming the sequences belonging to tables\\012------------------------------------------------------------------------------------\\012\\012CREATE FUNCTION RENAME_SEQUENCE(OLD_NAME VARCHAR, NEW_NAME VARCHAR) RETURNS INTEGER AS $$\\012DECLARE\\012  CURR_SEQ_VAL   INTEGER;\\012BEGIN\\012  SELECT INTO CURR_SEQ_VAL NEXTVAL(OLD_NAME);\\012  EXECUTE 'CREATE SEQUENCE ' || NEW_NAME || ' START WITH ' || CURR_SEQ_VAL;\\012  EXECUTE 'DROP SEQUENCE ' || OLD_NAME;\\012  RETURN CURR_SEQ_VAL;\\012END;\\012$$ LANGUAGE 'plpgsql';\\012\\012\\012------------------------------------------------------------------------------------\\012--  Purpose:  Add table INVALIDATIONS to store invalidations\\012------------------------------------------------------------------------------------\\012\\012CREATE TABLE INVALIDATIONS (ID TECH_ID NOT NULL,PERS_ID_REGISTERER TECH_ID NOT NULL,REGISTRATION_TIMESTAMP TIME_STAMP NOT NULL DEFAULT CURRENT_TIMESTAMP,REASON DESCRIPTION_250);\\012ALTER TABLE INVALIDATIONS ADD CONSTRAINT INVA_PK PRIMARY KEY(ID);\\012ALTER TABLE INVALIDATIONS ADD CONSTRAINT INVA_PERS_FK FOREIGN KEY (PERS_ID_REGISTERER) REFERENCES PERSONS(ID);\\012CREATE SEQUENCE INVALIDATION_ID_SEQ;\\012CREATE INDEX INVA_PERS_FK_I ON INVALIDATIONS (PERS_ID_REGISTERER);\\012\\012------------------------------------------------------------------------------------\\012--  Purpose:  Add column INVA_ID to table SAMPLES in order to allow invalidation of samples  \\012------------------------------------------------------------------------------------\\012\\012ALTER TABLE SAMPLES ADD INVA_ID TECH_ID;\\012ALTER TABLE SAMPLES ADD CONSTRAINT SAMP_INVA_FK FOREIGN KEY (INVA_ID) REFERENCES INVALIDATIONS(ID);\\012CREATE INDEX SAMP_INVA_FK_I ON SAMPLES (INVA_ID);\\012\\012\\012------------------------------------------------------------------------------------\\012--  Purpose:  Rename table EXPERIMENT_PROPERTIES TO EXPERIMENT_ATTACHMENTS  \\012------------------------------------------------------------------------------------\\012\\012ALTER TABLE EXPERIMENT_PROPERTIES DROP CONSTRAINT EXPR_PK;\\012ALTER TABLE EXPERIMENT_PROPERTIES DROP CONSTRAINT EXPR_BK_UK;\\012ALTER TABLE EXPERIMENT_PROPERTIES DROP CONSTRAINT EXPR_EXPE_FK;\\012ALTER TABLE EXPERIMENT_PROPERTIES DROP CONSTRAINT EXPR_PERS_FK;\\012\\012ALTER TABLE EXPERIMENT_PROPERTIES RENAME TO EXPERIMENT_ATTACHMENTS;\\012ALTER INDEX EXPR_EXPE_FK_I RENAME TO EXAT_EXPE_FK_I;\\012ALTER INDEX EXPR_PERS_FK_I RENAME TO EXAT_PERS_FK_I;\\012SELECT RENAME_SEQUENCE('EXPERIMENT_PROPERTY_ID_SEQ', 'EXPERIMENT_ATTACHMENT_ID_SEQ');\\012\\012ALTER TABLE EXPERIMENT_ATTACHMENTS ADD CONSTRAINT EXAT_PK PRIMARY KEY(ID);\\012ALTER TABLE EXPERIMENT_ATTACHMENTS ADD CONSTRAINT EXAT_BK_UK UNIQUE(EXPE_ID,FILE_NAME,VERSION);\\012ALTER TABLE EXPERIMENT_ATTACHMENTS ADD CONSTRAINT EXAT_EXPE_FK FOREIGN KEY (EXPE_ID) REFERENCES EXPERIMENTS(ID);\\012ALTER TABLE EXPERIMENT_ATTACHMENTS ADD CONSTRAINT EXAT_PERS_FK FOREIGN KEY (PERS_ID_REGISTERER) REFERENCES PERSONS(ID);\\012\\012\\012------------------------------------------------------------------------------------\\012--  Purpose:  Add the material type BACTERIUM\\012------------------------------------------------------------------------------------\\012\\012insert into material_types\\012(id\\012,code\\012,description)\\012values \\012(nextval('MATERIAL_TYPE_ID_SEQ')\\012,'BACTERIUM'\\012,'Bacterium'\\012);\\012\\012------------------------------------------------------------------------------------\\012--  Purpose:  Add the material type COMPOUND\\012------------------------------------------------------------------------------------\\012\\012insert into material_types\\012(id\\012,code\\012,description)\\012values \\012(nextval('MATERIAL_TYPE_ID_SEQ')\\012,'COMPOUND'\\012,'Compound'\\012);\\012\\012------------------------------------------------------------------------------------\\012--  Purpose:  Insert an initial data set into the table MATERIAL_TYPE_PROPERTY_TYPES\\012------------------------------------------------------------------------------------\\012\\012   -----------------------\\012   --  Material Type BACTERIUM\\012   -----------------------\\012\\012insert into material_type_property_types\\012(   id\\012   ,maty_id\\012   ,prty_id\\012   ,is_mandatory\\012   ,pers_id_registerer\\012   )\\012values \\012   (nextval('MTPT_ID_SEQ')\\012   ,(select id from material_types where code = 'BACTERIUM')\\012   ,(select id from property_types where code = 'DESCRIPTION')\\012   ,true\\012   ,(select id from persons where user_id ='system')\\012);\\012\\012   -----------------------\\012   --  Material Type COMPOUND\\012   -----------------------\\012\\012insert into material_type_property_types\\012(   id\\012   ,maty_id\\012   ,prty_id\\012   ,is_mandatory\\012   ,pers_id_registerer\\012   )\\012values \\012   (nextval('MTPT_ID_SEQ')\\012   ,(select id from material_types where code = 'COMPOUND')\\012   ,(select id from property_types where code = 'DESCRIPTION')\\012   ,true\\012   ,(select id from persons where user_id ='system')\\012);\\012\\012\\012------------------------------------------------------------------------------------\\012--  Purpose:  Change according to naming convention for CODEs\\012------------------------------------------------------------------------------------\\012\\012update procedure_types set code='DATA_ACQUISITION' where code='DATA ACQUISITION';\\012update procedure_types set code='IMAGE_ANALYSIS' where code='IMAGE ANALYSIS';\\012update locator_types set code='RELATIVE_LOCATION' where code='RELATIVE LOCATION';\\012update sample_types set code='MASTER_PLATE' where code='MASTER PLATE';\\012update sample_types set code='DILUTION_PLATE' where code='DILUTION PLATE';\\012update sample_types set code='CELL_PLATE' where code='CELL PLATE';\\012update sample_types set code='REINFECT_PLATE' where code='REINFECT PLATE';\\012update sample_types set description='Re-infection Plate' where code='REINFECT_PLATE';\\012update sample_types set code='CONTROL_LAYOUT' where code='CONTROL LAYOUT';\\012	\N
+./sourceTest/sql/postgresql/test_database_for_migration/postgresql/018/.svn/text-base/006=database_version_logs.tsv.svn-base:014	source/sql/postgresql/migration/migration-013-014.sql	SUCCESS	2008-08-29 08:10:55.582	----------------------------------------------------------------------------------------------\\012--  File: migration-013-014.sql\\012--\\012-- \\012--  This script enables the migration of the database schema from 013 to 014.\\012-- \\012--  Update History\\012--\\012--\\012--\\011Who\\011\\011\\011When\\011\\011What\\012--\\011---\\011\\011\\011----\\011\\011----\\012--\\011Charles Ramin-Wright\\0112008-01-29\\011Initial Version \\012--  \\012----------------------------------------------------------------------------------------------\\012\\012--=================================\\012-- New Tables and related objects\\012--=================================\\012\\012------------------------------------------------------------------------------------\\012--  Purpose:  Add tables CONTROLLED_VOCABULARIES and CONTROLLED_VOCABULARY_TERMS\\012------------------------------------------------------------------------------------\\012\\012CREATE TABLE CONTROLLED_VOCABULARIES (ID TECH_ID NOT NULL,CODE CODE NOT NULL,DESCRIPTION DESCRIPTION_80,REGISTRATION_TIMESTAMP TIME_STAMP NOT NULL DEFAULT CURRENT_TIMESTAMP,PERS_ID TECH_ID NOT NULL);\\012CREATE TABLE CONTROLLED_VOCABULARY_TERMS (ID TECH_ID NOT NULL,CODE OBJECT_NAME NOT NULL,REGISTRATION_TIMESTAMP TIME_STAMP NOT NULL DEFAULT CURRENT_TIMESTAMP,COVO_ID TECH_ID NOT NULL,PERS_ID TECH_ID NOT NULL);\\012\\012\\012-- Creating primary key constraints\\012\\012ALTER TABLE CONTROLLED_VOCABULARIES ADD CONSTRAINT COVO_PK PRIMARY KEY(ID);\\012ALTER TABLE CONTROLLED_VOCABULARY_TERMS ADD CONSTRAINT CVTE_PK PRIMARY KEY(ID);\\012\\012-- Creating unique constraints\\012\\012ALTER TABLE CONTROLLED_VOCABULARIES ADD CONSTRAINT COVO_BK_UK UNIQUE(CODE);\\012ALTER TABLE CONTROLLED_VOCABULARY_TERMS ADD CONSTRAINT CVTE_BK_UK UNIQUE(CODE,COVO_ID);\\012\\012-- Creating foreign key constraints\\012\\012ALTER TABLE CONTROLLED_VOCABULARIES ADD CONSTRAINT COVO_PERS_FK FOREIGN KEY (PERS_ID) REFERENCES PERSONS(ID);\\012ALTER TABLE CONTROLLED_VOCABULARY_TERMS ADD CONSTRAINT CVTE_COVO_FK FOREIGN KEY (COVO_ID) REFERENCES CONTROLLED_VOCABULARIES(ID);\\012ALTER TABLE CONTROLLED_VOCABULARY_TERMS ADD CONSTRAINT CVTE_PERS_FK FOREIGN KEY (PERS_ID) REFERENCES PERSONS(ID);\\012\\012-- Creating sequences\\012\\012CREATE SEQUENCE CONTROLLED_VOCABULARY_ID_SEQ;\\012CREATE SEQUENCE CVTE_ID_SEQ;\\012\\012\\012-- Creating indexes\\012\\012CREATE INDEX COVO_PERS_FK_I ON CONTROLLED_VOCABULARIES (PERS_ID);\\012CREATE INDEX CVTE_COVO_FK_I ON CONTROLLED_VOCABULARY_TERMS (COVO_ID);\\012CREATE INDEX CVTE_PERS_FK_I ON CONTROLLED_VOCABULARY_TERMS (PERS_ID);\\012\\012\\012--====================================\\012-- Modifications of existing objects\\012--====================================\\012\\012---------------------------------------------------------------------------------------------------\\012--  Purpose:  Add column INVA_ID to table EXPERIMENTS in order to allow invalidation of experiments\\012---------------------------------------------------------------------------------------------------\\012\\012ALTER TABLE EXPERIMENTS ADD INVA_ID TECH_ID;\\012ALTER TABLE EXPERIMENTS ADD CONSTRAINT EXPE_INVA_FK FOREIGN KEY (INVA_ID) REFERENCES INVALIDATIONS(ID);\\012CREATE INDEX EXPE_INVA_FK_I ON EXPERIMENTS (INVA_ID);\\012\\012------------------------------------------------------------------------------------\\012--  Purpose:  Add column SAMP_ID_CONTROL_LAYOUT to table SAMPLES in order to allow \\012--            the association of a sample of type CONTROL_LAYOUT to samples\\012------------------------------------------------------------------------------------\\012\\012ALTER TABLE SAMPLES ADD SAMP_ID_CONTROL_LAYOUT TECH_ID;\\012ALTER TABLE SAMPLES ADD CONSTRAINT SAMP_SAMP_FK_CONTROL_LAYOUT FOREIGN KEY (SAMP_ID_CONTROL_LAYOUT) REFERENCES SAMPLES(ID);\\012CREATE INDEX SAMP_SAMP_FK_I_CONTROL_LAYOUT ON SAMPLES (SAMP_ID_CONTROL_LAYOUT);\\012\\012\\012--------------------------------------------------------------\\012--  Purpose:  Add column CVTE_ID to table MATERIAL_PROPERTIES \\012--------------------------------------------------------------\\012ALTER TABLE MATERIAL_PROPERTIES ADD CVTE_ID TECH_ID;\\012ALTER TABLE MATERIAL_PROPERTIES ADD CONSTRAINT MAPR_CVTE_FK FOREIGN KEY (CVTE_ID) REFERENCES CONTROLLED_VOCABULARY_TERMS(ID);\\012CREATE INDEX MAPR_CVTE_FK_I ON MATERIAL_PROPERTIES (CVTE_ID);\\012\\012--------------------------------------------------------------\\012--  Purpose:  Change column VALUE from mandatory to optional\\012--------------------------------------------------------------\\012ALTER TABLE MATERIAL_PROPERTIES ALTER VALUE DROP NOT NULL;\\012\\012-- Creating check constraints\\012\\012ALTER TABLE MATERIAL_PROPERTIES ADD CONSTRAINT VALUE_OR_CVTE_ID CHECK ((value IS NOT NULL and cvte_id IS NULL) or (value IS NULL and cvte_id IS NOT NULL));\\012\\012\\012--------------------------------------------------------------\\012--  Purpose:  Add column COVO_ID to table PROPERTY_TYPES  \\012--------------------------------------------------------------\\012ALTER TABLE PROPERTY_TYPES ADD COVO_ID TECH_ID;\\012ALTER TABLE PROPERTY_TYPES ADD CONSTRAINT PRTY_COVO_FK FOREIGN KEY (COVO_ID) REFERENCES CONTROLLED_VOCABULARIES(ID);\\012CREATE INDEX PRTY_COVO_FK_I ON PROPERTY_TYPES (COVO_ID);\\012\\012\\012------------------------------------------------------------------------------------\\012--  Purpose:  Create trigger CONTROLLED_VOCABULARY_CHECK \\012------------------------------------------------------------------------------------\\012\\012CREATE OR REPLACE FUNCTION CONTROLLED_VOCABULARY_CHECK() RETURNS trigger AS $$\\012DECLARE\\012   cnt     INTEGER;\\012   v_code  CODE;\\012BEGIN\\012\\012   select code into v_code from data_types where id  = NEW.daty_id;\\012\\012   -- Check if the data is of type "CONTROLLEDVOCABULARY"\\012   if v_code = 'CONTROLLEDVOCABULARY' then\\012      if NEW.covo_id IS NULL then\\012         RAISE EXCEPTION 'Insert/Update of Property Type (Code: %) failed, as its Data Type is CONTROLLEDVOCABULARY, but it is not linked to a Controlled Vocabulary.', NEW.code;\\012      end if;\\012   end if;\\012\\012   RETURN NEW;\\012\\012END;\\012$$ LANGUAGE 'plpgsql';\\012\\012\\012CREATE TRIGGER CONTROLLED_VOCABULARY_CHECK BEFORE INSERT OR UPDATE ON PROPERTY_TYPES\\012    FOR EACH ROW EXECUTE PROCEDURE CONTROLLED_VOCABULARY_CHECK();\\012\\012\\012--====================================\\012-- Deletion of existing objects\\012--====================================\\012\\012drop trigger br001_crtl_plate_chk on samples;\\012drop function br001_crtl_plate_chk();\\012\\012\\012--====================================\\012-- Add Master Data\\012--====================================\\012\\012-----------------------------------------------------------------------------------\\012--  Purpose:  Insert into the table DATA_TYPES\\012--\\012--            Create the data type CONTROLLEDVOCABULARY.\\012-----------------------------------------------------------------------------------\\012insert into data_types\\012(id\\012,code\\012,description)\\012values \\012(nextval('DATA_TYPE_ID_SEQ')\\012,'CONTROLLEDVOCABULARY'\\012,'Controlled Vocabulary'\\012);\\012\\012--==========================================\\012--\\012--   Data Migration\\012--\\012--==========================================\\012\\012-----------------------------------------------------------------------------------\\012--  Purpose:  Migrate the CONTROL_LAYOUTs from the SAMPLE_INPUTS table \\012--            to the foreign key SAMP_SAMP_FK_CONTROL_LAYOUT in the SAMPLES table\\012--\\012--            This results in having all CONTROL_LAYOUTs being directly linked \\012--            to CELL_PLATEs.            \\012-----------------------------------------------------------------------------------\\012\\012UPDATE samples cell_plate\\012   SET samp_id_control_layout = \\012          (select control_layout.samp_id\\012           from   sample_inputs control_layout inner join samples s \\012           on     control_layout.samp_id = s.id\\012           where  s.saty_id = (select id from sample_types where code = 'CONTROL_LAYOUT')\\012           and    proc_id = (\\012              select  proc_id\\012              from sample_inputs cp\\012              where cp.samp_id = cell_plate.id))\\012   WHERE saty_id = (select id from sample_types where code = 'CELL_PLATE')\\012   and   id = (select distinct (samp_id)\\012                  from   sample_inputs sain inner join samples s2 \\012                  on  sain.samp_id = cell_plate.id)\\012;\\012\\012-----------------------------------------------------------------------------------\\012--   Delete the CONTROL LAYOUTs from the SAMPLE_INPUTS table\\012-----------------------------------------------------------------------------------\\012\\012delete from sample_inputs\\012where  id in (select si.id \\012              from   sample_inputs si inner join samples s \\012              on     si.samp_id = s.id\\012              where  s.saty_id = (select id from sample_types where code = 'CONTROL_LAYOUT')\\012              )\\012;\\012\\012	\N
+./sourceTest/sql/postgresql/test_database_for_migration/postgresql/018/.svn/text-base/006=database_version_logs.tsv.svn-base:016	source/sql/postgresql/migration/migration-015-016.sql	SUCCESS	2008-08-29 08:11:12.328	----------------------------------------------------------------------------------------------\\012--  File: migration-015-016.sql\\012--\\012-- \\012--  This script enables the migration of the database schema from 015 to 016.\\012-- \\012--  Update History\\012--\\012--\\012--\\011Who\\011\\011\\011When\\011\\011What\\012--\\011---\\011\\011\\011----\\011\\011----\\012--\\011Bernd Rinn\\0112008-03-22\\011Initial Version \\012--  \\012----------------------------------------------------------------------------------------------\\012\\012\\012--=================================\\012-- New Domains\\012--=================================\\012\\012-----------------------------------------------------------------------------------\\012--  Purpose:  Change all CODE columns to LONG_CODE, then re-create DOMAIN CODE identical to LONG_CODE\\012--  and change LONG_CODE columns back to the (new) CODE \\012-----------------------------------------------------------------------------------\\012\\012-- First step: create new domain LONG_CODE\\012CREATE DOMAIN LONG_CODE AS VARCHAR(40);\\012\\012-- Second step: change all CODE to LONG_CODE\\012ALTER TABLE CONTROLLED_VOCABULARIES ALTER COLUMN CODE TYPE LONG_CODE;\\012ALTER TABLE DATA_TYPES ALTER COLUMN CODE TYPE LONG_CODE;\\012ALTER TABLE EXPERIMENTS ALTER COLUMN CODE TYPE LONG_CODE;\\012ALTER TABLE EXPERIMENT_TYPES ALTER COLUMN CODE TYPE LONG_CODE;\\012ALTER TABLE FILE_FORMAT_TYPES ALTER COLUMN CODE TYPE LONG_CODE;\\012ALTER TABLE LOCATOR_TYPES ALTER COLUMN CODE TYPE LONG_CODE;\\012ALTER TABLE MATERIALS ALTER COLUMN CODE TYPE LONG_CODE;\\012ALTER TABLE MATERIAL_BATCHES ALTER COLUMN CODE TYPE LONG_CODE;\\012ALTER TABLE MATERIAL_TYPES ALTER COLUMN CODE TYPE LONG_CODE;\\012ALTER TABLE OBSERVABLE_TYPES ALTER COLUMN CODE TYPE LONG_CODE;\\012ALTER TABLE ORGANIZATIONS ALTER COLUMN CODE TYPE LONG_CODE;\\012ALTER TABLE PROCEDURE_TYPES ALTER COLUMN CODE TYPE LONG_CODE;\\012ALTER TABLE PROJECTS ALTER COLUMN CODE TYPE LONG_CODE;\\012ALTER TABLE PROPERTY_TYPES ALTER COLUMN CODE TYPE LONG_CODE;\\012ALTER TABLE SAMPLES ALTER COLUMN CODE TYPE LONG_CODE;\\012ALTER TABLE SAMPLE_COMPONENTS ALTER COLUMN CODE TYPE LONG_CODE;\\012ALTER TABLE SAMPLE_TYPES ALTER COLUMN CODE TYPE LONG_CODE;\\012\\012-- Third step: re-create CODE as VARCHAR(40)\\012DROP DOMAIN CODE;\\012CREATE DOMAIN CODE AS VARCHAR(40);\\012\\012-- Forth step: change all LONG_CODE columns back to CODE\\012ALTER TABLE CONTROLLED_VOCABULARIES ALTER COLUMN CODE TYPE CODE;\\012ALTER TABLE DATA_TYPES ALTER COLUMN CODE TYPE CODE;\\012ALTER TABLE EXPERIMENTS ALTER COLUMN CODE TYPE CODE;\\012ALTER TABLE EXPERIMENT_TYPES ALTER COLUMN CODE TYPE CODE;\\012ALTER TABLE FILE_FORMAT_TYPES ALTER COLUMN CODE TYPE CODE;\\012ALTER TABLE LOCATOR_TYPES ALTER COLUMN CODE TYPE CODE;\\012ALTER TABLE MATERIALS ALTER COLUMN CODE TYPE CODE;\\012ALTER TABLE MATERIAL_BATCHES ALTER COLUMN CODE TYPE CODE;\\012ALTER TABLE MATERIAL_TYPES ALTER COLUMN CODE TYPE CODE;\\012ALTER TABLE OBSERVABLE_TYPES ALTER COLUMN CODE TYPE CODE;\\012ALTER TABLE ORGANIZATIONS ALTER COLUMN CODE TYPE CODE;\\012ALTER TABLE PROCEDURE_TYPES ALTER COLUMN CODE TYPE CODE;\\012ALTER TABLE PROJECTS ALTER COLUMN CODE TYPE CODE;\\012ALTER TABLE PROPERTY_TYPES ALTER COLUMN CODE TYPE CODE;\\012ALTER TABLE SAMPLES ALTER COLUMN CODE TYPE CODE;\\012ALTER TABLE SAMPLE_COMPONENTS ALTER COLUMN CODE TYPE CODE;\\012ALTER TABLE SAMPLE_TYPES ALTER COLUMN CODE TYPE CODE;\\012\\012-- Fifth step: drop domain LONG_CODE\\012DROP DOMAIN LONG_CODE;\\012\\012-----------------------------------------------------------------------------------\\012--  Purpose:  Create new domain TIME_STAMP_DFL and change current users of TIME_STAMP to TIME_STAMP_DFL\\012--  This adds time zone information and allows for a clean separation between registration time stamps\\012--  which should have a default of CURRENT_TIMESTAMP and other time stamps which should not. \\012-----------------------------------------------------------------------------------\\012\\012-- First step: create new domain TIME_STAMP_DFL\\012CREATE DOMAIN TIME_STAMP_DFL AS TIMESTAMP WITH TIME ZONE NOT NULL DEFAULT CURRENT_TIMESTAMP;\\012\\012-- Second step: change all TIME_STAMP columns to TIME_STAMP_DFL\\012ALTER TABLE CONTROLLED_VOCABULARIES ALTER COLUMN REGISTRATION_TIMESTAMP TYPE TIME_STAMP_DFL;\\012ALTER TABLE CONTROLLED_VOCABULARIES ALTER COLUMN REGISTRATION_TIMESTAMP DROP NOT NULL;\\012ALTER TABLE CONTROLLED_VOCABULARIES ALTER COLUMN REGISTRATION_TIMESTAMP DROP DEFAULT;\\012ALTER TABLE CONTROLLED_VOCABULARY_TERMS ALTER COLUMN REGISTRATION_TIMESTAMP TYPE TIME_STAMP_DFL;\\012ALTER TABLE CONTROLLED_VOCABULARY_TERMS ALTER COLUMN REGISTRATION_TIMESTAMP DROP NOT NULL;\\012ALTER TABLE CONTROLLED_VOCABULARY_TERMS ALTER COLUMN REGISTRATION_TIMESTAMP DROP DEFAULT;\\012ALTER TABLE DATA ALTER COLUMN REGISTRATION_TIMESTAMP TYPE TIME_STAMP_DFL;\\012ALTER TABLE DATA ALTER COLUMN REGISTRATION_TIMESTAMP DROP NOT NULL;\\012ALTER TABLE DATA ALTER COLUMN REGISTRATION_TIMESTAMP DROP DEFAULT;\\012ALTER TABLE EXPERIMENTS ALTER COLUMN REGISTRATION_TIMESTAMP TYPE TIME_STAMP_DFL;\\012ALTER TABLE EXPERIMENTS ALTER COLUMN REGISTRATION_TIMESTAMP DROP NOT NULL;\\012ALTER TABLE EXPERIMENTS ALTER COLUMN REGISTRATION_TIMESTAMP DROP DEFAULT;\\012ALTER TABLE EXPERIMENT_ATTACHMENTS ALTER COLUMN REGISTRATION_TIMESTAMP TYPE TIME_STAMP_DFL;\\012ALTER TABLE EXPERIMENT_ATTACHMENTS ALTER COLUMN REGISTRATION_TIMESTAMP DROP NOT NULL;\\012ALTER TABLE EXPERIMENT_ATTACHMENTS ALTER COLUMN REGISTRATION_TIMESTAMP DROP DEFAULT;\\012ALTER TABLE EXPERIMENT_PROPERTIES ALTER COLUMN REGISTRATION_TIMESTAMP TYPE TIME_STAMP_DFL;\\012ALTER TABLE EXPERIMENT_PROPERTIES ALTER COLUMN REGISTRATION_TIMESTAMP DROP NOT NULL;\\012ALTER TABLE EXPERIMENT_PROPERTIES ALTER COLUMN REGISTRATION_TIMESTAMP DROP DEFAULT;\\012ALTER TABLE EXPERIMENT_TYPE_PROPERTY_TYPES ALTER COLUMN REGISTRATION_TIMESTAMP TYPE TIME_STAMP_DFL;\\012ALTER TABLE EXPERIMENT_TYPE_PROPERTY_TYPES ALTER COLUMN REGISTRATION_TIMESTAMP DROP NOT NULL;\\012ALTER TABLE EXPERIMENT_TYPE_PROPERTY_TYPES ALTER COLUMN REGISTRATION_TIMESTAMP DROP DEFAULT;\\012ALTER TABLE INVALIDATIONS ALTER COLUMN REGISTRATION_TIMESTAMP TYPE TIME_STAMP_DFL;\\012ALTER TABLE INVALIDATIONS ALTER COLUMN REGISTRATION_TIMESTAMP DROP NOT NULL;\\012ALTER TABLE INVALIDATIONS ALTER COLUMN REGISTRATION_TIMESTAMP DROP DEFAULT;\\012ALTER TABLE MATERIALS ALTER COLUMN REGISTRATION_TIMESTAMP TYPE TIME_STAMP_DFL;\\012ALTER TABLE MATERIALS ALTER COLUMN REGISTRATION_TIMESTAMP DROP NOT NULL;\\012ALTER TABLE MATERIALS ALTER COLUMN REGISTRATION_TIMESTAMP DROP DEFAULT;\\012ALTER TABLE MATERIAL_BATCHES ALTER COLUMN REGISTRATION_TIMESTAMP TYPE TIME_STAMP_DFL;\\012ALTER TABLE MATERIAL_BATCHES ALTER COLUMN REGISTRATION_TIMESTAMP DROP NOT NULL;\\012ALTER TABLE MATERIAL_BATCHES ALTER COLUMN REGISTRATION_TIMESTAMP DROP DEFAULT;\\012ALTER TABLE MATERIAL_PROPERTIES ALTER COLUMN REGISTRATION_TIMESTAMP TYPE TIME_STAMP_DFL;\\012ALTER TABLE MATERIAL_PROPERTIES ALTER COLUMN REGISTRATION_TIMESTAMP DROP NOT NULL;\\012ALTER TABLE MATERIAL_PROPERTIES ALTER COLUMN REGISTRATION_TIMESTAMP DROP DEFAULT;\\012ALTER TABLE MATERIAL_TYPE_PROPERTY_TYPES ALTER COLUMN REGISTRATION_TIMESTAMP TYPE TIME_STAMP_DFL;\\012ALTER TABLE MATERIAL_TYPE_PROPERTY_TYPES ALTER COLUMN REGISTRATION_TIMESTAMP DROP NOT NULL;\\012ALTER TABLE MATERIAL_TYPE_PROPERTY_TYPES ALTER COLUMN REGISTRATION_TIMESTAMP DROP DEFAULT;\\012ALTER TABLE PROCEDURES ALTER COLUMN REGISTRATION_TIMESTAMP TYPE TIME_STAMP_DFL;\\012ALTER TABLE PROCEDURES ALTER COLUMN REGISTRATION_TIMESTAMP DROP NOT NULL;\\012ALTER TABLE PROCEDURES ALTER COLUMN REGISTRATION_TIMESTAMP DROP DEFAULT;\\012ALTER TABLE PROPERTY_TYPES ALTER COLUMN REGISTRATION_TIMESTAMP TYPE TIME_STAMP_DFL;\\012ALTER TABLE PROPERTY_TYPES ALTER COLUMN REGISTRATION_TIMESTAMP DROP NOT NULL;\\012ALTER TABLE PROPERTY_TYPES ALTER COLUMN REGISTRATION_TIMESTAMP DROP DEFAULT;\\012ALTER TABLE SAMPLES ALTER COLUMN REGISTRATION_TIMESTAMP TYPE TIME_STAMP_DFL;\\012ALTER TABLE SAMPLES ALTER COLUMN REGISTRATION_TIMESTAMP DROP NOT NULL;\\012ALTER TABLE SAMPLES ALTER COLUMN REGISTRATION_TIMESTAMP DROP DEFAULT;\\012ALTER TABLE SAMPLE_PROPERTIES ALTER COLUMN REGISTRATION_TIMESTAMP TYPE TIME_STAMP_DFL;\\012ALTER TABLE SAMPLE_PROPERTIES ALTER COLUMN REGISTRATION_TIMESTAMP DROP NOT NULL;\\012ALTER TABLE SAMPLE_PROPERTIES ALTER COLUMN REGISTRATION_TIMESTAMP DROP DEFAULT;\\012ALTER TABLE SAMPLE_TYPE_PROPERTY_TYPES ALTER COLUMN REGISTRATION_TIMESTAMP TYPE TIME_STAMP_DFL;\\012ALTER TABLE SAMPLE_TYPE_PROPERTY_TYPES ALTER COLUMN REGISTRATION_TIMESTAMP DROP NOT NULL;\\012ALTER TABLE SAMPLE_TYPE_PROPERTY_TYPES ALTER COLUMN REGISTRATION_TIMESTAMP DROP DEFAULT;\\012\\012-- Third step: drop old domain TIME_STAMP\\012DROP DOMAIN TIME_STAMP;\\012\\012-- Forth step: create new domain time_stamp\\012CREATE DOMAIN TIME_STAMP AS TIMESTAMP WITH TIME ZONE;\\012\\012--=================================\\012-- New Tables and related objects\\012--=================================\\012\\012------------------------------------------------------------------------------------\\012-- table DATA_SET_RELATIONSHIPS (new)\\012------------------------------------------------------------------------------------\\012\\012-- Creating tables\\012\\012CREATE TABLE DATA_SET_RELATIONSHIPS (ID TECH_ID NOT NULL,DATA_ID_PARENT TECH_ID NOT NULL,DATA_ID_CHILD TECH_ID NOT NULL,REGISTRATION_TIMESTAMP TIME_STAMP_DFL);\\012\\012-- Creating primary key constraints\\012\\012ALTER TABLE DATA_SET_RELATIONSHIPS ADD CONSTRAINT DSRE_PK PRIMARY KEY(ID);\\012\\012-- Creating unique constraints\\012\\012ALTER TABLE DATA_SET_RELATIONSHIPS ADD CONSTRAINT DSRE_BK_UK UNIQUE(DATA_ID_CHILD,DATA_ID_PARENT);\\012\\012-- Creating foreign key constraints\\012\\012ALTER TABLE DATA_SET_RELATIONSHIPS ADD CONSTRAINT DSRE_DATA_FK_CHILD FOREIGN KEY (DATA_ID_CHILD) REFERENCES DATA(ID);\\012ALTER TABLE DATA_SET_RELATIONSHIPS ADD CONSTRAINT DSRE_DATA_FK_PARENT FOREIGN KEY (DATA_ID_PARENT) REFERENCES DATA(ID);\\012\\012-- Creating sequences\\012\\012CREATE SEQUENCE DATA_SET_RELATIONSHIP_ID_SEQ;\\012\\012-- Creating indexes\\012\\012CREATE INDEX DSRE_DATA_FK_I_CHILD ON DATA_SET_RELATIONSHIPS (DATA_ID_CHILD);\\012CREATE INDEX DSRE_DATA_FK_I_PARENT ON DATA_SET_RELATIONSHIPS (DATA_ID_PARENT);\\012\\012--====================================\\012-- Drop Tables and related objects\\012--====================================\\012\\012------------------------------------------------------------------------------------\\012-- table DATA_VALUES (deleted)\\012------------------------------------------------------------------------------------\\012\\012-- Delete constraints\\012\\012ALTER TABLE DATA_VALUES DROP CONSTRAINT DAVA_PK;\\012ALTER TABLE DATA_VALUES DROP CONSTRAINT DAVA_BK_UK;\\012ALTER TABLE DATA_VALUES DROP CONSTRAINT DAVA_DATA_FK;\\012ALTER TABLE DATA_VALUES DROP CONSTRAINT DAVA_SACO_FK;\\012\\012-- Delete indices\\012\\012DROP INDEX DAVA_DATA_FK_I;\\012DROP INDEX DAVA_SACO_FK_I;\\012\\012-- Delete sequences\\012\\012DROP SEQUENCE DATA_VALUE_ID_SEQ;\\012\\012-- Delete tables\\012\\012DROP TABLE DATA_VALUES;\\012\\012--====================================\\012-- Modifications of existing objects\\012--====================================\\012\\012------------------------------------------------------------------------------------\\012-- table ORGANIZATIONS (changed)\\012-- * rename to GROUPS\\012--\\012-- table DATA (changed)\\012-- * rename column PROC_ID_ACQUIRED_BY into: PROC_ID_PRODUCED_BY\\012-- * add columns:\\012-- ** IS_PLACEHOLDER BOOLEAN_CHAR\\012-- ** CODE CODE\\012-- ** DATA_PRODUCER_CODE CODE\\012-- ** PRODUCTION_TIMESTAMP TIME_STAMP\\012--\\012-- table EXTERNAL_DATA (changed)\\012-- * add column:\\012-- ** CVTE_ID_STOR_FMT TECH_ID NOT NULL\\012--\\012-- table PROPERTY_TYPES (changed)\\012-- * add column IS_MANAGED_INTERNALLY BOOLEAN_CHAR NOT NULL DEFAULT 'F'\\012-- * add unique constraint PRTY_BK_UK_LBL for column LABEL\\012--\\012-- tables EXPERIMENT_TYPE_PROPERTY_TYPES, MATERIAL_TYPE_PROPERTY_TYPES, SAMPLE_TYPE_PROPERTY_TYPES\\012-- * make the assignments of property types DESCRIPTION, NUCLEOTIDE_SEQUENCE, OFFSET and GENE_SYMBOL \\012--   to material types internally managed \\012--\\012-- table PROCEDURE_TYPES (changed)\\012-- * add column IS_DATA_ACQUISITION BOOLEAN_CHAR NOT NULL DEFAULT 'F'.\\012--\\012-- all tables\\012-- * convert all codes to upper case\\012------------------------------------------------------------------------------------\\012\\012---------------------------------------------------------------------------------------------------\\012--  Purpose:  Rename table ORGANIZATIONS to GROUPS.\\012---------------------------------------------------------------------------------------------------\\012\\012ALTER TABLE PROJECTS DROP CONSTRAINT PROJ_ORGA_FK;\\012ALTER TABLE ORGANIZATIONS DROP CONSTRAINT ORGA_BK_UK;\\012ALTER TABLE ORGANIZATIONS DROP CONSTRAINT ORGA_PK;\\012ALTER TABLE ORGANIZATIONS RENAME TO GROUPS;\\012ALTER INDEX PROJ_ORGA_FK_I RENAME TO PROJ_GROU_FK_I;\\012select RENAME_SEQUENCE('ORGANIZATION_ID_SEQ', 'GROUP_ID_SEQ');\\012ALTER TABLE PROJECTS RENAME COLUMN ORGA_ID TO GROU_ID;\\012ALTER TABLE GROUPS ADD CONSTRAINT GROU_PK PRIMARY KEY(ID);\\012ALTER TABLE GROUPS ADD CONSTRAINT GROU_BK_UK UNIQUE(CODE);\\012ALTER TABLE PROJECTS ADD CONSTRAINT PROJ_GROU_FK FOREIGN KEY (GROU_ID) REFERENCES GROUPS(ID);\\012\\012\\012---------------------------------------------------------------------------------------------------\\012--  Purpose:  Add columnd IS_PLACEHOLDER of table DATA.\\012---------------------------------------------------------------------------------------------------\\012\\012ALTER TABLE DATA ADD COLUMN IS_PLACEHOLDER BOOLEAN_CHAR NOT NULL;\\012\\012\\012---------------------------------------------------------------------------------------------------\\012--  Purpose:  Add and populate column CODE of table DATA.\\012---------------------------------------------------------------------------------------------------\\012\\012ALTER TABLE DATA ADD COLUMN CODE CODE;\\012\\012CREATE OR REPLACE FUNCTION populate_data_codes() RETURNS integer AS $$\\012DECLARE\\012    rec RECORD;\\012BEGIN\\012    FOR rec IN SELECT * FROM data LOOP\\012        rec.code := to_char(rec.registration_timestamp, 'YYYYMMDDHH24MISSMS') || '-' || to_char(rec.id, 'FM99999999999999999999');\\012        update data set code=rec.code where id=rec.id;\\012    END LOOP;\\012    RETURN 1;\\012END;\\012$$ LANGUAGE 'plpgsql';\\012\\012SELECT populate_data_codes();\\012DROP FUNCTION populate_data_codes();\\012\\012ALTER TABLE DATA ALTER COLUMN CODE SET NOT NULL;\\012ALTER TABLE DATA ADD CONSTRAINT DATA_BK_UK UNIQUE(CODE);\\012\\012---------------------------------------------------------------------------------------------------\\012--  Purpose:  Add and populate columns CVTE_ID_STOR_FMT.\\012---------------------------------------------------------------------------------------------------\\012\\012ALTER TABLE EXTERNAL_DATA ADD COLUMN CVTE_ID_STOR_FMT TECH_ID;\\012ALTER TABLE EXTERNAL_DATA ADD CONSTRAINT EXDA_STOR_FMT_FK FOREIGN KEY (CVTE_ID_STOR_FMT) REFERENCES CONTROLLED_VOCABULARY_TERMS(ID);\\012\\012------------------------------------------------------------------------------------\\012--  Purpose:  Create trigger EXTERNAL_DATA_STORAGE_FORMAT_CHECK \\012------------------------------------------------------------------------------------\\012\\012CREATE OR REPLACE FUNCTION EXTERNAL_DATA_STORAGE_FORMAT_CHECK() RETURNS trigger AS $$\\012DECLARE\\012   v_covo_code  CODE;\\012BEGIN\\012\\012   select code into v_covo_code from controlled_vocabularies\\012      where id = (select covo_id from controlled_vocabulary_terms where id = NEW.cvte_id_stor_fmt);\\012\\012   -- Check if the data storage format is a term of the controlled vocabulary "STORAGE_FORMAT"\\012   if v_covo_code != '.STORAGE_FORMAT' then\\012      RAISE EXCEPTION 'Insert/Update of Data (Code: %) failed, as its Storage Format is %, but is required to be STORAGE_FORMAT.', NEW.code, v_covo_code;\\012   end if;\\012\\012   RETURN NEW;\\012\\012END;\\012$$ LANGUAGE 'plpgsql';\\012\\012CREATE TRIGGER EXTERNAL_DATA_STORAGE_FORMAT_CHECK BEFORE INSERT OR UPDATE ON EXTERNAL_DATA\\012    FOR EACH ROW EXECUTE PROCEDURE EXTERNAL_DATA_STORAGE_FORMAT_CHECK();\\012\\012-----------------------------------------------------------------------------------\\012--  Purpose:  Create Controlled Vocabulary .STORAGE_FORMAT\\012-----------------------------------------------------------------------------------\\012insert into controlled_vocabularies \\012       ( id\\012       , code\\012       , description\\012       , pers_id_registerer\\012       , is_managed_internally )\\012values  (nextval('CONTROLLED_VOCABULARY_ID_SEQ')\\012       , '.STORAGE_FORMAT'\\012       , 'The on-disk storage format of a data set'\\012       , (select id from persons where user_id ='system')\\012       , true);\\012\\012\\012-----------------------------------------------------------------------------------\\012--  Purpose:  Create Controlled Vocabulary Terms for STORAGE_FORMAT\\012-----------------------------------------------------------------------------------\\012insert into controlled_vocabulary_terms \\012       ( id\\012       , code\\012       , covo_id \\012       , pers_id_registerer )\\012values  (nextval('CVTE_ID_SEQ')\\012       , 'PROPRIETARY'\\012       , (select id from controlled_vocabularies where code = '.STORAGE_FORMAT')\\012       , (select id from persons where user_id ='system'));\\012\\012insert into controlled_vocabulary_terms \\012       ( id\\012       , code\\012       , covo_id \\012       , pers_id_registerer )\\012values  (nextval('CVTE_ID_SEQ')\\012       , 'BDS_DIRECTORY'\\012       , (select id from controlled_vocabularies where code = '.STORAGE_FORMAT')\\012       , (select id from persons where user_id ='system'));\\012\\012\\012--------------------------------------------------------------------------\\012--  Purpose:  Insert an entry for OBSERVABLE_TYPE UNKNOWN\\012--------------------------------------------------------------------------\\012\\012insert into observable_types\\012(id\\012,code\\012,description)\\012values \\012(nextval('OBSERVABLE_TYPE_ID_SEQ')\\012,'UNKNOWN'\\012,'Unknown'\\012);\\012\\012----------------------------------------------------------------------\\012--  Purpose:  Insert an entry for PROCEDURE_TYPE UNKNOWN\\012-----------------------------------------------------------------------\\012\\012insert into procedure_types\\012(id\\012,code\\012,description)\\012values \\012(nextval('PROCEDURE_TYPE_ID_SEQ')\\012,'UNKNOWN'\\012,'Unknown'\\012);\\012\\012\\012---------------------------------------------------------------------------------------------------\\012--  Purpose:  Populate external_data.cvte_id_stor_fmt with a default value.\\012---------------------------------------------------------------------------------------------------\\012\\012CREATE OR REPLACE FUNCTION polulate_external_data_cvte_id_stor_fmt() RETURNS integer AS $$\\012DECLARE\\012    rec RECORD;\\012    dfl_stor_fmt_code VARCHAR := 'PROPRIETARY';\\012    dfl_stor_fmt_id TECH_ID;\\012BEGIN\\012    select cvte.id into dfl_stor_fmt_id from controlled_vocabulary_terms cvte, controlled_vocabularies cv \\012        where cvte.code = dfl_stor_fmt_code and cvte.covo_id = cv.id and cv.code = '.STORAGE_FORMAT'; \\012    update external_data set cvte_id_stor_fmt = dfl_stor_fmt_id;\\012    RETURN 1;\\012END;\\012$$ LANGUAGE 'plpgsql';\\012\\012SELECT polulate_external_data_cvte_id_stor_fmt();\\012DROP FUNCTION polulate_external_data_cvte_id_stor_fmt();\\012\\012-- Now that the field is populated, create the not null constraint for it.\\012\\012ALTER TABLE EXTERNAL_DATA ALTER COLUMN CVTE_ID_STOR_FMT SET NOT NULL;\\012\\012---------------------------------------------------------------------------------------------------\\012--  Purpose:  Add and populate columns DATA_PRODUCER_CODE and PRODUCTION_TIMESTAMP to table DATA.\\012---------------------------------------------------------------------------------------------------\\012\\012ALTER TABLE DATA ADD COLUMN DATA_PRODUCER_CODE CODE;\\012ALTER TABLE DATA ADD COLUMN PRODUCTION_TIMESTAMP TIME_STAMP;\\012\\012CREATE OR REPLACE FUNCTION populate_data_producer_code_and_production_timestamp() RETURNS integer AS $$\\012DECLARE\\012    rec RECORD;\\012    loty_rel_code VARCHAR := 'RELATIVE_LOCATION';\\012    loty_rel_id TECH_ID;\\012    meas_ts TIMESTAMP;\\012    ds_code CODE;\\012    meas_ts_str TEXT;\\012BEGIN\\012    select id into loty_rel_id from locator_types where code = loty_rel_code; \\012    FOR rec IN SELECT d.id, ed.location FROM data d, external_data ed where d.id = ed.data_id and ed.loty_id = loty_rel_id LOOP\\012        meas_ts_str = substring(rec.location from '^.*/([0-9]{14})_[^_]+_(.*)$');\\012        ds_code := substring(rec.location from '^.*/[0-9]{14}_([^_]+)_(.*)$');\\012        IF meas_ts_str is not null and ds_code is not null THEN\\012            meas_ts := to_timestamp(meas_ts_str, 'YYYYMMDDHH24MISS');\\012            update data set production_timestamp=meas_ts, data_producer_code=ds_code where id=rec.id;\\012        END IF;\\012    END LOOP;\\012    RETURN 1;\\012END;\\012$$ LANGUAGE 'plpgsql';\\012\\012SELECT populate_data_producer_code_and_production_timestamp();\\012DROP FUNCTION populate_data_producer_code_and_production_timestamp();\\012\\012-- Rename columns\\012\\012ALTER TABLE DATA RENAME COLUMN PROC_ID_ACQUIRED_BY to PROC_ID_PRODUCED_BY;\\012\\012---------------------------------------------------------------------------------------------------\\012--  Purpose:  Populate table DATA_SET_RELATIONSHIPS, by using heuristics.\\012---------------------------------------------------------------------------------------------------\\012\\012CREATE OR REPLACE FUNCTION abs_interval(ts1 time_stamp_dfl, ts2 time_stamp_dfl) returns interval AS $$\\012BEGIN\\012    IF ts1 < ts2 THEN\\012        RETURN ts2 - ts1;\\012    ELSE\\012        RETURN ts1 - ts2;\\012    END IF;\\012END;\\012$$ LANGUAGE 'plpgsql';\\012\\012CREATE OR REPLACE FUNCTION populate_data_set_relationships() RETURNS INTEGER AS $$\\012DECLARE\\012    source_id TECH_ID;\\012    rec_derived RECORD;\\012    rec_acquired RECORD;\\012    rel_location TEXT;\\012    data_set_code TEXT;\\012    data_set_code_trial TEXT;\\012    loty_rel_code TEXT := 'RELATIVE_LOCATION';\\012    loty_rel_id TECH_ID;\\012    count INTEGER := 0;\\012BEGIN\\012    select id into loty_rel_id from locator_types where code = loty_rel_code;\\012    FOR rec_derived IN select id, samp_id_derived_from, registration_timestamp from data where samp_id_derived_from is not null LOOP\\012        source_id := NULL;\\012        select location into rel_location from external_data where data_id = rec_derived.id and loty_id = loty_rel_id;\\012        IF rel_location is not null then\\012            data_set_code := substring(rel_location from '^.*/([0-9]{14}_[^_]+)_.*$');\\012            IF data_set_code is not null THEN\\012                FOR rec_acquired IN select id, samp_id_acquired_from from data where samp_id_acquired_from = rec_derived.samp_id_derived_from LOOP\\012                    select location into rel_location from external_data where data_id = rec_acquired.id and loty_id = loty_rel_id;\\012                    IF rel_location is not null THEN\\012                        data_set_code_trial := substring(rel_location from '^.*/([0-9]{14}_[^_]+)_.*$');\\012                        IF data_set_code_trial = data_set_code THEN\\012                            source_id = rec_acquired.id;\\012                            EXIT;\\012                        END IF;\\012                    END IF;\\012                END LOOP;\\012            END IF;\\012        END IF;\\012        -- If the location didn't tell us about data set relationships, try the backup strategy.\\012        IF source_id is null THEN\\012            -- Use the measured data set as source that is closest in registration timestamp.\\012            select id into source_id from data where samp_id_acquired_from = rec_derived.samp_id_derived_from \\012                and abs_interval(registration_timestamp, rec_derived.registration_timestamp) \\012                    = (select min(abs_interval(registration_timestamp, rec_derived.registration_timestamp)) \\012                        from data where samp_id_acquired_from = rec_derived.samp_id_derived_from);\\012        END IF;\\012        IF source_id is not null THEN\\012            insert into data_set_relationships (id, data_id_parent, data_id_child)\\012                values (nextval('DATA_SET_RELATIONSHIP_ID_SEQ'), source_id, rec_derived.id);\\012            count := count + 1;\\012        END IF;\\012    END LOOP;\\012    RETURN count;\\012END;\\012$$ LANGUAGE 'plpgsql';\\012\\012SELECT populate_data_set_relationships();\\012DROP FUNCTION populate_data_set_relationships();\\012DROP FUNCTION abs_interval(time_stamp_dfl, time_stamp_dfl);\\012\\012---------------------------------------------------------------------------------------------------\\012--  Purpose:  Add column IS_MANAGED_INTERNALLY to table PROPERTY_TYPES. Internally managed \\012--  properties can not be assigned by users of openBIS, but only by the system. \\012---------------------------------------------------------------------------------------------------\\012\\012ALTER TABLE PROPERTY_TYPES ADD COLUMN IS_MANAGED_INTERNALLY BOOLEAN_CHAR NOT NULL DEFAULT 'F';\\012\\012-- Update already existing property type PLATE_GEOMETRY\\012update property_types set is_managed_internally = true, code = '.' || code where code = 'PLATE_GEOMETRY';\\012\\012-- Update already existing controlled vocabulary PLATE_GEOMETRY \\012update controlled_vocabularies set code = '.' || code where code = 'PLATE_GEOMETRY';\\012\\012---------------------------------------------------------------------------------------------------\\012--  Purpose:  Add unique constraint on column LABEL. \\012---------------------------------------------------------------------------------------------------\\012\\012CREATE OR REPLACE FUNCTION make_prty_labels_unique() RETURNS INTEGER AS $$\\012DECLARE\\012    prev_key TEXT := NULL;\\012    this_key TEXT;\\012    dup_count INTEGER;\\012    cnt INTEGER := 0;\\012    already_exists INTEGER;\\012    new_label TEXT;\\012    this_id TECH_ID;\\012BEGIN\\012    FOR this_id, this_key IN select id, label from property_types order by label,id LOOP\\012        IF this_key = prev_key THEN\\012            dup_count := dup_count + 1;\\012            cnt := cnt + 1;\\012        ELSE\\012            dup_count := 0;\\012        END IF;\\012        IF dup_count > 0 THEN\\012            -- Check whether the new key already exists.\\012            LOOP\\012                new_label := this_key || '(' || dup_count::text || ')';\\012                select count(*) into already_exists from property_types where label = new_label;\\012                IF already_exists = 0 THEN\\012                    EXIT;\\012                END IF;\\012                dup_count := dup_count + 1;\\012            END LOOP;\\012            update property_types set label = new_label where id = this_id;\\012        END IF;\\012        prev_key := this_key;\\012    END LOOP;\\012    RETURN cnt;\\012END;\\012$$ LANGUAGE 'plpgsql';\\012\\012SELECT make_prty_labels_unique();\\012DROP FUNCTION make_prty_labels_unique();\\012\\012ALTER TABLE PROPERTY_TYPES ADD CONSTRAINT PRTY_BK_UK_LBL UNIQUE(LABEL);\\012\\012-----------------------------------------------------------------------------------\\012--  Purpose:  Add Controlled Vocabulary Terms to PLATE_GEOMETRY\\012-----------------------------------------------------------------------------------\\012\\012insert into controlled_vocabulary_terms \\012       ( id\\012       , code\\012       , covo_id \\012       , pers_id_registerer)\\012values  (nextval('CVTE_ID_SEQ')\\012       , '96_WELLS_8X12'\\012       , (select id from controlled_vocabularies where code = '.PLATE_GEOMETRY')\\012       , (select id from persons where user_id = 'system'));\\012\\012insert into controlled_vocabulary_terms \\012       ( id\\012       , code\\012       , covo_id \\012       , pers_id_registerer)\\012values  (nextval('CVTE_ID_SEQ')\\012       , '1536_WELLS_32X48'\\012       , (select id from controlled_vocabularies where code = '.PLATE_GEOMETRY')\\012       , (select id from persons where user_id = 'system'));\\012\\012\\012-----------------------------------------------------------------------------------\\012--  Purpose:  Rename Observable Types: IMAGE -> HCS_IMAGE, IMAGE_ANALYSIS_DATA -> HCS_IMAGE_ANALYSIS_DATA\\012--  and descriptions accordingly\\012-----------------------------------------------------------------------------------\\012\\012update observable_types set code = 'HCS_IMAGE', description = 'Data derived from analysis of HCS images' where code = 'IMAGE';\\012update observable_types set code = 'HCS_IMAGE_ANALYSIS_DATA', description = 'Data derived from analysis of HCS images' where code = 'IMAGE_ANALYSIS_DATA';\\012\\012\\012-----------------------------------------------------------------------------------\\012--  Purpose: Make the assignments of property types DESCRIPTION, NUCLEOTIDE_SEQUENCE, OFFSET \\012--  and GENE_SYMBOL to material types internally managed. \\012-----------------------------------------------------------------------------------\\012\\012update material_type_property_types set is_managed_internally = true\\012    where prty_id in (select id from property_types where code = 'DESCRIPTION' \\012        or code = 'NUCLEOTIDE_SEQUENCE' or code = 'OFFSET' or code = 'GENE_SYMBOL');\\012\\012-----------------------------------------------------------------------------------\\012--  Purpose: Add column IS_DATA_ACQUISITION BOOLEAN_CHAR NOT NULL DEFAULT 'F' to table PROCEDURE_TYPES.\\012-----------------------------------------------------------------------------------\\012\\012ALTER TABLE PROCEDURE_TYPES ADD COLUMN IS_DATA_ACQUISITION BOOLEAN_CHAR NOT NULL DEFAULT 'F';\\012\\012-- Set the new attribute for procedure type DATA_ACQUISITION\\012update procedure_types set is_data_acquisition = true where code = 'DATA_ACQUISITION';\\012\\012-----------------------------------------------------------------------------------\\012--  Purpose: Convert all codes to upper case. \\012-----------------------------------------------------------------------------------\\012\\012CREATE OR REPLACE FUNCTION column_to_uppercase_fix_duplicates(tbl TEXT, clm TEXT) RETURNS INTEGER AS $$\\012DECLARE\\012    prev_key TEXT := NULL;\\012    this_key TEXT;\\012    dup_count INTEGER;\\012    count INTEGER := 0;\\012    already_exists INTEGER;\\012    new_clm TEXT;\\012BEGIN\\012    FOR this_key IN EXECUTE 'select ' || clm || ' from ' || tbl \\012        || ' order by upper(' || clm || '),id' LOOP\\012        IF upper(this_key) = upper(prev_key) THEN\\012            dup_count := dup_count + 1;\\012            count := count + 1;\\012        ELSE\\012            dup_count := 0;\\012        END IF;\\012        IF dup_count > 0 THEN\\012            -- Check whether the new key already exists.\\012            LOOP\\012                new_clm := this_key || '(' || dup_count::text || ')';\\012                EXECUTE 'select count(*) from ' || tbl \\012                    || ' where upper(' || clm || ') = ' || quote_literal(upper(new_clm)) \\012                    into already_exists;\\012                IF already_exists = 0 THEN\\012                    EXIT;\\012                END IF;\\012                dup_count := dup_count + 1;\\012            END LOOP;\\012            EXECUTE 'update ' || tbl || ' set ' || clm || ' = ' || quote_literal(new_clm) || \\012                ' where ' || clm || ' = ' || quote_literal(this_key);\\012        END IF;\\012        prev_key := this_key;\\012    END LOOP;\\012    EXECUTE 'update ' || tbl || ' set ' || clm || ' = upper(' || clm || ')';\\012    RETURN count;\\012END;\\012$$ LANGUAGE 'plpgsql';\\012\\012\\012CREATE OR REPLACE FUNCTION column_to_uppercase_fix_duplicates(tbl TEXT, clm TEXT, clm2 TEXT) RETURNS INTEGER AS $$\\012DECLARE\\012    prev_key TEXT := NULL;\\012    prev_key2 TECH_ID;\\012    this_key TEXT;\\012    this_key2 TECH_ID;\\012    dup_count INTEGER;\\012    count INTEGER := 0;\\012    already_exists INTEGER;\\012    new_clm TEXT;\\012BEGIN\\012    FOR this_key, this_key2 IN EXECUTE 'select ' || clm || ',' || clm2 || ' from ' || tbl \\012        || ' order by ' || clm2 || ',upper(' ||  clm || '),id' LOOP\\012        IF upper(this_key) = upper(prev_key) and this_key2 = prev_key2 THEN\\012            dup_count := dup_count + 1;\\012            count := count + 1;\\012        ELSE\\012            dup_count := 0;\\012        END IF;\\012        IF dup_count > 0 THEN\\012            -- Check whether the new key already exists.\\012            LOOP\\012                new_clm := this_key || '(' || dup_count::text || ')';\\012                EXECUTE 'select count(*) from ' || tbl \\012                    || ' where upper(' || clm || ') = ' || quote_literal(upper(new_clm)) \\012                    || ' and ' || clm2 || ' = ' || quote_literal(this_key2) \\012                    into already_exists;\\012                IF already_exists = 0 THEN\\012                    EXIT;\\012                END IF;\\012                dup_count := dup_count + 1;\\012            END LOOP;\\012            EXECUTE 'update ' || tbl || ' set ' || clm || ' = ' || quote_literal(new_clm) || \\012                ' where ' || clm || ' = ' || quote_literal(this_key) || ' and ' \\012                || clm2 || ' = ' || quote_literal(this_key2);\\012        END IF;\\012        prev_key := this_key;\\012        prev_key2 := this_key2;\\012    END LOOP;\\012    EXECUTE 'update ' || tbl || ' set ' || clm || ' = upper(' || clm || ')';\\012    RETURN count;\\012END;\\012$$ LANGUAGE 'plpgsql';\\012\\012\\012SELECT column_to_uppercase_fix_duplicates('samples', 'code');\\012SELECT column_to_uppercase_fix_duplicates('property_types', 'code');\\012SELECT column_to_uppercase_fix_duplicates('controlled_vocabularies', 'code');\\012\\012SELECT column_to_uppercase_fix_duplicates('projects', 'code', 'grou_id');\\012SELECT column_to_uppercase_fix_duplicates('experiments', 'code', 'proj_id');\\012SELECT column_to_uppercase_fix_duplicates('controlled_vocabulary_terms', 'code', 'covo_id');\\012SELECT column_to_uppercase_fix_duplicates('materials', 'code', 'maty_id');\\012SELECT column_to_uppercase_fix_duplicates('material_batches', 'code', 'mate_id');\\012SELECT column_to_uppercase_fix_duplicates('sample_components', 'code', 'samp_id');\\012\\012-- These will only need changes if someone entered them through the 'back door' directly on the server.\\012\\012SELECT column_to_uppercase_fix_duplicates('groups', 'code');\\012SELECT column_to_uppercase_fix_duplicates('sample_types', 'code');\\012SELECT column_to_uppercase_fix_duplicates('material_types', 'code');\\012SELECT column_to_uppercase_fix_duplicates('experiment_types', 'code');\\012SELECT column_to_uppercase_fix_duplicates('procedure_types', 'code');\\012SELECT column_to_uppercase_fix_duplicates('observable_types', 'code');\\012SELECT column_to_uppercase_fix_duplicates('locator_types', 'code');\\012SELECT column_to_uppercase_fix_duplicates('file_format_types', 'code');\\012SELECT column_to_uppercase_fix_duplicates('data_types', 'code');\\012\\012DROP FUNCTION column_to_uppercase_fix_duplicates(TEXT, TEXT);\\012DROP FUNCTION column_to_uppercase_fix_duplicates(TEXT, TEXT, TEXT);\\012\\012-----------------------------------------------------------------------------------\\012--  Purpose:  Delete sample_components with no associated material_batches.\\012--  This deletes superfluous controls of master plates\\012-----------------------------------------------------------------------------------\\012\\012delete from sample_components\\012where  id in (select sc.id \\012              from   sample_components as sc left join sample_component_materials as scm \\012              on     scm.saco_id = sc.id \\012              where  scm.saco_id is null\\012              )\\012;\\012	\N
+./sourceTest/sql/postgresql/test_database_for_migration/postgresql/018/.svn/text-base/006=database_version_logs.tsv.svn-base:017	source/sql/postgresql/migration/migration-016-017.sql	SUCCESS	2008-08-29 08:11:12.644	----------------------------------------------------------------------------------------------\\012--  File: migration-016-017.sql\\012--\\012-- \\012--  This script enables the migration of the database schema from 016 to 017.\\012-- \\012--  Update History\\012--\\012--\\012--\\011Who\\011\\011\\011              When\\011\\011    What\\012--\\011---\\011\\011\\011              ----      \\011----\\012--\\011Charles Ramin-Wright\\0112008-04-11\\011Initial Version \\012--  \\012----------------------------------------------------------------------------------------------\\012\\012\\012--=================================\\012-- Create Objects\\012--=================================\\012\\012-- Domains\\012\\012-- 'F' is false, 'T' is true and 'U' is unknown\\012CREATE DOMAIN BOOLEAN_CHAR_OR_UNKNOWN AS CHAR(1) CHECK (VALUE in ('F', 'T', 'U'));\\012\\012-- Tables and related objects\\012\\012-- Sequences\\012\\012-- Indices\\012\\012--====================================\\012-- Delete Objects\\012--====================================\\012\\012-- Domains\\012\\012-- Tables\\012\\012-- Sequences\\012\\012-- Indices\\012\\012--====================================\\012-- Alter Objects\\012--====================================\\012\\012-- Add column IS_INTERNAL_NAMESPACE to table CONTROLLED_VOCABULARIES \\012\\012ALTER TABLE CONTROLLED_VOCABULARIES ADD IS_INTERNAL_NAMESPACE BOOLEAN_CHAR NOT NULL DEFAULT 'F';\\012\\012-- Add column IS_INTERNAL_NAMESPACE to table PROPERTY_TYPES \\012\\012ALTER TABLE PROPERTY_TYPES ADD IS_INTERNAL_NAMESPACE BOOLEAN_CHAR NOT NULL DEFAULT 'F';\\012\\012-- Add column IS_INTERNAL_NAMESPACE as key component to the unique key constraint COVO_BK_UK\\012\\012ALTER TABLE CONTROLLED_VOCABULARIES DROP CONSTRAINT COVO_BK_UK;\\012ALTER TABLE CONTROLLED_VOCABULARIES ADD CONSTRAINT COVO_BK_UK UNIQUE(CODE,IS_INTERNAL_NAMESPACE);\\012\\012-- Add column IS_INTERNAL_NAMESPACE as key component to the unique key constraint PRTY_BK_UK\\012\\012ALTER TABLE PROPERTY_TYPES DROP CONSTRAINT PRTY_BK_UK;\\012ALTER TABLE PROPERTY_TYPES ADD CONSTRAINT PRTY_BK_UK UNIQUE(CODE,IS_INTERNAL_NAMESPACE);\\012\\012-- Delete unique key constraint PRTY_BK_UK_LBL (which was for column LABEL) from table PROPERTY_TYPES\\012\\012ALTER TABLE PROPERTY_TYPES DROP CONSTRAINT PRTY_BK_UK_LBL;\\012\\012\\012-- Change unique constraint EXDA_BK_UK to contain EXTERNAL_DATA.LOTY_ID \\012\\012ALTER TABLE EXTERNAL_DATA DROP CONSTRAINT EXDA_BK_UK;\\012ALTER TABLE EXTERNAL_DATA ADD CONSTRAINT EXDA_BK_UK UNIQUE(LOCATION,LOTY_ID);\\012\\012\\012-- Increase length of EXTERNAL_DATA.LOCATION from 200 to 1024\\012\\012ALTER TABLE EXTERNAL_DATA ALTER COLUMN LOCATION TYPE VARCHAR(1024);\\012\\012\\012-- Add column IS_COMPLETE to table EXTERNAL_DATA\\012\\012ALTER TABLE EXTERNAL_DATA ADD COLUMN IS_COMPLETE BOOLEAN_CHAR_OR_UNKNOWN NOT NULL DEFAULT 'U';\\012\\012\\012--=================================\\012-- Replace EXTERNAL_DATA_STORAGE_FORMAT_CHECK() function\\012--=================================\\012\\012CREATE OR REPLACE FUNCTION EXTERNAL_DATA_STORAGE_FORMAT_CHECK() RETURNS trigger AS $$\\012DECLARE\\012   v_covo_code  CODE;\\012   data_code CODE;\\012BEGIN\\012\\012   select code into v_covo_code from controlled_vocabularies\\012      where is_internal_namespace = true and \\012         id = (select covo_id from controlled_vocabulary_terms where id = NEW.cvte_id_stor_fmt);\\012\\012-- Check if the data storage format is a term of the controlled vocabulary "STORAGE_FORMAT"\\012   if v_covo_code != 'STORAGE_FORMAT' then\\012      select code into data_code from data where id = NEW.data_id; \\012      RAISE EXCEPTION 'Insert/Update of Data (Code: %) failed, as its Storage Format is %, but is required to be STORAGE_FORMAT.', data_code, v_covo_code;\\012   end if;\\012\\012   RETURN NEW;\\012\\012END;\\012$$ LANGUAGE 'plpgsql';\\012\\012\\012--=================================\\012-- Data Migration\\012--=================================\\012\\012\\012---------------------------------------------------------------------------------------\\012--   Translate the internally managed CODES which are represented by the Dot-Prefix to:\\012--\\012--   CODE without a Dot-Prefix plus the new column IS_INTERNAL_NAMESPACE = true.\\012---------------------------------------------------------------------------------------\\012\\012UPDATE property_types\\012SET    code = substr(code,2,length(code))\\012     , is_internal_namespace = true \\012WHERE  substr(code,1,1) = '.';\\012\\012UPDATE controlled_vocabularies\\012SET    code = substr(code,2,length(code))\\012     , is_internal_namespace = true \\012WHERE  substr(code,1,1) = '.';\\012\\012------------------------------------------------------------------------------------\\012--  Purpose: Move experiment descriptions from column to property DESCRIPTION\\012------------------------------------------------------------------------------------\\012\\012   -----------------------\\012   --  Material Type SIRNHACS\\012   -----------------------\\012\\012insert into experiment_type_property_types\\012(   id\\012   ,exty_id\\012   ,prty_id\\012   ,is_mandatory\\012   ,is_managed_internally\\012   ,pers_id_registerer\\012   )\\012values \\012(   nextval('ETPT_ID_SEQ')\\012   ,(select id from experiment_types where code = 'SIRNAHCS')\\012   ,(select id from property_types where code = 'DESCRIPTION')\\012   ,true\\012   ,true\\012   ,(select id from persons where user_id ='system')\\012);\\012\\012-- Add experiment_properties for descriptions of all experiments of type SIRNAHCS \\012\\012insert into experiment_properties\\012(   id\\012   ,expe_id\\012   ,value\\012   ,etpt_id\\012   ,pers_id_registerer\\012)\\012select\\012    nextval('EXPERIMENT_PROPERTY_ID_SEQ')\\012   ,id\\012   ,case when description is not null then description else 'No description given' end\\012   ,currval('ETPT_ID_SEQ')\\012   ,(select id from persons where user_id ='system')  \\012from experiments where exty_id = (select id from experiment_types where code = 'SIRNAHCS');\\012\\012-- Finally: drop column\\012\\012ALTER TABLE EXPERIMENTS DROP COLUMN DESCRIPTION;\\012	\N
+./sourceTest/sql/postgresql/test_database_for_migration/postgresql/018/.svn/text-base/schema-018.sql.svn-base:    LANGUAGE plpgsql;
+./sourceTest/sql/postgresql/test_database_for_migration/postgresql/018/.svn/text-base/schema-018.sql.svn-base:    LANGUAGE plpgsql;
+./sourceTest/sql/postgresql/test_database_for_migration/postgresql/018/.svn/text-base/schema-018.sql.svn-base:    LANGUAGE plpgsql;
+./sourceTest/sql/postgresql/test_database_for_migration/postgresql/018/006=database_version_logs.tsv:007	source/sql/postgresql/007/schema-007.sql	SUCCESS	2007-12-04 15:50:54.064	-- D:\\\\DDL\\\\postgresql\\\\schema-007.sql\\012--\\012-- Generated for ANSI SQL92 on Thu Aug 23  19:02:15 2007 by Server Generator 10.1.2.6.18\\012-- Post generation PostgreSQL specific Changes:\\012-- \\012--  1. change domain FILE from BIT(32000) to BYTEA\\012--  2. change domain TECH_ID from NUMERIC(20) to BIGINT\\012--  3. Put single quotes around the default value NOW in the create domain statement for the domain TIME_STAMP\\012--     i.e. change CREATE DOMAIN TIME_STAMP AS TIMESTAMP DEFAULT now; to CREATE DOMAIN TIME_STAMP AS TIMESTAMP DEFAULT 'now';\\012--  4. Temporarily not created, due to data quality issues with the master plate layout data\\012--\\012-- ALTER TABLE MOLECULES ADD CONSTRAINT MOLE_BK_UK UNIQUE(SEQUENCE);\\012\\012\\012\\012CREATE DOMAIN DESCRIPTION_80 AS VARCHAR(80);\\012CREATE DOMAIN USER_ID AS VARCHAR(20);\\012CREATE DOMAIN DOUBLE_PRECISION_VALUE AS DOUBLE PRECISION;\\012CREATE DOMAIN FILE_NAME AS VARCHAR(100);\\012CREATE DOMAIN TECH_ID AS BIGINT;\\012CREATE DOMAIN OBJECT_NAME AS VARCHAR(50);\\012CREATE DOMAIN TIME_STAMP AS TIMESTAMP DEFAULT CURRENT_TIMESTAMP;\\012CREATE DOMAIN REAL_VALUE AS REAL;\\012CREATE DOMAIN FILE AS BYTEA;\\012CREATE DOMAIN CODE AS VARCHAR(20);\\012CREATE DOMAIN DESCRIPTION_250 AS VARCHAR(250);\\012CREATE TABLE EXPERIMENT_PROPERTIES  (ID TECH_ID NOT NULL,EXPE_ID TECH_ID NOT NULL,FILE_NAME FILE_NAME NOT NULL,REGISTRATION_TIMESTAMP TIME_STAMP NOT NULL DEFAULT CURRENT_TIMESTAMP,VALUE FILE NOT NULL,VERSION INTEGER NOT NULL,PERS_ID_REGISTERER TECH_ID NOT NULL) ;\\012CREATE TABLE EXPERIMENT_TYPES  (ID TECH_ID NOT NULL,CODE CODE NOT NULL,DESCRIPTION DESCRIPTION_80) ;\\012CREATE TABLE DATA_VALUES  (ID TECH_ID NOT NULL,DATA_ID TECH_ID NOT NULL,SACO_ID TECH_ID NOT NULL,VALUE DOUBLE_PRECISION_VALUE NOT NULL) ;\\012CREATE TABLE PERSONS  (ID TECH_ID NOT NULL,FIRST_NAME VARCHAR(30),LAST_NAME VARCHAR(30),USER_ID USER_ID,EMAIL OBJECT_NAME) ;\\012CREATE TABLE FILE_FORMAT_TYPES  (ID TECH_ID NOT NULL,CODE CODE NOT NULL,DESCRIPTION DESCRIPTION_80) ;\\012CREATE TABLE SAMPLE_INPUTS  (ID TECH_ID NOT NULL,SAMP_ID TECH_ID NOT NULL,PROC_ID TECH_ID NOT NULL) ;\\012CREATE TABLE OBSERVABLE_TYPES  (ID TECH_ID NOT NULL,CODE CODE NOT NULL,DESCRIPTION DESCRIPTION_80) ;\\012CREATE TABLE LOCATOR_TYPES  (ID TECH_ID NOT NULL,CODE CODE NOT NULL,DESCRIPTION DESCRIPTION_80) ;\\012CREATE TABLE SAMPLE_COMPONENTS  (ID TECH_ID NOT NULL,CODE CODE NOT NULL,SAMP_ID TECH_ID NOT NULL) ;\\012CREATE TABLE SAMPLE_TYPES  (ID TECH_ID NOT NULL,CODE CODE NOT NULL,DESCRIPTION DESCRIPTION_80) ;\\012CREATE TABLE ORGANIZATIONS  (ID TECH_ID NOT NULL,CODE CODE NOT NULL) ;\\012CREATE TABLE PROCEDURES  (ID TECH_ID NOT NULL,REGISTRATION_TIMESTAMP TIME_STAMP NOT NULL DEFAULT CURRENT_TIMESTAMP,EXPE_ID TECH_ID NOT NULL,PCTY_ID TECH_ID NOT NULL,PERS_ID TECH_ID) ;\\012CREATE TABLE PROCEDURE_TYPES  (ID TECH_ID NOT NULL,CODE CODE NOT NULL,DESCRIPTION DESCRIPTION_80 NOT NULL) ;\\012CREATE TABLE PROJECTS  (ID TECH_ID NOT NULL,CODE CODE NOT NULL,ORGA_ID TECH_ID NOT NULL) ;\\012CREATE TABLE SAMPLE_COMPONENT_MATERIALS  (ID TECH_ID NOT NULL,SACO_ID TECH_ID NOT NULL,MABA_ID TECH_ID NOT NULL) ;\\012CREATE TABLE EXTERNAL_DATA  (DATA_ID TECH_ID NOT NULL,LOCATION VARCHAR(200) NOT NULL,LOTY_ID TECH_ID NOT NULL,FFTY_ID TECH_ID NOT NULL) ;\\012CREATE TABLE DATA  (ID TECH_ID NOT NULL,REGISTRATION_TIMESTAMP TIME_STAMP NOT NULL DEFAULT CURRENT_TIMESTAMP,OBTY_ID TECH_ID NOT NULL,PROC_ID_ACQUIRED_BY TECH_ID NOT NULL,SAMP_ID_ACQUIRED_FROM TECH_ID,SAMP_ID_DERIVED_FROM TECH_ID) ;\\012CREATE TABLE SAMPLES  (ID TECH_ID NOT NULL,CODE CODE NOT NULL,CONT_ID TECH_ID,PROC_ID TECH_ID,SAMP_ID_TOP TECH_ID,SAMP_ID_GENERATED_FROM TECH_ID,SATY_ID TECH_ID NOT NULL,REGISTRATION_TIMESTAMP TIME_STAMP NOT NULL DEFAULT CURRENT_TIMESTAMP,PERS_ID_REGISTERER TECH_ID NOT NULL) ;\\012CREATE TABLE MATERIAL_TYPES  (ID TECH_ID NOT NULL,CODE CODE NOT NULL,DESCRIPTION DESCRIPTION_80) ;\\012CREATE TABLE MATERIAL_BATCHES  (ID TECH_ID NOT NULL,CODE CODE NOT NULL,AMOUNT REAL_VALUE,MATE_ID TECH_ID NOT NULL,CONT_ID TECH_ID,PROC_ID TECH_ID,REGISTRATION_TIMESTAMP TIME_STAMP NOT NULL DEFAULT CURRENT_TIMESTAMP,PERS_ID_REGISTERER TECH_ID NOT NULL) ;\\012CREATE TABLE MATERIALS  (ID TECH_ID NOT NULL,CODE CODE NOT NULL,DESCRIPTION DESCRIPTION_250,MATY_ID TECH_ID NOT NULL,REGISTRATION_TIMESTAMP TIME_STAMP NOT NULL DEFAULT CURRENT_TIMESTAMP,PERS_ID_REGISTERER TECH_ID NOT NULL) ;\\012CREATE TABLE MOLECULES  (MATE_ID TECH_ID NOT NULL,SEQUENCE VARCHAR(100),ACCESSION_NUMBER OBJECT_NAME,OFF_SET VARCHAR(20),MOLE_ID_INHIBITOR_OF TECH_ID,GENE_SYMBOL CODE) ;\\012CREATE TABLE EXPERIMENTS  (ID TECH_ID NOT NULL,CODE CODE NOT NULL,EXTY_ID TECH_ID NOT NULL,MATE_ID_STUDY_OBJECT TECH_ID,PERS_ID_REGISTERER TECH_ID,REGISTRATION_TIMESTAMP TIME_STAMP NOT NULL DEFAULT CURRENT_TIMESTAMP,DESCRIPTION DESCRIPTION_250,PROJ_ID TECH_ID NOT NULL) ;\\012\\012ALTER TABLE EXPERIMENT_PROPERTIES ADD CONSTRAINT EXPR_PK PRIMARY KEY(ID);\\012ALTER TABLE EXPERIMENT_TYPES ADD CONSTRAINT EXTY_PK PRIMARY KEY(ID);\\012ALTER TABLE DATA_VALUES ADD CONSTRAINT DAVA_PK PRIMARY KEY(ID);\\012ALTER TABLE PERSONS ADD CONSTRAINT PERS_PK PRIMARY KEY(ID);\\012ALTER TABLE FILE_FORMAT_TYPES ADD CONSTRAINT FFTY_PK PRIMARY KEY(ID);\\012ALTER TABLE SAMPLE_INPUTS ADD CONSTRAINT SAIN_PK PRIMARY KEY(ID);\\012ALTER TABLE OBSERVABLE_TYPES ADD CONSTRAINT OBTY_PK PRIMARY KEY(ID);\\012ALTER TABLE LOCATOR_TYPES ADD CONSTRAINT LOTY_PK PRIMARY KEY(ID);\\012ALTER TABLE SAMPLE_COMPONENTS ADD CONSTRAINT SACO_PK PRIMARY KEY(ID);\\012ALTER TABLE SAMPLE_TYPES ADD CONSTRAINT SATY_PK PRIMARY KEY(ID);\\012ALTER TABLE ORGANIZATIONS ADD CONSTRAINT ORGA_PK PRIMARY KEY(ID);\\012ALTER TABLE PROCEDURES ADD CONSTRAINT PROC_PK PRIMARY KEY(ID);\\012ALTER TABLE PROCEDURE_TYPES ADD CONSTRAINT PCTY_PK PRIMARY KEY(ID);\\012ALTER TABLE PROJECTS ADD CONSTRAINT PROJ_PK PRIMARY KEY(ID);\\012ALTER TABLE SAMPLE_COMPONENT_MATERIALS ADD CONSTRAINT SCMA_PK PRIMARY KEY(ID);\\012ALTER TABLE EXTERNAL_DATA ADD CONSTRAINT EXDA_PK PRIMARY KEY(DATA_ID);\\012ALTER TABLE DATA ADD CONSTRAINT DATA_PK PRIMARY KEY(ID);\\012ALTER TABLE SAMPLES ADD CONSTRAINT SAMP_PK PRIMARY KEY(ID);\\012ALTER TABLE MATERIAL_TYPES ADD CONSTRAINT MATY_PK PRIMARY KEY(ID);\\012ALTER TABLE MATERIAL_BATCHES ADD CONSTRAINT MABA_PK PRIMARY KEY(ID);\\012ALTER TABLE MATERIALS ADD CONSTRAINT MATE_PK PRIMARY KEY(ID);\\012ALTER TABLE MOLECULES ADD CONSTRAINT MOLE_PK PRIMARY KEY(MATE_ID);\\012ALTER TABLE EXPERIMENTS ADD CONSTRAINT EXPE_PK PRIMARY KEY(ID);\\012ALTER TABLE EXPERIMENT_PROPERTIES ADD CONSTRAINT EXPR_BK_UK UNIQUE(EXPE_ID,FILE_NAME,VERSION);\\012ALTER TABLE EXPERIMENT_TYPES ADD CONSTRAINT EXTY_BK_UK UNIQUE(CODE);\\012ALTER TABLE DATA_VALUES ADD CONSTRAINT DAVA_BK_UK UNIQUE(DATA_ID,SACO_ID);\\012ALTER TABLE PERSONS ADD CONSTRAINT PERS_BK_UK UNIQUE(USER_ID);\\012ALTER TABLE FILE_FORMAT_TYPES ADD CONSTRAINT FFTY_BK_UK UNIQUE(CODE);\\012ALTER TABLE SAMPLE_INPUTS ADD CONSTRAINT SAIN_BK_UK UNIQUE(SAMP_ID,PROC_ID);\\012ALTER TABLE OBSERVABLE_TYPES ADD CONSTRAINT OBTY_BK_UK UNIQUE(CODE);\\012ALTER TABLE LOCATOR_TYPES ADD CONSTRAINT LOTY_BK_UK UNIQUE(CODE);\\012ALTER TABLE SAMPLE_COMPONENTS ADD CONSTRAINT SACO_BK_UK UNIQUE(CODE,SAMP_ID);\\012ALTER TABLE SAMPLE_TYPES ADD CONSTRAINT SATY_BK_UK UNIQUE(CODE);\\012ALTER TABLE ORGANIZATIONS ADD CONSTRAINT ORGA_BK_UK UNIQUE(CODE);\\012ALTER TABLE PROCEDURE_TYPES ADD CONSTRAINT PCTY_BK_UK UNIQUE(CODE);\\012ALTER TABLE PROJECTS ADD CONSTRAINT PROJ_BK_UK UNIQUE(CODE,ORGA_ID);\\012ALTER TABLE SAMPLE_COMPONENT_MATERIALS ADD CONSTRAINT SCMA_BK_UK UNIQUE(MABA_ID,SACO_ID);\\012ALTER TABLE EXTERNAL_DATA ADD CONSTRAINT EXDA_BK_UK UNIQUE(LOCATION);\\012ALTER TABLE SAMPLES ADD CONSTRAINT SAMP_BK_UK UNIQUE(CODE);\\012ALTER TABLE MATERIAL_TYPES ADD CONSTRAINT MATY_UK UNIQUE(CODE);\\012ALTER TABLE MATERIAL_TYPES ADD CONSTRAINT MATY_BK_UK UNIQUE(CODE);\\012ALTER TABLE MATERIALS ADD CONSTRAINT MATE_BK_UK UNIQUE(CODE);\\012--\\012--  Temporarily not created, due to data quality issues with the master plate layout data\\012--\\012-- ALTER TABLE MOLECULES ADD CONSTRAINT MOLE_BK_UK UNIQUE(SEQUENCE);\\012ALTER TABLE EXPERIMENTS ADD CONSTRAINT EXPE_BK_UK UNIQUE(CODE,PROJ_ID);\\012\\012ALTER TABLE DATA ADD CONSTRAINT DATA_SAMP_ARC_CK CHECK ((samp_id_acquired_from IS NOT NULL \\012and samp_id_derived_from IS NULL) \\012or (samp_id_acquired_from IS NULL \\012and samp_id_derived_from IS NOT NULL)) ;\\012ALTER TABLE EXPERIMENT_PROPERTIES ADD CONSTRAINT EXPR_PERS_FK FOREIGN KEY (PERS_ID_REGISTERER)REFERENCES PERSONS(ID);\\012ALTER TABLE EXPERIMENT_PROPERTIES ADD CONSTRAINT EXPR_EXPE_FK FOREIGN KEY (EXPE_ID)REFERENCES EXPERIMENTS(ID);\\012ALTER TABLE DATA_VALUES ADD CONSTRAINT DAVA_DATA_FK FOREIGN KEY (DATA_ID)REFERENCES DATA(ID);\\012ALTER TABLE DATA_VALUES ADD CONSTRAINT DAVA_SACO_FK FOREIGN KEY (SACO_ID)REFERENCES SAMPLE_COMPONENTS(ID);\\012ALTER TABLE SAMPLE_INPUTS ADD CONSTRAINT SAIN_PROC_FK FOREIGN KEY (PROC_ID)REFERENCES PROCEDURES(ID);\\012ALTER TABLE SAMPLE_INPUTS ADD CONSTRAINT SAIN_SAMP_FK FOREIGN KEY (SAMP_ID)REFERENCES SAMPLES(ID);\\012ALTER TABLE SAMPLE_COMPONENTS ADD CONSTRAINT SACO_SAMP_FK FOREIGN KEY (SAMP_ID)REFERENCES SAMPLES(ID);\\012ALTER TABLE PROCEDURES ADD CONSTRAINT PROC_PCTY_FK FOREIGN KEY (PCTY_ID)REFERENCES PROCEDURE_TYPES(ID);\\012ALTER TABLE PROCEDURES ADD CONSTRAINT PROC_PERS_FK FOREIGN KEY (PERS_ID)REFERENCES PERSONS(ID);\\012ALTER TABLE PROCEDURES ADD CONSTRAINT PROC_EXPE_FK FOREIGN KEY (EXPE_ID)REFERENCES EXPERIMENTS(ID);\\012ALTER TABLE PROJECTS ADD CONSTRAINT PROJ_ORGA_FK FOREIGN KEY (ORGA_ID)REFERENCES ORGANIZATIONS(ID);\\012ALTER TABLE SAMPLE_COMPONENT_MATERIALS ADD CONSTRAINT SCMA_MABA_FK FOREIGN KEY (MABA_ID)REFERENCES MATERIAL_BATCHES(ID);\\012ALTER TABLE SAMPLE_COMPONENT_MATERIALS ADD CONSTRAINT SCMA_SACO_FK FOREIGN KEY (SACO_ID)REFERENCES SAMPLE_COMPONENTS(ID);\\012ALTER TABLE EXTERNAL_DATA ADD CONSTRAINT EXDA_DATA_FK FOREIGN KEY (DATA_ID)REFERENCES DATA(ID);\\012ALTER TABLE EXTERNAL_DATA ADD CONSTRAINT EXDA_LOTY_FK FOREIGN KEY (LOTY_ID)REFERENCES LOCATOR_TYPES(ID);\\012ALTER TABLE EXTERNAL_DATA ADD CONSTRAINT EXDA_FFTY_FK FOREIGN KEY (FFTY_ID)REFERENCES FILE_FORMAT_TYPES(ID);\\012ALTER TABLE DATA ADD CONSTRAINT DATA_SAMP_DERIVED_FROM_FK FOREIGN KEY (SAMP_ID_DERIVED_FROM)REFERENCES SAMPLES(ID);\\012ALTER TABLE DATA ADD CONSTRAINT DATA_SAMP_FK FOREIGN KEY (SAMP_ID_ACQUIRED_FROM)REFERENCES SAMPLES(ID);\\012ALTER TABLE DATA ADD CONSTRAINT DATA_PROC_FK FOREIGN KEY (PROC_ID_ACQUIRED_BY)REFERENCES PROCEDURES(ID);\\012ALTER TABLE DATA ADD CONSTRAINT DATA_OBTY_FK FOREIGN KEY (OBTY_ID)REFERENCES OBSERVABLE_TYPES(ID);\\012ALTER TABLE SAMPLES ADD CONSTRAINT SAMP_PERS_FK FOREIGN KEY (PERS_ID_REGISTERER)REFERENCES PERSONS(ID);\\012ALTER TABLE SAMPLES ADD CONSTRAINT SAMP_PROC_FK FOREIGN KEY (PROC_ID)REFERENCES PROCEDURES(ID);\\012ALTER TABLE SAMPLES ADD CONSTRAINT SAMP_SAMP_FK_GENERATED_FROM FOREIGN KEY (SAMP_ID_GENERATED_FROM)REFERENCES SAMPLES(ID);\\012ALTER TABLE SAMPLES ADD CONSTRAINT SAMP_SAMP_FK_TOP FOREIGN KEY (SAMP_ID_TOP)REFERENCES SAMPLES(ID);\\012ALTER TABLE SAMPLES ADD CONSTRAINT SAMP_SATY_FK FOREIGN KEY (SATY_ID)REFERENCES SAMPLE_TYPES(ID);\\012ALTER TABLE MATERIAL_BATCHES ADD CONSTRAINT MABA_PERS_FK FOREIGN KEY (PERS_ID_REGISTERER)REFERENCES PERSONS(ID);\\012ALTER TABLE MATERIAL_BATCHES ADD CONSTRAINT MABA_MATE_FK FOREIGN KEY (MATE_ID)REFERENCES MATERIALS(ID);\\012ALTER TABLE MATERIAL_BATCHES ADD CONSTRAINT MABA_PROC_FK FOREIGN KEY (PROC_ID)REFERENCES PROCEDURES(ID);\\012ALTER TABLE MATERIALS ADD CONSTRAINT MATE_MATY_FK FOREIGN KEY (MATY_ID)REFERENCES MATERIAL_TYPES(ID);\\012ALTER TABLE MATERIALS ADD CONSTRAINT MATE_PERS_FK FOREIGN KEY (PERS_ID_REGISTERER)REFERENCES PERSONS(ID);\\012ALTER TABLE MOLECULES ADD CONSTRAINT MOLE_MATE_FK FOREIGN KEY (MATE_ID)REFERENCES MATERIALS(ID);\\012ALTER TABLE MOLECULES ADD CONSTRAINT MOLE_MOLE_FK FOREIGN KEY (MOLE_ID_INHIBITOR_OF)REFERENCES MOLECULES(MATE_ID);\\012ALTER TABLE EXPERIMENTS ADD CONSTRAINT EXPE_MATE_FK FOREIGN KEY (MATE_ID_STUDY_OBJECT)REFERENCES MATERIALS(ID);\\012ALTER TABLE EXPERIMENTS ADD CONSTRAINT EXPE_EXTY_FK FOREIGN KEY (EXTY_ID)REFERENCES EXPERIMENT_TYPES(ID);\\012ALTER TABLE EXPERIMENTS ADD CONSTRAINT EXPE_PERS_FK FOREIGN KEY (PERS_ID_REGISTERER)REFERENCES PERSONS(ID);\\012ALTER TABLE EXPERIMENTS ADD CONSTRAINT EXPE_PROJ_FK FOREIGN KEY (PROJ_ID)REFERENCES PROJECTS(ID);\\012\\012\\012\\012--  Creating Sequences\\012\\012CREATE SEQUENCE EXPERIMENT_PROPERTY_ID_SEQ;\\012\\012CREATE SEQUENCE PROCEDURE_TYPE_ID_SEQ;\\012\\012CREATE SEQUENCE SAMPLE_INPUT_ID_SEQ;\\012\\012CREATE SEQUENCE SAMPLE_TYPE_ID_SEQ;\\012\\012CREATE SEQUENCE LOCATOR_TYPE_ID_SEQ;\\012\\012CREATE SEQUENCE SAMPLE_ID_SEQ;\\012\\012CREATE SEQUENCE EXPERIMENT_ID_SEQ;\\012\\012CREATE SEQUENCE MATERIAL_BATCH_ID_SEQ;\\012\\012CREATE SEQUENCE OBSERVABLE_TYPE_ID_SEQ;\\012\\012CREATE SEQUENCE SAMPLE_COMPONENT_ID_SEQ;\\012\\012CREATE SEQUENCE MATERIAL_ID_SEQ;\\012\\012CREATE SEQUENCE DATA_ID_SEQ;\\012\\012--  Creating Sequence for the SAMPLE_COMPONENT_MATERIALS table (standard naming convention was too long)\\012CREATE SEQUENCE SCMA_ID_SEQ;\\012\\012CREATE SEQUENCE PROCEDURE_ID_SEQ;\\012\\012CREATE SEQUENCE FILE_FORMAT_TYPE_ID_SEQ;\\012\\012CREATE SEQUENCE MATERIAL_TYPE_ID_SEQ;\\012\\012CREATE SEQUENCE EXPERIMENT_TYPE_ID_SEQ;\\012\\012CREATE SEQUENCE PERSON_ID_SEQ;\\012\\012CREATE SEQUENCE ORGANIZATION_ID_SEQ;\\012\\012CREATE SEQUENCE PROJECT_ID_SEQ;\\012\\012CREATE SEQUENCE DATA_VALUE_ID_SEQ;\\012\\012\\012\\012/*\\012   Trigger Section\\012   ===============*/\\012\\012CREATE OR REPLACE FUNCTION br001_crtl_plate_chk() RETURNS trigger AS $br001_crtl_plate_chk$\\012DECLARE\\012   cnt           INTEGER;\\012   v_cell_plate  CODE;\\012BEGIN\\012\\012   select code into v_cell_plate from sample_types where id  = NEW.saty_id;\\012\\012   -- Check if the sample is of type "Cell Plate"\\012   if v_cell_plate = 'CELL PLATE' then\\012\\012      -- Check that a Control Plate exists before registering the Cell Plate\\012      select count(*) into cnt from samples s, sample_types st where s.saty_id = st.id and st.code = 'CONTROL LAYOUT';\\011 \\012      IF cnt = 0 THEN\\012\\011\\011 -- Doens't make sense, so comment it out\\012         -- RAISE EXCEPTION 'A Control Plate must exist before you can register Cell Plate: %', NEW.code;\\012      END IF;\\012\\012   end if;\\012\\012   RETURN NEW;\\012\\012END;\\012$br001_crtl_plate_chk$ LANGUAGE plpgsql;\\012\\012\\012CREATE TRIGGER br001_crtl_plate_chk BEFORE INSERT ON samples\\012    FOR EACH ROW EXECUTE PROCEDURE br001_crtl_plate_chk();\\012	\N
+./sourceTest/sql/postgresql/test_database_for_migration/postgresql/018/006=database_version_logs.tsv:013	source/sql/postgresql/migration/migration-012-013.sql	SUCCESS	2008-08-29 08:10:55.399	----------------------------------------------------------------------------------------------\\012--  File: migration-012-013.sql\\012--\\012-- \\012--  This script enables the migration of the database schema from 012 to 013.\\012-- \\012--  Update History\\012--\\012--\\012--\\011Who\\011\\011\\011\\011\\011\\011\\011When\\011\\011\\011\\011What\\012--\\011---\\011\\011\\011\\011\\011\\011\\011----\\011\\011\\011\\011----\\012--\\011Bernd Rinn\\011\\0112008-01-04\\011Initial Version - add support for invalidations and material type BACTERIUM \\012--\\011Bernd Rinn\\011\\0112008-01-05\\011Add material type COMPOUND and material type property type entries for the new material types \\012--  \\012----------------------------------------------------------------------------------------------\\012\\012------------------------------------------------------------------------------------\\012--  Purpose:  Create function RENAME_SEQUENCE() that is required for renaming the sequences belonging to tables\\012------------------------------------------------------------------------------------\\012\\012CREATE FUNCTION RENAME_SEQUENCE(OLD_NAME VARCHAR, NEW_NAME VARCHAR) RETURNS INTEGER AS $$\\012DECLARE\\012  CURR_SEQ_VAL   INTEGER;\\012BEGIN\\012  SELECT INTO CURR_SEQ_VAL NEXTVAL(OLD_NAME);\\012  EXECUTE 'CREATE SEQUENCE ' || NEW_NAME || ' START WITH ' || CURR_SEQ_VAL;\\012  EXECUTE 'DROP SEQUENCE ' || OLD_NAME;\\012  RETURN CURR_SEQ_VAL;\\012END;\\012$$ LANGUAGE 'plpgsql';\\012\\012\\012------------------------------------------------------------------------------------\\012--  Purpose:  Add table INVALIDATIONS to store invalidations\\012------------------------------------------------------------------------------------\\012\\012CREATE TABLE INVALIDATIONS (ID TECH_ID NOT NULL,PERS_ID_REGISTERER TECH_ID NOT NULL,REGISTRATION_TIMESTAMP TIME_STAMP NOT NULL DEFAULT CURRENT_TIMESTAMP,REASON DESCRIPTION_250);\\012ALTER TABLE INVALIDATIONS ADD CONSTRAINT INVA_PK PRIMARY KEY(ID);\\012ALTER TABLE INVALIDATIONS ADD CONSTRAINT INVA_PERS_FK FOREIGN KEY (PERS_ID_REGISTERER) REFERENCES PERSONS(ID);\\012CREATE SEQUENCE INVALIDATION_ID_SEQ;\\012CREATE INDEX INVA_PERS_FK_I ON INVALIDATIONS (PERS_ID_REGISTERER);\\012\\012------------------------------------------------------------------------------------\\012--  Purpose:  Add column INVA_ID to table SAMPLES in order to allow invalidation of samples  \\012------------------------------------------------------------------------------------\\012\\012ALTER TABLE SAMPLES ADD INVA_ID TECH_ID;\\012ALTER TABLE SAMPLES ADD CONSTRAINT SAMP_INVA_FK FOREIGN KEY (INVA_ID) REFERENCES INVALIDATIONS(ID);\\012CREATE INDEX SAMP_INVA_FK_I ON SAMPLES (INVA_ID);\\012\\012\\012------------------------------------------------------------------------------------\\012--  Purpose:  Rename table EXPERIMENT_PROPERTIES TO EXPERIMENT_ATTACHMENTS  \\012------------------------------------------------------------------------------------\\012\\012ALTER TABLE EXPERIMENT_PROPERTIES DROP CONSTRAINT EXPR_PK;\\012ALTER TABLE EXPERIMENT_PROPERTIES DROP CONSTRAINT EXPR_BK_UK;\\012ALTER TABLE EXPERIMENT_PROPERTIES DROP CONSTRAINT EXPR_EXPE_FK;\\012ALTER TABLE EXPERIMENT_PROPERTIES DROP CONSTRAINT EXPR_PERS_FK;\\012\\012ALTER TABLE EXPERIMENT_PROPERTIES RENAME TO EXPERIMENT_ATTACHMENTS;\\012ALTER INDEX EXPR_EXPE_FK_I RENAME TO EXAT_EXPE_FK_I;\\012ALTER INDEX EXPR_PERS_FK_I RENAME TO EXAT_PERS_FK_I;\\012SELECT RENAME_SEQUENCE('EXPERIMENT_PROPERTY_ID_SEQ', 'EXPERIMENT_ATTACHMENT_ID_SEQ');\\012\\012ALTER TABLE EXPERIMENT_ATTACHMENTS ADD CONSTRAINT EXAT_PK PRIMARY KEY(ID);\\012ALTER TABLE EXPERIMENT_ATTACHMENTS ADD CONSTRAINT EXAT_BK_UK UNIQUE(EXPE_ID,FILE_NAME,VERSION);\\012ALTER TABLE EXPERIMENT_ATTACHMENTS ADD CONSTRAINT EXAT_EXPE_FK FOREIGN KEY (EXPE_ID) REFERENCES EXPERIMENTS(ID);\\012ALTER TABLE EXPERIMENT_ATTACHMENTS ADD CONSTRAINT EXAT_PERS_FK FOREIGN KEY (PERS_ID_REGISTERER) REFERENCES PERSONS(ID);\\012\\012\\012------------------------------------------------------------------------------------\\012--  Purpose:  Add the material type BACTERIUM\\012------------------------------------------------------------------------------------\\012\\012insert into material_types\\012(id\\012,code\\012,description)\\012values \\012(nextval('MATERIAL_TYPE_ID_SEQ')\\012,'BACTERIUM'\\012,'Bacterium'\\012);\\012\\012------------------------------------------------------------------------------------\\012--  Purpose:  Add the material type COMPOUND\\012------------------------------------------------------------------------------------\\012\\012insert into material_types\\012(id\\012,code\\012,description)\\012values \\012(nextval('MATERIAL_TYPE_ID_SEQ')\\012,'COMPOUND'\\012,'Compound'\\012);\\012\\012------------------------------------------------------------------------------------\\012--  Purpose:  Insert an initial data set into the table MATERIAL_TYPE_PROPERTY_TYPES\\012------------------------------------------------------------------------------------\\012\\012   -----------------------\\012   --  Material Type BACTERIUM\\012   -----------------------\\012\\012insert into material_type_property_types\\012(   id\\012   ,maty_id\\012   ,prty_id\\012   ,is_mandatory\\012   ,pers_id_registerer\\012   )\\012values \\012   (nextval('MTPT_ID_SEQ')\\012   ,(select id from material_types where code = 'BACTERIUM')\\012   ,(select id from property_types where code = 'DESCRIPTION')\\012   ,true\\012   ,(select id from persons where user_id ='system')\\012);\\012\\012   -----------------------\\012   --  Material Type COMPOUND\\012   -----------------------\\012\\012insert into material_type_property_types\\012(   id\\012   ,maty_id\\012   ,prty_id\\012   ,is_mandatory\\012   ,pers_id_registerer\\012   )\\012values \\012   (nextval('MTPT_ID_SEQ')\\012   ,(select id from material_types where code = 'COMPOUND')\\012   ,(select id from property_types where code = 'DESCRIPTION')\\012   ,true\\012   ,(select id from persons where user_id ='system')\\012);\\012\\012\\012------------------------------------------------------------------------------------\\012--  Purpose:  Change according to naming convention for CODEs\\012------------------------------------------------------------------------------------\\012\\012update procedure_types set code='DATA_ACQUISITION' where code='DATA ACQUISITION';\\012update procedure_types set code='IMAGE_ANALYSIS' where code='IMAGE ANALYSIS';\\012update locator_types set code='RELATIVE_LOCATION' where code='RELATIVE LOCATION';\\012update sample_types set code='MASTER_PLATE' where code='MASTER PLATE';\\012update sample_types set code='DILUTION_PLATE' where code='DILUTION PLATE';\\012update sample_types set code='CELL_PLATE' where code='CELL PLATE';\\012update sample_types set code='REINFECT_PLATE' where code='REINFECT PLATE';\\012update sample_types set description='Re-infection Plate' where code='REINFECT_PLATE';\\012update sample_types set code='CONTROL_LAYOUT' where code='CONTROL LAYOUT';\\012	\N
+./sourceTest/sql/postgresql/test_database_for_migration/postgresql/018/006=database_version_logs.tsv:014	source/sql/postgresql/migration/migration-013-014.sql	SUCCESS	2008-08-29 08:10:55.582	----------------------------------------------------------------------------------------------\\012--  File: migration-013-014.sql\\012--\\012-- \\012--  This script enables the migration of the database schema from 013 to 014.\\012-- \\012--  Update History\\012--\\012--\\012--\\011Who\\011\\011\\011When\\011\\011What\\012--\\011---\\011\\011\\011----\\011\\011----\\012--\\011Charles Ramin-Wright\\0112008-01-29\\011Initial Version \\012--  \\012----------------------------------------------------------------------------------------------\\012\\012--=================================\\012-- New Tables and related objects\\012--=================================\\012\\012------------------------------------------------------------------------------------\\012--  Purpose:  Add tables CONTROLLED_VOCABULARIES and CONTROLLED_VOCABULARY_TERMS\\012------------------------------------------------------------------------------------\\012\\012CREATE TABLE CONTROLLED_VOCABULARIES (ID TECH_ID NOT NULL,CODE CODE NOT NULL,DESCRIPTION DESCRIPTION_80,REGISTRATION_TIMESTAMP TIME_STAMP NOT NULL DEFAULT CURRENT_TIMESTAMP,PERS_ID TECH_ID NOT NULL);\\012CREATE TABLE CONTROLLED_VOCABULARY_TERMS (ID TECH_ID NOT NULL,CODE OBJECT_NAME NOT NULL,REGISTRATION_TIMESTAMP TIME_STAMP NOT NULL DEFAULT CURRENT_TIMESTAMP,COVO_ID TECH_ID NOT NULL,PERS_ID TECH_ID NOT NULL);\\012\\012\\012-- Creating primary key constraints\\012\\012ALTER TABLE CONTROLLED_VOCABULARIES ADD CONSTRAINT COVO_PK PRIMARY KEY(ID);\\012ALTER TABLE CONTROLLED_VOCABULARY_TERMS ADD CONSTRAINT CVTE_PK PRIMARY KEY(ID);\\012\\012-- Creating unique constraints\\012\\012ALTER TABLE CONTROLLED_VOCABULARIES ADD CONSTRAINT COVO_BK_UK UNIQUE(CODE);\\012ALTER TABLE CONTROLLED_VOCABULARY_TERMS ADD CONSTRAINT CVTE_BK_UK UNIQUE(CODE,COVO_ID);\\012\\012-- Creating foreign key constraints\\012\\012ALTER TABLE CONTROLLED_VOCABULARIES ADD CONSTRAINT COVO_PERS_FK FOREIGN KEY (PERS_ID) REFERENCES PERSONS(ID);\\012ALTER TABLE CONTROLLED_VOCABULARY_TERMS ADD CONSTRAINT CVTE_COVO_FK FOREIGN KEY (COVO_ID) REFERENCES CONTROLLED_VOCABULARIES(ID);\\012ALTER TABLE CONTROLLED_VOCABULARY_TERMS ADD CONSTRAINT CVTE_PERS_FK FOREIGN KEY (PERS_ID) REFERENCES PERSONS(ID);\\012\\012-- Creating sequences\\012\\012CREATE SEQUENCE CONTROLLED_VOCABULARY_ID_SEQ;\\012CREATE SEQUENCE CVTE_ID_SEQ;\\012\\012\\012-- Creating indexes\\012\\012CREATE INDEX COVO_PERS_FK_I ON CONTROLLED_VOCABULARIES (PERS_ID);\\012CREATE INDEX CVTE_COVO_FK_I ON CONTROLLED_VOCABULARY_TERMS (COVO_ID);\\012CREATE INDEX CVTE_PERS_FK_I ON CONTROLLED_VOCABULARY_TERMS (PERS_ID);\\012\\012\\012--====================================\\012-- Modifications of existing objects\\012--====================================\\012\\012---------------------------------------------------------------------------------------------------\\012--  Purpose:  Add column INVA_ID to table EXPERIMENTS in order to allow invalidation of experiments\\012---------------------------------------------------------------------------------------------------\\012\\012ALTER TABLE EXPERIMENTS ADD INVA_ID TECH_ID;\\012ALTER TABLE EXPERIMENTS ADD CONSTRAINT EXPE_INVA_FK FOREIGN KEY (INVA_ID) REFERENCES INVALIDATIONS(ID);\\012CREATE INDEX EXPE_INVA_FK_I ON EXPERIMENTS (INVA_ID);\\012\\012------------------------------------------------------------------------------------\\012--  Purpose:  Add column SAMP_ID_CONTROL_LAYOUT to table SAMPLES in order to allow \\012--            the association of a sample of type CONTROL_LAYOUT to samples\\012------------------------------------------------------------------------------------\\012\\012ALTER TABLE SAMPLES ADD SAMP_ID_CONTROL_LAYOUT TECH_ID;\\012ALTER TABLE SAMPLES ADD CONSTRAINT SAMP_SAMP_FK_CONTROL_LAYOUT FOREIGN KEY (SAMP_ID_CONTROL_LAYOUT) REFERENCES SAMPLES(ID);\\012CREATE INDEX SAMP_SAMP_FK_I_CONTROL_LAYOUT ON SAMPLES (SAMP_ID_CONTROL_LAYOUT);\\012\\012\\012--------------------------------------------------------------\\012--  Purpose:  Add column CVTE_ID to table MATERIAL_PROPERTIES \\012--------------------------------------------------------------\\012ALTER TABLE MATERIAL_PROPERTIES ADD CVTE_ID TECH_ID;\\012ALTER TABLE MATERIAL_PROPERTIES ADD CONSTRAINT MAPR_CVTE_FK FOREIGN KEY (CVTE_ID) REFERENCES CONTROLLED_VOCABULARY_TERMS(ID);\\012CREATE INDEX MAPR_CVTE_FK_I ON MATERIAL_PROPERTIES (CVTE_ID);\\012\\012--------------------------------------------------------------\\012--  Purpose:  Change column VALUE from mandatory to optional\\012--------------------------------------------------------------\\012ALTER TABLE MATERIAL_PROPERTIES ALTER VALUE DROP NOT NULL;\\012\\012-- Creating check constraints\\012\\012ALTER TABLE MATERIAL_PROPERTIES ADD CONSTRAINT VALUE_OR_CVTE_ID CHECK ((value IS NOT NULL and cvte_id IS NULL) or (value IS NULL and cvte_id IS NOT NULL));\\012\\012\\012--------------------------------------------------------------\\012--  Purpose:  Add column COVO_ID to table PROPERTY_TYPES  \\012--------------------------------------------------------------\\012ALTER TABLE PROPERTY_TYPES ADD COVO_ID TECH_ID;\\012ALTER TABLE PROPERTY_TYPES ADD CONSTRAINT PRTY_COVO_FK FOREIGN KEY (COVO_ID) REFERENCES CONTROLLED_VOCABULARIES(ID);\\012CREATE INDEX PRTY_COVO_FK_I ON PROPERTY_TYPES (COVO_ID);\\012\\012\\012------------------------------------------------------------------------------------\\012--  Purpose:  Create trigger CONTROLLED_VOCABULARY_CHECK \\012------------------------------------------------------------------------------------\\012\\012CREATE OR REPLACE FUNCTION CONTROLLED_VOCABULARY_CHECK() RETURNS trigger AS $$\\012DECLARE\\012   cnt     INTEGER;\\012   v_code  CODE;\\012BEGIN\\012\\012   select code into v_code from data_types where id  = NEW.daty_id;\\012\\012   -- Check if the data is of type "CONTROLLEDVOCABULARY"\\012   if v_code = 'CONTROLLEDVOCABULARY' then\\012      if NEW.covo_id IS NULL then\\012         RAISE EXCEPTION 'Insert/Update of Property Type (Code: %) failed, as its Data Type is CONTROLLEDVOCABULARY, but it is not linked to a Controlled Vocabulary.', NEW.code;\\012      end if;\\012   end if;\\012\\012   RETURN NEW;\\012\\012END;\\012$$ LANGUAGE 'plpgsql';\\012\\012\\012CREATE TRIGGER CONTROLLED_VOCABULARY_CHECK BEFORE INSERT OR UPDATE ON PROPERTY_TYPES\\012    FOR EACH ROW EXECUTE PROCEDURE CONTROLLED_VOCABULARY_CHECK();\\012\\012\\012--====================================\\012-- Deletion of existing objects\\012--====================================\\012\\012drop trigger br001_crtl_plate_chk on samples;\\012drop function br001_crtl_plate_chk();\\012\\012\\012--====================================\\012-- Add Master Data\\012--====================================\\012\\012-----------------------------------------------------------------------------------\\012--  Purpose:  Insert into the table DATA_TYPES\\012--\\012--            Create the data type CONTROLLEDVOCABULARY.\\012-----------------------------------------------------------------------------------\\012insert into data_types\\012(id\\012,code\\012,description)\\012values \\012(nextval('DATA_TYPE_ID_SEQ')\\012,'CONTROLLEDVOCABULARY'\\012,'Controlled Vocabulary'\\012);\\012\\012--==========================================\\012--\\012--   Data Migration\\012--\\012--==========================================\\012\\012-----------------------------------------------------------------------------------\\012--  Purpose:  Migrate the CONTROL_LAYOUTs from the SAMPLE_INPUTS table \\012--            to the foreign key SAMP_SAMP_FK_CONTROL_LAYOUT in the SAMPLES table\\012--\\012--            This results in having all CONTROL_LAYOUTs being directly linked \\012--            to CELL_PLATEs.            \\012-----------------------------------------------------------------------------------\\012\\012UPDATE samples cell_plate\\012   SET samp_id_control_layout = \\012          (select control_layout.samp_id\\012           from   sample_inputs control_layout inner join samples s \\012           on     control_layout.samp_id = s.id\\012           where  s.saty_id = (select id from sample_types where code = 'CONTROL_LAYOUT')\\012           and    proc_id = (\\012              select  proc_id\\012              from sample_inputs cp\\012              where cp.samp_id = cell_plate.id))\\012   WHERE saty_id = (select id from sample_types where code = 'CELL_PLATE')\\012   and   id = (select distinct (samp_id)\\012                  from   sample_inputs sain inner join samples s2 \\012                  on  sain.samp_id = cell_plate.id)\\012;\\012\\012-----------------------------------------------------------------------------------\\012--   Delete the CONTROL LAYOUTs from the SAMPLE_INPUTS table\\012-----------------------------------------------------------------------------------\\012\\012delete from sample_inputs\\012where  id in (select si.id \\012              from   sample_inputs si inner join samples s \\012              on     si.samp_id = s.id\\012              where  s.saty_id = (select id from sample_types where code = 'CONTROL_LAYOUT')\\012              )\\012;\\012\\012	\N
+./sourceTest/sql/postgresql/test_database_for_migration/postgresql/018/006=database_version_logs.tsv:016	source/sql/postgresql/migration/migration-015-016.sql	SUCCESS	2008-08-29 08:11:12.328	----------------------------------------------------------------------------------------------\\012--  File: migration-015-016.sql\\012--\\012-- \\012--  This script enables the migration of the database schema from 015 to 016.\\012-- \\012--  Update History\\012--\\012--\\012--\\011Who\\011\\011\\011When\\011\\011What\\012--\\011---\\011\\011\\011----\\011\\011----\\012--\\011Bernd Rinn\\0112008-03-22\\011Initial Version \\012--  \\012----------------------------------------------------------------------------------------------\\012\\012\\012--=================================\\012-- New Domains\\012--=================================\\012\\012-----------------------------------------------------------------------------------\\012--  Purpose:  Change all CODE columns to LONG_CODE, then re-create DOMAIN CODE identical to LONG_CODE\\012--  and change LONG_CODE columns back to the (new) CODE \\012-----------------------------------------------------------------------------------\\012\\012-- First step: create new domain LONG_CODE\\012CREATE DOMAIN LONG_CODE AS VARCHAR(40);\\012\\012-- Second step: change all CODE to LONG_CODE\\012ALTER TABLE CONTROLLED_VOCABULARIES ALTER COLUMN CODE TYPE LONG_CODE;\\012ALTER TABLE DATA_TYPES ALTER COLUMN CODE TYPE LONG_CODE;\\012ALTER TABLE EXPERIMENTS ALTER COLUMN CODE TYPE LONG_CODE;\\012ALTER TABLE EXPERIMENT_TYPES ALTER COLUMN CODE TYPE LONG_CODE;\\012ALTER TABLE FILE_FORMAT_TYPES ALTER COLUMN CODE TYPE LONG_CODE;\\012ALTER TABLE LOCATOR_TYPES ALTER COLUMN CODE TYPE LONG_CODE;\\012ALTER TABLE MATERIALS ALTER COLUMN CODE TYPE LONG_CODE;\\012ALTER TABLE MATERIAL_BATCHES ALTER COLUMN CODE TYPE LONG_CODE;\\012ALTER TABLE MATERIAL_TYPES ALTER COLUMN CODE TYPE LONG_CODE;\\012ALTER TABLE OBSERVABLE_TYPES ALTER COLUMN CODE TYPE LONG_CODE;\\012ALTER TABLE ORGANIZATIONS ALTER COLUMN CODE TYPE LONG_CODE;\\012ALTER TABLE PROCEDURE_TYPES ALTER COLUMN CODE TYPE LONG_CODE;\\012ALTER TABLE PROJECTS ALTER COLUMN CODE TYPE LONG_CODE;\\012ALTER TABLE PROPERTY_TYPES ALTER COLUMN CODE TYPE LONG_CODE;\\012ALTER TABLE SAMPLES ALTER COLUMN CODE TYPE LONG_CODE;\\012ALTER TABLE SAMPLE_COMPONENTS ALTER COLUMN CODE TYPE LONG_CODE;\\012ALTER TABLE SAMPLE_TYPES ALTER COLUMN CODE TYPE LONG_CODE;\\012\\012-- Third step: re-create CODE as VARCHAR(40)\\012DROP DOMAIN CODE;\\012CREATE DOMAIN CODE AS VARCHAR(40);\\012\\012-- Forth step: change all LONG_CODE columns back to CODE\\012ALTER TABLE CONTROLLED_VOCABULARIES ALTER COLUMN CODE TYPE CODE;\\012ALTER TABLE DATA_TYPES ALTER COLUMN CODE TYPE CODE;\\012ALTER TABLE EXPERIMENTS ALTER COLUMN CODE TYPE CODE;\\012ALTER TABLE EXPERIMENT_TYPES ALTER COLUMN CODE TYPE CODE;\\012ALTER TABLE FILE_FORMAT_TYPES ALTER COLUMN CODE TYPE CODE;\\012ALTER TABLE LOCATOR_TYPES ALTER COLUMN CODE TYPE CODE;\\012ALTER TABLE MATERIALS ALTER COLUMN CODE TYPE CODE;\\012ALTER TABLE MATERIAL_BATCHES ALTER COLUMN CODE TYPE CODE;\\012ALTER TABLE MATERIAL_TYPES ALTER COLUMN CODE TYPE CODE;\\012ALTER TABLE OBSERVABLE_TYPES ALTER COLUMN CODE TYPE CODE;\\012ALTER TABLE ORGANIZATIONS ALTER COLUMN CODE TYPE CODE;\\012ALTER TABLE PROCEDURE_TYPES ALTER COLUMN CODE TYPE CODE;\\012ALTER TABLE PROJECTS ALTER COLUMN CODE TYPE CODE;\\012ALTER TABLE PROPERTY_TYPES ALTER COLUMN CODE TYPE CODE;\\012ALTER TABLE SAMPLES ALTER COLUMN CODE TYPE CODE;\\012ALTER TABLE SAMPLE_COMPONENTS ALTER COLUMN CODE TYPE CODE;\\012ALTER TABLE SAMPLE_TYPES ALTER COLUMN CODE TYPE CODE;\\012\\012-- Fifth step: drop domain LONG_CODE\\012DROP DOMAIN LONG_CODE;\\012\\012-----------------------------------------------------------------------------------\\012--  Purpose:  Create new domain TIME_STAMP_DFL and change current users of TIME_STAMP to TIME_STAMP_DFL\\012--  This adds time zone information and allows for a clean separation between registration time stamps\\012--  which should have a default of CURRENT_TIMESTAMP and other time stamps which should not. \\012-----------------------------------------------------------------------------------\\012\\012-- First step: create new domain TIME_STAMP_DFL\\012CREATE DOMAIN TIME_STAMP_DFL AS TIMESTAMP WITH TIME ZONE NOT NULL DEFAULT CURRENT_TIMESTAMP;\\012\\012-- Second step: change all TIME_STAMP columns to TIME_STAMP_DFL\\012ALTER TABLE CONTROLLED_VOCABULARIES ALTER COLUMN REGISTRATION_TIMESTAMP TYPE TIME_STAMP_DFL;\\012ALTER TABLE CONTROLLED_VOCABULARIES ALTER COLUMN REGISTRATION_TIMESTAMP DROP NOT NULL;\\012ALTER TABLE CONTROLLED_VOCABULARIES ALTER COLUMN REGISTRATION_TIMESTAMP DROP DEFAULT;\\012ALTER TABLE CONTROLLED_VOCABULARY_TERMS ALTER COLUMN REGISTRATION_TIMESTAMP TYPE TIME_STAMP_DFL;\\012ALTER TABLE CONTROLLED_VOCABULARY_TERMS ALTER COLUMN REGISTRATION_TIMESTAMP DROP NOT NULL;\\012ALTER TABLE CONTROLLED_VOCABULARY_TERMS ALTER COLUMN REGISTRATION_TIMESTAMP DROP DEFAULT;\\012ALTER TABLE DATA ALTER COLUMN REGISTRATION_TIMESTAMP TYPE TIME_STAMP_DFL;\\012ALTER TABLE DATA ALTER COLUMN REGISTRATION_TIMESTAMP DROP NOT NULL;\\012ALTER TABLE DATA ALTER COLUMN REGISTRATION_TIMESTAMP DROP DEFAULT;\\012ALTER TABLE EXPERIMENTS ALTER COLUMN REGISTRATION_TIMESTAMP TYPE TIME_STAMP_DFL;\\012ALTER TABLE EXPERIMENTS ALTER COLUMN REGISTRATION_TIMESTAMP DROP NOT NULL;\\012ALTER TABLE EXPERIMENTS ALTER COLUMN REGISTRATION_TIMESTAMP DROP DEFAULT;\\012ALTER TABLE EXPERIMENT_ATTACHMENTS ALTER COLUMN REGISTRATION_TIMESTAMP TYPE TIME_STAMP_DFL;\\012ALTER TABLE EXPERIMENT_ATTACHMENTS ALTER COLUMN REGISTRATION_TIMESTAMP DROP NOT NULL;\\012ALTER TABLE EXPERIMENT_ATTACHMENTS ALTER COLUMN REGISTRATION_TIMESTAMP DROP DEFAULT;\\012ALTER TABLE EXPERIMENT_PROPERTIES ALTER COLUMN REGISTRATION_TIMESTAMP TYPE TIME_STAMP_DFL;\\012ALTER TABLE EXPERIMENT_PROPERTIES ALTER COLUMN REGISTRATION_TIMESTAMP DROP NOT NULL;\\012ALTER TABLE EXPERIMENT_PROPERTIES ALTER COLUMN REGISTRATION_TIMESTAMP DROP DEFAULT;\\012ALTER TABLE EXPERIMENT_TYPE_PROPERTY_TYPES ALTER COLUMN REGISTRATION_TIMESTAMP TYPE TIME_STAMP_DFL;\\012ALTER TABLE EXPERIMENT_TYPE_PROPERTY_TYPES ALTER COLUMN REGISTRATION_TIMESTAMP DROP NOT NULL;\\012ALTER TABLE EXPERIMENT_TYPE_PROPERTY_TYPES ALTER COLUMN REGISTRATION_TIMESTAMP DROP DEFAULT;\\012ALTER TABLE INVALIDATIONS ALTER COLUMN REGISTRATION_TIMESTAMP TYPE TIME_STAMP_DFL;\\012ALTER TABLE INVALIDATIONS ALTER COLUMN REGISTRATION_TIMESTAMP DROP NOT NULL;\\012ALTER TABLE INVALIDATIONS ALTER COLUMN REGISTRATION_TIMESTAMP DROP DEFAULT;\\012ALTER TABLE MATERIALS ALTER COLUMN REGISTRATION_TIMESTAMP TYPE TIME_STAMP_DFL;\\012ALTER TABLE MATERIALS ALTER COLUMN REGISTRATION_TIMESTAMP DROP NOT NULL;\\012ALTER TABLE MATERIALS ALTER COLUMN REGISTRATION_TIMESTAMP DROP DEFAULT;\\012ALTER TABLE MATERIAL_BATCHES ALTER COLUMN REGISTRATION_TIMESTAMP TYPE TIME_STAMP_DFL;\\012ALTER TABLE MATERIAL_BATCHES ALTER COLUMN REGISTRATION_TIMESTAMP DROP NOT NULL;\\012ALTER TABLE MATERIAL_BATCHES ALTER COLUMN REGISTRATION_TIMESTAMP DROP DEFAULT;\\012ALTER TABLE MATERIAL_PROPERTIES ALTER COLUMN REGISTRATION_TIMESTAMP TYPE TIME_STAMP_DFL;\\012ALTER TABLE MATERIAL_PROPERTIES ALTER COLUMN REGISTRATION_TIMESTAMP DROP NOT NULL;\\012ALTER TABLE MATERIAL_PROPERTIES ALTER COLUMN REGISTRATION_TIMESTAMP DROP DEFAULT;\\012ALTER TABLE MATERIAL_TYPE_PROPERTY_TYPES ALTER COLUMN REGISTRATION_TIMESTAMP TYPE TIME_STAMP_DFL;\\012ALTER TABLE MATERIAL_TYPE_PROPERTY_TYPES ALTER COLUMN REGISTRATION_TIMESTAMP DROP NOT NULL;\\012ALTER TABLE MATERIAL_TYPE_PROPERTY_TYPES ALTER COLUMN REGISTRATION_TIMESTAMP DROP DEFAULT;\\012ALTER TABLE PROCEDURES ALTER COLUMN REGISTRATION_TIMESTAMP TYPE TIME_STAMP_DFL;\\012ALTER TABLE PROCEDURES ALTER COLUMN REGISTRATION_TIMESTAMP DROP NOT NULL;\\012ALTER TABLE PROCEDURES ALTER COLUMN REGISTRATION_TIMESTAMP DROP DEFAULT;\\012ALTER TABLE PROPERTY_TYPES ALTER COLUMN REGISTRATION_TIMESTAMP TYPE TIME_STAMP_DFL;\\012ALTER TABLE PROPERTY_TYPES ALTER COLUMN REGISTRATION_TIMESTAMP DROP NOT NULL;\\012ALTER TABLE PROPERTY_TYPES ALTER COLUMN REGISTRATION_TIMESTAMP DROP DEFAULT;\\012ALTER TABLE SAMPLES ALTER COLUMN REGISTRATION_TIMESTAMP TYPE TIME_STAMP_DFL;\\012ALTER TABLE SAMPLES ALTER COLUMN REGISTRATION_TIMESTAMP DROP NOT NULL;\\012ALTER TABLE SAMPLES ALTER COLUMN REGISTRATION_TIMESTAMP DROP DEFAULT;\\012ALTER TABLE SAMPLE_PROPERTIES ALTER COLUMN REGISTRATION_TIMESTAMP TYPE TIME_STAMP_DFL;\\012ALTER TABLE SAMPLE_PROPERTIES ALTER COLUMN REGISTRATION_TIMESTAMP DROP NOT NULL;\\012ALTER TABLE SAMPLE_PROPERTIES ALTER COLUMN REGISTRATION_TIMESTAMP DROP DEFAULT;\\012ALTER TABLE SAMPLE_TYPE_PROPERTY_TYPES ALTER COLUMN REGISTRATION_TIMESTAMP TYPE TIME_STAMP_DFL;\\012ALTER TABLE SAMPLE_TYPE_PROPERTY_TYPES ALTER COLUMN REGISTRATION_TIMESTAMP DROP NOT NULL;\\012ALTER TABLE SAMPLE_TYPE_PROPERTY_TYPES ALTER COLUMN REGISTRATION_TIMESTAMP DROP DEFAULT;\\012\\012-- Third step: drop old domain TIME_STAMP\\012DROP DOMAIN TIME_STAMP;\\012\\012-- Forth step: create new domain time_stamp\\012CREATE DOMAIN TIME_STAMP AS TIMESTAMP WITH TIME ZONE;\\012\\012--=================================\\012-- New Tables and related objects\\012--=================================\\012\\012------------------------------------------------------------------------------------\\012-- table DATA_SET_RELATIONSHIPS (new)\\012------------------------------------------------------------------------------------\\012\\012-- Creating tables\\012\\012CREATE TABLE DATA_SET_RELATIONSHIPS (ID TECH_ID NOT NULL,DATA_ID_PARENT TECH_ID NOT NULL,DATA_ID_CHILD TECH_ID NOT NULL,REGISTRATION_TIMESTAMP TIME_STAMP_DFL);\\012\\012-- Creating primary key constraints\\012\\012ALTER TABLE DATA_SET_RELATIONSHIPS ADD CONSTRAINT DSRE_PK PRIMARY KEY(ID);\\012\\012-- Creating unique constraints\\012\\012ALTER TABLE DATA_SET_RELATIONSHIPS ADD CONSTRAINT DSRE_BK_UK UNIQUE(DATA_ID_CHILD,DATA_ID_PARENT);\\012\\012-- Creating foreign key constraints\\012\\012ALTER TABLE DATA_SET_RELATIONSHIPS ADD CONSTRAINT DSRE_DATA_FK_CHILD FOREIGN KEY (DATA_ID_CHILD) REFERENCES DATA(ID);\\012ALTER TABLE DATA_SET_RELATIONSHIPS ADD CONSTRAINT DSRE_DATA_FK_PARENT FOREIGN KEY (DATA_ID_PARENT) REFERENCES DATA(ID);\\012\\012-- Creating sequences\\012\\012CREATE SEQUENCE DATA_SET_RELATIONSHIP_ID_SEQ;\\012\\012-- Creating indexes\\012\\012CREATE INDEX DSRE_DATA_FK_I_CHILD ON DATA_SET_RELATIONSHIPS (DATA_ID_CHILD);\\012CREATE INDEX DSRE_DATA_FK_I_PARENT ON DATA_SET_RELATIONSHIPS (DATA_ID_PARENT);\\012\\012--====================================\\012-- Drop Tables and related objects\\012--====================================\\012\\012------------------------------------------------------------------------------------\\012-- table DATA_VALUES (deleted)\\012------------------------------------------------------------------------------------\\012\\012-- Delete constraints\\012\\012ALTER TABLE DATA_VALUES DROP CONSTRAINT DAVA_PK;\\012ALTER TABLE DATA_VALUES DROP CONSTRAINT DAVA_BK_UK;\\012ALTER TABLE DATA_VALUES DROP CONSTRAINT DAVA_DATA_FK;\\012ALTER TABLE DATA_VALUES DROP CONSTRAINT DAVA_SACO_FK;\\012\\012-- Delete indices\\012\\012DROP INDEX DAVA_DATA_FK_I;\\012DROP INDEX DAVA_SACO_FK_I;\\012\\012-- Delete sequences\\012\\012DROP SEQUENCE DATA_VALUE_ID_SEQ;\\012\\012-- Delete tables\\012\\012DROP TABLE DATA_VALUES;\\012\\012--====================================\\012-- Modifications of existing objects\\012--====================================\\012\\012------------------------------------------------------------------------------------\\012-- table ORGANIZATIONS (changed)\\012-- * rename to GROUPS\\012--\\012-- table DATA (changed)\\012-- * rename column PROC_ID_ACQUIRED_BY into: PROC_ID_PRODUCED_BY\\012-- * add columns:\\012-- ** IS_PLACEHOLDER BOOLEAN_CHAR\\012-- ** CODE CODE\\012-- ** DATA_PRODUCER_CODE CODE\\012-- ** PRODUCTION_TIMESTAMP TIME_STAMP\\012--\\012-- table EXTERNAL_DATA (changed)\\012-- * add column:\\012-- ** CVTE_ID_STOR_FMT TECH_ID NOT NULL\\012--\\012-- table PROPERTY_TYPES (changed)\\012-- * add column IS_MANAGED_INTERNALLY BOOLEAN_CHAR NOT NULL DEFAULT 'F'\\012-- * add unique constraint PRTY_BK_UK_LBL for column LABEL\\012--\\012-- tables EXPERIMENT_TYPE_PROPERTY_TYPES, MATERIAL_TYPE_PROPERTY_TYPES, SAMPLE_TYPE_PROPERTY_TYPES\\012-- * make the assignments of property types DESCRIPTION, NUCLEOTIDE_SEQUENCE, OFFSET and GENE_SYMBOL \\012--   to material types internally managed \\012--\\012-- table PROCEDURE_TYPES (changed)\\012-- * add column IS_DATA_ACQUISITION BOOLEAN_CHAR NOT NULL DEFAULT 'F'.\\012--\\012-- all tables\\012-- * convert all codes to upper case\\012------------------------------------------------------------------------------------\\012\\012---------------------------------------------------------------------------------------------------\\012--  Purpose:  Rename table ORGANIZATIONS to GROUPS.\\012---------------------------------------------------------------------------------------------------\\012\\012ALTER TABLE PROJECTS DROP CONSTRAINT PROJ_ORGA_FK;\\012ALTER TABLE ORGANIZATIONS DROP CONSTRAINT ORGA_BK_UK;\\012ALTER TABLE ORGANIZATIONS DROP CONSTRAINT ORGA_PK;\\012ALTER TABLE ORGANIZATIONS RENAME TO GROUPS;\\012ALTER INDEX PROJ_ORGA_FK_I RENAME TO PROJ_GROU_FK_I;\\012select RENAME_SEQUENCE('ORGANIZATION_ID_SEQ', 'GROUP_ID_SEQ');\\012ALTER TABLE PROJECTS RENAME COLUMN ORGA_ID TO GROU_ID;\\012ALTER TABLE GROUPS ADD CONSTRAINT GROU_PK PRIMARY KEY(ID);\\012ALTER TABLE GROUPS ADD CONSTRAINT GROU_BK_UK UNIQUE(CODE);\\012ALTER TABLE PROJECTS ADD CONSTRAINT PROJ_GROU_FK FOREIGN KEY (GROU_ID) REFERENCES GROUPS(ID);\\012\\012\\012---------------------------------------------------------------------------------------------------\\012--  Purpose:  Add columnd IS_PLACEHOLDER of table DATA.\\012---------------------------------------------------------------------------------------------------\\012\\012ALTER TABLE DATA ADD COLUMN IS_PLACEHOLDER BOOLEAN_CHAR NOT NULL;\\012\\012\\012---------------------------------------------------------------------------------------------------\\012--  Purpose:  Add and populate column CODE of table DATA.\\012---------------------------------------------------------------------------------------------------\\012\\012ALTER TABLE DATA ADD COLUMN CODE CODE;\\012\\012CREATE OR REPLACE FUNCTION populate_data_codes() RETURNS integer AS $$\\012DECLARE\\012    rec RECORD;\\012BEGIN\\012    FOR rec IN SELECT * FROM data LOOP\\012        rec.code := to_char(rec.registration_timestamp, 'YYYYMMDDHH24MISSMS') || '-' || to_char(rec.id, 'FM99999999999999999999');\\012        update data set code=rec.code where id=rec.id;\\012    END LOOP;\\012    RETURN 1;\\012END;\\012$$ LANGUAGE 'plpgsql';\\012\\012SELECT populate_data_codes();\\012DROP FUNCTION populate_data_codes();\\012\\012ALTER TABLE DATA ALTER COLUMN CODE SET NOT NULL;\\012ALTER TABLE DATA ADD CONSTRAINT DATA_BK_UK UNIQUE(CODE);\\012\\012---------------------------------------------------------------------------------------------------\\012--  Purpose:  Add and populate columns CVTE_ID_STOR_FMT.\\012---------------------------------------------------------------------------------------------------\\012\\012ALTER TABLE EXTERNAL_DATA ADD COLUMN CVTE_ID_STOR_FMT TECH_ID;\\012ALTER TABLE EXTERNAL_DATA ADD CONSTRAINT EXDA_STOR_FMT_FK FOREIGN KEY (CVTE_ID_STOR_FMT) REFERENCES CONTROLLED_VOCABULARY_TERMS(ID);\\012\\012------------------------------------------------------------------------------------\\012--  Purpose:  Create trigger EXTERNAL_DATA_STORAGE_FORMAT_CHECK \\012------------------------------------------------------------------------------------\\012\\012CREATE OR REPLACE FUNCTION EXTERNAL_DATA_STORAGE_FORMAT_CHECK() RETURNS trigger AS $$\\012DECLARE\\012   v_covo_code  CODE;\\012BEGIN\\012\\012   select code into v_covo_code from controlled_vocabularies\\012      where id = (select covo_id from controlled_vocabulary_terms where id = NEW.cvte_id_stor_fmt);\\012\\012   -- Check if the data storage format is a term of the controlled vocabulary "STORAGE_FORMAT"\\012   if v_covo_code != '.STORAGE_FORMAT' then\\012      RAISE EXCEPTION 'Insert/Update of Data (Code: %) failed, as its Storage Format is %, but is required to be STORAGE_FORMAT.', NEW.code, v_covo_code;\\012   end if;\\012\\012   RETURN NEW;\\012\\012END;\\012$$ LANGUAGE 'plpgsql';\\012\\012CREATE TRIGGER EXTERNAL_DATA_STORAGE_FORMAT_CHECK BEFORE INSERT OR UPDATE ON EXTERNAL_DATA\\012    FOR EACH ROW EXECUTE PROCEDURE EXTERNAL_DATA_STORAGE_FORMAT_CHECK();\\012\\012-----------------------------------------------------------------------------------\\012--  Purpose:  Create Controlled Vocabulary .STORAGE_FORMAT\\012-----------------------------------------------------------------------------------\\012insert into controlled_vocabularies \\012       ( id\\012       , code\\012       , description\\012       , pers_id_registerer\\012       , is_managed_internally )\\012values  (nextval('CONTROLLED_VOCABULARY_ID_SEQ')\\012       , '.STORAGE_FORMAT'\\012       , 'The on-disk storage format of a data set'\\012       , (select id from persons where user_id ='system')\\012       , true);\\012\\012\\012-----------------------------------------------------------------------------------\\012--  Purpose:  Create Controlled Vocabulary Terms for STORAGE_FORMAT\\012-----------------------------------------------------------------------------------\\012insert into controlled_vocabulary_terms \\012       ( id\\012       , code\\012       , covo_id \\012       , pers_id_registerer )\\012values  (nextval('CVTE_ID_SEQ')\\012       , 'PROPRIETARY'\\012       , (select id from controlled_vocabularies where code = '.STORAGE_FORMAT')\\012       , (select id from persons where user_id ='system'));\\012\\012insert into controlled_vocabulary_terms \\012       ( id\\012       , code\\012       , covo_id \\012       , pers_id_registerer )\\012values  (nextval('CVTE_ID_SEQ')\\012       , 'BDS_DIRECTORY'\\012       , (select id from controlled_vocabularies where code = '.STORAGE_FORMAT')\\012       , (select id from persons where user_id ='system'));\\012\\012\\012--------------------------------------------------------------------------\\012--  Purpose:  Insert an entry for OBSERVABLE_TYPE UNKNOWN\\012--------------------------------------------------------------------------\\012\\012insert into observable_types\\012(id\\012,code\\012,description)\\012values \\012(nextval('OBSERVABLE_TYPE_ID_SEQ')\\012,'UNKNOWN'\\012,'Unknown'\\012);\\012\\012----------------------------------------------------------------------\\012--  Purpose:  Insert an entry for PROCEDURE_TYPE UNKNOWN\\012-----------------------------------------------------------------------\\012\\012insert into procedure_types\\012(id\\012,code\\012,description)\\012values \\012(nextval('PROCEDURE_TYPE_ID_SEQ')\\012,'UNKNOWN'\\012,'Unknown'\\012);\\012\\012\\012---------------------------------------------------------------------------------------------------\\012--  Purpose:  Populate external_data.cvte_id_stor_fmt with a default value.\\012---------------------------------------------------------------------------------------------------\\012\\012CREATE OR REPLACE FUNCTION polulate_external_data_cvte_id_stor_fmt() RETURNS integer AS $$\\012DECLARE\\012    rec RECORD;\\012    dfl_stor_fmt_code VARCHAR := 'PROPRIETARY';\\012    dfl_stor_fmt_id TECH_ID;\\012BEGIN\\012    select cvte.id into dfl_stor_fmt_id from controlled_vocabulary_terms cvte, controlled_vocabularies cv \\012        where cvte.code = dfl_stor_fmt_code and cvte.covo_id = cv.id and cv.code = '.STORAGE_FORMAT'; \\012    update external_data set cvte_id_stor_fmt = dfl_stor_fmt_id;\\012    RETURN 1;\\012END;\\012$$ LANGUAGE 'plpgsql';\\012\\012SELECT polulate_external_data_cvte_id_stor_fmt();\\012DROP FUNCTION polulate_external_data_cvte_id_stor_fmt();\\012\\012-- Now that the field is populated, create the not null constraint for it.\\012\\012ALTER TABLE EXTERNAL_DATA ALTER COLUMN CVTE_ID_STOR_FMT SET NOT NULL;\\012\\012---------------------------------------------------------------------------------------------------\\012--  Purpose:  Add and populate columns DATA_PRODUCER_CODE and PRODUCTION_TIMESTAMP to table DATA.\\012---------------------------------------------------------------------------------------------------\\012\\012ALTER TABLE DATA ADD COLUMN DATA_PRODUCER_CODE CODE;\\012ALTER TABLE DATA ADD COLUMN PRODUCTION_TIMESTAMP TIME_STAMP;\\012\\012CREATE OR REPLACE FUNCTION populate_data_producer_code_and_production_timestamp() RETURNS integer AS $$\\012DECLARE\\012    rec RECORD;\\012    loty_rel_code VARCHAR := 'RELATIVE_LOCATION';\\012    loty_rel_id TECH_ID;\\012    meas_ts TIMESTAMP;\\012    ds_code CODE;\\012    meas_ts_str TEXT;\\012BEGIN\\012    select id into loty_rel_id from locator_types where code = loty_rel_code; \\012    FOR rec IN SELECT d.id, ed.location FROM data d, external_data ed where d.id = ed.data_id and ed.loty_id = loty_rel_id LOOP\\012        meas_ts_str = substring(rec.location from '^.*/([0-9]{14})_[^_]+_(.*)$');\\012        ds_code := substring(rec.location from '^.*/[0-9]{14}_([^_]+)_(.*)$');\\012        IF meas_ts_str is not null and ds_code is not null THEN\\012            meas_ts := to_timestamp(meas_ts_str, 'YYYYMMDDHH24MISS');\\012            update data set production_timestamp=meas_ts, data_producer_code=ds_code where id=rec.id;\\012        END IF;\\012    END LOOP;\\012    RETURN 1;\\012END;\\012$$ LANGUAGE 'plpgsql';\\012\\012SELECT populate_data_producer_code_and_production_timestamp();\\012DROP FUNCTION populate_data_producer_code_and_production_timestamp();\\012\\012-- Rename columns\\012\\012ALTER TABLE DATA RENAME COLUMN PROC_ID_ACQUIRED_BY to PROC_ID_PRODUCED_BY;\\012\\012---------------------------------------------------------------------------------------------------\\012--  Purpose:  Populate table DATA_SET_RELATIONSHIPS, by using heuristics.\\012---------------------------------------------------------------------------------------------------\\012\\012CREATE OR REPLACE FUNCTION abs_interval(ts1 time_stamp_dfl, ts2 time_stamp_dfl) returns interval AS $$\\012BEGIN\\012    IF ts1 < ts2 THEN\\012        RETURN ts2 - ts1;\\012    ELSE\\012        RETURN ts1 - ts2;\\012    END IF;\\012END;\\012$$ LANGUAGE 'plpgsql';\\012\\012CREATE OR REPLACE FUNCTION populate_data_set_relationships() RETURNS INTEGER AS $$\\012DECLARE\\012    source_id TECH_ID;\\012    rec_derived RECORD;\\012    rec_acquired RECORD;\\012    rel_location TEXT;\\012    data_set_code TEXT;\\012    data_set_code_trial TEXT;\\012    loty_rel_code TEXT := 'RELATIVE_LOCATION';\\012    loty_rel_id TECH_ID;\\012    count INTEGER := 0;\\012BEGIN\\012    select id into loty_rel_id from locator_types where code = loty_rel_code;\\012    FOR rec_derived IN select id, samp_id_derived_from, registration_timestamp from data where samp_id_derived_from is not null LOOP\\012        source_id := NULL;\\012        select location into rel_location from external_data where data_id = rec_derived.id and loty_id = loty_rel_id;\\012        IF rel_location is not null then\\012            data_set_code := substring(rel_location from '^.*/([0-9]{14}_[^_]+)_.*$');\\012            IF data_set_code is not null THEN\\012                FOR rec_acquired IN select id, samp_id_acquired_from from data where samp_id_acquired_from = rec_derived.samp_id_derived_from LOOP\\012                    select location into rel_location from external_data where data_id = rec_acquired.id and loty_id = loty_rel_id;\\012                    IF rel_location is not null THEN\\012                        data_set_code_trial := substring(rel_location from '^.*/([0-9]{14}_[^_]+)_.*$');\\012                        IF data_set_code_trial = data_set_code THEN\\012                            source_id = rec_acquired.id;\\012                            EXIT;\\012                        END IF;\\012                    END IF;\\012                END LOOP;\\012            END IF;\\012        END IF;\\012        -- If the location didn't tell us about data set relationships, try the backup strategy.\\012        IF source_id is null THEN\\012            -- Use the measured data set as source that is closest in registration timestamp.\\012            select id into source_id from data where samp_id_acquired_from = rec_derived.samp_id_derived_from \\012                and abs_interval(registration_timestamp, rec_derived.registration_timestamp) \\012                    = (select min(abs_interval(registration_timestamp, rec_derived.registration_timestamp)) \\012                        from data where samp_id_acquired_from = rec_derived.samp_id_derived_from);\\012        END IF;\\012        IF source_id is not null THEN\\012            insert into data_set_relationships (id, data_id_parent, data_id_child)\\012                values (nextval('DATA_SET_RELATIONSHIP_ID_SEQ'), source_id, rec_derived.id);\\012            count := count + 1;\\012        END IF;\\012    END LOOP;\\012    RETURN count;\\012END;\\012$$ LANGUAGE 'plpgsql';\\012\\012SELECT populate_data_set_relationships();\\012DROP FUNCTION populate_data_set_relationships();\\012DROP FUNCTION abs_interval(time_stamp_dfl, time_stamp_dfl);\\012\\012---------------------------------------------------------------------------------------------------\\012--  Purpose:  Add column IS_MANAGED_INTERNALLY to table PROPERTY_TYPES. Internally managed \\012--  properties can not be assigned by users of openBIS, but only by the system. \\012---------------------------------------------------------------------------------------------------\\012\\012ALTER TABLE PROPERTY_TYPES ADD COLUMN IS_MANAGED_INTERNALLY BOOLEAN_CHAR NOT NULL DEFAULT 'F';\\012\\012-- Update already existing property type PLATE_GEOMETRY\\012update property_types set is_managed_internally = true, code = '.' || code where code = 'PLATE_GEOMETRY';\\012\\012-- Update already existing controlled vocabulary PLATE_GEOMETRY \\012update controlled_vocabularies set code = '.' || code where code = 'PLATE_GEOMETRY';\\012\\012---------------------------------------------------------------------------------------------------\\012--  Purpose:  Add unique constraint on column LABEL. \\012---------------------------------------------------------------------------------------------------\\012\\012CREATE OR REPLACE FUNCTION make_prty_labels_unique() RETURNS INTEGER AS $$\\012DECLARE\\012    prev_key TEXT := NULL;\\012    this_key TEXT;\\012    dup_count INTEGER;\\012    cnt INTEGER := 0;\\012    already_exists INTEGER;\\012    new_label TEXT;\\012    this_id TECH_ID;\\012BEGIN\\012    FOR this_id, this_key IN select id, label from property_types order by label,id LOOP\\012        IF this_key = prev_key THEN\\012            dup_count := dup_count + 1;\\012            cnt := cnt + 1;\\012        ELSE\\012            dup_count := 0;\\012        END IF;\\012        IF dup_count > 0 THEN\\012            -- Check whether the new key already exists.\\012            LOOP\\012                new_label := this_key || '(' || dup_count::text || ')';\\012                select count(*) into already_exists from property_types where label = new_label;\\012                IF already_exists = 0 THEN\\012                    EXIT;\\012                END IF;\\012                dup_count := dup_count + 1;\\012            END LOOP;\\012            update property_types set label = new_label where id = this_id;\\012        END IF;\\012        prev_key := this_key;\\012    END LOOP;\\012    RETURN cnt;\\012END;\\012$$ LANGUAGE 'plpgsql';\\012\\012SELECT make_prty_labels_unique();\\012DROP FUNCTION make_prty_labels_unique();\\012\\012ALTER TABLE PROPERTY_TYPES ADD CONSTRAINT PRTY_BK_UK_LBL UNIQUE(LABEL);\\012\\012-----------------------------------------------------------------------------------\\012--  Purpose:  Add Controlled Vocabulary Terms to PLATE_GEOMETRY\\012-----------------------------------------------------------------------------------\\012\\012insert into controlled_vocabulary_terms \\012       ( id\\012       , code\\012       , covo_id \\012       , pers_id_registerer)\\012values  (nextval('CVTE_ID_SEQ')\\012       , '96_WELLS_8X12'\\012       , (select id from controlled_vocabularies where code = '.PLATE_GEOMETRY')\\012       , (select id from persons where user_id = 'system'));\\012\\012insert into controlled_vocabulary_terms \\012       ( id\\012       , code\\012       , covo_id \\012       , pers_id_registerer)\\012values  (nextval('CVTE_ID_SEQ')\\012       , '1536_WELLS_32X48'\\012       , (select id from controlled_vocabularies where code = '.PLATE_GEOMETRY')\\012       , (select id from persons where user_id = 'system'));\\012\\012\\012-----------------------------------------------------------------------------------\\012--  Purpose:  Rename Observable Types: IMAGE -> HCS_IMAGE, IMAGE_ANALYSIS_DATA -> HCS_IMAGE_ANALYSIS_DATA\\012--  and descriptions accordingly\\012-----------------------------------------------------------------------------------\\012\\012update observable_types set code = 'HCS_IMAGE', description = 'Data derived from analysis of HCS images' where code = 'IMAGE';\\012update observable_types set code = 'HCS_IMAGE_ANALYSIS_DATA', description = 'Data derived from analysis of HCS images' where code = 'IMAGE_ANALYSIS_DATA';\\012\\012\\012-----------------------------------------------------------------------------------\\012--  Purpose: Make the assignments of property types DESCRIPTION, NUCLEOTIDE_SEQUENCE, OFFSET \\012--  and GENE_SYMBOL to material types internally managed. \\012-----------------------------------------------------------------------------------\\012\\012update material_type_property_types set is_managed_internally = true\\012    where prty_id in (select id from property_types where code = 'DESCRIPTION' \\012        or code = 'NUCLEOTIDE_SEQUENCE' or code = 'OFFSET' or code = 'GENE_SYMBOL');\\012\\012-----------------------------------------------------------------------------------\\012--  Purpose: Add column IS_DATA_ACQUISITION BOOLEAN_CHAR NOT NULL DEFAULT 'F' to table PROCEDURE_TYPES.\\012-----------------------------------------------------------------------------------\\012\\012ALTER TABLE PROCEDURE_TYPES ADD COLUMN IS_DATA_ACQUISITION BOOLEAN_CHAR NOT NULL DEFAULT 'F';\\012\\012-- Set the new attribute for procedure type DATA_ACQUISITION\\012update procedure_types set is_data_acquisition = true where code = 'DATA_ACQUISITION';\\012\\012-----------------------------------------------------------------------------------\\012--  Purpose: Convert all codes to upper case. \\012-----------------------------------------------------------------------------------\\012\\012CREATE OR REPLACE FUNCTION column_to_uppercase_fix_duplicates(tbl TEXT, clm TEXT) RETURNS INTEGER AS $$\\012DECLARE\\012    prev_key TEXT := NULL;\\012    this_key TEXT;\\012    dup_count INTEGER;\\012    count INTEGER := 0;\\012    already_exists INTEGER;\\012    new_clm TEXT;\\012BEGIN\\012    FOR this_key IN EXECUTE 'select ' || clm || ' from ' || tbl \\012        || ' order by upper(' || clm || '),id' LOOP\\012        IF upper(this_key) = upper(prev_key) THEN\\012            dup_count := dup_count + 1;\\012            count := count + 1;\\012        ELSE\\012            dup_count := 0;\\012        END IF;\\012        IF dup_count > 0 THEN\\012            -- Check whether the new key already exists.\\012            LOOP\\012                new_clm := this_key || '(' || dup_count::text || ')';\\012                EXECUTE 'select count(*) from ' || tbl \\012                    || ' where upper(' || clm || ') = ' || quote_literal(upper(new_clm)) \\012                    into already_exists;\\012                IF already_exists = 0 THEN\\012                    EXIT;\\012                END IF;\\012                dup_count := dup_count + 1;\\012            END LOOP;\\012            EXECUTE 'update ' || tbl || ' set ' || clm || ' = ' || quote_literal(new_clm) || \\012                ' where ' || clm || ' = ' || quote_literal(this_key);\\012        END IF;\\012        prev_key := this_key;\\012    END LOOP;\\012    EXECUTE 'update ' || tbl || ' set ' || clm || ' = upper(' || clm || ')';\\012    RETURN count;\\012END;\\012$$ LANGUAGE 'plpgsql';\\012\\012\\012CREATE OR REPLACE FUNCTION column_to_uppercase_fix_duplicates(tbl TEXT, clm TEXT, clm2 TEXT) RETURNS INTEGER AS $$\\012DECLARE\\012    prev_key TEXT := NULL;\\012    prev_key2 TECH_ID;\\012    this_key TEXT;\\012    this_key2 TECH_ID;\\012    dup_count INTEGER;\\012    count INTEGER := 0;\\012    already_exists INTEGER;\\012    new_clm TEXT;\\012BEGIN\\012    FOR this_key, this_key2 IN EXECUTE 'select ' || clm || ',' || clm2 || ' from ' || tbl \\012        || ' order by ' || clm2 || ',upper(' ||  clm || '),id' LOOP\\012        IF upper(this_key) = upper(prev_key) and this_key2 = prev_key2 THEN\\012            dup_count := dup_count + 1;\\012            count := count + 1;\\012        ELSE\\012            dup_count := 0;\\012        END IF;\\012        IF dup_count > 0 THEN\\012            -- Check whether the new key already exists.\\012            LOOP\\012                new_clm := this_key || '(' || dup_count::text || ')';\\012                EXECUTE 'select count(*) from ' || tbl \\012                    || ' where upper(' || clm || ') = ' || quote_literal(upper(new_clm)) \\012                    || ' and ' || clm2 || ' = ' || quote_literal(this_key2) \\012                    into already_exists;\\012                IF already_exists = 0 THEN\\012                    EXIT;\\012                END IF;\\012                dup_count := dup_count + 1;\\012            END LOOP;\\012            EXECUTE 'update ' || tbl || ' set ' || clm || ' = ' || quote_literal(new_clm) || \\012                ' where ' || clm || ' = ' || quote_literal(this_key) || ' and ' \\012                || clm2 || ' = ' || quote_literal(this_key2);\\012        END IF;\\012        prev_key := this_key;\\012        prev_key2 := this_key2;\\012    END LOOP;\\012    EXECUTE 'update ' || tbl || ' set ' || clm || ' = upper(' || clm || ')';\\012    RETURN count;\\012END;\\012$$ LANGUAGE 'plpgsql';\\012\\012\\012SELECT column_to_uppercase_fix_duplicates('samples', 'code');\\012SELECT column_to_uppercase_fix_duplicates('property_types', 'code');\\012SELECT column_to_uppercase_fix_duplicates('controlled_vocabularies', 'code');\\012\\012SELECT column_to_uppercase_fix_duplicates('projects', 'code', 'grou_id');\\012SELECT column_to_uppercase_fix_duplicates('experiments', 'code', 'proj_id');\\012SELECT column_to_uppercase_fix_duplicates('controlled_vocabulary_terms', 'code', 'covo_id');\\012SELECT column_to_uppercase_fix_duplicates('materials', 'code', 'maty_id');\\012SELECT column_to_uppercase_fix_duplicates('material_batches', 'code', 'mate_id');\\012SELECT column_to_uppercase_fix_duplicates('sample_components', 'code', 'samp_id');\\012\\012-- These will only need changes if someone entered them through the 'back door' directly on the server.\\012\\012SELECT column_to_uppercase_fix_duplicates('groups', 'code');\\012SELECT column_to_uppercase_fix_duplicates('sample_types', 'code');\\012SELECT column_to_uppercase_fix_duplicates('material_types', 'code');\\012SELECT column_to_uppercase_fix_duplicates('experiment_types', 'code');\\012SELECT column_to_uppercase_fix_duplicates('procedure_types', 'code');\\012SELECT column_to_uppercase_fix_duplicates('observable_types', 'code');\\012SELECT column_to_uppercase_fix_duplicates('locator_types', 'code');\\012SELECT column_to_uppercase_fix_duplicates('file_format_types', 'code');\\012SELECT column_to_uppercase_fix_duplicates('data_types', 'code');\\012\\012DROP FUNCTION column_to_uppercase_fix_duplicates(TEXT, TEXT);\\012DROP FUNCTION column_to_uppercase_fix_duplicates(TEXT, TEXT, TEXT);\\012\\012-----------------------------------------------------------------------------------\\012--  Purpose:  Delete sample_components with no associated material_batches.\\012--  This deletes superfluous controls of master plates\\012-----------------------------------------------------------------------------------\\012\\012delete from sample_components\\012where  id in (select sc.id \\012              from   sample_components as sc left join sample_component_materials as scm \\012              on     scm.saco_id = sc.id \\012              where  scm.saco_id is null\\012              )\\012;\\012	\N
+./sourceTest/sql/postgresql/test_database_for_migration/postgresql/018/006=database_version_logs.tsv:017	source/sql/postgresql/migration/migration-016-017.sql	SUCCESS	2008-08-29 08:11:12.644	----------------------------------------------------------------------------------------------\\012--  File: migration-016-017.sql\\012--\\012-- \\012--  This script enables the migration of the database schema from 016 to 017.\\012-- \\012--  Update History\\012--\\012--\\012--\\011Who\\011\\011\\011              When\\011\\011    What\\012--\\011---\\011\\011\\011              ----      \\011----\\012--\\011Charles Ramin-Wright\\0112008-04-11\\011Initial Version \\012--  \\012----------------------------------------------------------------------------------------------\\012\\012\\012--=================================\\012-- Create Objects\\012--=================================\\012\\012-- Domains\\012\\012-- 'F' is false, 'T' is true and 'U' is unknown\\012CREATE DOMAIN BOOLEAN_CHAR_OR_UNKNOWN AS CHAR(1) CHECK (VALUE in ('F', 'T', 'U'));\\012\\012-- Tables and related objects\\012\\012-- Sequences\\012\\012-- Indices\\012\\012--====================================\\012-- Delete Objects\\012--====================================\\012\\012-- Domains\\012\\012-- Tables\\012\\012-- Sequences\\012\\012-- Indices\\012\\012--====================================\\012-- Alter Objects\\012--====================================\\012\\012-- Add column IS_INTERNAL_NAMESPACE to table CONTROLLED_VOCABULARIES \\012\\012ALTER TABLE CONTROLLED_VOCABULARIES ADD IS_INTERNAL_NAMESPACE BOOLEAN_CHAR NOT NULL DEFAULT 'F';\\012\\012-- Add column IS_INTERNAL_NAMESPACE to table PROPERTY_TYPES \\012\\012ALTER TABLE PROPERTY_TYPES ADD IS_INTERNAL_NAMESPACE BOOLEAN_CHAR NOT NULL DEFAULT 'F';\\012\\012-- Add column IS_INTERNAL_NAMESPACE as key component to the unique key constraint COVO_BK_UK\\012\\012ALTER TABLE CONTROLLED_VOCABULARIES DROP CONSTRAINT COVO_BK_UK;\\012ALTER TABLE CONTROLLED_VOCABULARIES ADD CONSTRAINT COVO_BK_UK UNIQUE(CODE,IS_INTERNAL_NAMESPACE);\\012\\012-- Add column IS_INTERNAL_NAMESPACE as key component to the unique key constraint PRTY_BK_UK\\012\\012ALTER TABLE PROPERTY_TYPES DROP CONSTRAINT PRTY_BK_UK;\\012ALTER TABLE PROPERTY_TYPES ADD CONSTRAINT PRTY_BK_UK UNIQUE(CODE,IS_INTERNAL_NAMESPACE);\\012\\012-- Delete unique key constraint PRTY_BK_UK_LBL (which was for column LABEL) from table PROPERTY_TYPES\\012\\012ALTER TABLE PROPERTY_TYPES DROP CONSTRAINT PRTY_BK_UK_LBL;\\012\\012\\012-- Change unique constraint EXDA_BK_UK to contain EXTERNAL_DATA.LOTY_ID \\012\\012ALTER TABLE EXTERNAL_DATA DROP CONSTRAINT EXDA_BK_UK;\\012ALTER TABLE EXTERNAL_DATA ADD CONSTRAINT EXDA_BK_UK UNIQUE(LOCATION,LOTY_ID);\\012\\012\\012-- Increase length of EXTERNAL_DATA.LOCATION from 200 to 1024\\012\\012ALTER TABLE EXTERNAL_DATA ALTER COLUMN LOCATION TYPE VARCHAR(1024);\\012\\012\\012-- Add column IS_COMPLETE to table EXTERNAL_DATA\\012\\012ALTER TABLE EXTERNAL_DATA ADD COLUMN IS_COMPLETE BOOLEAN_CHAR_OR_UNKNOWN NOT NULL DEFAULT 'U';\\012\\012\\012--=================================\\012-- Replace EXTERNAL_DATA_STORAGE_FORMAT_CHECK() function\\012--=================================\\012\\012CREATE OR REPLACE FUNCTION EXTERNAL_DATA_STORAGE_FORMAT_CHECK() RETURNS trigger AS $$\\012DECLARE\\012   v_covo_code  CODE;\\012   data_code CODE;\\012BEGIN\\012\\012   select code into v_covo_code from controlled_vocabularies\\012      where is_internal_namespace = true and \\012         id = (select covo_id from controlled_vocabulary_terms where id = NEW.cvte_id_stor_fmt);\\012\\012-- Check if the data storage format is a term of the controlled vocabulary "STORAGE_FORMAT"\\012   if v_covo_code != 'STORAGE_FORMAT' then\\012      select code into data_code from data where id = NEW.data_id; \\012      RAISE EXCEPTION 'Insert/Update of Data (Code: %) failed, as its Storage Format is %, but is required to be STORAGE_FORMAT.', data_code, v_covo_code;\\012   end if;\\012\\012   RETURN NEW;\\012\\012END;\\012$$ LANGUAGE 'plpgsql';\\012\\012\\012--=================================\\012-- Data Migration\\012--=================================\\012\\012\\012---------------------------------------------------------------------------------------\\012--   Translate the internally managed CODES which are represented by the Dot-Prefix to:\\012--\\012--   CODE without a Dot-Prefix plus the new column IS_INTERNAL_NAMESPACE = true.\\012---------------------------------------------------------------------------------------\\012\\012UPDATE property_types\\012SET    code = substr(code,2,length(code))\\012     , is_internal_namespace = true \\012WHERE  substr(code,1,1) = '.';\\012\\012UPDATE controlled_vocabularies\\012SET    code = substr(code,2,length(code))\\012     , is_internal_namespace = true \\012WHERE  substr(code,1,1) = '.';\\012\\012------------------------------------------------------------------------------------\\012--  Purpose: Move experiment descriptions from column to property DESCRIPTION\\012------------------------------------------------------------------------------------\\012\\012   -----------------------\\012   --  Material Type SIRNHACS\\012   -----------------------\\012\\012insert into experiment_type_property_types\\012(   id\\012   ,exty_id\\012   ,prty_id\\012   ,is_mandatory\\012   ,is_managed_internally\\012   ,pers_id_registerer\\012   )\\012values \\012(   nextval('ETPT_ID_SEQ')\\012   ,(select id from experiment_types where code = 'SIRNAHCS')\\012   ,(select id from property_types where code = 'DESCRIPTION')\\012   ,true\\012   ,true\\012   ,(select id from persons where user_id ='system')\\012);\\012\\012-- Add experiment_properties for descriptions of all experiments of type SIRNAHCS \\012\\012insert into experiment_properties\\012(   id\\012   ,expe_id\\012   ,value\\012   ,etpt_id\\012   ,pers_id_registerer\\012)\\012select\\012    nextval('EXPERIMENT_PROPERTY_ID_SEQ')\\012   ,id\\012   ,case when description is not null then description else 'No description given' end\\012   ,currval('ETPT_ID_SEQ')\\012   ,(select id from persons where user_id ='system')  \\012from experiments where exty_id = (select id from experiment_types where code = 'SIRNAHCS');\\012\\012-- Finally: drop column\\012\\012ALTER TABLE EXPERIMENTS DROP COLUMN DESCRIPTION;\\012	\N
+./sourceTest/sql/postgresql/test_database_for_migration/postgresql/018/schema-018.sql:    LANGUAGE plpgsql;
+./sourceTest/sql/postgresql/test_database_for_migration/postgresql/018/schema-018.sql:    LANGUAGE plpgsql;
+./sourceTest/sql/postgresql/test_database_for_migration/postgresql/018/schema-018.sql:    LANGUAGE plpgsql;
+Binary file ./targets/ant/classes/ch/systemsx/cisd/openbis/generic/server/business/importer/DatabaseInstanceImporterTest.class matches
+./targets/dump.sql:-- Name: plpgsql; Type: PROCEDURAL LANGUAGE; Schema: -; Owner: -
+./targets/dump.sql:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql;
+./targets/dump.sql:    LANGUAGE plpgsql
+./targets/dump.sql:    LANGUAGE plpgsql
+./targets/dump.sql:    LANGUAGE plpgsql
+./targets/dump.sql:    LANGUAGE plpgsql
+./targets/dump.sql:    LANGUAGE plpgsql
+./targets/dump.sql:    LANGUAGE plpgsql
+./targets/dump.sql:    LANGUAGE plpgsql
+./targets/dump.sql:    LANGUAGE plpgsql
+./targets/dump.sql:    LANGUAGE plpgsql
+./targets/dump.sql:    LANGUAGE plpgsql
+./targets/dump.sql:    LANGUAGE plpgsql
+./targets/dump.sql:    LANGUAGE plpgsql
+./targets/dump.sql:    LANGUAGE plpgsql
+./targets/dump.sql:    LANGUAGE plpgsql
+./targets/unit-test-wd/currentDatabaseSchema.sql:-- Name: plpgsql; Type: PROCEDURAL LANGUAGE; Schema: -; Owner: -
+./targets/unit-test-wd/currentDatabaseSchema.sql:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql;
+./targets/unit-test-wd/currentDatabaseSchema.sql:    LANGUAGE plpgsql
+./targets/unit-test-wd/currentDatabaseSchema.sql:    LANGUAGE plpgsql
+./targets/unit-test-wd/currentDatabaseSchema.sql:    LANGUAGE plpgsql
+./targets/unit-test-wd/currentDatabaseSchema.sql:    LANGUAGE plpgsql
+./targets/unit-test-wd/currentDatabaseSchema.sql:    LANGUAGE plpgsql
+./targets/unit-test-wd/currentDatabaseSchema.sql:    LANGUAGE plpgsql
+./targets/unit-test-wd/currentDatabaseSchema.sql:    LANGUAGE plpgsql
+./targets/unit-test-wd/currentDatabaseSchema.sql:    LANGUAGE plpgsql
+./targets/unit-test-wd/currentDatabaseSchema.sql:    LANGUAGE plpgsql
+./targets/unit-test-wd/currentDatabaseSchema.sql:    LANGUAGE plpgsql
+./targets/unit-test-wd/currentDatabaseSchema.sql:    LANGUAGE plpgsql
+./targets/unit-test-wd/currentDatabaseSchema.sql:    LANGUAGE plpgsql
+./targets/unit-test-wd/currentDatabaseSchema.sql:    LANGUAGE plpgsql
+./targets/unit-test-wd/currentDatabaseSchema.sql:    LANGUAGE plpgsql
+./targets/unit-test-wd/migratedDatabaseSchema.sql:-- Name: plpgsql; Type: PROCEDURAL LANGUAGE; Schema: -; Owner: -
+./targets/unit-test-wd/migratedDatabaseSchema.sql:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql;
+./targets/unit-test-wd/migratedDatabaseSchema.sql:    LANGUAGE plpgsql
+./targets/unit-test-wd/migratedDatabaseSchema.sql:    LANGUAGE plpgsql
+./targets/unit-test-wd/migratedDatabaseSchema.sql:    LANGUAGE plpgsql
+./targets/unit-test-wd/migratedDatabaseSchema.sql:    LANGUAGE plpgsql
+./targets/unit-test-wd/migratedDatabaseSchema.sql:    LANGUAGE plpgsql
+./targets/unit-test-wd/migratedDatabaseSchema.sql:    LANGUAGE plpgsql
+./targets/unit-test-wd/migratedDatabaseSchema.sql:    LANGUAGE plpgsql
+./targets/unit-test-wd/migratedDatabaseSchema.sql:    LANGUAGE plpgsql
+./targets/unit-test-wd/migratedDatabaseSchema.sql:    LANGUAGE plpgsql
+./targets/unit-test-wd/migratedDatabaseSchema.sql:    LANGUAGE plpgsql
+./targets/unit-test-wd/migratedDatabaseSchema.sql:    LANGUAGE plpgsql
+./targets/unit-test-wd/migratedDatabaseSchema.sql:    LANGUAGE plpgsql
+./targets/unit-test-wd/migratedDatabaseSchema.sql:    LANGUAGE plpgsql
+./targets/unit-test-wd/migratedDatabaseSchema.sql:    LANGUAGE plpgsql
+Binary file ./targets/www/WEB-INF/classes/ch/systemsx/cisd/openbis/generic/server/business/importer/DatabaseInstanceImporterTest.class matches
+./test-output/Db/Db.html:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql;
+./test-output/Db/Db.html:    LANGUAGE plpgsql
+./test-output/Db/Db.html:    LANGUAGE plpgsql
+./test-output/Db/Db.html:    LANGUAGE plpgsql
+./test-output/Db/Db.html:    LANGUAGE plpgsql
+./test-output/Db/Db.html:    LANGUAGE plpgsql
+./test-output/Db/Db.html:    LANGUAGE plpgsql
+./test-output/Db/Db.html:    LANGUAGE plpgsql
+./test-output/Db/Db.html:    LANGUAGE plpgsql
+./test-output/Db/Db.html:    LANGUAGE plpgsql
+./test-output/Db/Db.html:    LANGUAGE plpgsql
+./test-output/Db/Db.html:    LANGUAGE plpgsql
+./test-output/Db/Db.html:    LANGUAGE plpgsql
+./test-output/Db/Db.html:    LANGUAGE plpgsql
+./test-output/Db/Db.html:    LANGUAGE plpgsql
+./test-output/Db/Db.html:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql
+./test-output/Db/Db.html:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql;
+./test-output/Db/Db.html:    LANGUAGE plpgsql
+./test-output/Db/Db.html:    LANGUAGE plpgsql
+./test-output/Db/Db.html:    LANGUAGE plpgsql
+./test-output/Db/Db.html:    LANGUAGE plpgsql
+./test-output/Db/Db.html:    LANGUAGE plpgsql
+./test-output/Db/Db.html:    LANGUAGE plpgsql
+./test-output/Db/Db.html:    LANGUAGE plpgsql
+./test-output/Db/Db.html:    LANGUAGE plpgsql
+./test-output/Db/Db.html:    LANGUAGE plpgsql
+./test-output/Db/Db.html:    LANGUAGE plpgsql
+./test-output/Db/Db.html:    LANGUAGE plpgsql
+./test-output/Db/Db.html:    LANGUAGE plpgsql
+./test-output/Db/Db.html:    LANGUAGE plpgsql
+./test-output/Db/Db.html:    LANGUAGE plpgsql
+./test-output/Db/Db.html:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql
+./test-output/Db/Db.html:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql;
+./test-output/Db/Db.html:    LANGUAGE plpgsql
+./test-output/Db/Db.html:    LANGUAGE plpgsql
+./test-output/Db/Db.html:    LANGUAGE plpgsql
+./test-output/Db/Db.html:    LANGUAGE plpgsql
+./test-output/Db/Db.html:    LANGUAGE plpgsql
+./test-output/Db/Db.html:    LANGUAGE plpgsql
+./test-output/Db/Db.html:    LANGUAGE plpgsql
+./test-output/Db/Db.html:    LANGUAGE plpgsql
+./test-output/Db/Db.html:    LANGUAGE plpgsql
+./test-output/Db/Db.html:    LANGUAGE plpgsql
+./test-output/Db/Db.html:    LANGUAGE plpgsql
+./test-output/Db/Db.html:    LANGUAGE plpgsql
+./test-output/Db/Db.html:    LANGUAGE plpgsql
+./test-output/Db/Db.html:    LANGUAGE plpgsql
+./test-output/Db/Db.html:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql
+./test-output/Db/Db.html:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql;
+./test-output/Db/Db.html:    LANGUAGE plpgsql
+./test-output/Db/Db.html:    LANGUAGE plpgsql
+./test-output/Db/Db.html:    LANGUAGE plpgsql
+./test-output/Db/Db.html:    LANGUAGE plpgsql
+./test-output/Db/Db.html:    LANGUAGE plpgsql
+./test-output/Db/Db.html:    LANGUAGE plpgsql
+./test-output/Db/Db.html:    LANGUAGE plpgsql
+./test-output/Db/Db.html:    LANGUAGE plpgsql
+./test-output/Db/Db.html:    LANGUAGE plpgsql
+./test-output/Db/Db.html:    LANGUAGE plpgsql
+./test-output/Db/Db.html:    LANGUAGE plpgsql
+./test-output/Db/Db.html:    LANGUAGE plpgsql
+./test-output/Db/Db.html:    LANGUAGE plpgsql
+./test-output/Db/Db.html:    LANGUAGE plpgsql
+./test-output/Db/Db.html:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql
+./test-output/Db/Db.html:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql;
+./test-output/Db/Db.html:    LANGUAGE plpgsql
+./test-output/Db/Db.html:    LANGUAGE plpgsql
+./test-output/Db/Db.html:    LANGUAGE plpgsql
+./test-output/Db/Db.html:    LANGUAGE plpgsql
+./test-output/Db/Db.html:    LANGUAGE plpgsql
+./test-output/Db/Db.html:    LANGUAGE plpgsql
+./test-output/Db/Db.html:    LANGUAGE plpgsql
+./test-output/Db/Db.html:    LANGUAGE plpgsql
+./test-output/Db/Db.html:    LANGUAGE plpgsql
+./test-output/Db/Db.html:    LANGUAGE plpgsql
+./test-output/Db/Db.html:    LANGUAGE plpgsql
+./test-output/Db/Db.html:    LANGUAGE plpgsql
+./test-output/Db/Db.html:    LANGUAGE plpgsql
+./test-output/Db/Db.html:    LANGUAGE plpgsql
+./test-output/Db/Db.html:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql
+./test-output/Db/Db.html:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql;
+./test-output/Db/Db.html:    LANGUAGE plpgsql
+./test-output/Db/Db.html:    LANGUAGE plpgsql
+./test-output/Db/Db.html:    LANGUAGE plpgsql
+./test-output/Db/Db.html:    LANGUAGE plpgsql
+./test-output/Db/Db.html:    LANGUAGE plpgsql
+./test-output/Db/Db.html:    LANGUAGE plpgsql
+./test-output/Db/Db.html:    LANGUAGE plpgsql
+./test-output/Db/Db.html:    LANGUAGE plpgsql
+./test-output/Db/Db.html:    LANGUAGE plpgsql
+./test-output/Db/Db.html:    LANGUAGE plpgsql
+./test-output/Db/Db.html:    LANGUAGE plpgsql
+./test-output/Db/Db.html:    LANGUAGE plpgsql
+./test-output/Db/Db.html:    LANGUAGE plpgsql
+./test-output/Db/Db.html:    LANGUAGE plpgsql
+./test-output/Db/Db.html:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql
+./test-output/Db/Db.html:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql;
+./test-output/Db/Db.html:    LANGUAGE plpgsql
+./test-output/Db/Db.html:    LANGUAGE plpgsql
+./test-output/Db/Db.html:    LANGUAGE plpgsql
+./test-output/Db/Db.html:    LANGUAGE plpgsql
+./test-output/Db/Db.html:    LANGUAGE plpgsql
+./test-output/Db/Db.html:    LANGUAGE plpgsql
+./test-output/Db/Db.html:    LANGUAGE plpgsql
+./test-output/Db/Db.html:    LANGUAGE plpgsql
+./test-output/Db/Db.html:    LANGUAGE plpgsql
+./test-output/Db/Db.html:    LANGUAGE plpgsql
+./test-output/Db/Db.html:    LANGUAGE plpgsql
+./test-output/Db/Db.html:    LANGUAGE plpgsql
+./test-output/Db/Db.html:    LANGUAGE plpgsql
+./test-output/Db/Db.html:    LANGUAGE plpgsql
+./test-output/Db/Db.html:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql
+./test-output/Db/Db.html:Caused by: org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql
+./test-output/Db/Db.html:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql;
+./test-output/Db/Db.html:    LANGUAGE plpgsql
+./test-output/Db/Db.html:    LANGUAGE plpgsql
+./test-output/Db/Db.html:    LANGUAGE plpgsql
+./test-output/Db/Db.html:    LANGUAGE plpgsql
+./test-output/Db/Db.html:    LANGUAGE plpgsql
+./test-output/Db/Db.html:    LANGUAGE plpgsql
+./test-output/Db/Db.html:    LANGUAGE plpgsql
+./test-output/Db/Db.html:    LANGUAGE plpgsql
+./test-output/Db/Db.html:    LANGUAGE plpgsql
+./test-output/Db/Db.html:    LANGUAGE plpgsql
+./test-output/Db/Db.html:    LANGUAGE plpgsql
+./test-output/Db/Db.html:    LANGUAGE plpgsql
+./test-output/Db/Db.html:    LANGUAGE plpgsql
+./test-output/Db/Db.html:    LANGUAGE plpgsql
+./test-output/Db/Db.html:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql
+./test-output/Db/Db.html:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql;
+./test-output/Db/Db.html:    LANGUAGE plpgsql
+./test-output/Db/Db.html:    LANGUAGE plpgsql
+./test-output/Db/Db.html:    LANGUAGE plpgsql
+./test-output/Db/Db.html:    LANGUAGE plpgsql
+./test-output/Db/Db.html:    LANGUAGE plpgsql
+./test-output/Db/Db.html:    LANGUAGE plpgsql
+./test-output/Db/Db.html:    LANGUAGE plpgsql
+./test-output/Db/Db.html:    LANGUAGE plpgsql
+./test-output/Db/Db.html:    LANGUAGE plpgsql
+./test-output/Db/Db.html:    LANGUAGE plpgsql
+./test-output/Db/Db.html:    LANGUAGE plpgsql
+./test-output/Db/Db.html:    LANGUAGE plpgsql
+./test-output/Db/Db.html:    LANGUAGE plpgsql
+./test-output/Db/Db.html:    LANGUAGE plpgsql
+./test-output/Db/Db.html:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql
+./test-output/Db/Db.html:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql;
+./test-output/Db/Db.html:    LANGUAGE plpgsql
+./test-output/Db/Db.html:    LANGUAGE plpgsql
+./test-output/Db/Db.html:    LANGUAGE plpgsql
+./test-output/Db/Db.html:    LANGUAGE plpgsql
+./test-output/Db/Db.html:    LANGUAGE plpgsql
+./test-output/Db/Db.html:    LANGUAGE plpgsql
+./test-output/Db/Db.html:    LANGUAGE plpgsql
+./test-output/Db/Db.html:    LANGUAGE plpgsql
+./test-output/Db/Db.html:    LANGUAGE plpgsql
+./test-output/Db/Db.html:    LANGUAGE plpgsql
+./test-output/Db/Db.html:    LANGUAGE plpgsql
+./test-output/Db/Db.html:    LANGUAGE plpgsql
+./test-output/Db/Db.html:    LANGUAGE plpgsql
+./test-output/Db/Db.html:    LANGUAGE plpgsql
+./test-output/Db/Db.html:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql
+./test-output/Db/Db.html:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql;
+./test-output/Db/Db.html:    LANGUAGE plpgsql
+./test-output/Db/Db.html:    LANGUAGE plpgsql
+./test-output/Db/Db.html:    LANGUAGE plpgsql
+./test-output/Db/Db.html:    LANGUAGE plpgsql
+./test-output/Db/Db.html:    LANGUAGE plpgsql
+./test-output/Db/Db.html:    LANGUAGE plpgsql
+./test-output/Db/Db.html:    LANGUAGE plpgsql
+./test-output/Db/Db.html:    LANGUAGE plpgsql
+./test-output/Db/Db.html:    LANGUAGE plpgsql
+./test-output/Db/Db.html:    LANGUAGE plpgsql
+./test-output/Db/Db.html:    LANGUAGE plpgsql
+./test-output/Db/Db.html:    LANGUAGE plpgsql
+./test-output/Db/Db.html:    LANGUAGE plpgsql
+./test-output/Db/Db.html:    LANGUAGE plpgsql
+./test-output/Db/Db.html:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql
+./test-output/Db/Db.html:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql;
+./test-output/Db/Db.html:    LANGUAGE plpgsql
+./test-output/Db/Db.html:    LANGUAGE plpgsql
+./test-output/Db/Db.html:    LANGUAGE plpgsql
+./test-output/Db/Db.html:    LANGUAGE plpgsql
+./test-output/Db/Db.html:    LANGUAGE plpgsql
+./test-output/Db/Db.html:    LANGUAGE plpgsql
+./test-output/Db/Db.html:    LANGUAGE plpgsql
+./test-output/Db/Db.html:    LANGUAGE plpgsql
+./test-output/Db/Db.html:    LANGUAGE plpgsql
+./test-output/Db/Db.html:    LANGUAGE plpgsql
+./test-output/Db/Db.html:    LANGUAGE plpgsql
+./test-output/Db/Db.html:    LANGUAGE plpgsql
+./test-output/Db/Db.html:    LANGUAGE plpgsql
+./test-output/Db/Db.html:    LANGUAGE plpgsql
+./test-output/Db/Db.html:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql
+./test-output/Db/Db.html:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql;
+./test-output/Db/Db.html:    LANGUAGE plpgsql
+./test-output/Db/Db.html:    LANGUAGE plpgsql
+./test-output/Db/Db.html:    LANGUAGE plpgsql
+./test-output/Db/Db.html:    LANGUAGE plpgsql
+./test-output/Db/Db.html:    LANGUAGE plpgsql
+./test-output/Db/Db.html:    LANGUAGE plpgsql
+./test-output/Db/Db.html:    LANGUAGE plpgsql
+./test-output/Db/Db.html:    LANGUAGE plpgsql
+./test-output/Db/Db.html:    LANGUAGE plpgsql
+./test-output/Db/Db.html:    LANGUAGE plpgsql
+./test-output/Db/Db.html:    LANGUAGE plpgsql
+./test-output/Db/Db.html:    LANGUAGE plpgsql
+./test-output/Db/Db.html:    LANGUAGE plpgsql
+./test-output/Db/Db.html:    LANGUAGE plpgsql
+./test-output/Db/Db.html:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql
+./test-output/Db/Db.html:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql;
+./test-output/Db/Db.html:    LANGUAGE plpgsql
+./test-output/Db/Db.html:    LANGUAGE plpgsql
+./test-output/Db/Db.html:    LANGUAGE plpgsql
+./test-output/Db/Db.html:    LANGUAGE plpgsql
+./test-output/Db/Db.html:    LANGUAGE plpgsql
+./test-output/Db/Db.html:    LANGUAGE plpgsql
+./test-output/Db/Db.html:    LANGUAGE plpgsql
+./test-output/Db/Db.html:    LANGUAGE plpgsql
+./test-output/Db/Db.html:    LANGUAGE plpgsql
+./test-output/Db/Db.html:    LANGUAGE plpgsql
+./test-output/Db/Db.html:    LANGUAGE plpgsql
+./test-output/Db/Db.html:    LANGUAGE plpgsql
+./test-output/Db/Db.html:    LANGUAGE plpgsql
+./test-output/Db/Db.html:    LANGUAGE plpgsql
+./test-output/Db/Db.html:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql
+./test-output/Db/Db.html:Caused by: org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql
+./test-output/Db/Db.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql;
+./test-output/Db/Db.xml:    LANGUAGE plpgsql
+./test-output/Db/Db.xml:    LANGUAGE plpgsql
+./test-output/Db/Db.xml:    LANGUAGE plpgsql
+./test-output/Db/Db.xml:    LANGUAGE plpgsql
+./test-output/Db/Db.xml:    LANGUAGE plpgsql
+./test-output/Db/Db.xml:    LANGUAGE plpgsql
+./test-output/Db/Db.xml:    LANGUAGE plpgsql
+./test-output/Db/Db.xml:    LANGUAGE plpgsql
+./test-output/Db/Db.xml:    LANGUAGE plpgsql
+./test-output/Db/Db.xml:    LANGUAGE plpgsql
+./test-output/Db/Db.xml:    LANGUAGE plpgsql
+./test-output/Db/Db.xml:    LANGUAGE plpgsql
+./test-output/Db/Db.xml:    LANGUAGE plpgsql
+./test-output/Db/Db.xml:    LANGUAGE plpgsql
+./test-output/Db/Db.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql
+./test-output/Db/Db.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql;
+./test-output/Db/Db.xml:    LANGUAGE plpgsql
+./test-output/Db/Db.xml:    LANGUAGE plpgsql
+./test-output/Db/Db.xml:    LANGUAGE plpgsql
+./test-output/Db/Db.xml:    LANGUAGE plpgsql
+./test-output/Db/Db.xml:    LANGUAGE plpgsql
+./test-output/Db/Db.xml:    LANGUAGE plpgsql
+./test-output/Db/Db.xml:    LANGUAGE plpgsql
+./test-output/Db/Db.xml:    LANGUAGE plpgsql
+./test-output/Db/Db.xml:    LANGUAGE plpgsql
+./test-output/Db/Db.xml:    LANGUAGE plpgsql
+./test-output/Db/Db.xml:    LANGUAGE plpgsql
+./test-output/Db/Db.xml:    LANGUAGE plpgsql
+./test-output/Db/Db.xml:    LANGUAGE plpgsql
+./test-output/Db/Db.xml:    LANGUAGE plpgsql
+./test-output/Db/Db.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql
+./test-output/Db/Db.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql;
+./test-output/Db/Db.xml:    LANGUAGE plpgsql
+./test-output/Db/Db.xml:    LANGUAGE plpgsql
+./test-output/Db/Db.xml:    LANGUAGE plpgsql
+./test-output/Db/Db.xml:    LANGUAGE plpgsql
+./test-output/Db/Db.xml:    LANGUAGE plpgsql
+./test-output/Db/Db.xml:    LANGUAGE plpgsql
+./test-output/Db/Db.xml:    LANGUAGE plpgsql
+./test-output/Db/Db.xml:    LANGUAGE plpgsql
+./test-output/Db/Db.xml:    LANGUAGE plpgsql
+./test-output/Db/Db.xml:    LANGUAGE plpgsql
+./test-output/Db/Db.xml:    LANGUAGE plpgsql
+./test-output/Db/Db.xml:    LANGUAGE plpgsql
+./test-output/Db/Db.xml:    LANGUAGE plpgsql
+./test-output/Db/Db.xml:    LANGUAGE plpgsql
+./test-output/Db/Db.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql
+./test-output/Db/Db.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql;
+./test-output/Db/Db.xml:    LANGUAGE plpgsql
+./test-output/Db/Db.xml:    LANGUAGE plpgsql
+./test-output/Db/Db.xml:    LANGUAGE plpgsql
+./test-output/Db/Db.xml:    LANGUAGE plpgsql
+./test-output/Db/Db.xml:    LANGUAGE plpgsql
+./test-output/Db/Db.xml:    LANGUAGE plpgsql
+./test-output/Db/Db.xml:    LANGUAGE plpgsql
+./test-output/Db/Db.xml:    LANGUAGE plpgsql
+./test-output/Db/Db.xml:    LANGUAGE plpgsql
+./test-output/Db/Db.xml:    LANGUAGE plpgsql
+./test-output/Db/Db.xml:    LANGUAGE plpgsql
+./test-output/Db/Db.xml:    LANGUAGE plpgsql
+./test-output/Db/Db.xml:    LANGUAGE plpgsql
+./test-output/Db/Db.xml:    LANGUAGE plpgsql
+./test-output/Db/Db.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql
+./test-output/Db/Db.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql;
+./test-output/Db/Db.xml:    LANGUAGE plpgsql
+./test-output/Db/Db.xml:    LANGUAGE plpgsql
+./test-output/Db/Db.xml:    LANGUAGE plpgsql
+./test-output/Db/Db.xml:    LANGUAGE plpgsql
+./test-output/Db/Db.xml:    LANGUAGE plpgsql
+./test-output/Db/Db.xml:    LANGUAGE plpgsql
+./test-output/Db/Db.xml:    LANGUAGE plpgsql
+./test-output/Db/Db.xml:    LANGUAGE plpgsql
+./test-output/Db/Db.xml:    LANGUAGE plpgsql
+./test-output/Db/Db.xml:    LANGUAGE plpgsql
+./test-output/Db/Db.xml:    LANGUAGE plpgsql
+./test-output/Db/Db.xml:    LANGUAGE plpgsql
+./test-output/Db/Db.xml:    LANGUAGE plpgsql
+./test-output/Db/Db.xml:    LANGUAGE plpgsql
+./test-output/Db/Db.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql
+./test-output/Db/Db.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql;
+./test-output/Db/Db.xml:    LANGUAGE plpgsql
+./test-output/Db/Db.xml:    LANGUAGE plpgsql
+./test-output/Db/Db.xml:    LANGUAGE plpgsql
+./test-output/Db/Db.xml:    LANGUAGE plpgsql
+./test-output/Db/Db.xml:    LANGUAGE plpgsql
+./test-output/Db/Db.xml:    LANGUAGE plpgsql
+./test-output/Db/Db.xml:    LANGUAGE plpgsql
+./test-output/Db/Db.xml:    LANGUAGE plpgsql
+./test-output/Db/Db.xml:    LANGUAGE plpgsql
+./test-output/Db/Db.xml:    LANGUAGE plpgsql
+./test-output/Db/Db.xml:    LANGUAGE plpgsql
+./test-output/Db/Db.xml:    LANGUAGE plpgsql
+./test-output/Db/Db.xml:    LANGUAGE plpgsql
+./test-output/Db/Db.xml:    LANGUAGE plpgsql
+./test-output/Db/Db.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql
+./test-output/Db/Db.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql;
+./test-output/Db/Db.xml:    LANGUAGE plpgsql
+./test-output/Db/Db.xml:    LANGUAGE plpgsql
+./test-output/Db/Db.xml:    LANGUAGE plpgsql
+./test-output/Db/Db.xml:    LANGUAGE plpgsql
+./test-output/Db/Db.xml:    LANGUAGE plpgsql
+./test-output/Db/Db.xml:    LANGUAGE plpgsql
+./test-output/Db/Db.xml:    LANGUAGE plpgsql
+./test-output/Db/Db.xml:    LANGUAGE plpgsql
+./test-output/Db/Db.xml:    LANGUAGE plpgsql
+./test-output/Db/Db.xml:    LANGUAGE plpgsql
+./test-output/Db/Db.xml:    LANGUAGE plpgsql
+./test-output/Db/Db.xml:    LANGUAGE plpgsql
+./test-output/Db/Db.xml:    LANGUAGE plpgsql
+./test-output/Db/Db.xml:    LANGUAGE plpgsql
+./test-output/Db/Db.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql
+./test-output/Db/Db.xml:Caused by: org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql
+./test-output/emailable-report.html:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql;
+./test-output/emailable-report.html:    LANGUAGE plpgsql
+./test-output/emailable-report.html:    LANGUAGE plpgsql
+./test-output/emailable-report.html:    LANGUAGE plpgsql
+./test-output/emailable-report.html:    LANGUAGE plpgsql
+./test-output/emailable-report.html:    LANGUAGE plpgsql
+./test-output/emailable-report.html:    LANGUAGE plpgsql
+./test-output/emailable-report.html:    LANGUAGE plpgsql
+./test-output/emailable-report.html:    LANGUAGE plpgsql
+./test-output/emailable-report.html:    LANGUAGE plpgsql
+./test-output/emailable-report.html:    LANGUAGE plpgsql
+./test-output/emailable-report.html:    LANGUAGE plpgsql
+./test-output/emailable-report.html:    LANGUAGE plpgsql
+./test-output/emailable-report.html:    LANGUAGE plpgsql
+./test-output/emailable-report.html:    LANGUAGE plpgsql
+./test-output/emailable-report.html:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql</p>
+./test-output/emailable-report.html:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql;
+./test-output/emailable-report.html:    LANGUAGE plpgsql
+./test-output/emailable-report.html:    LANGUAGE plpgsql
+./test-output/emailable-report.html:    LANGUAGE plpgsql
+./test-output/emailable-report.html:    LANGUAGE plpgsql
+./test-output/emailable-report.html:    LANGUAGE plpgsql
+./test-output/emailable-report.html:    LANGUAGE plpgsql
+./test-output/emailable-report.html:    LANGUAGE plpgsql
+./test-output/emailable-report.html:    LANGUAGE plpgsql
+./test-output/emailable-report.html:    LANGUAGE plpgsql
+./test-output/emailable-report.html:    LANGUAGE plpgsql
+./test-output/emailable-report.html:    LANGUAGE plpgsql
+./test-output/emailable-report.html:    LANGUAGE plpgsql
+./test-output/emailable-report.html:    LANGUAGE plpgsql
+./test-output/emailable-report.html:    LANGUAGE plpgsql
+./test-output/emailable-report.html:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql</p>
+./test-output/emailable-report.html:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql;
+./test-output/emailable-report.html:    LANGUAGE plpgsql
+./test-output/emailable-report.html:    LANGUAGE plpgsql
+./test-output/emailable-report.html:    LANGUAGE plpgsql
+./test-output/emailable-report.html:    LANGUAGE plpgsql
+./test-output/emailable-report.html:    LANGUAGE plpgsql
+./test-output/emailable-report.html:    LANGUAGE plpgsql
+./test-output/emailable-report.html:    LANGUAGE plpgsql
+./test-output/emailable-report.html:    LANGUAGE plpgsql
+./test-output/emailable-report.html:    LANGUAGE plpgsql
+./test-output/emailable-report.html:    LANGUAGE plpgsql
+./test-output/emailable-report.html:    LANGUAGE plpgsql
+./test-output/emailable-report.html:    LANGUAGE plpgsql
+./test-output/emailable-report.html:    LANGUAGE plpgsql
+./test-output/emailable-report.html:    LANGUAGE plpgsql
+./test-output/emailable-report.html:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql</p>
+./test-output/emailable-report.html:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql;
+./test-output/emailable-report.html:    LANGUAGE plpgsql
+./test-output/emailable-report.html:    LANGUAGE plpgsql
+./test-output/emailable-report.html:    LANGUAGE plpgsql
+./test-output/emailable-report.html:    LANGUAGE plpgsql
+./test-output/emailable-report.html:    LANGUAGE plpgsql
+./test-output/emailable-report.html:    LANGUAGE plpgsql
+./test-output/emailable-report.html:    LANGUAGE plpgsql
+./test-output/emailable-report.html:    LANGUAGE plpgsql
+./test-output/emailable-report.html:    LANGUAGE plpgsql
+./test-output/emailable-report.html:    LANGUAGE plpgsql
+./test-output/emailable-report.html:    LANGUAGE plpgsql
+./test-output/emailable-report.html:    LANGUAGE plpgsql
+./test-output/emailable-report.html:    LANGUAGE plpgsql
+./test-output/emailable-report.html:    LANGUAGE plpgsql
+./test-output/emailable-report.html:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql</p>
+./test-output/emailable-report.html:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql;
+./test-output/emailable-report.html:    LANGUAGE plpgsql
+./test-output/emailable-report.html:    LANGUAGE plpgsql
+./test-output/emailable-report.html:    LANGUAGE plpgsql
+./test-output/emailable-report.html:    LANGUAGE plpgsql
+./test-output/emailable-report.html:    LANGUAGE plpgsql
+./test-output/emailable-report.html:    LANGUAGE plpgsql
+./test-output/emailable-report.html:    LANGUAGE plpgsql
+./test-output/emailable-report.html:    LANGUAGE plpgsql
+./test-output/emailable-report.html:    LANGUAGE plpgsql
+./test-output/emailable-report.html:    LANGUAGE plpgsql
+./test-output/emailable-report.html:    LANGUAGE plpgsql
+./test-output/emailable-report.html:    LANGUAGE plpgsql
+./test-output/emailable-report.html:    LANGUAGE plpgsql
+./test-output/emailable-report.html:    LANGUAGE plpgsql
+./test-output/emailable-report.html:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql</p>
+./test-output/emailable-report.html:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql;
+./test-output/emailable-report.html:    LANGUAGE plpgsql
+./test-output/emailable-report.html:    LANGUAGE plpgsql
+./test-output/emailable-report.html:    LANGUAGE plpgsql
+./test-output/emailable-report.html:    LANGUAGE plpgsql
+./test-output/emailable-report.html:    LANGUAGE plpgsql
+./test-output/emailable-report.html:    LANGUAGE plpgsql
+./test-output/emailable-report.html:    LANGUAGE plpgsql
+./test-output/emailable-report.html:    LANGUAGE plpgsql
+./test-output/emailable-report.html:    LANGUAGE plpgsql
+./test-output/emailable-report.html:    LANGUAGE plpgsql
+./test-output/emailable-report.html:    LANGUAGE plpgsql
+./test-output/emailable-report.html:    LANGUAGE plpgsql
+./test-output/emailable-report.html:    LANGUAGE plpgsql
+./test-output/emailable-report.html:    LANGUAGE plpgsql
+./test-output/emailable-report.html:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql</p>
+./test-output/emailable-report.html:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql;
+./test-output/emailable-report.html:    LANGUAGE plpgsql
+./test-output/emailable-report.html:    LANGUAGE plpgsql
+./test-output/emailable-report.html:    LANGUAGE plpgsql
+./test-output/emailable-report.html:    LANGUAGE plpgsql
+./test-output/emailable-report.html:    LANGUAGE plpgsql
+./test-output/emailable-report.html:    LANGUAGE plpgsql
+./test-output/emailable-report.html:    LANGUAGE plpgsql
+./test-output/emailable-report.html:    LANGUAGE plpgsql
+./test-output/emailable-report.html:    LANGUAGE plpgsql
+./test-output/emailable-report.html:    LANGUAGE plpgsql
+./test-output/emailable-report.html:    LANGUAGE plpgsql
+./test-output/emailable-report.html:    LANGUAGE plpgsql
+./test-output/emailable-report.html:    LANGUAGE plpgsql
+./test-output/emailable-report.html:    LANGUAGE plpgsql
+./test-output/emailable-report.html:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql</p>
+./test-output/emailable-report.html:<p>Caused by ERROR: must be owner of language plpgsql</p>
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.common.entity.SecondaryEntityListingQueryTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql;
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.common.entity.SecondaryEntityListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.common.entity.SecondaryEntityListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.common.entity.SecondaryEntityListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.common.entity.SecondaryEntityListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.common.entity.SecondaryEntityListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.common.entity.SecondaryEntityListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.common.entity.SecondaryEntityListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.common.entity.SecondaryEntityListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.common.entity.SecondaryEntityListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.common.entity.SecondaryEntityListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.common.entity.SecondaryEntityListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.common.entity.SecondaryEntityListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.common.entity.SecondaryEntityListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.common.entity.SecondaryEntityListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.common.entity.SecondaryEntityListingQueryTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.common.entity.SecondaryEntityListingQueryTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql;
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.common.entity.SecondaryEntityListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.common.entity.SecondaryEntityListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.common.entity.SecondaryEntityListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.common.entity.SecondaryEntityListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.common.entity.SecondaryEntityListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.common.entity.SecondaryEntityListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.common.entity.SecondaryEntityListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.common.entity.SecondaryEntityListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.common.entity.SecondaryEntityListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.common.entity.SecondaryEntityListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.common.entity.SecondaryEntityListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.common.entity.SecondaryEntityListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.common.entity.SecondaryEntityListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.common.entity.SecondaryEntityListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.common.entity.SecondaryEntityListingQueryTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.common.entity.SecondaryEntityListingQueryTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql;
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.common.entity.SecondaryEntityListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.common.entity.SecondaryEntityListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.common.entity.SecondaryEntityListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.common.entity.SecondaryEntityListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.common.entity.SecondaryEntityListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.common.entity.SecondaryEntityListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.common.entity.SecondaryEntityListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.common.entity.SecondaryEntityListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.common.entity.SecondaryEntityListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.common.entity.SecondaryEntityListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.common.entity.SecondaryEntityListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.common.entity.SecondaryEntityListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.common.entity.SecondaryEntityListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.common.entity.SecondaryEntityListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.common.entity.SecondaryEntityListingQueryTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.common.entity.SecondaryEntityListingQueryTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql;
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.common.entity.SecondaryEntityListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.common.entity.SecondaryEntityListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.common.entity.SecondaryEntityListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.common.entity.SecondaryEntityListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.common.entity.SecondaryEntityListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.common.entity.SecondaryEntityListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.common.entity.SecondaryEntityListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.common.entity.SecondaryEntityListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.common.entity.SecondaryEntityListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.common.entity.SecondaryEntityListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.common.entity.SecondaryEntityListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.common.entity.SecondaryEntityListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.common.entity.SecondaryEntityListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.common.entity.SecondaryEntityListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.common.entity.SecondaryEntityListingQueryTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.common.entity.SecondaryEntityListingQueryTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql;
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.common.entity.SecondaryEntityListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.common.entity.SecondaryEntityListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.common.entity.SecondaryEntityListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.common.entity.SecondaryEntityListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.common.entity.SecondaryEntityListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.common.entity.SecondaryEntityListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.common.entity.SecondaryEntityListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.common.entity.SecondaryEntityListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.common.entity.SecondaryEntityListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.common.entity.SecondaryEntityListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.common.entity.SecondaryEntityListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.common.entity.SecondaryEntityListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.common.entity.SecondaryEntityListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.common.entity.SecondaryEntityListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.common.entity.SecondaryEntityListingQueryTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.common.entity.SecondaryEntityListingQueryTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql;
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.common.entity.SecondaryEntityListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.common.entity.SecondaryEntityListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.common.entity.SecondaryEntityListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.common.entity.SecondaryEntityListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.common.entity.SecondaryEntityListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.common.entity.SecondaryEntityListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.common.entity.SecondaryEntityListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.common.entity.SecondaryEntityListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.common.entity.SecondaryEntityListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.common.entity.SecondaryEntityListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.common.entity.SecondaryEntityListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.common.entity.SecondaryEntityListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.common.entity.SecondaryEntityListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.common.entity.SecondaryEntityListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.common.entity.SecondaryEntityListingQueryTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.common.entity.SecondaryEntityListingQueryTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql;
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.common.entity.SecondaryEntityListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.common.entity.SecondaryEntityListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.common.entity.SecondaryEntityListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.common.entity.SecondaryEntityListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.common.entity.SecondaryEntityListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.common.entity.SecondaryEntityListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.common.entity.SecondaryEntityListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.common.entity.SecondaryEntityListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.common.entity.SecondaryEntityListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.common.entity.SecondaryEntityListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.common.entity.SecondaryEntityListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.common.entity.SecondaryEntityListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.common.entity.SecondaryEntityListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.common.entity.SecondaryEntityListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.common.entity.SecondaryEntityListingQueryTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.common.entity.SecondaryEntityListingQueryTest.xml:Caused by: org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.common.entity.SecondaryEntityListingQueryTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql;
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.common.entity.SecondaryEntityListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.common.entity.SecondaryEntityListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.common.entity.SecondaryEntityListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.common.entity.SecondaryEntityListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.common.entity.SecondaryEntityListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.common.entity.SecondaryEntityListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.common.entity.SecondaryEntityListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.common.entity.SecondaryEntityListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.common.entity.SecondaryEntityListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.common.entity.SecondaryEntityListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.common.entity.SecondaryEntityListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.common.entity.SecondaryEntityListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.common.entity.SecondaryEntityListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.common.entity.SecondaryEntityListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.common.entity.SecondaryEntityListingQueryTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.common.entity.SecondaryEntityListingQueryTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql;
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.common.entity.SecondaryEntityListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.common.entity.SecondaryEntityListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.common.entity.SecondaryEntityListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.common.entity.SecondaryEntityListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.common.entity.SecondaryEntityListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.common.entity.SecondaryEntityListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.common.entity.SecondaryEntityListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.common.entity.SecondaryEntityListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.common.entity.SecondaryEntityListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.common.entity.SecondaryEntityListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.common.entity.SecondaryEntityListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.common.entity.SecondaryEntityListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.common.entity.SecondaryEntityListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.common.entity.SecondaryEntityListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.common.entity.SecondaryEntityListingQueryTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.common.entity.SecondaryEntityListingQueryTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql;
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.common.entity.SecondaryEntityListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.common.entity.SecondaryEntityListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.common.entity.SecondaryEntityListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.common.entity.SecondaryEntityListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.common.entity.SecondaryEntityListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.common.entity.SecondaryEntityListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.common.entity.SecondaryEntityListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.common.entity.SecondaryEntityListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.common.entity.SecondaryEntityListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.common.entity.SecondaryEntityListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.common.entity.SecondaryEntityListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.common.entity.SecondaryEntityListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.common.entity.SecondaryEntityListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.common.entity.SecondaryEntityListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.common.entity.SecondaryEntityListingQueryTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.common.entity.SecondaryEntityListingQueryTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql;
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.common.entity.SecondaryEntityListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.common.entity.SecondaryEntityListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.common.entity.SecondaryEntityListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.common.entity.SecondaryEntityListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.common.entity.SecondaryEntityListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.common.entity.SecondaryEntityListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.common.entity.SecondaryEntityListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.common.entity.SecondaryEntityListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.common.entity.SecondaryEntityListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.common.entity.SecondaryEntityListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.common.entity.SecondaryEntityListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.common.entity.SecondaryEntityListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.common.entity.SecondaryEntityListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.common.entity.SecondaryEntityListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.common.entity.SecondaryEntityListingQueryTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.common.entity.SecondaryEntityListingQueryTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql;
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.common.entity.SecondaryEntityListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.common.entity.SecondaryEntityListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.common.entity.SecondaryEntityListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.common.entity.SecondaryEntityListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.common.entity.SecondaryEntityListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.common.entity.SecondaryEntityListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.common.entity.SecondaryEntityListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.common.entity.SecondaryEntityListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.common.entity.SecondaryEntityListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.common.entity.SecondaryEntityListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.common.entity.SecondaryEntityListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.common.entity.SecondaryEntityListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.common.entity.SecondaryEntityListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.common.entity.SecondaryEntityListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.common.entity.SecondaryEntityListingQueryTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.common.entity.SecondaryEntityListingQueryTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql;
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.common.entity.SecondaryEntityListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.common.entity.SecondaryEntityListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.common.entity.SecondaryEntityListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.common.entity.SecondaryEntityListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.common.entity.SecondaryEntityListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.common.entity.SecondaryEntityListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.common.entity.SecondaryEntityListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.common.entity.SecondaryEntityListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.common.entity.SecondaryEntityListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.common.entity.SecondaryEntityListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.common.entity.SecondaryEntityListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.common.entity.SecondaryEntityListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.common.entity.SecondaryEntityListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.common.entity.SecondaryEntityListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.common.entity.SecondaryEntityListingQueryTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.common.entity.SecondaryEntityListingQueryTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql;
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.common.entity.SecondaryEntityListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.common.entity.SecondaryEntityListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.common.entity.SecondaryEntityListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.common.entity.SecondaryEntityListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.common.entity.SecondaryEntityListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.common.entity.SecondaryEntityListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.common.entity.SecondaryEntityListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.common.entity.SecondaryEntityListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.common.entity.SecondaryEntityListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.common.entity.SecondaryEntityListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.common.entity.SecondaryEntityListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.common.entity.SecondaryEntityListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.common.entity.SecondaryEntityListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.common.entity.SecondaryEntityListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.common.entity.SecondaryEntityListingQueryTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.common.entity.SecondaryEntityListingQueryTest.xml:Caused by: org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.common.entity.SecondaryEntityListingQueryTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql;
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.common.entity.SecondaryEntityListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.common.entity.SecondaryEntityListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.common.entity.SecondaryEntityListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.common.entity.SecondaryEntityListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.common.entity.SecondaryEntityListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.common.entity.SecondaryEntityListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.common.entity.SecondaryEntityListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.common.entity.SecondaryEntityListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.common.entity.SecondaryEntityListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.common.entity.SecondaryEntityListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.common.entity.SecondaryEntityListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.common.entity.SecondaryEntityListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.common.entity.SecondaryEntityListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.common.entity.SecondaryEntityListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.common.entity.SecondaryEntityListingQueryTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.common.entity.SecondaryEntityListingQueryTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql;
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.common.entity.SecondaryEntityListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.common.entity.SecondaryEntityListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.common.entity.SecondaryEntityListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.common.entity.SecondaryEntityListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.common.entity.SecondaryEntityListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.common.entity.SecondaryEntityListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.common.entity.SecondaryEntityListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.common.entity.SecondaryEntityListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.common.entity.SecondaryEntityListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.common.entity.SecondaryEntityListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.common.entity.SecondaryEntityListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.common.entity.SecondaryEntityListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.common.entity.SecondaryEntityListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.common.entity.SecondaryEntityListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.common.entity.SecondaryEntityListingQueryTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.common.entity.SecondaryEntityListingQueryTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql;
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.common.entity.SecondaryEntityListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.common.entity.SecondaryEntityListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.common.entity.SecondaryEntityListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.common.entity.SecondaryEntityListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.common.entity.SecondaryEntityListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.common.entity.SecondaryEntityListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.common.entity.SecondaryEntityListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.common.entity.SecondaryEntityListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.common.entity.SecondaryEntityListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.common.entity.SecondaryEntityListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.common.entity.SecondaryEntityListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.common.entity.SecondaryEntityListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.common.entity.SecondaryEntityListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.common.entity.SecondaryEntityListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.common.entity.SecondaryEntityListingQueryTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.common.entity.SecondaryEntityListingQueryTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql;
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.common.entity.SecondaryEntityListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.common.entity.SecondaryEntityListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.common.entity.SecondaryEntityListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.common.entity.SecondaryEntityListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.common.entity.SecondaryEntityListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.common.entity.SecondaryEntityListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.common.entity.SecondaryEntityListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.common.entity.SecondaryEntityListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.common.entity.SecondaryEntityListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.common.entity.SecondaryEntityListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.common.entity.SecondaryEntityListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.common.entity.SecondaryEntityListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.common.entity.SecondaryEntityListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.common.entity.SecondaryEntityListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.common.entity.SecondaryEntityListingQueryTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.common.entity.SecondaryEntityListingQueryTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql;
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.common.entity.SecondaryEntityListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.common.entity.SecondaryEntityListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.common.entity.SecondaryEntityListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.common.entity.SecondaryEntityListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.common.entity.SecondaryEntityListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.common.entity.SecondaryEntityListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.common.entity.SecondaryEntityListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.common.entity.SecondaryEntityListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.common.entity.SecondaryEntityListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.common.entity.SecondaryEntityListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.common.entity.SecondaryEntityListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.common.entity.SecondaryEntityListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.common.entity.SecondaryEntityListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.common.entity.SecondaryEntityListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.common.entity.SecondaryEntityListingQueryTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.common.entity.SecondaryEntityListingQueryTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql;
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.common.entity.SecondaryEntityListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.common.entity.SecondaryEntityListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.common.entity.SecondaryEntityListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.common.entity.SecondaryEntityListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.common.entity.SecondaryEntityListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.common.entity.SecondaryEntityListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.common.entity.SecondaryEntityListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.common.entity.SecondaryEntityListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.common.entity.SecondaryEntityListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.common.entity.SecondaryEntityListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.common.entity.SecondaryEntityListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.common.entity.SecondaryEntityListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.common.entity.SecondaryEntityListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.common.entity.SecondaryEntityListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.common.entity.SecondaryEntityListingQueryTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.common.entity.SecondaryEntityListingQueryTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql;
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.common.entity.SecondaryEntityListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.common.entity.SecondaryEntityListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.common.entity.SecondaryEntityListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.common.entity.SecondaryEntityListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.common.entity.SecondaryEntityListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.common.entity.SecondaryEntityListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.common.entity.SecondaryEntityListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.common.entity.SecondaryEntityListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.common.entity.SecondaryEntityListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.common.entity.SecondaryEntityListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.common.entity.SecondaryEntityListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.common.entity.SecondaryEntityListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.common.entity.SecondaryEntityListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.common.entity.SecondaryEntityListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.common.entity.SecondaryEntityListingQueryTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.common.entity.SecondaryEntityListingQueryTest.xml:Caused by: org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.common.entity.SecondaryEntityListingQueryTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql;
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.common.entity.SecondaryEntityListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.common.entity.SecondaryEntityListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.common.entity.SecondaryEntityListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.common.entity.SecondaryEntityListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.common.entity.SecondaryEntityListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.common.entity.SecondaryEntityListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.common.entity.SecondaryEntityListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.common.entity.SecondaryEntityListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.common.entity.SecondaryEntityListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.common.entity.SecondaryEntityListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.common.entity.SecondaryEntityListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.common.entity.SecondaryEntityListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.common.entity.SecondaryEntityListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.common.entity.SecondaryEntityListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.common.entity.SecondaryEntityListingQueryTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.common.entity.SecondaryEntityListingQueryTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql;
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.common.entity.SecondaryEntityListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.common.entity.SecondaryEntityListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.common.entity.SecondaryEntityListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.common.entity.SecondaryEntityListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.common.entity.SecondaryEntityListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.common.entity.SecondaryEntityListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.common.entity.SecondaryEntityListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.common.entity.SecondaryEntityListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.common.entity.SecondaryEntityListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.common.entity.SecondaryEntityListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.common.entity.SecondaryEntityListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.common.entity.SecondaryEntityListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.common.entity.SecondaryEntityListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.common.entity.SecondaryEntityListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.common.entity.SecondaryEntityListingQueryTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.common.entity.SecondaryEntityListingQueryTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql;
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.common.entity.SecondaryEntityListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.common.entity.SecondaryEntityListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.common.entity.SecondaryEntityListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.common.entity.SecondaryEntityListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.common.entity.SecondaryEntityListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.common.entity.SecondaryEntityListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.common.entity.SecondaryEntityListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.common.entity.SecondaryEntityListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.common.entity.SecondaryEntityListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.common.entity.SecondaryEntityListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.common.entity.SecondaryEntityListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.common.entity.SecondaryEntityListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.common.entity.SecondaryEntityListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.common.entity.SecondaryEntityListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.common.entity.SecondaryEntityListingQueryTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.common.entity.SecondaryEntityListingQueryTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql;
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.common.entity.SecondaryEntityListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.common.entity.SecondaryEntityListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.common.entity.SecondaryEntityListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.common.entity.SecondaryEntityListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.common.entity.SecondaryEntityListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.common.entity.SecondaryEntityListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.common.entity.SecondaryEntityListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.common.entity.SecondaryEntityListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.common.entity.SecondaryEntityListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.common.entity.SecondaryEntityListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.common.entity.SecondaryEntityListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.common.entity.SecondaryEntityListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.common.entity.SecondaryEntityListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.common.entity.SecondaryEntityListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.common.entity.SecondaryEntityListingQueryTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.common.entity.SecondaryEntityListingQueryTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql;
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.common.entity.SecondaryEntityListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.common.entity.SecondaryEntityListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.common.entity.SecondaryEntityListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.common.entity.SecondaryEntityListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.common.entity.SecondaryEntityListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.common.entity.SecondaryEntityListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.common.entity.SecondaryEntityListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.common.entity.SecondaryEntityListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.common.entity.SecondaryEntityListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.common.entity.SecondaryEntityListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.common.entity.SecondaryEntityListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.common.entity.SecondaryEntityListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.common.entity.SecondaryEntityListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.common.entity.SecondaryEntityListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.common.entity.SecondaryEntityListingQueryTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.common.entity.SecondaryEntityListingQueryTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql;
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.common.entity.SecondaryEntityListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.common.entity.SecondaryEntityListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.common.entity.SecondaryEntityListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.common.entity.SecondaryEntityListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.common.entity.SecondaryEntityListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.common.entity.SecondaryEntityListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.common.entity.SecondaryEntityListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.common.entity.SecondaryEntityListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.common.entity.SecondaryEntityListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.common.entity.SecondaryEntityListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.common.entity.SecondaryEntityListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.common.entity.SecondaryEntityListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.common.entity.SecondaryEntityListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.common.entity.SecondaryEntityListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.common.entity.SecondaryEntityListingQueryTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.common.entity.SecondaryEntityListingQueryTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql;
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.common.entity.SecondaryEntityListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.common.entity.SecondaryEntityListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.common.entity.SecondaryEntityListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.common.entity.SecondaryEntityListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.common.entity.SecondaryEntityListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.common.entity.SecondaryEntityListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.common.entity.SecondaryEntityListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.common.entity.SecondaryEntityListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.common.entity.SecondaryEntityListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.common.entity.SecondaryEntityListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.common.entity.SecondaryEntityListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.common.entity.SecondaryEntityListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.common.entity.SecondaryEntityListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.common.entity.SecondaryEntityListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.common.entity.SecondaryEntityListingQueryTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.common.entity.SecondaryEntityListingQueryTest.xml:Caused by: org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListerTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql;
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListerTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListerTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListerTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListerTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListerTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListerTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListerTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListerTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListerTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListerTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListerTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListerTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListerTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListerTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListerTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListerTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql;
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListerTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListerTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListerTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListerTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListerTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListerTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListerTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListerTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListerTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListerTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListerTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListerTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListerTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListerTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListerTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListerTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql;
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListerTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListerTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListerTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListerTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListerTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListerTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListerTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListerTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListerTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListerTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListerTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListerTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListerTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListerTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListerTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListerTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql;
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListerTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListerTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListerTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListerTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListerTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListerTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListerTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListerTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListerTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListerTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListerTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListerTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListerTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListerTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListerTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListerTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql;
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListerTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListerTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListerTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListerTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListerTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListerTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListerTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListerTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListerTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListerTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListerTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListerTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListerTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListerTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListerTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListerTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql;
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListerTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListerTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListerTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListerTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListerTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListerTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListerTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListerTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListerTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListerTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListerTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListerTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListerTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListerTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListerTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListerTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql;
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListerTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListerTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListerTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListerTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListerTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListerTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListerTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListerTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListerTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListerTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListerTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListerTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListerTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListerTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListerTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListerTest.xml:Caused by: org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListerTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql;
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListerTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListerTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListerTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListerTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListerTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListerTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListerTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListerTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListerTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListerTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListerTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListerTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListerTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListerTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListerTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListerTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql;
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListerTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListerTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListerTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListerTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListerTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListerTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListerTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListerTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListerTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListerTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListerTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListerTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListerTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListerTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListerTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListerTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql;
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListerTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListerTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListerTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListerTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListerTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListerTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListerTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListerTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListerTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListerTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListerTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListerTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListerTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListerTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListerTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListerTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql;
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListerTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListerTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListerTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListerTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListerTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListerTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListerTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListerTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListerTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListerTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListerTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListerTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListerTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListerTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListerTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListerTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql;
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListerTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListerTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListerTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListerTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListerTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListerTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListerTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListerTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListerTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListerTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListerTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListerTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListerTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListerTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListerTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListerTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql;
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListerTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListerTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListerTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListerTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListerTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListerTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListerTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListerTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListerTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListerTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListerTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListerTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListerTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListerTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListerTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListerTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql;
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListerTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListerTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListerTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListerTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListerTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListerTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListerTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListerTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListerTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListerTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListerTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListerTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListerTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListerTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListerTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListerTest.xml:Caused by: org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListerTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql;
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListerTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListerTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListerTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListerTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListerTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListerTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListerTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListerTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListerTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListerTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListerTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListerTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListerTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListerTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListerTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListerTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql;
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListerTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListerTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListerTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListerTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListerTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListerTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListerTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListerTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListerTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListerTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListerTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListerTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListerTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListerTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListerTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListerTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql;
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListerTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListerTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListerTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListerTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListerTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListerTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListerTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListerTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListerTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListerTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListerTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListerTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListerTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListerTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListerTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListerTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql;
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListerTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListerTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListerTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListerTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListerTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListerTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListerTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListerTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListerTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListerTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListerTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListerTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListerTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListerTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListerTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListerTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql;
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListerTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListerTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListerTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListerTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListerTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListerTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListerTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListerTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListerTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListerTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListerTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListerTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListerTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListerTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListerTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListerTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql;
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListerTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListerTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListerTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListerTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListerTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListerTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListerTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListerTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListerTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListerTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListerTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListerTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListerTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListerTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListerTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListerTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql;
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListerTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListerTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListerTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListerTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListerTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListerTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListerTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListerTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListerTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListerTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListerTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListerTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListerTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListerTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListerTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListerTest.xml:Caused by: org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListerTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql;
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListerTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListerTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListerTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListerTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListerTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListerTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListerTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListerTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListerTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListerTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListerTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListerTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListerTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListerTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListerTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListerTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql;
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListerTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListerTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListerTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListerTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListerTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListerTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListerTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListerTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListerTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListerTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListerTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListerTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListerTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListerTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListerTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListerTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql;
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListerTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListerTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListerTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListerTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListerTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListerTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListerTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListerTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListerTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListerTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListerTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListerTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListerTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListerTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListerTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListerTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql;
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListerTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListerTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListerTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListerTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListerTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListerTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListerTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListerTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListerTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListerTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListerTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListerTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListerTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListerTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListerTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListerTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql;
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListerTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListerTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListerTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListerTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListerTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListerTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListerTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListerTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListerTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListerTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListerTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListerTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListerTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListerTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListerTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListerTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql;
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListerTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListerTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListerTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListerTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListerTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListerTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListerTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListerTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListerTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListerTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListerTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListerTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListerTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListerTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListerTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListerTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql;
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListerTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListerTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListerTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListerTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListerTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListerTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListerTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListerTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListerTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListerTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListerTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListerTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListerTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListerTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListerTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListerTest.xml:Caused by: org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListerTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql;
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListerTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListerTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListerTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListerTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListerTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListerTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListerTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListerTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListerTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListerTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListerTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListerTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListerTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListerTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListerTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListerTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql;
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListerTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListerTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListerTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListerTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListerTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListerTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListerTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListerTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListerTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListerTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListerTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListerTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListerTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListerTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListerTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListerTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql;
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListerTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListerTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListerTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListerTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListerTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListerTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListerTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListerTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListerTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListerTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListerTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListerTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListerTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListerTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListerTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListerTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql;
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListerTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListerTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListerTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListerTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListerTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListerTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListerTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListerTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListerTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListerTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListerTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListerTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListerTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListerTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListerTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListerTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql;
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListerTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListerTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListerTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListerTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListerTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListerTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListerTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListerTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListerTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListerTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListerTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListerTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListerTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListerTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListerTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListerTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql;
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListerTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListerTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListerTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListerTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListerTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListerTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListerTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListerTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListerTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListerTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListerTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListerTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListerTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListerTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListerTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListerTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql;
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListerTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListerTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListerTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListerTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListerTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListerTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListerTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListerTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListerTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListerTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListerTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListerTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListerTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListerTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListerTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListerTest.xml:Caused by: org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListerTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql;
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListerTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListerTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListerTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListerTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListerTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListerTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListerTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListerTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListerTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListerTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListerTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListerTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListerTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListerTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListerTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListerTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql;
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListerTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListerTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListerTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListerTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListerTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListerTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListerTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListerTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListerTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListerTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListerTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListerTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListerTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListerTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListerTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListerTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql;
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListerTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListerTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListerTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListerTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListerTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListerTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListerTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListerTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListerTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListerTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListerTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListerTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListerTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListerTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListerTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListerTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql;
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListerTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListerTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListerTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListerTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListerTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListerTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListerTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListerTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListerTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListerTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListerTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListerTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListerTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListerTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListerTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListerTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql;
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListerTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListerTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListerTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListerTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListerTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListerTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListerTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListerTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListerTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListerTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListerTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListerTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListerTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListerTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListerTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListerTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql;
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListerTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListerTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListerTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListerTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListerTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListerTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListerTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListerTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListerTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListerTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListerTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListerTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListerTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListerTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListerTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListerTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql;
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListerTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListerTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListerTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListerTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListerTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListerTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListerTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListerTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListerTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListerTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListerTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListerTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListerTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListerTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListerTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListerTest.xml:Caused by: org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListerTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql;
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListerTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListerTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListerTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListerTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListerTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListerTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListerTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListerTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListerTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListerTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListerTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListerTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListerTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListerTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListerTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListerTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql;
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListerTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListerTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListerTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListerTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListerTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListerTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListerTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListerTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListerTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListerTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListerTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListerTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListerTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListerTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListerTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListerTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql;
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListerTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListerTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListerTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListerTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListerTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListerTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListerTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListerTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListerTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListerTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListerTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListerTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListerTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListerTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListerTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListerTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql;
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListerTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListerTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListerTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListerTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListerTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListerTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListerTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListerTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListerTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListerTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListerTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListerTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListerTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListerTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListerTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListerTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql;
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListerTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListerTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListerTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListerTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListerTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListerTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListerTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListerTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListerTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListerTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListerTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListerTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListerTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListerTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListerTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListerTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql;
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListerTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListerTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListerTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListerTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListerTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListerTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListerTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListerTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListerTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListerTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListerTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListerTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListerTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListerTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListerTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListerTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql;
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListerTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListerTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListerTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListerTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListerTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListerTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListerTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListerTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListerTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListerTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListerTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListerTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListerTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListerTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListerTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListerTest.xml:Caused by: org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListerTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql;
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListerTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListerTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListerTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListerTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListerTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListerTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListerTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListerTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListerTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListerTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListerTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListerTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListerTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListerTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListerTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListerTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql;
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListerTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListerTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListerTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListerTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListerTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListerTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListerTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListerTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListerTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListerTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListerTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListerTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListerTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListerTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListerTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListerTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql;
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListerTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListerTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListerTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListerTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListerTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListerTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListerTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListerTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListerTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListerTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListerTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListerTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListerTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListerTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListerTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListerTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql;
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListerTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListerTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListerTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListerTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListerTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListerTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListerTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListerTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListerTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListerTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListerTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListerTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListerTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListerTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListerTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListerTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql;
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListerTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListerTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListerTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListerTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListerTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListerTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListerTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListerTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListerTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListerTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListerTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListerTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListerTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListerTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListerTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListerTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql;
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListerTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListerTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListerTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListerTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListerTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListerTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListerTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListerTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListerTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListerTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListerTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListerTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListerTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListerTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListerTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListerTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql;
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListerTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListerTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListerTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListerTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListerTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListerTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListerTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListerTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListerTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListerTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListerTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListerTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListerTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListerTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListerTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListerTest.xml:Caused by: org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListerTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql;
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListerTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListerTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListerTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListerTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListerTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListerTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListerTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListerTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListerTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListerTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListerTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListerTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListerTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListerTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListerTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListerTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql;
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListerTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListerTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListerTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListerTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListerTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListerTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListerTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListerTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListerTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListerTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListerTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListerTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListerTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListerTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListerTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListerTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql;
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListerTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListerTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListerTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListerTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListerTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListerTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListerTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListerTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListerTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListerTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListerTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListerTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListerTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListerTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListerTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListerTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql;
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListerTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListerTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListerTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListerTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListerTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListerTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListerTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListerTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListerTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListerTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListerTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListerTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListerTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListerTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListerTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListerTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql;
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListerTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListerTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListerTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListerTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListerTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListerTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListerTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListerTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListerTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListerTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListerTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListerTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListerTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListerTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListerTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListerTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql;
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListerTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListerTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListerTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListerTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListerTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListerTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListerTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListerTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListerTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListerTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListerTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListerTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListerTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListerTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListerTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListerTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql;
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListerTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListerTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListerTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListerTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListerTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListerTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListerTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListerTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListerTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListerTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListerTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListerTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListerTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListerTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListerTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListerTest.xml:Caused by: org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListerTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql;
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListerTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListerTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListerTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListerTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListerTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListerTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListerTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListerTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListerTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListerTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListerTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListerTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListerTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListerTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListerTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListerTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql;
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListerTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListerTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListerTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListerTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListerTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListerTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListerTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListerTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListerTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListerTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListerTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListerTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListerTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListerTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListerTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListerTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql;
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListerTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListerTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListerTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListerTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListerTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListerTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListerTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListerTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListerTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListerTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListerTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListerTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListerTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListerTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListerTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListerTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql;
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListerTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListerTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListerTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListerTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListerTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListerTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListerTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListerTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListerTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListerTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListerTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListerTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListerTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListerTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListerTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListerTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql;
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListerTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListerTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListerTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListerTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListerTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListerTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListerTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListerTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListerTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListerTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListerTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListerTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListerTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListerTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListerTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListerTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql;
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListerTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListerTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListerTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListerTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListerTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListerTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListerTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListerTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListerTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListerTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListerTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListerTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListerTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListerTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListerTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListerTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql;
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListerTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListerTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListerTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListerTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListerTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListerTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListerTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListerTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListerTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListerTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListerTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListerTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListerTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListerTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListerTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListerTest.xml:Caused by: org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListerTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql;
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListerTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListerTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListerTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListerTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListerTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListerTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListerTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListerTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListerTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListerTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListerTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListerTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListerTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListerTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListerTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListerTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql;
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListerTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListerTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListerTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListerTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListerTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListerTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListerTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListerTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListerTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListerTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListerTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListerTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListerTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListerTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListerTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListerTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql;
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListerTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListerTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListerTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListerTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListerTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListerTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListerTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListerTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListerTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListerTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListerTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListerTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListerTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListerTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListerTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListerTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql;
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListerTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListerTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListerTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListerTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListerTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListerTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListerTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListerTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListerTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListerTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListerTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListerTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListerTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListerTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListerTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListerTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql;
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListerTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListerTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListerTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListerTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListerTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListerTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListerTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListerTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListerTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListerTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListerTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListerTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListerTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListerTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListerTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListerTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql;
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListerTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListerTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListerTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListerTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListerTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListerTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListerTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListerTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListerTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListerTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListerTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListerTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListerTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListerTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListerTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListerTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql;
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListerTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListerTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListerTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListerTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListerTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListerTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListerTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListerTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListerTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListerTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListerTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListerTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListerTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListerTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListerTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListerTest.xml:Caused by: org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListerTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql;
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListerTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListerTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListerTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListerTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListerTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListerTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListerTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListerTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListerTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListerTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListerTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListerTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListerTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListerTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListerTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListerTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql;
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListerTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListerTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListerTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListerTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListerTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListerTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListerTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListerTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListerTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListerTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListerTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListerTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListerTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListerTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListerTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListerTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql;
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListerTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListerTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListerTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListerTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListerTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListerTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListerTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListerTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListerTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListerTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListerTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListerTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListerTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListerTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListerTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListerTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql;
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListerTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListerTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListerTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListerTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListerTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListerTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListerTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListerTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListerTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListerTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListerTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListerTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListerTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListerTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListerTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListerTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql;
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListerTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListerTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListerTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListerTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListerTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListerTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListerTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListerTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListerTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListerTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListerTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListerTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListerTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListerTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListerTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListerTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql;
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListerTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListerTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListerTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListerTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListerTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListerTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListerTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListerTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListerTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListerTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListerTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListerTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListerTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListerTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListerTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListerTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql;
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListerTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListerTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListerTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListerTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListerTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListerTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListerTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListerTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListerTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListerTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListerTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListerTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListerTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListerTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListerTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListerTest.xml:Caused by: org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListingQueryTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql;
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListingQueryTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListingQueryTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql;
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListingQueryTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListingQueryTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql;
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListingQueryTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListingQueryTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql;
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListingQueryTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListingQueryTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql;
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListingQueryTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListingQueryTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql;
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListingQueryTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListingQueryTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql;
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListingQueryTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListingQueryTest.xml:Caused by: org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListingQueryTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql;
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListingQueryTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListingQueryTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql;
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListingQueryTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListingQueryTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql;
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListingQueryTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListingQueryTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql;
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListingQueryTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListingQueryTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql;
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListingQueryTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListingQueryTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql;
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListingQueryTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListingQueryTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql;
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListingQueryTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListingQueryTest.xml:Caused by: org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListingQueryTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql;
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListingQueryTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListingQueryTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql;
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListingQueryTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListingQueryTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql;
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListingQueryTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListingQueryTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql;
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListingQueryTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListingQueryTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql;
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListingQueryTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListingQueryTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql;
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListingQueryTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListingQueryTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql;
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListingQueryTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListingQueryTest.xml:Caused by: org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListingQueryTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql;
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListingQueryTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListingQueryTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql;
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListingQueryTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListingQueryTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql;
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListingQueryTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListingQueryTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql;
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListingQueryTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListingQueryTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql;
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListingQueryTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListingQueryTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql;
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListingQueryTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListingQueryTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql;
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListingQueryTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListingQueryTest.xml:Caused by: org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListingQueryTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql;
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListingQueryTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListingQueryTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql;
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListingQueryTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListingQueryTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql;
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListingQueryTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListingQueryTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql;
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListingQueryTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListingQueryTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql;
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListingQueryTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListingQueryTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql;
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListingQueryTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListingQueryTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql;
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListingQueryTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListingQueryTest.xml:Caused by: org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListingQueryTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql;
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListingQueryTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListingQueryTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql;
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListingQueryTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListingQueryTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql;
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListingQueryTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListingQueryTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql;
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListingQueryTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListingQueryTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql;
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListingQueryTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListingQueryTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql;
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListingQueryTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListingQueryTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql;
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListingQueryTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListingQueryTest.xml:Caused by: org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListingQueryTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql;
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListingQueryTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListingQueryTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql;
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListingQueryTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListingQueryTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql;
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListingQueryTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListingQueryTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql;
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListingQueryTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListingQueryTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql;
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListingQueryTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListingQueryTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql;
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListingQueryTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListingQueryTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql;
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListingQueryTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListingQueryTest.xml:Caused by: org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListingQueryTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql;
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListingQueryTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListingQueryTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql;
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListingQueryTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListingQueryTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql;
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListingQueryTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListingQueryTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql;
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListingQueryTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListingQueryTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql;
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListingQueryTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListingQueryTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql;
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListingQueryTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListingQueryTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql;
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListingQueryTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListingQueryTest.xml:Caused by: org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListingQueryTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql;
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListingQueryTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListingQueryTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql;
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListingQueryTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListingQueryTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql;
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListingQueryTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListingQueryTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql;
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListingQueryTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListingQueryTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql;
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListingQueryTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListingQueryTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql;
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListingQueryTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListingQueryTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql;
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListingQueryTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListingQueryTest.xml:Caused by: org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListingQueryTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql;
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListingQueryTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListingQueryTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql;
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListingQueryTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListingQueryTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql;
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListingQueryTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListingQueryTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql;
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListingQueryTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListingQueryTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql;
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListingQueryTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListingQueryTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql;
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListingQueryTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListingQueryTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql;
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListingQueryTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListingQueryTest.xml:Caused by: org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListingQueryTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql;
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListingQueryTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListingQueryTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql;
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListingQueryTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListingQueryTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql;
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListingQueryTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListingQueryTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql;
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListingQueryTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListingQueryTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql;
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListingQueryTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListingQueryTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql;
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListingQueryTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListingQueryTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql;
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListingQueryTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetListingQueryTest.xml:Caused by: org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetSetListingQueryTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql;
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetSetListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetSetListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetSetListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetSetListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetSetListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetSetListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetSetListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetSetListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetSetListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetSetListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetSetListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetSetListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetSetListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetSetListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetSetListingQueryTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetSetListingQueryTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql;
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetSetListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetSetListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetSetListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetSetListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetSetListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetSetListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetSetListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetSetListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetSetListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetSetListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetSetListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetSetListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetSetListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetSetListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetSetListingQueryTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetSetListingQueryTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql;
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetSetListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetSetListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetSetListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetSetListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetSetListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetSetListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetSetListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetSetListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetSetListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetSetListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetSetListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetSetListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetSetListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetSetListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetSetListingQueryTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetSetListingQueryTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql;
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetSetListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetSetListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetSetListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetSetListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetSetListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetSetListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetSetListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetSetListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetSetListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetSetListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetSetListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetSetListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetSetListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetSetListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetSetListingQueryTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetSetListingQueryTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql;
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetSetListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetSetListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetSetListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetSetListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetSetListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetSetListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetSetListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetSetListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetSetListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetSetListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetSetListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetSetListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetSetListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetSetListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetSetListingQueryTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetSetListingQueryTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql;
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetSetListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetSetListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetSetListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetSetListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetSetListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetSetListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetSetListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetSetListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetSetListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetSetListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetSetListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetSetListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetSetListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetSetListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetSetListingQueryTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetSetListingQueryTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql;
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetSetListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetSetListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetSetListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetSetListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetSetListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetSetListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetSetListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetSetListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetSetListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetSetListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetSetListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetSetListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetSetListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetSetListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetSetListingQueryTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetSetListingQueryTest.xml:Caused by: org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetSetListingQueryTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql;
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetSetListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetSetListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetSetListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetSetListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetSetListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetSetListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetSetListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetSetListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetSetListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetSetListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetSetListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetSetListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetSetListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetSetListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetSetListingQueryTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetSetListingQueryTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql;
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetSetListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetSetListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetSetListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetSetListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetSetListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetSetListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetSetListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetSetListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetSetListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetSetListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetSetListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetSetListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetSetListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetSetListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetSetListingQueryTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetSetListingQueryTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql;
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetSetListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetSetListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetSetListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetSetListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetSetListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetSetListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetSetListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetSetListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetSetListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetSetListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetSetListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetSetListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetSetListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetSetListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetSetListingQueryTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetSetListingQueryTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql;
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetSetListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetSetListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetSetListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetSetListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetSetListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetSetListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetSetListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetSetListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetSetListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetSetListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetSetListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetSetListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetSetListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetSetListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetSetListingQueryTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetSetListingQueryTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql;
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetSetListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetSetListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetSetListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetSetListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetSetListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetSetListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetSetListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetSetListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetSetListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetSetListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetSetListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetSetListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetSetListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetSetListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetSetListingQueryTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetSetListingQueryTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql;
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetSetListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetSetListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetSetListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetSetListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetSetListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetSetListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetSetListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetSetListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetSetListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetSetListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetSetListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetSetListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetSetListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetSetListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetSetListingQueryTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetSetListingQueryTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql;
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetSetListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetSetListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetSetListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetSetListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetSetListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetSetListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetSetListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetSetListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetSetListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetSetListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetSetListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetSetListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetSetListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetSetListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetSetListingQueryTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.datasetlister.DatasetSetListingQueryTest.xml:Caused by: org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.materiallister.MaterialListerTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql;
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.materiallister.MaterialListerTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.materiallister.MaterialListerTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.materiallister.MaterialListerTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.materiallister.MaterialListerTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.materiallister.MaterialListerTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.materiallister.MaterialListerTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.materiallister.MaterialListerTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.materiallister.MaterialListerTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.materiallister.MaterialListerTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.materiallister.MaterialListerTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.materiallister.MaterialListerTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.materiallister.MaterialListerTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.materiallister.MaterialListerTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.materiallister.MaterialListerTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.materiallister.MaterialListerTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.materiallister.MaterialListerTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql;
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.materiallister.MaterialListerTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.materiallister.MaterialListerTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.materiallister.MaterialListerTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.materiallister.MaterialListerTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.materiallister.MaterialListerTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.materiallister.MaterialListerTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.materiallister.MaterialListerTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.materiallister.MaterialListerTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.materiallister.MaterialListerTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.materiallister.MaterialListerTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.materiallister.MaterialListerTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.materiallister.MaterialListerTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.materiallister.MaterialListerTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.materiallister.MaterialListerTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.materiallister.MaterialListerTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.materiallister.MaterialListerTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql;
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.materiallister.MaterialListerTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.materiallister.MaterialListerTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.materiallister.MaterialListerTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.materiallister.MaterialListerTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.materiallister.MaterialListerTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.materiallister.MaterialListerTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.materiallister.MaterialListerTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.materiallister.MaterialListerTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.materiallister.MaterialListerTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.materiallister.MaterialListerTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.materiallister.MaterialListerTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.materiallister.MaterialListerTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.materiallister.MaterialListerTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.materiallister.MaterialListerTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.materiallister.MaterialListerTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.materiallister.MaterialListerTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql;
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.materiallister.MaterialListerTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.materiallister.MaterialListerTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.materiallister.MaterialListerTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.materiallister.MaterialListerTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.materiallister.MaterialListerTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.materiallister.MaterialListerTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.materiallister.MaterialListerTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.materiallister.MaterialListerTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.materiallister.MaterialListerTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.materiallister.MaterialListerTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.materiallister.MaterialListerTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.materiallister.MaterialListerTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.materiallister.MaterialListerTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.materiallister.MaterialListerTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.materiallister.MaterialListerTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.materiallister.MaterialListerTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql;
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.materiallister.MaterialListerTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.materiallister.MaterialListerTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.materiallister.MaterialListerTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.materiallister.MaterialListerTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.materiallister.MaterialListerTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.materiallister.MaterialListerTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.materiallister.MaterialListerTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.materiallister.MaterialListerTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.materiallister.MaterialListerTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.materiallister.MaterialListerTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.materiallister.MaterialListerTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.materiallister.MaterialListerTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.materiallister.MaterialListerTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.materiallister.MaterialListerTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.materiallister.MaterialListerTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.materiallister.MaterialListerTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql;
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.materiallister.MaterialListerTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.materiallister.MaterialListerTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.materiallister.MaterialListerTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.materiallister.MaterialListerTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.materiallister.MaterialListerTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.materiallister.MaterialListerTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.materiallister.MaterialListerTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.materiallister.MaterialListerTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.materiallister.MaterialListerTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.materiallister.MaterialListerTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.materiallister.MaterialListerTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.materiallister.MaterialListerTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.materiallister.MaterialListerTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.materiallister.MaterialListerTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.materiallister.MaterialListerTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.materiallister.MaterialListerTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql;
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.materiallister.MaterialListerTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.materiallister.MaterialListerTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.materiallister.MaterialListerTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.materiallister.MaterialListerTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.materiallister.MaterialListerTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.materiallister.MaterialListerTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.materiallister.MaterialListerTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.materiallister.MaterialListerTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.materiallister.MaterialListerTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.materiallister.MaterialListerTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.materiallister.MaterialListerTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.materiallister.MaterialListerTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.materiallister.MaterialListerTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.materiallister.MaterialListerTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.materiallister.MaterialListerTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.materiallister.MaterialListerTest.xml:Caused by: org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.materiallister.MaterialListerTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql;
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.materiallister.MaterialListerTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.materiallister.MaterialListerTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.materiallister.MaterialListerTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.materiallister.MaterialListerTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.materiallister.MaterialListerTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.materiallister.MaterialListerTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.materiallister.MaterialListerTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.materiallister.MaterialListerTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.materiallister.MaterialListerTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.materiallister.MaterialListerTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.materiallister.MaterialListerTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.materiallister.MaterialListerTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.materiallister.MaterialListerTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.materiallister.MaterialListerTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.materiallister.MaterialListerTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.materiallister.MaterialListerTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql;
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.materiallister.MaterialListerTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.materiallister.MaterialListerTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.materiallister.MaterialListerTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.materiallister.MaterialListerTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.materiallister.MaterialListerTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.materiallister.MaterialListerTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.materiallister.MaterialListerTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.materiallister.MaterialListerTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.materiallister.MaterialListerTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.materiallister.MaterialListerTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.materiallister.MaterialListerTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.materiallister.MaterialListerTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.materiallister.MaterialListerTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.materiallister.MaterialListerTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.materiallister.MaterialListerTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.materiallister.MaterialListerTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql;
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.materiallister.MaterialListerTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.materiallister.MaterialListerTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.materiallister.MaterialListerTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.materiallister.MaterialListerTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.materiallister.MaterialListerTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.materiallister.MaterialListerTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.materiallister.MaterialListerTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.materiallister.MaterialListerTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.materiallister.MaterialListerTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.materiallister.MaterialListerTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.materiallister.MaterialListerTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.materiallister.MaterialListerTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.materiallister.MaterialListerTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.materiallister.MaterialListerTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.materiallister.MaterialListerTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.materiallister.MaterialListerTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql;
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.materiallister.MaterialListerTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.materiallister.MaterialListerTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.materiallister.MaterialListerTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.materiallister.MaterialListerTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.materiallister.MaterialListerTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.materiallister.MaterialListerTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.materiallister.MaterialListerTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.materiallister.MaterialListerTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.materiallister.MaterialListerTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.materiallister.MaterialListerTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.materiallister.MaterialListerTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.materiallister.MaterialListerTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.materiallister.MaterialListerTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.materiallister.MaterialListerTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.materiallister.MaterialListerTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.materiallister.MaterialListerTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql;
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.materiallister.MaterialListerTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.materiallister.MaterialListerTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.materiallister.MaterialListerTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.materiallister.MaterialListerTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.materiallister.MaterialListerTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.materiallister.MaterialListerTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.materiallister.MaterialListerTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.materiallister.MaterialListerTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.materiallister.MaterialListerTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.materiallister.MaterialListerTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.materiallister.MaterialListerTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.materiallister.MaterialListerTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.materiallister.MaterialListerTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.materiallister.MaterialListerTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.materiallister.MaterialListerTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.materiallister.MaterialListerTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql;
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.materiallister.MaterialListerTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.materiallister.MaterialListerTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.materiallister.MaterialListerTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.materiallister.MaterialListerTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.materiallister.MaterialListerTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.materiallister.MaterialListerTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.materiallister.MaterialListerTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.materiallister.MaterialListerTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.materiallister.MaterialListerTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.materiallister.MaterialListerTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.materiallister.MaterialListerTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.materiallister.MaterialListerTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.materiallister.MaterialListerTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.materiallister.MaterialListerTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.materiallister.MaterialListerTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.materiallister.MaterialListerTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql;
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.materiallister.MaterialListerTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.materiallister.MaterialListerTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.materiallister.MaterialListerTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.materiallister.MaterialListerTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.materiallister.MaterialListerTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.materiallister.MaterialListerTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.materiallister.MaterialListerTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.materiallister.MaterialListerTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.materiallister.MaterialListerTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.materiallister.MaterialListerTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.materiallister.MaterialListerTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.materiallister.MaterialListerTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.materiallister.MaterialListerTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.materiallister.MaterialListerTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.materiallister.MaterialListerTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.materiallister.MaterialListerTest.xml:Caused by: org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.materiallister.MaterialListerTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql;
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.materiallister.MaterialListerTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.materiallister.MaterialListerTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.materiallister.MaterialListerTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.materiallister.MaterialListerTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.materiallister.MaterialListerTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.materiallister.MaterialListerTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.materiallister.MaterialListerTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.materiallister.MaterialListerTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.materiallister.MaterialListerTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.materiallister.MaterialListerTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.materiallister.MaterialListerTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.materiallister.MaterialListerTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.materiallister.MaterialListerTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.materiallister.MaterialListerTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.materiallister.MaterialListerTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.materiallister.MaterialListerTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql;
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.materiallister.MaterialListerTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.materiallister.MaterialListerTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.materiallister.MaterialListerTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.materiallister.MaterialListerTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.materiallister.MaterialListerTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.materiallister.MaterialListerTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.materiallister.MaterialListerTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.materiallister.MaterialListerTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.materiallister.MaterialListerTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.materiallister.MaterialListerTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.materiallister.MaterialListerTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.materiallister.MaterialListerTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.materiallister.MaterialListerTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.materiallister.MaterialListerTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.materiallister.MaterialListerTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.materiallister.MaterialListerTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql;
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.materiallister.MaterialListerTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.materiallister.MaterialListerTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.materiallister.MaterialListerTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.materiallister.MaterialListerTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.materiallister.MaterialListerTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.materiallister.MaterialListerTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.materiallister.MaterialListerTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.materiallister.MaterialListerTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.materiallister.MaterialListerTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.materiallister.MaterialListerTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.materiallister.MaterialListerTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.materiallister.MaterialListerTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.materiallister.MaterialListerTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.materiallister.MaterialListerTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.materiallister.MaterialListerTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.materiallister.MaterialListerTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql;
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.materiallister.MaterialListerTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.materiallister.MaterialListerTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.materiallister.MaterialListerTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.materiallister.MaterialListerTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.materiallister.MaterialListerTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.materiallister.MaterialListerTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.materiallister.MaterialListerTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.materiallister.MaterialListerTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.materiallister.MaterialListerTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.materiallister.MaterialListerTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.materiallister.MaterialListerTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.materiallister.MaterialListerTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.materiallister.MaterialListerTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.materiallister.MaterialListerTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.materiallister.MaterialListerTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.materiallister.MaterialListerTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql;
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.materiallister.MaterialListerTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.materiallister.MaterialListerTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.materiallister.MaterialListerTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.materiallister.MaterialListerTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.materiallister.MaterialListerTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.materiallister.MaterialListerTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.materiallister.MaterialListerTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.materiallister.MaterialListerTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.materiallister.MaterialListerTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.materiallister.MaterialListerTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.materiallister.MaterialListerTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.materiallister.MaterialListerTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.materiallister.MaterialListerTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.materiallister.MaterialListerTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.materiallister.MaterialListerTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.materiallister.MaterialListerTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql;
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.materiallister.MaterialListerTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.materiallister.MaterialListerTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.materiallister.MaterialListerTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.materiallister.MaterialListerTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.materiallister.MaterialListerTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.materiallister.MaterialListerTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.materiallister.MaterialListerTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.materiallister.MaterialListerTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.materiallister.MaterialListerTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.materiallister.MaterialListerTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.materiallister.MaterialListerTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.materiallister.MaterialListerTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.materiallister.MaterialListerTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.materiallister.MaterialListerTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.materiallister.MaterialListerTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.materiallister.MaterialListerTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql;
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.materiallister.MaterialListerTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.materiallister.MaterialListerTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.materiallister.MaterialListerTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.materiallister.MaterialListerTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.materiallister.MaterialListerTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.materiallister.MaterialListerTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.materiallister.MaterialListerTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.materiallister.MaterialListerTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.materiallister.MaterialListerTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.materiallister.MaterialListerTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.materiallister.MaterialListerTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.materiallister.MaterialListerTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.materiallister.MaterialListerTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.materiallister.MaterialListerTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.materiallister.MaterialListerTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.materiallister.MaterialListerTest.xml:Caused by: org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.materiallister.MaterialListingQueryTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql;
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.materiallister.MaterialListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.materiallister.MaterialListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.materiallister.MaterialListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.materiallister.MaterialListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.materiallister.MaterialListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.materiallister.MaterialListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.materiallister.MaterialListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.materiallister.MaterialListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.materiallister.MaterialListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.materiallister.MaterialListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.materiallister.MaterialListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.materiallister.MaterialListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.materiallister.MaterialListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.materiallister.MaterialListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.materiallister.MaterialListingQueryTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.materiallister.MaterialListingQueryTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql;
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.materiallister.MaterialListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.materiallister.MaterialListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.materiallister.MaterialListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.materiallister.MaterialListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.materiallister.MaterialListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.materiallister.MaterialListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.materiallister.MaterialListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.materiallister.MaterialListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.materiallister.MaterialListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.materiallister.MaterialListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.materiallister.MaterialListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.materiallister.MaterialListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.materiallister.MaterialListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.materiallister.MaterialListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.materiallister.MaterialListingQueryTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.materiallister.MaterialListingQueryTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql;
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.materiallister.MaterialListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.materiallister.MaterialListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.materiallister.MaterialListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.materiallister.MaterialListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.materiallister.MaterialListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.materiallister.MaterialListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.materiallister.MaterialListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.materiallister.MaterialListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.materiallister.MaterialListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.materiallister.MaterialListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.materiallister.MaterialListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.materiallister.MaterialListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.materiallister.MaterialListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.materiallister.MaterialListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.materiallister.MaterialListingQueryTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.materiallister.MaterialListingQueryTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql;
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.materiallister.MaterialListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.materiallister.MaterialListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.materiallister.MaterialListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.materiallister.MaterialListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.materiallister.MaterialListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.materiallister.MaterialListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.materiallister.MaterialListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.materiallister.MaterialListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.materiallister.MaterialListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.materiallister.MaterialListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.materiallister.MaterialListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.materiallister.MaterialListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.materiallister.MaterialListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.materiallister.MaterialListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.materiallister.MaterialListingQueryTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.materiallister.MaterialListingQueryTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql;
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.materiallister.MaterialListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.materiallister.MaterialListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.materiallister.MaterialListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.materiallister.MaterialListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.materiallister.MaterialListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.materiallister.MaterialListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.materiallister.MaterialListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.materiallister.MaterialListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.materiallister.MaterialListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.materiallister.MaterialListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.materiallister.MaterialListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.materiallister.MaterialListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.materiallister.MaterialListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.materiallister.MaterialListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.materiallister.MaterialListingQueryTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.materiallister.MaterialListingQueryTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql;
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.materiallister.MaterialListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.materiallister.MaterialListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.materiallister.MaterialListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.materiallister.MaterialListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.materiallister.MaterialListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.materiallister.MaterialListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.materiallister.MaterialListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.materiallister.MaterialListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.materiallister.MaterialListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.materiallister.MaterialListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.materiallister.MaterialListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.materiallister.MaterialListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.materiallister.MaterialListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.materiallister.MaterialListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.materiallister.MaterialListingQueryTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.materiallister.MaterialListingQueryTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql;
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.materiallister.MaterialListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.materiallister.MaterialListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.materiallister.MaterialListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.materiallister.MaterialListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.materiallister.MaterialListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.materiallister.MaterialListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.materiallister.MaterialListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.materiallister.MaterialListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.materiallister.MaterialListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.materiallister.MaterialListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.materiallister.MaterialListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.materiallister.MaterialListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.materiallister.MaterialListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.materiallister.MaterialListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.materiallister.MaterialListingQueryTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.materiallister.MaterialListingQueryTest.xml:Caused by: org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.materiallister.MaterialListingQueryTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql;
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.materiallister.MaterialListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.materiallister.MaterialListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.materiallister.MaterialListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.materiallister.MaterialListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.materiallister.MaterialListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.materiallister.MaterialListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.materiallister.MaterialListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.materiallister.MaterialListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.materiallister.MaterialListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.materiallister.MaterialListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.materiallister.MaterialListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.materiallister.MaterialListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.materiallister.MaterialListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.materiallister.MaterialListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.materiallister.MaterialListingQueryTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.materiallister.MaterialListingQueryTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql;
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.materiallister.MaterialListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.materiallister.MaterialListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.materiallister.MaterialListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.materiallister.MaterialListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.materiallister.MaterialListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.materiallister.MaterialListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.materiallister.MaterialListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.materiallister.MaterialListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.materiallister.MaterialListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.materiallister.MaterialListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.materiallister.MaterialListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.materiallister.MaterialListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.materiallister.MaterialListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.materiallister.MaterialListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.materiallister.MaterialListingQueryTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.materiallister.MaterialListingQueryTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql;
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.materiallister.MaterialListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.materiallister.MaterialListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.materiallister.MaterialListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.materiallister.MaterialListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.materiallister.MaterialListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.materiallister.MaterialListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.materiallister.MaterialListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.materiallister.MaterialListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.materiallister.MaterialListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.materiallister.MaterialListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.materiallister.MaterialListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.materiallister.MaterialListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.materiallister.MaterialListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.materiallister.MaterialListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.materiallister.MaterialListingQueryTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.materiallister.MaterialListingQueryTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql;
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.materiallister.MaterialListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.materiallister.MaterialListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.materiallister.MaterialListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.materiallister.MaterialListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.materiallister.MaterialListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.materiallister.MaterialListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.materiallister.MaterialListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.materiallister.MaterialListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.materiallister.MaterialListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.materiallister.MaterialListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.materiallister.MaterialListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.materiallister.MaterialListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.materiallister.MaterialListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.materiallister.MaterialListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.materiallister.MaterialListingQueryTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.materiallister.MaterialListingQueryTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql;
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.materiallister.MaterialListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.materiallister.MaterialListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.materiallister.MaterialListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.materiallister.MaterialListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.materiallister.MaterialListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.materiallister.MaterialListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.materiallister.MaterialListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.materiallister.MaterialListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.materiallister.MaterialListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.materiallister.MaterialListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.materiallister.MaterialListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.materiallister.MaterialListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.materiallister.MaterialListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.materiallister.MaterialListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.materiallister.MaterialListingQueryTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.materiallister.MaterialListingQueryTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql;
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.materiallister.MaterialListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.materiallister.MaterialListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.materiallister.MaterialListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.materiallister.MaterialListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.materiallister.MaterialListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.materiallister.MaterialListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.materiallister.MaterialListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.materiallister.MaterialListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.materiallister.MaterialListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.materiallister.MaterialListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.materiallister.MaterialListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.materiallister.MaterialListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.materiallister.MaterialListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.materiallister.MaterialListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.materiallister.MaterialListingQueryTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.materiallister.MaterialListingQueryTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql;
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.materiallister.MaterialListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.materiallister.MaterialListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.materiallister.MaterialListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.materiallister.MaterialListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.materiallister.MaterialListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.materiallister.MaterialListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.materiallister.MaterialListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.materiallister.MaterialListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.materiallister.MaterialListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.materiallister.MaterialListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.materiallister.MaterialListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.materiallister.MaterialListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.materiallister.MaterialListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.materiallister.MaterialListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.materiallister.MaterialListingQueryTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.materiallister.MaterialListingQueryTest.xml:Caused by: org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.materiallister.MaterialListingQueryTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql;
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.materiallister.MaterialListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.materiallister.MaterialListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.materiallister.MaterialListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.materiallister.MaterialListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.materiallister.MaterialListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.materiallister.MaterialListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.materiallister.MaterialListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.materiallister.MaterialListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.materiallister.MaterialListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.materiallister.MaterialListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.materiallister.MaterialListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.materiallister.MaterialListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.materiallister.MaterialListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.materiallister.MaterialListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.materiallister.MaterialListingQueryTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.materiallister.MaterialListingQueryTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql;
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.materiallister.MaterialListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.materiallister.MaterialListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.materiallister.MaterialListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.materiallister.MaterialListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.materiallister.MaterialListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.materiallister.MaterialListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.materiallister.MaterialListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.materiallister.MaterialListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.materiallister.MaterialListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.materiallister.MaterialListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.materiallister.MaterialListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.materiallister.MaterialListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.materiallister.MaterialListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.materiallister.MaterialListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.materiallister.MaterialListingQueryTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.materiallister.MaterialListingQueryTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql;
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.materiallister.MaterialListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.materiallister.MaterialListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.materiallister.MaterialListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.materiallister.MaterialListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.materiallister.MaterialListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.materiallister.MaterialListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.materiallister.MaterialListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.materiallister.MaterialListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.materiallister.MaterialListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.materiallister.MaterialListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.materiallister.MaterialListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.materiallister.MaterialListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.materiallister.MaterialListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.materiallister.MaterialListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.materiallister.MaterialListingQueryTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.materiallister.MaterialListingQueryTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql;
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.materiallister.MaterialListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.materiallister.MaterialListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.materiallister.MaterialListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.materiallister.MaterialListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.materiallister.MaterialListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.materiallister.MaterialListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.materiallister.MaterialListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.materiallister.MaterialListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.materiallister.MaterialListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.materiallister.MaterialListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.materiallister.MaterialListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.materiallister.MaterialListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.materiallister.MaterialListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.materiallister.MaterialListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.materiallister.MaterialListingQueryTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.materiallister.MaterialListingQueryTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql;
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.materiallister.MaterialListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.materiallister.MaterialListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.materiallister.MaterialListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.materiallister.MaterialListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.materiallister.MaterialListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.materiallister.MaterialListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.materiallister.MaterialListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.materiallister.MaterialListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.materiallister.MaterialListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.materiallister.MaterialListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.materiallister.MaterialListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.materiallister.MaterialListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.materiallister.MaterialListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.materiallister.MaterialListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.materiallister.MaterialListingQueryTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.materiallister.MaterialListingQueryTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql;
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.materiallister.MaterialListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.materiallister.MaterialListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.materiallister.MaterialListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.materiallister.MaterialListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.materiallister.MaterialListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.materiallister.MaterialListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.materiallister.MaterialListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.materiallister.MaterialListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.materiallister.MaterialListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.materiallister.MaterialListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.materiallister.MaterialListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.materiallister.MaterialListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.materiallister.MaterialListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.materiallister.MaterialListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.materiallister.MaterialListingQueryTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.materiallister.MaterialListingQueryTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql;
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.materiallister.MaterialListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.materiallister.MaterialListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.materiallister.MaterialListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.materiallister.MaterialListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.materiallister.MaterialListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.materiallister.MaterialListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.materiallister.MaterialListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.materiallister.MaterialListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.materiallister.MaterialListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.materiallister.MaterialListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.materiallister.MaterialListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.materiallister.MaterialListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.materiallister.MaterialListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.materiallister.MaterialListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.materiallister.MaterialListingQueryTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.materiallister.MaterialListingQueryTest.xml:Caused by: org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.materiallister.MaterialListingQueryTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql;
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.materiallister.MaterialListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.materiallister.MaterialListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.materiallister.MaterialListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.materiallister.MaterialListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.materiallister.MaterialListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.materiallister.MaterialListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.materiallister.MaterialListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.materiallister.MaterialListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.materiallister.MaterialListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.materiallister.MaterialListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.materiallister.MaterialListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.materiallister.MaterialListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.materiallister.MaterialListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.materiallister.MaterialListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.materiallister.MaterialListingQueryTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.materiallister.MaterialListingQueryTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql;
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.materiallister.MaterialListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.materiallister.MaterialListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.materiallister.MaterialListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.materiallister.MaterialListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.materiallister.MaterialListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.materiallister.MaterialListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.materiallister.MaterialListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.materiallister.MaterialListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.materiallister.MaterialListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.materiallister.MaterialListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.materiallister.MaterialListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.materiallister.MaterialListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.materiallister.MaterialListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.materiallister.MaterialListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.materiallister.MaterialListingQueryTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.materiallister.MaterialListingQueryTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql;
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.materiallister.MaterialListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.materiallister.MaterialListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.materiallister.MaterialListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.materiallister.MaterialListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.materiallister.MaterialListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.materiallister.MaterialListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.materiallister.MaterialListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.materiallister.MaterialListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.materiallister.MaterialListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.materiallister.MaterialListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.materiallister.MaterialListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.materiallister.MaterialListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.materiallister.MaterialListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.materiallister.MaterialListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.materiallister.MaterialListingQueryTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.materiallister.MaterialListingQueryTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql;
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.materiallister.MaterialListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.materiallister.MaterialListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.materiallister.MaterialListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.materiallister.MaterialListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.materiallister.MaterialListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.materiallister.MaterialListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.materiallister.MaterialListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.materiallister.MaterialListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.materiallister.MaterialListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.materiallister.MaterialListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.materiallister.MaterialListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.materiallister.MaterialListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.materiallister.MaterialListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.materiallister.MaterialListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.materiallister.MaterialListingQueryTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.materiallister.MaterialListingQueryTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql;
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.materiallister.MaterialListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.materiallister.MaterialListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.materiallister.MaterialListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.materiallister.MaterialListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.materiallister.MaterialListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.materiallister.MaterialListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.materiallister.MaterialListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.materiallister.MaterialListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.materiallister.MaterialListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.materiallister.MaterialListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.materiallister.MaterialListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.materiallister.MaterialListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.materiallister.MaterialListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.materiallister.MaterialListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.materiallister.MaterialListingQueryTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.materiallister.MaterialListingQueryTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql;
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.materiallister.MaterialListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.materiallister.MaterialListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.materiallister.MaterialListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.materiallister.MaterialListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.materiallister.MaterialListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.materiallister.MaterialListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.materiallister.MaterialListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.materiallister.MaterialListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.materiallister.MaterialListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.materiallister.MaterialListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.materiallister.MaterialListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.materiallister.MaterialListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.materiallister.MaterialListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.materiallister.MaterialListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.materiallister.MaterialListingQueryTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.materiallister.MaterialListingQueryTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql;
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.materiallister.MaterialListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.materiallister.MaterialListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.materiallister.MaterialListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.materiallister.MaterialListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.materiallister.MaterialListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.materiallister.MaterialListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.materiallister.MaterialListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.materiallister.MaterialListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.materiallister.MaterialListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.materiallister.MaterialListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.materiallister.MaterialListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.materiallister.MaterialListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.materiallister.MaterialListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.materiallister.MaterialListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.materiallister.MaterialListingQueryTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.materiallister.MaterialListingQueryTest.xml:Caused by: org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.materiallister.MaterialListingQueryTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql;
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.materiallister.MaterialListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.materiallister.MaterialListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.materiallister.MaterialListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.materiallister.MaterialListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.materiallister.MaterialListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.materiallister.MaterialListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.materiallister.MaterialListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.materiallister.MaterialListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.materiallister.MaterialListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.materiallister.MaterialListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.materiallister.MaterialListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.materiallister.MaterialListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.materiallister.MaterialListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.materiallister.MaterialListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.materiallister.MaterialListingQueryTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.materiallister.MaterialListingQueryTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql;
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.materiallister.MaterialListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.materiallister.MaterialListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.materiallister.MaterialListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.materiallister.MaterialListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.materiallister.MaterialListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.materiallister.MaterialListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.materiallister.MaterialListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.materiallister.MaterialListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.materiallister.MaterialListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.materiallister.MaterialListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.materiallister.MaterialListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.materiallister.MaterialListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.materiallister.MaterialListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.materiallister.MaterialListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.materiallister.MaterialListingQueryTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.materiallister.MaterialListingQueryTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql;
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.materiallister.MaterialListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.materiallister.MaterialListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.materiallister.MaterialListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.materiallister.MaterialListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.materiallister.MaterialListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.materiallister.MaterialListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.materiallister.MaterialListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.materiallister.MaterialListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.materiallister.MaterialListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.materiallister.MaterialListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.materiallister.MaterialListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.materiallister.MaterialListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.materiallister.MaterialListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.materiallister.MaterialListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.materiallister.MaterialListingQueryTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.materiallister.MaterialListingQueryTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql;
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.materiallister.MaterialListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.materiallister.MaterialListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.materiallister.MaterialListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.materiallister.MaterialListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.materiallister.MaterialListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.materiallister.MaterialListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.materiallister.MaterialListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.materiallister.MaterialListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.materiallister.MaterialListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.materiallister.MaterialListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.materiallister.MaterialListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.materiallister.MaterialListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.materiallister.MaterialListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.materiallister.MaterialListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.materiallister.MaterialListingQueryTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.materiallister.MaterialListingQueryTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql;
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.materiallister.MaterialListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.materiallister.MaterialListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.materiallister.MaterialListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.materiallister.MaterialListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.materiallister.MaterialListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.materiallister.MaterialListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.materiallister.MaterialListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.materiallister.MaterialListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.materiallister.MaterialListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.materiallister.MaterialListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.materiallister.MaterialListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.materiallister.MaterialListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.materiallister.MaterialListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.materiallister.MaterialListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.materiallister.MaterialListingQueryTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.materiallister.MaterialListingQueryTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql;
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.materiallister.MaterialListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.materiallister.MaterialListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.materiallister.MaterialListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.materiallister.MaterialListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.materiallister.MaterialListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.materiallister.MaterialListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.materiallister.MaterialListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.materiallister.MaterialListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.materiallister.MaterialListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.materiallister.MaterialListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.materiallister.MaterialListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.materiallister.MaterialListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.materiallister.MaterialListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.materiallister.MaterialListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.materiallister.MaterialListingQueryTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.materiallister.MaterialListingQueryTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql;
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.materiallister.MaterialListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.materiallister.MaterialListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.materiallister.MaterialListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.materiallister.MaterialListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.materiallister.MaterialListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.materiallister.MaterialListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.materiallister.MaterialListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.materiallister.MaterialListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.materiallister.MaterialListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.materiallister.MaterialListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.materiallister.MaterialListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.materiallister.MaterialListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.materiallister.MaterialListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.materiallister.MaterialListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.materiallister.MaterialListingQueryTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.materiallister.MaterialListingQueryTest.xml:Caused by: org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql;
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql;
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql;
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql;
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql;
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql;
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql;
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml:Caused by: org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql;
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql;
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql;
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql;
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql;
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql;
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql;
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml:Caused by: org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql;
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql;
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql;
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql;
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql;
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql;
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql;
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml:Caused by: org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql;
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql;
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql;
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql;
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql;
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql;
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql;
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml:Caused by: org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql;
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql;
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql;
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql;
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql;
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql;
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql;
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml:Caused by: org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql;
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql;
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql;
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql;
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql;
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql;
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql;
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml:Caused by: org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql;
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql;
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql;
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql;
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql;
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql;
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql;
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml:Caused by: org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql;
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql;
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql;
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql;
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql;
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql;
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql;
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml:Caused by: org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql;
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql;
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql;
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql;
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql;
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql;
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql;
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml:Caused by: org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql;
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql;
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql;
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql;
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql;
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql;
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql;
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml:Caused by: org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql;
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql;
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql;
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql;
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql;
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql;
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql;
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml:Caused by: org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql;
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql;
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql;
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql;
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql;
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql;
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql;
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml:Caused by: org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql;
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql;
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql;
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql;
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql;
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql;
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql;
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml:Caused by: org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql;
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql;
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql;
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql;
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql;
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql;
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql;
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml:Caused by: org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql;
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql;
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql;
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql;
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql;
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql;
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql;
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml:Caused by: org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql;
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql;
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql;
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql;
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql;
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql;
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql;
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleListingQueryTest.xml:Caused by: org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleSetListingQueryTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql;
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleSetListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleSetListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleSetListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleSetListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleSetListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleSetListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleSetListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleSetListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleSetListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleSetListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleSetListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleSetListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleSetListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleSetListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleSetListingQueryTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleSetListingQueryTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql;
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleSetListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleSetListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleSetListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleSetListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleSetListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleSetListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleSetListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleSetListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleSetListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleSetListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleSetListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleSetListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleSetListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleSetListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleSetListingQueryTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleSetListingQueryTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql;
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleSetListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleSetListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleSetListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleSetListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleSetListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleSetListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleSetListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleSetListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleSetListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleSetListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleSetListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleSetListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleSetListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleSetListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleSetListingQueryTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleSetListingQueryTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql;
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleSetListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleSetListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleSetListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleSetListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleSetListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleSetListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleSetListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleSetListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleSetListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleSetListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleSetListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleSetListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleSetListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleSetListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleSetListingQueryTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleSetListingQueryTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql;
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleSetListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleSetListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleSetListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleSetListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleSetListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleSetListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleSetListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleSetListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleSetListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleSetListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleSetListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleSetListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleSetListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleSetListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleSetListingQueryTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleSetListingQueryTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql;
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleSetListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleSetListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleSetListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleSetListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleSetListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleSetListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleSetListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleSetListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleSetListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleSetListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleSetListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleSetListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleSetListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleSetListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleSetListingQueryTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleSetListingQueryTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql;
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleSetListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleSetListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleSetListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleSetListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleSetListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleSetListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleSetListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleSetListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleSetListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleSetListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleSetListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleSetListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleSetListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleSetListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleSetListingQueryTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleSetListingQueryTest.xml:Caused by: org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleSetListingQueryTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql;
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleSetListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleSetListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleSetListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleSetListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleSetListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleSetListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleSetListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleSetListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleSetListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleSetListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleSetListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleSetListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleSetListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleSetListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleSetListingQueryTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleSetListingQueryTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql;
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleSetListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleSetListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleSetListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleSetListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleSetListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleSetListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleSetListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleSetListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleSetListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleSetListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleSetListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleSetListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleSetListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleSetListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleSetListingQueryTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleSetListingQueryTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql;
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleSetListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleSetListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleSetListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleSetListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleSetListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleSetListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleSetListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleSetListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleSetListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleSetListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleSetListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleSetListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleSetListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleSetListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleSetListingQueryTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleSetListingQueryTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql;
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleSetListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleSetListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleSetListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleSetListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleSetListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleSetListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleSetListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleSetListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleSetListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleSetListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleSetListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleSetListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleSetListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleSetListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleSetListingQueryTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleSetListingQueryTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql;
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleSetListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleSetListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleSetListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleSetListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleSetListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleSetListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleSetListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleSetListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleSetListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleSetListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleSetListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleSetListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleSetListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleSetListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleSetListingQueryTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleSetListingQueryTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql;
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleSetListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleSetListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleSetListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleSetListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleSetListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleSetListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleSetListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleSetListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleSetListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleSetListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleSetListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleSetListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleSetListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleSetListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleSetListingQueryTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleSetListingQueryTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql;
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleSetListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleSetListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleSetListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleSetListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleSetListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleSetListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleSetListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleSetListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleSetListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleSetListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleSetListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleSetListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleSetListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleSetListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleSetListingQueryTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleSetListingQueryTest.xml:Caused by: org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleSetListingQueryTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql;
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleSetListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleSetListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleSetListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleSetListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleSetListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleSetListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleSetListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleSetListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleSetListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleSetListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleSetListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleSetListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleSetListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleSetListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleSetListingQueryTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleSetListingQueryTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql;
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleSetListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleSetListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleSetListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleSetListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleSetListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleSetListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleSetListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleSetListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleSetListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleSetListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleSetListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleSetListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleSetListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleSetListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleSetListingQueryTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleSetListingQueryTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql;
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleSetListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleSetListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleSetListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleSetListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleSetListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleSetListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleSetListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleSetListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleSetListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleSetListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleSetListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleSetListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleSetListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleSetListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleSetListingQueryTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleSetListingQueryTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql;
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleSetListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleSetListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleSetListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleSetListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleSetListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleSetListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleSetListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleSetListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleSetListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleSetListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleSetListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleSetListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleSetListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleSetListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleSetListingQueryTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleSetListingQueryTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql;
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleSetListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleSetListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleSetListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleSetListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleSetListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleSetListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleSetListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleSetListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleSetListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleSetListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleSetListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleSetListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleSetListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleSetListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleSetListingQueryTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleSetListingQueryTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql;
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleSetListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleSetListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleSetListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleSetListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleSetListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleSetListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleSetListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleSetListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleSetListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleSetListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleSetListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleSetListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleSetListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleSetListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleSetListingQueryTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleSetListingQueryTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql;
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleSetListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleSetListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleSetListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleSetListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleSetListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleSetListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleSetListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleSetListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleSetListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleSetListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleSetListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleSetListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleSetListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleSetListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleSetListingQueryTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleSetListingQueryTest.xml:Caused by: org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleSetListingQueryTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql;
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleSetListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleSetListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleSetListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleSetListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleSetListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleSetListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleSetListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleSetListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleSetListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleSetListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleSetListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleSetListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleSetListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleSetListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleSetListingQueryTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleSetListingQueryTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql;
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleSetListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleSetListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleSetListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleSetListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleSetListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleSetListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleSetListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleSetListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleSetListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleSetListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleSetListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleSetListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleSetListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleSetListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleSetListingQueryTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleSetListingQueryTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql;
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleSetListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleSetListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleSetListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleSetListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleSetListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleSetListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleSetListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleSetListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleSetListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleSetListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleSetListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleSetListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleSetListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleSetListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleSetListingQueryTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleSetListingQueryTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql;
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleSetListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleSetListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleSetListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleSetListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleSetListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleSetListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleSetListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleSetListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleSetListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleSetListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleSetListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleSetListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleSetListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleSetListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleSetListingQueryTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleSetListingQueryTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql;
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleSetListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleSetListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleSetListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleSetListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleSetListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleSetListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleSetListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleSetListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleSetListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleSetListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleSetListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleSetListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleSetListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleSetListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleSetListingQueryTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleSetListingQueryTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql;
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleSetListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleSetListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleSetListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleSetListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleSetListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleSetListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleSetListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleSetListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleSetListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleSetListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleSetListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleSetListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleSetListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleSetListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleSetListingQueryTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleSetListingQueryTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql;
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleSetListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleSetListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleSetListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleSetListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleSetListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleSetListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleSetListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleSetListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleSetListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleSetListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleSetListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleSetListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleSetListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleSetListingQueryTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleSetListingQueryTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.business.bo.samplelister.SampleSetListingQueryTest.xml:Caused by: org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.AttachmentDAOTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql;
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.AttachmentDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.AttachmentDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.AttachmentDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.AttachmentDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.AttachmentDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.AttachmentDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.AttachmentDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.AttachmentDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.AttachmentDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.AttachmentDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.AttachmentDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.AttachmentDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.AttachmentDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.AttachmentDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.AttachmentDAOTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.AttachmentDAOTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql;
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.AttachmentDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.AttachmentDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.AttachmentDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.AttachmentDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.AttachmentDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.AttachmentDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.AttachmentDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.AttachmentDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.AttachmentDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.AttachmentDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.AttachmentDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.AttachmentDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.AttachmentDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.AttachmentDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.AttachmentDAOTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.AttachmentDAOTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql;
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.AttachmentDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.AttachmentDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.AttachmentDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.AttachmentDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.AttachmentDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.AttachmentDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.AttachmentDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.AttachmentDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.AttachmentDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.AttachmentDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.AttachmentDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.AttachmentDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.AttachmentDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.AttachmentDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.AttachmentDAOTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.AttachmentDAOTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql;
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.AttachmentDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.AttachmentDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.AttachmentDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.AttachmentDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.AttachmentDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.AttachmentDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.AttachmentDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.AttachmentDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.AttachmentDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.AttachmentDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.AttachmentDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.AttachmentDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.AttachmentDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.AttachmentDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.AttachmentDAOTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.AttachmentDAOTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql;
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.AttachmentDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.AttachmentDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.AttachmentDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.AttachmentDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.AttachmentDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.AttachmentDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.AttachmentDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.AttachmentDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.AttachmentDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.AttachmentDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.AttachmentDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.AttachmentDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.AttachmentDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.AttachmentDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.AttachmentDAOTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.AttachmentDAOTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql;
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.AttachmentDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.AttachmentDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.AttachmentDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.AttachmentDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.AttachmentDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.AttachmentDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.AttachmentDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.AttachmentDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.AttachmentDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.AttachmentDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.AttachmentDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.AttachmentDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.AttachmentDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.AttachmentDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.AttachmentDAOTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.AttachmentDAOTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql;
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.AttachmentDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.AttachmentDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.AttachmentDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.AttachmentDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.AttachmentDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.AttachmentDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.AttachmentDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.AttachmentDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.AttachmentDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.AttachmentDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.AttachmentDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.AttachmentDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.AttachmentDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.AttachmentDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.AttachmentDAOTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.AttachmentDAOTest.xml:Caused by: org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.AuthorizationGroupDAOTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql;
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.AuthorizationGroupDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.AuthorizationGroupDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.AuthorizationGroupDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.AuthorizationGroupDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.AuthorizationGroupDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.AuthorizationGroupDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.AuthorizationGroupDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.AuthorizationGroupDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.AuthorizationGroupDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.AuthorizationGroupDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.AuthorizationGroupDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.AuthorizationGroupDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.AuthorizationGroupDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.AuthorizationGroupDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.AuthorizationGroupDAOTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.AuthorizationGroupDAOTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql;
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.AuthorizationGroupDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.AuthorizationGroupDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.AuthorizationGroupDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.AuthorizationGroupDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.AuthorizationGroupDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.AuthorizationGroupDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.AuthorizationGroupDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.AuthorizationGroupDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.AuthorizationGroupDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.AuthorizationGroupDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.AuthorizationGroupDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.AuthorizationGroupDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.AuthorizationGroupDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.AuthorizationGroupDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.AuthorizationGroupDAOTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.AuthorizationGroupDAOTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql;
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.AuthorizationGroupDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.AuthorizationGroupDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.AuthorizationGroupDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.AuthorizationGroupDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.AuthorizationGroupDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.AuthorizationGroupDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.AuthorizationGroupDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.AuthorizationGroupDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.AuthorizationGroupDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.AuthorizationGroupDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.AuthorizationGroupDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.AuthorizationGroupDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.AuthorizationGroupDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.AuthorizationGroupDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.AuthorizationGroupDAOTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.AuthorizationGroupDAOTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql;
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.AuthorizationGroupDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.AuthorizationGroupDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.AuthorizationGroupDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.AuthorizationGroupDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.AuthorizationGroupDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.AuthorizationGroupDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.AuthorizationGroupDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.AuthorizationGroupDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.AuthorizationGroupDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.AuthorizationGroupDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.AuthorizationGroupDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.AuthorizationGroupDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.AuthorizationGroupDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.AuthorizationGroupDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.AuthorizationGroupDAOTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.AuthorizationGroupDAOTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql;
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.AuthorizationGroupDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.AuthorizationGroupDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.AuthorizationGroupDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.AuthorizationGroupDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.AuthorizationGroupDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.AuthorizationGroupDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.AuthorizationGroupDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.AuthorizationGroupDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.AuthorizationGroupDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.AuthorizationGroupDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.AuthorizationGroupDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.AuthorizationGroupDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.AuthorizationGroupDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.AuthorizationGroupDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.AuthorizationGroupDAOTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.AuthorizationGroupDAOTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql;
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.AuthorizationGroupDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.AuthorizationGroupDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.AuthorizationGroupDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.AuthorizationGroupDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.AuthorizationGroupDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.AuthorizationGroupDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.AuthorizationGroupDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.AuthorizationGroupDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.AuthorizationGroupDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.AuthorizationGroupDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.AuthorizationGroupDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.AuthorizationGroupDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.AuthorizationGroupDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.AuthorizationGroupDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.AuthorizationGroupDAOTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.AuthorizationGroupDAOTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql;
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.AuthorizationGroupDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.AuthorizationGroupDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.AuthorizationGroupDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.AuthorizationGroupDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.AuthorizationGroupDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.AuthorizationGroupDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.AuthorizationGroupDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.AuthorizationGroupDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.AuthorizationGroupDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.AuthorizationGroupDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.AuthorizationGroupDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.AuthorizationGroupDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.AuthorizationGroupDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.AuthorizationGroupDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.AuthorizationGroupDAOTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.AuthorizationGroupDAOTest.xml:Caused by: org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.AuthorizationGroupDAOTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql;
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.AuthorizationGroupDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.AuthorizationGroupDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.AuthorizationGroupDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.AuthorizationGroupDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.AuthorizationGroupDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.AuthorizationGroupDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.AuthorizationGroupDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.AuthorizationGroupDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.AuthorizationGroupDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.AuthorizationGroupDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.AuthorizationGroupDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.AuthorizationGroupDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.AuthorizationGroupDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.AuthorizationGroupDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.AuthorizationGroupDAOTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.AuthorizationGroupDAOTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql;
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.AuthorizationGroupDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.AuthorizationGroupDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.AuthorizationGroupDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.AuthorizationGroupDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.AuthorizationGroupDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.AuthorizationGroupDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.AuthorizationGroupDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.AuthorizationGroupDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.AuthorizationGroupDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.AuthorizationGroupDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.AuthorizationGroupDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.AuthorizationGroupDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.AuthorizationGroupDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.AuthorizationGroupDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.AuthorizationGroupDAOTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.AuthorizationGroupDAOTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql;
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.AuthorizationGroupDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.AuthorizationGroupDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.AuthorizationGroupDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.AuthorizationGroupDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.AuthorizationGroupDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.AuthorizationGroupDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.AuthorizationGroupDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.AuthorizationGroupDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.AuthorizationGroupDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.AuthorizationGroupDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.AuthorizationGroupDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.AuthorizationGroupDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.AuthorizationGroupDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.AuthorizationGroupDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.AuthorizationGroupDAOTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.AuthorizationGroupDAOTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql;
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.AuthorizationGroupDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.AuthorizationGroupDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.AuthorizationGroupDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.AuthorizationGroupDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.AuthorizationGroupDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.AuthorizationGroupDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.AuthorizationGroupDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.AuthorizationGroupDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.AuthorizationGroupDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.AuthorizationGroupDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.AuthorizationGroupDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.AuthorizationGroupDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.AuthorizationGroupDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.AuthorizationGroupDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.AuthorizationGroupDAOTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.AuthorizationGroupDAOTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql;
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.AuthorizationGroupDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.AuthorizationGroupDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.AuthorizationGroupDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.AuthorizationGroupDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.AuthorizationGroupDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.AuthorizationGroupDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.AuthorizationGroupDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.AuthorizationGroupDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.AuthorizationGroupDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.AuthorizationGroupDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.AuthorizationGroupDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.AuthorizationGroupDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.AuthorizationGroupDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.AuthorizationGroupDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.AuthorizationGroupDAOTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.AuthorizationGroupDAOTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql;
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.AuthorizationGroupDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.AuthorizationGroupDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.AuthorizationGroupDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.AuthorizationGroupDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.AuthorizationGroupDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.AuthorizationGroupDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.AuthorizationGroupDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.AuthorizationGroupDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.AuthorizationGroupDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.AuthorizationGroupDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.AuthorizationGroupDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.AuthorizationGroupDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.AuthorizationGroupDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.AuthorizationGroupDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.AuthorizationGroupDAOTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.AuthorizationGroupDAOTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql;
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.AuthorizationGroupDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.AuthorizationGroupDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.AuthorizationGroupDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.AuthorizationGroupDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.AuthorizationGroupDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.AuthorizationGroupDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.AuthorizationGroupDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.AuthorizationGroupDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.AuthorizationGroupDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.AuthorizationGroupDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.AuthorizationGroupDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.AuthorizationGroupDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.AuthorizationGroupDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.AuthorizationGroupDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.AuthorizationGroupDAOTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.AuthorizationGroupDAOTest.xml:Caused by: org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.AuthorizationGroupDAOTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql;
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.AuthorizationGroupDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.AuthorizationGroupDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.AuthorizationGroupDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.AuthorizationGroupDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.AuthorizationGroupDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.AuthorizationGroupDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.AuthorizationGroupDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.AuthorizationGroupDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.AuthorizationGroupDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.AuthorizationGroupDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.AuthorizationGroupDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.AuthorizationGroupDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.AuthorizationGroupDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.AuthorizationGroupDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.AuthorizationGroupDAOTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.AuthorizationGroupDAOTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql;
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.AuthorizationGroupDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.AuthorizationGroupDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.AuthorizationGroupDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.AuthorizationGroupDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.AuthorizationGroupDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.AuthorizationGroupDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.AuthorizationGroupDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.AuthorizationGroupDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.AuthorizationGroupDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.AuthorizationGroupDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.AuthorizationGroupDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.AuthorizationGroupDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.AuthorizationGroupDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.AuthorizationGroupDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.AuthorizationGroupDAOTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.AuthorizationGroupDAOTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql;
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.AuthorizationGroupDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.AuthorizationGroupDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.AuthorizationGroupDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.AuthorizationGroupDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.AuthorizationGroupDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.AuthorizationGroupDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.AuthorizationGroupDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.AuthorizationGroupDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.AuthorizationGroupDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.AuthorizationGroupDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.AuthorizationGroupDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.AuthorizationGroupDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.AuthorizationGroupDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.AuthorizationGroupDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.AuthorizationGroupDAOTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.AuthorizationGroupDAOTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql;
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.AuthorizationGroupDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.AuthorizationGroupDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.AuthorizationGroupDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.AuthorizationGroupDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.AuthorizationGroupDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.AuthorizationGroupDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.AuthorizationGroupDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.AuthorizationGroupDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.AuthorizationGroupDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.AuthorizationGroupDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.AuthorizationGroupDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.AuthorizationGroupDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.AuthorizationGroupDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.AuthorizationGroupDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.AuthorizationGroupDAOTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.AuthorizationGroupDAOTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql;
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.AuthorizationGroupDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.AuthorizationGroupDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.AuthorizationGroupDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.AuthorizationGroupDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.AuthorizationGroupDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.AuthorizationGroupDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.AuthorizationGroupDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.AuthorizationGroupDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.AuthorizationGroupDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.AuthorizationGroupDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.AuthorizationGroupDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.AuthorizationGroupDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.AuthorizationGroupDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.AuthorizationGroupDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.AuthorizationGroupDAOTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.AuthorizationGroupDAOTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql;
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.AuthorizationGroupDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.AuthorizationGroupDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.AuthorizationGroupDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.AuthorizationGroupDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.AuthorizationGroupDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.AuthorizationGroupDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.AuthorizationGroupDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.AuthorizationGroupDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.AuthorizationGroupDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.AuthorizationGroupDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.AuthorizationGroupDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.AuthorizationGroupDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.AuthorizationGroupDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.AuthorizationGroupDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.AuthorizationGroupDAOTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.AuthorizationGroupDAOTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql;
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.AuthorizationGroupDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.AuthorizationGroupDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.AuthorizationGroupDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.AuthorizationGroupDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.AuthorizationGroupDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.AuthorizationGroupDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.AuthorizationGroupDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.AuthorizationGroupDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.AuthorizationGroupDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.AuthorizationGroupDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.AuthorizationGroupDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.AuthorizationGroupDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.AuthorizationGroupDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.AuthorizationGroupDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.AuthorizationGroupDAOTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.AuthorizationGroupDAOTest.xml:Caused by: org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.AuthorizationGroupDAOTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql;
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.AuthorizationGroupDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.AuthorizationGroupDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.AuthorizationGroupDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.AuthorizationGroupDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.AuthorizationGroupDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.AuthorizationGroupDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.AuthorizationGroupDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.AuthorizationGroupDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.AuthorizationGroupDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.AuthorizationGroupDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.AuthorizationGroupDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.AuthorizationGroupDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.AuthorizationGroupDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.AuthorizationGroupDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.AuthorizationGroupDAOTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.AuthorizationGroupDAOTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql;
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.AuthorizationGroupDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.AuthorizationGroupDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.AuthorizationGroupDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.AuthorizationGroupDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.AuthorizationGroupDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.AuthorizationGroupDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.AuthorizationGroupDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.AuthorizationGroupDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.AuthorizationGroupDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.AuthorizationGroupDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.AuthorizationGroupDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.AuthorizationGroupDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.AuthorizationGroupDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.AuthorizationGroupDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.AuthorizationGroupDAOTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.AuthorizationGroupDAOTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql;
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.AuthorizationGroupDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.AuthorizationGroupDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.AuthorizationGroupDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.AuthorizationGroupDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.AuthorizationGroupDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.AuthorizationGroupDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.AuthorizationGroupDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.AuthorizationGroupDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.AuthorizationGroupDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.AuthorizationGroupDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.AuthorizationGroupDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.AuthorizationGroupDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.AuthorizationGroupDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.AuthorizationGroupDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.AuthorizationGroupDAOTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.AuthorizationGroupDAOTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql;
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.AuthorizationGroupDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.AuthorizationGroupDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.AuthorizationGroupDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.AuthorizationGroupDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.AuthorizationGroupDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.AuthorizationGroupDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.AuthorizationGroupDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.AuthorizationGroupDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.AuthorizationGroupDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.AuthorizationGroupDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.AuthorizationGroupDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.AuthorizationGroupDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.AuthorizationGroupDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.AuthorizationGroupDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.AuthorizationGroupDAOTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.AuthorizationGroupDAOTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql;
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.AuthorizationGroupDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.AuthorizationGroupDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.AuthorizationGroupDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.AuthorizationGroupDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.AuthorizationGroupDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.AuthorizationGroupDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.AuthorizationGroupDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.AuthorizationGroupDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.AuthorizationGroupDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.AuthorizationGroupDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.AuthorizationGroupDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.AuthorizationGroupDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.AuthorizationGroupDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.AuthorizationGroupDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.AuthorizationGroupDAOTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.AuthorizationGroupDAOTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql;
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.AuthorizationGroupDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.AuthorizationGroupDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.AuthorizationGroupDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.AuthorizationGroupDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.AuthorizationGroupDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.AuthorizationGroupDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.AuthorizationGroupDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.AuthorizationGroupDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.AuthorizationGroupDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.AuthorizationGroupDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.AuthorizationGroupDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.AuthorizationGroupDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.AuthorizationGroupDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.AuthorizationGroupDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.AuthorizationGroupDAOTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.AuthorizationGroupDAOTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql;
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.AuthorizationGroupDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.AuthorizationGroupDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.AuthorizationGroupDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.AuthorizationGroupDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.AuthorizationGroupDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.AuthorizationGroupDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.AuthorizationGroupDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.AuthorizationGroupDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.AuthorizationGroupDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.AuthorizationGroupDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.AuthorizationGroupDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.AuthorizationGroupDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.AuthorizationGroupDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.AuthorizationGroupDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.AuthorizationGroupDAOTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.AuthorizationGroupDAOTest.xml:Caused by: org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.AuthorizationGroupDAOTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql;
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.AuthorizationGroupDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.AuthorizationGroupDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.AuthorizationGroupDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.AuthorizationGroupDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.AuthorizationGroupDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.AuthorizationGroupDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.AuthorizationGroupDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.AuthorizationGroupDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.AuthorizationGroupDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.AuthorizationGroupDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.AuthorizationGroupDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.AuthorizationGroupDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.AuthorizationGroupDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.AuthorizationGroupDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.AuthorizationGroupDAOTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.AuthorizationGroupDAOTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql;
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.AuthorizationGroupDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.AuthorizationGroupDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.AuthorizationGroupDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.AuthorizationGroupDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.AuthorizationGroupDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.AuthorizationGroupDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.AuthorizationGroupDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.AuthorizationGroupDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.AuthorizationGroupDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.AuthorizationGroupDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.AuthorizationGroupDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.AuthorizationGroupDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.AuthorizationGroupDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.AuthorizationGroupDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.AuthorizationGroupDAOTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.AuthorizationGroupDAOTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql;
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.AuthorizationGroupDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.AuthorizationGroupDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.AuthorizationGroupDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.AuthorizationGroupDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.AuthorizationGroupDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.AuthorizationGroupDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.AuthorizationGroupDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.AuthorizationGroupDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.AuthorizationGroupDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.AuthorizationGroupDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.AuthorizationGroupDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.AuthorizationGroupDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.AuthorizationGroupDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.AuthorizationGroupDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.AuthorizationGroupDAOTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.AuthorizationGroupDAOTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql;
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.AuthorizationGroupDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.AuthorizationGroupDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.AuthorizationGroupDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.AuthorizationGroupDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.AuthorizationGroupDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.AuthorizationGroupDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.AuthorizationGroupDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.AuthorizationGroupDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.AuthorizationGroupDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.AuthorizationGroupDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.AuthorizationGroupDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.AuthorizationGroupDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.AuthorizationGroupDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.AuthorizationGroupDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.AuthorizationGroupDAOTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.AuthorizationGroupDAOTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql;
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.AuthorizationGroupDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.AuthorizationGroupDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.AuthorizationGroupDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.AuthorizationGroupDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.AuthorizationGroupDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.AuthorizationGroupDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.AuthorizationGroupDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.AuthorizationGroupDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.AuthorizationGroupDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.AuthorizationGroupDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.AuthorizationGroupDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.AuthorizationGroupDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.AuthorizationGroupDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.AuthorizationGroupDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.AuthorizationGroupDAOTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.AuthorizationGroupDAOTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql;
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.AuthorizationGroupDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.AuthorizationGroupDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.AuthorizationGroupDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.AuthorizationGroupDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.AuthorizationGroupDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.AuthorizationGroupDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.AuthorizationGroupDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.AuthorizationGroupDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.AuthorizationGroupDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.AuthorizationGroupDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.AuthorizationGroupDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.AuthorizationGroupDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.AuthorizationGroupDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.AuthorizationGroupDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.AuthorizationGroupDAOTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.AuthorizationGroupDAOTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql;
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.AuthorizationGroupDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.AuthorizationGroupDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.AuthorizationGroupDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.AuthorizationGroupDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.AuthorizationGroupDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.AuthorizationGroupDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.AuthorizationGroupDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.AuthorizationGroupDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.AuthorizationGroupDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.AuthorizationGroupDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.AuthorizationGroupDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.AuthorizationGroupDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.AuthorizationGroupDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.AuthorizationGroupDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.AuthorizationGroupDAOTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.AuthorizationGroupDAOTest.xml:Caused by: org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.AuthorizationGroupDAOTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql;
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.AuthorizationGroupDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.AuthorizationGroupDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.AuthorizationGroupDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.AuthorizationGroupDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.AuthorizationGroupDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.AuthorizationGroupDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.AuthorizationGroupDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.AuthorizationGroupDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.AuthorizationGroupDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.AuthorizationGroupDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.AuthorizationGroupDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.AuthorizationGroupDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.AuthorizationGroupDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.AuthorizationGroupDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.AuthorizationGroupDAOTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.AuthorizationGroupDAOTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql;
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.AuthorizationGroupDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.AuthorizationGroupDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.AuthorizationGroupDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.AuthorizationGroupDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.AuthorizationGroupDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.AuthorizationGroupDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.AuthorizationGroupDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.AuthorizationGroupDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.AuthorizationGroupDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.AuthorizationGroupDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.AuthorizationGroupDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.AuthorizationGroupDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.AuthorizationGroupDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.AuthorizationGroupDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.AuthorizationGroupDAOTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.AuthorizationGroupDAOTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql;
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.AuthorizationGroupDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.AuthorizationGroupDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.AuthorizationGroupDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.AuthorizationGroupDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.AuthorizationGroupDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.AuthorizationGroupDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.AuthorizationGroupDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.AuthorizationGroupDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.AuthorizationGroupDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.AuthorizationGroupDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.AuthorizationGroupDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.AuthorizationGroupDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.AuthorizationGroupDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.AuthorizationGroupDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.AuthorizationGroupDAOTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.AuthorizationGroupDAOTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql;
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.AuthorizationGroupDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.AuthorizationGroupDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.AuthorizationGroupDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.AuthorizationGroupDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.AuthorizationGroupDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.AuthorizationGroupDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.AuthorizationGroupDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.AuthorizationGroupDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.AuthorizationGroupDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.AuthorizationGroupDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.AuthorizationGroupDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.AuthorizationGroupDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.AuthorizationGroupDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.AuthorizationGroupDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.AuthorizationGroupDAOTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.AuthorizationGroupDAOTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql;
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.AuthorizationGroupDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.AuthorizationGroupDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.AuthorizationGroupDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.AuthorizationGroupDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.AuthorizationGroupDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.AuthorizationGroupDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.AuthorizationGroupDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.AuthorizationGroupDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.AuthorizationGroupDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.AuthorizationGroupDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.AuthorizationGroupDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.AuthorizationGroupDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.AuthorizationGroupDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.AuthorizationGroupDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.AuthorizationGroupDAOTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.AuthorizationGroupDAOTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql;
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.AuthorizationGroupDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.AuthorizationGroupDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.AuthorizationGroupDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.AuthorizationGroupDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.AuthorizationGroupDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.AuthorizationGroupDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.AuthorizationGroupDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.AuthorizationGroupDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.AuthorizationGroupDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.AuthorizationGroupDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.AuthorizationGroupDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.AuthorizationGroupDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.AuthorizationGroupDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.AuthorizationGroupDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.AuthorizationGroupDAOTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.AuthorizationGroupDAOTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql;
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.AuthorizationGroupDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.AuthorizationGroupDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.AuthorizationGroupDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.AuthorizationGroupDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.AuthorizationGroupDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.AuthorizationGroupDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.AuthorizationGroupDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.AuthorizationGroupDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.AuthorizationGroupDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.AuthorizationGroupDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.AuthorizationGroupDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.AuthorizationGroupDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.AuthorizationGroupDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.AuthorizationGroupDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.AuthorizationGroupDAOTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.AuthorizationGroupDAOTest.xml:Caused by: org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.AuthorizationGroupDAOTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql;
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.AuthorizationGroupDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.AuthorizationGroupDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.AuthorizationGroupDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.AuthorizationGroupDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.AuthorizationGroupDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.AuthorizationGroupDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.AuthorizationGroupDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.AuthorizationGroupDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.AuthorizationGroupDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.AuthorizationGroupDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.AuthorizationGroupDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.AuthorizationGroupDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.AuthorizationGroupDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.AuthorizationGroupDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.AuthorizationGroupDAOTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.AuthorizationGroupDAOTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql;
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.AuthorizationGroupDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.AuthorizationGroupDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.AuthorizationGroupDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.AuthorizationGroupDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.AuthorizationGroupDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.AuthorizationGroupDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.AuthorizationGroupDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.AuthorizationGroupDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.AuthorizationGroupDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.AuthorizationGroupDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.AuthorizationGroupDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.AuthorizationGroupDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.AuthorizationGroupDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.AuthorizationGroupDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.AuthorizationGroupDAOTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.AuthorizationGroupDAOTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql;
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.AuthorizationGroupDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.AuthorizationGroupDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.AuthorizationGroupDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.AuthorizationGroupDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.AuthorizationGroupDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.AuthorizationGroupDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.AuthorizationGroupDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.AuthorizationGroupDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.AuthorizationGroupDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.AuthorizationGroupDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.AuthorizationGroupDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.AuthorizationGroupDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.AuthorizationGroupDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.AuthorizationGroupDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.AuthorizationGroupDAOTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.AuthorizationGroupDAOTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql;
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.AuthorizationGroupDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.AuthorizationGroupDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.AuthorizationGroupDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.AuthorizationGroupDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.AuthorizationGroupDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.AuthorizationGroupDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.AuthorizationGroupDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.AuthorizationGroupDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.AuthorizationGroupDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.AuthorizationGroupDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.AuthorizationGroupDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.AuthorizationGroupDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.AuthorizationGroupDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.AuthorizationGroupDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.AuthorizationGroupDAOTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.AuthorizationGroupDAOTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql;
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.AuthorizationGroupDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.AuthorizationGroupDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.AuthorizationGroupDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.AuthorizationGroupDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.AuthorizationGroupDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.AuthorizationGroupDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.AuthorizationGroupDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.AuthorizationGroupDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.AuthorizationGroupDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.AuthorizationGroupDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.AuthorizationGroupDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.AuthorizationGroupDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.AuthorizationGroupDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.AuthorizationGroupDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.AuthorizationGroupDAOTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.AuthorizationGroupDAOTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql;
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.AuthorizationGroupDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.AuthorizationGroupDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.AuthorizationGroupDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.AuthorizationGroupDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.AuthorizationGroupDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.AuthorizationGroupDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.AuthorizationGroupDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.AuthorizationGroupDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.AuthorizationGroupDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.AuthorizationGroupDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.AuthorizationGroupDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.AuthorizationGroupDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.AuthorizationGroupDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.AuthorizationGroupDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.AuthorizationGroupDAOTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.AuthorizationGroupDAOTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql;
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.AuthorizationGroupDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.AuthorizationGroupDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.AuthorizationGroupDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.AuthorizationGroupDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.AuthorizationGroupDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.AuthorizationGroupDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.AuthorizationGroupDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.AuthorizationGroupDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.AuthorizationGroupDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.AuthorizationGroupDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.AuthorizationGroupDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.AuthorizationGroupDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.AuthorizationGroupDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.AuthorizationGroupDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.AuthorizationGroupDAOTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.AuthorizationGroupDAOTest.xml:Caused by: org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.AuthorizationGroupDAOTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql;
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.AuthorizationGroupDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.AuthorizationGroupDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.AuthorizationGroupDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.AuthorizationGroupDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.AuthorizationGroupDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.AuthorizationGroupDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.AuthorizationGroupDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.AuthorizationGroupDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.AuthorizationGroupDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.AuthorizationGroupDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.AuthorizationGroupDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.AuthorizationGroupDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.AuthorizationGroupDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.AuthorizationGroupDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.AuthorizationGroupDAOTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.AuthorizationGroupDAOTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql;
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.AuthorizationGroupDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.AuthorizationGroupDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.AuthorizationGroupDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.AuthorizationGroupDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.AuthorizationGroupDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.AuthorizationGroupDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.AuthorizationGroupDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.AuthorizationGroupDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.AuthorizationGroupDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.AuthorizationGroupDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.AuthorizationGroupDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.AuthorizationGroupDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.AuthorizationGroupDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.AuthorizationGroupDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.AuthorizationGroupDAOTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.AuthorizationGroupDAOTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql;
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.AuthorizationGroupDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.AuthorizationGroupDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.AuthorizationGroupDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.AuthorizationGroupDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.AuthorizationGroupDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.AuthorizationGroupDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.AuthorizationGroupDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.AuthorizationGroupDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.AuthorizationGroupDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.AuthorizationGroupDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.AuthorizationGroupDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.AuthorizationGroupDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.AuthorizationGroupDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.AuthorizationGroupDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.AuthorizationGroupDAOTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.AuthorizationGroupDAOTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql;
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.AuthorizationGroupDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.AuthorizationGroupDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.AuthorizationGroupDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.AuthorizationGroupDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.AuthorizationGroupDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.AuthorizationGroupDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.AuthorizationGroupDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.AuthorizationGroupDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.AuthorizationGroupDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.AuthorizationGroupDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.AuthorizationGroupDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.AuthorizationGroupDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.AuthorizationGroupDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.AuthorizationGroupDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.AuthorizationGroupDAOTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.AuthorizationGroupDAOTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql;
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.AuthorizationGroupDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.AuthorizationGroupDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.AuthorizationGroupDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.AuthorizationGroupDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.AuthorizationGroupDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.AuthorizationGroupDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.AuthorizationGroupDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.AuthorizationGroupDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.AuthorizationGroupDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.AuthorizationGroupDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.AuthorizationGroupDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.AuthorizationGroupDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.AuthorizationGroupDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.AuthorizationGroupDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.AuthorizationGroupDAOTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.AuthorizationGroupDAOTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql;
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.AuthorizationGroupDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.AuthorizationGroupDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.AuthorizationGroupDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.AuthorizationGroupDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.AuthorizationGroupDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.AuthorizationGroupDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.AuthorizationGroupDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.AuthorizationGroupDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.AuthorizationGroupDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.AuthorizationGroupDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.AuthorizationGroupDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.AuthorizationGroupDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.AuthorizationGroupDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.AuthorizationGroupDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.AuthorizationGroupDAOTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.AuthorizationGroupDAOTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql;
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.AuthorizationGroupDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.AuthorizationGroupDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.AuthorizationGroupDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.AuthorizationGroupDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.AuthorizationGroupDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.AuthorizationGroupDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.AuthorizationGroupDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.AuthorizationGroupDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.AuthorizationGroupDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.AuthorizationGroupDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.AuthorizationGroupDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.AuthorizationGroupDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.AuthorizationGroupDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.AuthorizationGroupDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.AuthorizationGroupDAOTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.AuthorizationGroupDAOTest.xml:Caused by: org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.AuthorizationGroupDAOTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql;
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.AuthorizationGroupDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.AuthorizationGroupDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.AuthorizationGroupDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.AuthorizationGroupDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.AuthorizationGroupDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.AuthorizationGroupDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.AuthorizationGroupDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.AuthorizationGroupDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.AuthorizationGroupDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.AuthorizationGroupDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.AuthorizationGroupDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.AuthorizationGroupDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.AuthorizationGroupDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.AuthorizationGroupDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.AuthorizationGroupDAOTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.AuthorizationGroupDAOTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql;
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.AuthorizationGroupDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.AuthorizationGroupDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.AuthorizationGroupDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.AuthorizationGroupDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.AuthorizationGroupDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.AuthorizationGroupDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.AuthorizationGroupDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.AuthorizationGroupDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.AuthorizationGroupDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.AuthorizationGroupDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.AuthorizationGroupDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.AuthorizationGroupDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.AuthorizationGroupDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.AuthorizationGroupDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.AuthorizationGroupDAOTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.AuthorizationGroupDAOTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql;
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.AuthorizationGroupDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.AuthorizationGroupDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.AuthorizationGroupDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.AuthorizationGroupDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.AuthorizationGroupDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.AuthorizationGroupDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.AuthorizationGroupDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.AuthorizationGroupDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.AuthorizationGroupDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.AuthorizationGroupDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.AuthorizationGroupDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.AuthorizationGroupDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.AuthorizationGroupDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.AuthorizationGroupDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.AuthorizationGroupDAOTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.AuthorizationGroupDAOTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql;
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.AuthorizationGroupDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.AuthorizationGroupDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.AuthorizationGroupDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.AuthorizationGroupDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.AuthorizationGroupDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.AuthorizationGroupDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.AuthorizationGroupDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.AuthorizationGroupDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.AuthorizationGroupDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.AuthorizationGroupDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.AuthorizationGroupDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.AuthorizationGroupDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.AuthorizationGroupDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.AuthorizationGroupDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.AuthorizationGroupDAOTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.AuthorizationGroupDAOTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql;
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.AuthorizationGroupDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.AuthorizationGroupDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.AuthorizationGroupDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.AuthorizationGroupDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.AuthorizationGroupDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.AuthorizationGroupDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.AuthorizationGroupDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.AuthorizationGroupDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.AuthorizationGroupDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.AuthorizationGroupDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.AuthorizationGroupDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.AuthorizationGroupDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.AuthorizationGroupDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.AuthorizationGroupDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.AuthorizationGroupDAOTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.AuthorizationGroupDAOTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql;
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.AuthorizationGroupDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.AuthorizationGroupDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.AuthorizationGroupDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.AuthorizationGroupDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.AuthorizationGroupDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.AuthorizationGroupDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.AuthorizationGroupDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.AuthorizationGroupDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.AuthorizationGroupDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.AuthorizationGroupDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.AuthorizationGroupDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.AuthorizationGroupDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.AuthorizationGroupDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.AuthorizationGroupDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.AuthorizationGroupDAOTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.AuthorizationGroupDAOTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql;
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.AuthorizationGroupDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.AuthorizationGroupDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.AuthorizationGroupDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.AuthorizationGroupDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.AuthorizationGroupDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.AuthorizationGroupDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.AuthorizationGroupDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.AuthorizationGroupDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.AuthorizationGroupDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.AuthorizationGroupDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.AuthorizationGroupDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.AuthorizationGroupDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.AuthorizationGroupDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.AuthorizationGroupDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.AuthorizationGroupDAOTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.AuthorizationGroupDAOTest.xml:Caused by: org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.AuthorizationGroupDAOTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql;
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.AuthorizationGroupDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.AuthorizationGroupDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.AuthorizationGroupDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.AuthorizationGroupDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.AuthorizationGroupDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.AuthorizationGroupDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.AuthorizationGroupDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.AuthorizationGroupDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.AuthorizationGroupDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.AuthorizationGroupDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.AuthorizationGroupDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.AuthorizationGroupDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.AuthorizationGroupDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.AuthorizationGroupDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.AuthorizationGroupDAOTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.AuthorizationGroupDAOTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql;
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.AuthorizationGroupDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.AuthorizationGroupDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.AuthorizationGroupDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.AuthorizationGroupDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.AuthorizationGroupDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.AuthorizationGroupDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.AuthorizationGroupDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.AuthorizationGroupDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.AuthorizationGroupDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.AuthorizationGroupDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.AuthorizationGroupDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.AuthorizationGroupDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.AuthorizationGroupDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.AuthorizationGroupDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.AuthorizationGroupDAOTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.AuthorizationGroupDAOTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql;
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.AuthorizationGroupDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.AuthorizationGroupDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.AuthorizationGroupDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.AuthorizationGroupDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.AuthorizationGroupDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.AuthorizationGroupDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.AuthorizationGroupDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.AuthorizationGroupDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.AuthorizationGroupDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.AuthorizationGroupDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.AuthorizationGroupDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.AuthorizationGroupDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.AuthorizationGroupDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.AuthorizationGroupDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.AuthorizationGroupDAOTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.AuthorizationGroupDAOTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql;
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.AuthorizationGroupDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.AuthorizationGroupDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.AuthorizationGroupDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.AuthorizationGroupDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.AuthorizationGroupDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.AuthorizationGroupDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.AuthorizationGroupDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.AuthorizationGroupDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.AuthorizationGroupDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.AuthorizationGroupDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.AuthorizationGroupDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.AuthorizationGroupDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.AuthorizationGroupDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.AuthorizationGroupDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.AuthorizationGroupDAOTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.AuthorizationGroupDAOTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql;
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.AuthorizationGroupDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.AuthorizationGroupDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.AuthorizationGroupDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.AuthorizationGroupDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.AuthorizationGroupDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.AuthorizationGroupDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.AuthorizationGroupDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.AuthorizationGroupDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.AuthorizationGroupDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.AuthorizationGroupDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.AuthorizationGroupDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.AuthorizationGroupDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.AuthorizationGroupDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.AuthorizationGroupDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.AuthorizationGroupDAOTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.AuthorizationGroupDAOTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql;
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.AuthorizationGroupDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.AuthorizationGroupDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.AuthorizationGroupDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.AuthorizationGroupDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.AuthorizationGroupDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.AuthorizationGroupDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.AuthorizationGroupDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.AuthorizationGroupDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.AuthorizationGroupDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.AuthorizationGroupDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.AuthorizationGroupDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.AuthorizationGroupDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.AuthorizationGroupDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.AuthorizationGroupDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.AuthorizationGroupDAOTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.AuthorizationGroupDAOTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql;
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.AuthorizationGroupDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.AuthorizationGroupDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.AuthorizationGroupDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.AuthorizationGroupDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.AuthorizationGroupDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.AuthorizationGroupDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.AuthorizationGroupDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.AuthorizationGroupDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.AuthorizationGroupDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.AuthorizationGroupDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.AuthorizationGroupDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.AuthorizationGroupDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.AuthorizationGroupDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.AuthorizationGroupDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.AuthorizationGroupDAOTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.AuthorizationGroupDAOTest.xml:Caused by: org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql;
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql;
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql;
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql;
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql;
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql;
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql;
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml:Caused by: org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql;
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql;
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql;
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql;
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql;
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql;
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql;
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml:Caused by: org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql;
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql;
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql;
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql;
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql;
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql;
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql;
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml:Caused by: org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql;
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql;
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql;
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql;
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql;
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql;
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql;
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml:Caused by: org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql;
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql;
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql;
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql;
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql;
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql;
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql;
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml:Caused by: org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql;
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql;
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql;
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql;
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql;
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql;
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql;
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml:Caused by: org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql;
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql;
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql;
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql;
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql;
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql;
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql;
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml:Caused by: org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql;
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql;
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql;
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql;
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql;
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql;
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql;
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml:Caused by: org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql;
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql;
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql;
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql;
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql;
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql;
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql;
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml:Caused by: org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql;
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql;
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql;
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql;
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql;
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql;
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql;
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml:Caused by: org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql;
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql;
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql;
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql;
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql;
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql;
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql;
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml:Caused by: org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql;
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql;
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql;
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql;
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql;
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql;
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql;
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml:Caused by: org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql;
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql;
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql;
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql;
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql;
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql;
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql;
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml:Caused by: org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql;
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql;
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql;
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql;
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql;
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql;
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql;
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml:Caused by: org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql;
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql;
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql;
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql;
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql;
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql;
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql;
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml:Caused by: org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql;
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql;
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql;
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql;
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql;
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql;
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql;
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml:Caused by: org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql;
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql;
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql;
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql;
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql;
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql;
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql;
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataDAOTest.xml:Caused by: org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataStoreDAOTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql;
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataStoreDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataStoreDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataStoreDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataStoreDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataStoreDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataStoreDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataStoreDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataStoreDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataStoreDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataStoreDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataStoreDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataStoreDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataStoreDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataStoreDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataStoreDAOTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataStoreDAOTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql;
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataStoreDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataStoreDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataStoreDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataStoreDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataStoreDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataStoreDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataStoreDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataStoreDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataStoreDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataStoreDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataStoreDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataStoreDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataStoreDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataStoreDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataStoreDAOTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataStoreDAOTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql;
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataStoreDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataStoreDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataStoreDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataStoreDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataStoreDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataStoreDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataStoreDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataStoreDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataStoreDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataStoreDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataStoreDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataStoreDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataStoreDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataStoreDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataStoreDAOTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataStoreDAOTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql;
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataStoreDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataStoreDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataStoreDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataStoreDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataStoreDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataStoreDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataStoreDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataStoreDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataStoreDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataStoreDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataStoreDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataStoreDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataStoreDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataStoreDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataStoreDAOTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataStoreDAOTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql;
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataStoreDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataStoreDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataStoreDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataStoreDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataStoreDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataStoreDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataStoreDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataStoreDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataStoreDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataStoreDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataStoreDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataStoreDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataStoreDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataStoreDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataStoreDAOTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataStoreDAOTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql;
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataStoreDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataStoreDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataStoreDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataStoreDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataStoreDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataStoreDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataStoreDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataStoreDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataStoreDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataStoreDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataStoreDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataStoreDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataStoreDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataStoreDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataStoreDAOTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataStoreDAOTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql;
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataStoreDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataStoreDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataStoreDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataStoreDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataStoreDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataStoreDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataStoreDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataStoreDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataStoreDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataStoreDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataStoreDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataStoreDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataStoreDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataStoreDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataStoreDAOTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataStoreDAOTest.xml:Caused by: org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataStoreDAOTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql;
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataStoreDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataStoreDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataStoreDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataStoreDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataStoreDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataStoreDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataStoreDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataStoreDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataStoreDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataStoreDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataStoreDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataStoreDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataStoreDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataStoreDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataStoreDAOTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataStoreDAOTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql;
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataStoreDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataStoreDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataStoreDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataStoreDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataStoreDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataStoreDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataStoreDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataStoreDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataStoreDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataStoreDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataStoreDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataStoreDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataStoreDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataStoreDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataStoreDAOTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataStoreDAOTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql;
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataStoreDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataStoreDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataStoreDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataStoreDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataStoreDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataStoreDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataStoreDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataStoreDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataStoreDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataStoreDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataStoreDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataStoreDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataStoreDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataStoreDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataStoreDAOTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataStoreDAOTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql;
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataStoreDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataStoreDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataStoreDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataStoreDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataStoreDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataStoreDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataStoreDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataStoreDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataStoreDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataStoreDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataStoreDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataStoreDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataStoreDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataStoreDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataStoreDAOTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataStoreDAOTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql;
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataStoreDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataStoreDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataStoreDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataStoreDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataStoreDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataStoreDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataStoreDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataStoreDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataStoreDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataStoreDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataStoreDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataStoreDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataStoreDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataStoreDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataStoreDAOTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataStoreDAOTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql;
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataStoreDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataStoreDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataStoreDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataStoreDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataStoreDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataStoreDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataStoreDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataStoreDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataStoreDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataStoreDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataStoreDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataStoreDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataStoreDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataStoreDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataStoreDAOTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataStoreDAOTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql;
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataStoreDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataStoreDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataStoreDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataStoreDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataStoreDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataStoreDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataStoreDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataStoreDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataStoreDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataStoreDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataStoreDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataStoreDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataStoreDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataStoreDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataStoreDAOTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DataStoreDAOTest.xml:Caused by: org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DeletionDAOTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql;
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DeletionDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DeletionDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DeletionDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DeletionDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DeletionDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DeletionDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DeletionDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DeletionDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DeletionDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DeletionDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DeletionDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DeletionDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DeletionDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DeletionDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DeletionDAOTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DeletionDAOTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql;
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DeletionDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DeletionDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DeletionDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DeletionDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DeletionDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DeletionDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DeletionDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DeletionDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DeletionDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DeletionDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DeletionDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DeletionDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DeletionDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DeletionDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DeletionDAOTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DeletionDAOTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql;
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DeletionDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DeletionDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DeletionDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DeletionDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DeletionDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DeletionDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DeletionDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DeletionDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DeletionDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DeletionDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DeletionDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DeletionDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DeletionDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DeletionDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DeletionDAOTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DeletionDAOTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql;
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DeletionDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DeletionDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DeletionDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DeletionDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DeletionDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DeletionDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DeletionDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DeletionDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DeletionDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DeletionDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DeletionDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DeletionDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DeletionDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DeletionDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DeletionDAOTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DeletionDAOTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql;
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DeletionDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DeletionDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DeletionDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DeletionDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DeletionDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DeletionDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DeletionDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DeletionDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DeletionDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DeletionDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DeletionDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DeletionDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DeletionDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DeletionDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DeletionDAOTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DeletionDAOTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql;
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DeletionDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DeletionDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DeletionDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DeletionDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DeletionDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DeletionDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DeletionDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DeletionDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DeletionDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DeletionDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DeletionDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DeletionDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DeletionDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DeletionDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DeletionDAOTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DeletionDAOTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql;
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DeletionDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DeletionDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DeletionDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DeletionDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DeletionDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DeletionDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DeletionDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DeletionDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DeletionDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DeletionDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DeletionDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DeletionDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DeletionDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DeletionDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DeletionDAOTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DeletionDAOTest.xml:Caused by: org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DeletionDAOTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql;
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DeletionDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DeletionDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DeletionDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DeletionDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DeletionDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DeletionDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DeletionDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DeletionDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DeletionDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DeletionDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DeletionDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DeletionDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DeletionDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DeletionDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DeletionDAOTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DeletionDAOTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql;
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DeletionDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DeletionDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DeletionDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DeletionDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DeletionDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DeletionDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DeletionDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DeletionDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DeletionDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DeletionDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DeletionDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DeletionDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DeletionDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DeletionDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DeletionDAOTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DeletionDAOTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql;
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DeletionDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DeletionDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DeletionDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DeletionDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DeletionDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DeletionDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DeletionDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DeletionDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DeletionDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DeletionDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DeletionDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DeletionDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DeletionDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DeletionDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DeletionDAOTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DeletionDAOTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql;
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DeletionDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DeletionDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DeletionDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DeletionDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DeletionDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DeletionDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DeletionDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DeletionDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DeletionDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DeletionDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DeletionDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DeletionDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DeletionDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DeletionDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DeletionDAOTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DeletionDAOTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql;
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DeletionDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DeletionDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DeletionDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DeletionDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DeletionDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DeletionDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DeletionDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DeletionDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DeletionDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DeletionDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DeletionDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DeletionDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DeletionDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DeletionDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DeletionDAOTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DeletionDAOTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql;
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DeletionDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DeletionDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DeletionDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DeletionDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DeletionDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DeletionDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DeletionDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DeletionDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DeletionDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DeletionDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DeletionDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DeletionDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DeletionDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DeletionDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DeletionDAOTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DeletionDAOTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql;
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DeletionDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DeletionDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DeletionDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DeletionDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DeletionDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DeletionDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DeletionDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DeletionDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DeletionDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DeletionDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DeletionDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DeletionDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DeletionDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DeletionDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DeletionDAOTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DeletionDAOTest.xml:Caused by: org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DeletionDAOTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql;
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DeletionDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DeletionDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DeletionDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DeletionDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DeletionDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DeletionDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DeletionDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DeletionDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DeletionDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DeletionDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DeletionDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DeletionDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DeletionDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DeletionDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DeletionDAOTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DeletionDAOTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql;
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DeletionDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DeletionDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DeletionDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DeletionDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DeletionDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DeletionDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DeletionDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DeletionDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DeletionDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DeletionDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DeletionDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DeletionDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DeletionDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DeletionDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DeletionDAOTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DeletionDAOTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql;
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DeletionDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DeletionDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DeletionDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DeletionDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DeletionDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DeletionDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DeletionDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DeletionDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DeletionDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DeletionDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DeletionDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DeletionDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DeletionDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DeletionDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DeletionDAOTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DeletionDAOTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql;
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DeletionDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DeletionDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DeletionDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DeletionDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DeletionDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DeletionDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DeletionDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DeletionDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DeletionDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DeletionDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DeletionDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DeletionDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DeletionDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DeletionDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DeletionDAOTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DeletionDAOTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql;
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DeletionDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DeletionDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DeletionDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DeletionDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DeletionDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DeletionDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DeletionDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DeletionDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DeletionDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DeletionDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DeletionDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DeletionDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DeletionDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DeletionDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DeletionDAOTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DeletionDAOTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql;
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DeletionDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DeletionDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DeletionDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DeletionDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DeletionDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DeletionDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DeletionDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DeletionDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DeletionDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DeletionDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DeletionDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DeletionDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DeletionDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DeletionDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DeletionDAOTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DeletionDAOTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql;
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DeletionDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DeletionDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DeletionDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DeletionDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DeletionDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DeletionDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DeletionDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DeletionDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DeletionDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DeletionDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DeletionDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DeletionDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DeletionDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DeletionDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DeletionDAOTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DeletionDAOTest.xml:Caused by: org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DeletionDAOTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql;
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DeletionDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DeletionDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DeletionDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DeletionDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DeletionDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DeletionDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DeletionDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DeletionDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DeletionDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DeletionDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DeletionDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DeletionDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DeletionDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DeletionDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DeletionDAOTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DeletionDAOTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql;
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DeletionDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DeletionDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DeletionDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DeletionDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DeletionDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DeletionDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DeletionDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DeletionDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DeletionDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DeletionDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DeletionDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DeletionDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DeletionDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DeletionDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DeletionDAOTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DeletionDAOTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql;
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DeletionDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DeletionDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DeletionDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DeletionDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DeletionDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DeletionDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DeletionDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DeletionDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DeletionDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DeletionDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DeletionDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DeletionDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DeletionDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DeletionDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DeletionDAOTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DeletionDAOTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql;
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DeletionDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DeletionDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DeletionDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DeletionDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DeletionDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DeletionDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DeletionDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DeletionDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DeletionDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DeletionDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DeletionDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DeletionDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DeletionDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DeletionDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DeletionDAOTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DeletionDAOTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql;
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DeletionDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DeletionDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DeletionDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DeletionDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DeletionDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DeletionDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DeletionDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DeletionDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DeletionDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DeletionDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DeletionDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DeletionDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DeletionDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DeletionDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DeletionDAOTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DeletionDAOTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql;
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DeletionDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DeletionDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DeletionDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DeletionDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DeletionDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DeletionDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DeletionDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DeletionDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DeletionDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DeletionDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DeletionDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DeletionDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DeletionDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DeletionDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DeletionDAOTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DeletionDAOTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql;
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DeletionDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DeletionDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DeletionDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DeletionDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DeletionDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DeletionDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DeletionDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DeletionDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DeletionDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DeletionDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DeletionDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DeletionDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DeletionDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DeletionDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DeletionDAOTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.DeletionDAOTest.xml:Caused by: org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql;
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql;
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql;
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql;
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql;
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql;
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql;
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml:Caused by: org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql;
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql;
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql;
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql;
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql;
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql;
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql;
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml:Caused by: org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql;
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql;
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql;
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql;
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql;
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql;
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql;
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml:Caused by: org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql;
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql;
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql;
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql;
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql;
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql;
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql;
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml:Caused by: org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql;
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql;
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql;
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql;
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql;
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql;
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql;
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml:Caused by: org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql;
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql;
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql;
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql;
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql;
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql;
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql;
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml:Caused by: org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql;
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql;
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql;
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql;
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql;
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql;
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql;
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml:Caused by: org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql;
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql;
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql;
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql;
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql;
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql;
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql;
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml:Caused by: org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql;
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql;
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql;
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql;
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql;
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql;
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql;
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml:Caused by: org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql;
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql;
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql;
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql;
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql;
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql;
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql;
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml:Caused by: org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql;
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql;
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql;
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql;
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql;
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql;
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql;
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml:Caused by: org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql;
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql;
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql;
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql;
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql;
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql;
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql;
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml:Caused by: org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql;
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql;
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql;
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql;
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql;
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql;
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql;
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityPropertyTypeDAOTest.xml:Caused by: org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityTypeDAOTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql;
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityTypeDAOTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityTypeDAOTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql;
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityTypeDAOTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityTypeDAOTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql;
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityTypeDAOTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityTypeDAOTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql;
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityTypeDAOTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityTypeDAOTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql;
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityTypeDAOTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityTypeDAOTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql;
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityTypeDAOTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityTypeDAOTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql;
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityTypeDAOTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityTypeDAOTest.xml:Caused by: org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityTypeDAOTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql;
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityTypeDAOTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityTypeDAOTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql;
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityTypeDAOTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityTypeDAOTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql;
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityTypeDAOTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityTypeDAOTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql;
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityTypeDAOTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityTypeDAOTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql;
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityTypeDAOTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityTypeDAOTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql;
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityTypeDAOTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityTypeDAOTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql;
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityTypeDAOTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityTypeDAOTest.xml:Caused by: org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityTypeDAOTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql;
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityTypeDAOTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityTypeDAOTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql;
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityTypeDAOTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityTypeDAOTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql;
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityTypeDAOTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityTypeDAOTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql;
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityTypeDAOTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityTypeDAOTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql;
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityTypeDAOTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityTypeDAOTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql;
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityTypeDAOTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityTypeDAOTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql;
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityTypeDAOTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityTypeDAOTest.xml:Caused by: org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityTypeDAOTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql;
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityTypeDAOTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityTypeDAOTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql;
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityTypeDAOTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityTypeDAOTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql;
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityTypeDAOTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityTypeDAOTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql;
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityTypeDAOTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityTypeDAOTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql;
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityTypeDAOTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityTypeDAOTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql;
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityTypeDAOTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityTypeDAOTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql;
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityTypeDAOTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityTypeDAOTest.xml:Caused by: org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityTypeDAOTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql;
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityTypeDAOTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityTypeDAOTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql;
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityTypeDAOTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityTypeDAOTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql;
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityTypeDAOTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityTypeDAOTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql;
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityTypeDAOTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityTypeDAOTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql;
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityTypeDAOTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityTypeDAOTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql;
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityTypeDAOTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityTypeDAOTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql;
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityTypeDAOTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityTypeDAOTest.xml:Caused by: org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityTypeDAOTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql;
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityTypeDAOTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityTypeDAOTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql;
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityTypeDAOTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityTypeDAOTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql;
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityTypeDAOTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityTypeDAOTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql;
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityTypeDAOTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityTypeDAOTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql;
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityTypeDAOTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityTypeDAOTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql;
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityTypeDAOTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityTypeDAOTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql;
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityTypeDAOTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityTypeDAOTest.xml:Caused by: org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityTypeDAOTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql;
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityTypeDAOTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityTypeDAOTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql;
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityTypeDAOTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityTypeDAOTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql;
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityTypeDAOTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityTypeDAOTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql;
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityTypeDAOTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityTypeDAOTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql;
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityTypeDAOTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityTypeDAOTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql;
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityTypeDAOTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityTypeDAOTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql;
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityTypeDAOTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityTypeDAOTest.xml:Caused by: org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityTypeDAOTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql;
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityTypeDAOTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityTypeDAOTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql;
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityTypeDAOTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityTypeDAOTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql;
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityTypeDAOTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityTypeDAOTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql;
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityTypeDAOTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityTypeDAOTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql;
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityTypeDAOTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityTypeDAOTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql;
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityTypeDAOTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityTypeDAOTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql;
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityTypeDAOTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityTypeDAOTest.xml:Caused by: org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityTypeDAOTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql;
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityTypeDAOTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityTypeDAOTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql;
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityTypeDAOTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityTypeDAOTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql;
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityTypeDAOTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityTypeDAOTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql;
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityTypeDAOTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityTypeDAOTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql;
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityTypeDAOTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityTypeDAOTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql;
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityTypeDAOTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityTypeDAOTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql;
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityTypeDAOTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityTypeDAOTest.xml:Caused by: org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityTypeDAOTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql;
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityTypeDAOTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityTypeDAOTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql;
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityTypeDAOTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityTypeDAOTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql;
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityTypeDAOTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityTypeDAOTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql;
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityTypeDAOTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityTypeDAOTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql;
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityTypeDAOTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityTypeDAOTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql;
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityTypeDAOTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityTypeDAOTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql;
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityTypeDAOTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EntityTypeDAOTest.xml:Caused by: org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EventDAOTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql;
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EventDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EventDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EventDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EventDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EventDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EventDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EventDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EventDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EventDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EventDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EventDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EventDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EventDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EventDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EventDAOTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EventDAOTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql;
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EventDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EventDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EventDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EventDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EventDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EventDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EventDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EventDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EventDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EventDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EventDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EventDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EventDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EventDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EventDAOTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EventDAOTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql;
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EventDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EventDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EventDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EventDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EventDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EventDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EventDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EventDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EventDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EventDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EventDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EventDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EventDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EventDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EventDAOTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EventDAOTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql;
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EventDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EventDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EventDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EventDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EventDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EventDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EventDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EventDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EventDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EventDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EventDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EventDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EventDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EventDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EventDAOTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EventDAOTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql;
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EventDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EventDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EventDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EventDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EventDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EventDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EventDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EventDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EventDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EventDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EventDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EventDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EventDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EventDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EventDAOTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EventDAOTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql;
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EventDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EventDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EventDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EventDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EventDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EventDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EventDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EventDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EventDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EventDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EventDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EventDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EventDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EventDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EventDAOTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EventDAOTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql;
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EventDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EventDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EventDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EventDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EventDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EventDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EventDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EventDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EventDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EventDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EventDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EventDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EventDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EventDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EventDAOTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EventDAOTest.xml:Caused by: org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EventDAOTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql;
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EventDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EventDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EventDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EventDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EventDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EventDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EventDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EventDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EventDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EventDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EventDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EventDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EventDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EventDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EventDAOTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EventDAOTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql;
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EventDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EventDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EventDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EventDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EventDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EventDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EventDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EventDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EventDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EventDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EventDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EventDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EventDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EventDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EventDAOTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EventDAOTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql;
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EventDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EventDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EventDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EventDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EventDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EventDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EventDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EventDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EventDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EventDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EventDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EventDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EventDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EventDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EventDAOTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EventDAOTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql;
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EventDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EventDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EventDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EventDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EventDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EventDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EventDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EventDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EventDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EventDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EventDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EventDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EventDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EventDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EventDAOTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EventDAOTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql;
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EventDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EventDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EventDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EventDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EventDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EventDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EventDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EventDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EventDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EventDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EventDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EventDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EventDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EventDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EventDAOTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EventDAOTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql;
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EventDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EventDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EventDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EventDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EventDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EventDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EventDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EventDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EventDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EventDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EventDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EventDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EventDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EventDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EventDAOTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EventDAOTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql;
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EventDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EventDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EventDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EventDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EventDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EventDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EventDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EventDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EventDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EventDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EventDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EventDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EventDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EventDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EventDAOTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EventDAOTest.xml:Caused by: org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EventDAOTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql;
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EventDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EventDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EventDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EventDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EventDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EventDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EventDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EventDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EventDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EventDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EventDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EventDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EventDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EventDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EventDAOTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EventDAOTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql;
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EventDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EventDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EventDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EventDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EventDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EventDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EventDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EventDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EventDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EventDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EventDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EventDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EventDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EventDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EventDAOTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EventDAOTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql;
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EventDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EventDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EventDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EventDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EventDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EventDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EventDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EventDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EventDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EventDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EventDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EventDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EventDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EventDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EventDAOTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EventDAOTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql;
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EventDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EventDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EventDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EventDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EventDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EventDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EventDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EventDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EventDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EventDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EventDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EventDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EventDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EventDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EventDAOTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EventDAOTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql;
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EventDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EventDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EventDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EventDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EventDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EventDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EventDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EventDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EventDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EventDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EventDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EventDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EventDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EventDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EventDAOTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EventDAOTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql;
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EventDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EventDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EventDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EventDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EventDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EventDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EventDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EventDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EventDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EventDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EventDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EventDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EventDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EventDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EventDAOTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EventDAOTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql;
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EventDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EventDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EventDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EventDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EventDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EventDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EventDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EventDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EventDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EventDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EventDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EventDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EventDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EventDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EventDAOTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EventDAOTest.xml:Caused by: org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EventDAOTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql;
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EventDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EventDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EventDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EventDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EventDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EventDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EventDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EventDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EventDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EventDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EventDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EventDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EventDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EventDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EventDAOTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EventDAOTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql;
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EventDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EventDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EventDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EventDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EventDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EventDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EventDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EventDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EventDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EventDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EventDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EventDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EventDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EventDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EventDAOTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EventDAOTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql;
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EventDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EventDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EventDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EventDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EventDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EventDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EventDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EventDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EventDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EventDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EventDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EventDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EventDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EventDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EventDAOTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EventDAOTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql;
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EventDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EventDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EventDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EventDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EventDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EventDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EventDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EventDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EventDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EventDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EventDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EventDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EventDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EventDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EventDAOTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EventDAOTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql;
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EventDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EventDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EventDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EventDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EventDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EventDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EventDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EventDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EventDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EventDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EventDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EventDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EventDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EventDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EventDAOTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EventDAOTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql;
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EventDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EventDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EventDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EventDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EventDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EventDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EventDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EventDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EventDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EventDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EventDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EventDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EventDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EventDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EventDAOTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EventDAOTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql;
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EventDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EventDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EventDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EventDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EventDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EventDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EventDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EventDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EventDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EventDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EventDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EventDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EventDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EventDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EventDAOTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EventDAOTest.xml:Caused by: org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EventDAOTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql;
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EventDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EventDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EventDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EventDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EventDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EventDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EventDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EventDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EventDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EventDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EventDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EventDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EventDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EventDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EventDAOTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EventDAOTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql;
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EventDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EventDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EventDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EventDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EventDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EventDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EventDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EventDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EventDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EventDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EventDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EventDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EventDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EventDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EventDAOTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EventDAOTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql;
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EventDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EventDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EventDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EventDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EventDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EventDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EventDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EventDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EventDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EventDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EventDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EventDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EventDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EventDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EventDAOTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EventDAOTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql;
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EventDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EventDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EventDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EventDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EventDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EventDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EventDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EventDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EventDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EventDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EventDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EventDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EventDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EventDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EventDAOTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EventDAOTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql;
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EventDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EventDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EventDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EventDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EventDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EventDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EventDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EventDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EventDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EventDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EventDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EventDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EventDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EventDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EventDAOTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EventDAOTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql;
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EventDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EventDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EventDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EventDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EventDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EventDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EventDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EventDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EventDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EventDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EventDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EventDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EventDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EventDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EventDAOTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EventDAOTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql;
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EventDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EventDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EventDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EventDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EventDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EventDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EventDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EventDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EventDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EventDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EventDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EventDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EventDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EventDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EventDAOTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EventDAOTest.xml:Caused by: org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EventDAOTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql;
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EventDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EventDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EventDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EventDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EventDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EventDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EventDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EventDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EventDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EventDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EventDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EventDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EventDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EventDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EventDAOTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EventDAOTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql;
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EventDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EventDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EventDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EventDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EventDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EventDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EventDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EventDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EventDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EventDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EventDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EventDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EventDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EventDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EventDAOTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EventDAOTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql;
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EventDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EventDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EventDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EventDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EventDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EventDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EventDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EventDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EventDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EventDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EventDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EventDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EventDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EventDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EventDAOTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EventDAOTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql;
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EventDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EventDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EventDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EventDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EventDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EventDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EventDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EventDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EventDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EventDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EventDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EventDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EventDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EventDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EventDAOTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EventDAOTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql;
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EventDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EventDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EventDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EventDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EventDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EventDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EventDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EventDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EventDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EventDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EventDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EventDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EventDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EventDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EventDAOTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EventDAOTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql;
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EventDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EventDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EventDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EventDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EventDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EventDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EventDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EventDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EventDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EventDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EventDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EventDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EventDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EventDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EventDAOTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EventDAOTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql;
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EventDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EventDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EventDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EventDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EventDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EventDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EventDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EventDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EventDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EventDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EventDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EventDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EventDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EventDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EventDAOTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EventDAOTest.xml:Caused by: org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EventDAOTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql;
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EventDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EventDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EventDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EventDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EventDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EventDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EventDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EventDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EventDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EventDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EventDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EventDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EventDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EventDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EventDAOTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EventDAOTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql;
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EventDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EventDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EventDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EventDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EventDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EventDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EventDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EventDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EventDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EventDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EventDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EventDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EventDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EventDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EventDAOTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EventDAOTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql;
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EventDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EventDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EventDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EventDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EventDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EventDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EventDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EventDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EventDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EventDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EventDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EventDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EventDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EventDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EventDAOTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EventDAOTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql;
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EventDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EventDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EventDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EventDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EventDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EventDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EventDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EventDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EventDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EventDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EventDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EventDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EventDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EventDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EventDAOTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EventDAOTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql;
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EventDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EventDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EventDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EventDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EventDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EventDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EventDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EventDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EventDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EventDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EventDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EventDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EventDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EventDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EventDAOTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EventDAOTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql;
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EventDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EventDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EventDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EventDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EventDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EventDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EventDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EventDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EventDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EventDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EventDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EventDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EventDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EventDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EventDAOTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EventDAOTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql;
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EventDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EventDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EventDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EventDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EventDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EventDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EventDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EventDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EventDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EventDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EventDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EventDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EventDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EventDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EventDAOTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.EventDAOTest.xml:Caused by: org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql;
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql;
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql;
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql;
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql;
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql;
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql;
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:Caused by: org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql;
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql;
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql;
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql;
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql;
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql;
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql;
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:Caused by: org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql;
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql;
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql;
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql;
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql;
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql;
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql;
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:Caused by: org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql;
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql;
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql;
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql;
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql;
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql;
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql;
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:Caused by: org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql;
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql;
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql;
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql;
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql;
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql;
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql;
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:Caused by: org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql;
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql;
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql;
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql;
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql;
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql;
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql;
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:Caused by: org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql;
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql;
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql;
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql;
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql;
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql;
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql;
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:Caused by: org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql;
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql;
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql;
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql;
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql;
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql;
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql;
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:Caused by: org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql;
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql;
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql;
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql;
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql;
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql;
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql;
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:Caused by: org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql;
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql;
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql;
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql;
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql;
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql;
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql;
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:Caused by: org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql;
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql;
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql;
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql;
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql;
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql;
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql;
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:Caused by: org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql;
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql;
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql;
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql;
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql;
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql;
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql;
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:Caused by: org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql;
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql;
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql;
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql;
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql;
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql;
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql;
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:Caused by: org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql;
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql;
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql;
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql;
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql;
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql;
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql;
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:Caused by: org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql;
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql;
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql;
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql;
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql;
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql;
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql;
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:Caused by: org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql;
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql;
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql;
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql;
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql;
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql;
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql;
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:Caused by: org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql;
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql;
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql;
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql;
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql;
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql;
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql;
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:Caused by: org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql;
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql;
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql;
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql;
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql;
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql;
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql;
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:Caused by: org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql;
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql;
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql;
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql;
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql;
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql;
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql;
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:Caused by: org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql;
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql;
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql;
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql;
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql;
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql;
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql;
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:Caused by: org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql;
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql;
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql;
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql;
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql;
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql;
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql;
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:Caused by: org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql;
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql;
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql;
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql;
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql;
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql;
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql;
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:Caused by: org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql;
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql;
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql;
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql;
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql;
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql;
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql;
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:Caused by: org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql;
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql;
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql;
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql;
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql;
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql;
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql;
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:Caused by: org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql;
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql;
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql;
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql;
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql;
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql;
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql;
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ExperimentDAOTest.xml:Caused by: org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.FileFormatTypeDAOTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql;
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.FileFormatTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.FileFormatTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.FileFormatTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.FileFormatTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.FileFormatTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.FileFormatTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.FileFormatTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.FileFormatTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.FileFormatTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.FileFormatTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.FileFormatTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.FileFormatTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.FileFormatTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.FileFormatTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.FileFormatTypeDAOTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.FileFormatTypeDAOTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql;
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.FileFormatTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.FileFormatTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.FileFormatTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.FileFormatTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.FileFormatTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.FileFormatTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.FileFormatTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.FileFormatTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.FileFormatTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.FileFormatTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.FileFormatTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.FileFormatTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.FileFormatTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.FileFormatTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.FileFormatTypeDAOTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.FileFormatTypeDAOTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql;
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.FileFormatTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.FileFormatTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.FileFormatTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.FileFormatTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.FileFormatTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.FileFormatTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.FileFormatTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.FileFormatTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.FileFormatTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.FileFormatTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.FileFormatTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.FileFormatTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.FileFormatTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.FileFormatTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.FileFormatTypeDAOTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.FileFormatTypeDAOTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql;
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.FileFormatTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.FileFormatTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.FileFormatTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.FileFormatTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.FileFormatTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.FileFormatTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.FileFormatTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.FileFormatTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.FileFormatTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.FileFormatTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.FileFormatTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.FileFormatTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.FileFormatTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.FileFormatTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.FileFormatTypeDAOTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.FileFormatTypeDAOTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql;
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.FileFormatTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.FileFormatTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.FileFormatTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.FileFormatTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.FileFormatTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.FileFormatTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.FileFormatTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.FileFormatTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.FileFormatTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.FileFormatTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.FileFormatTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.FileFormatTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.FileFormatTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.FileFormatTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.FileFormatTypeDAOTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.FileFormatTypeDAOTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql;
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.FileFormatTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.FileFormatTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.FileFormatTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.FileFormatTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.FileFormatTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.FileFormatTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.FileFormatTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.FileFormatTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.FileFormatTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.FileFormatTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.FileFormatTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.FileFormatTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.FileFormatTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.FileFormatTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.FileFormatTypeDAOTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.FileFormatTypeDAOTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql;
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.FileFormatTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.FileFormatTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.FileFormatTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.FileFormatTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.FileFormatTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.FileFormatTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.FileFormatTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.FileFormatTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.FileFormatTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.FileFormatTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.FileFormatTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.FileFormatTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.FileFormatTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.FileFormatTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.FileFormatTypeDAOTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.FileFormatTypeDAOTest.xml:Caused by: org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.FileFormatTypeDAOTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql;
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.FileFormatTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.FileFormatTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.FileFormatTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.FileFormatTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.FileFormatTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.FileFormatTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.FileFormatTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.FileFormatTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.FileFormatTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.FileFormatTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.FileFormatTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.FileFormatTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.FileFormatTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.FileFormatTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.FileFormatTypeDAOTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.FileFormatTypeDAOTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql;
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.FileFormatTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.FileFormatTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.FileFormatTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.FileFormatTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.FileFormatTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.FileFormatTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.FileFormatTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.FileFormatTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.FileFormatTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.FileFormatTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.FileFormatTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.FileFormatTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.FileFormatTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.FileFormatTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.FileFormatTypeDAOTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.FileFormatTypeDAOTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql;
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.FileFormatTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.FileFormatTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.FileFormatTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.FileFormatTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.FileFormatTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.FileFormatTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.FileFormatTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.FileFormatTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.FileFormatTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.FileFormatTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.FileFormatTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.FileFormatTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.FileFormatTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.FileFormatTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.FileFormatTypeDAOTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.FileFormatTypeDAOTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql;
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.FileFormatTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.FileFormatTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.FileFormatTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.FileFormatTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.FileFormatTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.FileFormatTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.FileFormatTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.FileFormatTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.FileFormatTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.FileFormatTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.FileFormatTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.FileFormatTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.FileFormatTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.FileFormatTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.FileFormatTypeDAOTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.FileFormatTypeDAOTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql;
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.FileFormatTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.FileFormatTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.FileFormatTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.FileFormatTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.FileFormatTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.FileFormatTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.FileFormatTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.FileFormatTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.FileFormatTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.FileFormatTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.FileFormatTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.FileFormatTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.FileFormatTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.FileFormatTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.FileFormatTypeDAOTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.FileFormatTypeDAOTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql;
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.FileFormatTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.FileFormatTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.FileFormatTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.FileFormatTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.FileFormatTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.FileFormatTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.FileFormatTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.FileFormatTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.FileFormatTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.FileFormatTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.FileFormatTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.FileFormatTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.FileFormatTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.FileFormatTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.FileFormatTypeDAOTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.FileFormatTypeDAOTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql;
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.FileFormatTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.FileFormatTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.FileFormatTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.FileFormatTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.FileFormatTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.FileFormatTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.FileFormatTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.FileFormatTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.FileFormatTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.FileFormatTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.FileFormatTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.FileFormatTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.FileFormatTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.FileFormatTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.FileFormatTypeDAOTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.FileFormatTypeDAOTest.xml:Caused by: org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.FileFormatTypeDAOTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql;
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.FileFormatTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.FileFormatTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.FileFormatTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.FileFormatTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.FileFormatTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.FileFormatTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.FileFormatTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.FileFormatTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.FileFormatTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.FileFormatTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.FileFormatTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.FileFormatTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.FileFormatTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.FileFormatTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.FileFormatTypeDAOTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.FileFormatTypeDAOTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql;
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.FileFormatTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.FileFormatTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.FileFormatTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.FileFormatTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.FileFormatTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.FileFormatTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.FileFormatTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.FileFormatTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.FileFormatTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.FileFormatTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.FileFormatTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.FileFormatTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.FileFormatTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.FileFormatTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.FileFormatTypeDAOTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.FileFormatTypeDAOTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql;
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.FileFormatTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.FileFormatTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.FileFormatTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.FileFormatTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.FileFormatTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.FileFormatTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.FileFormatTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.FileFormatTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.FileFormatTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.FileFormatTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.FileFormatTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.FileFormatTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.FileFormatTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.FileFormatTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.FileFormatTypeDAOTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.FileFormatTypeDAOTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql;
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.FileFormatTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.FileFormatTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.FileFormatTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.FileFormatTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.FileFormatTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.FileFormatTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.FileFormatTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.FileFormatTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.FileFormatTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.FileFormatTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.FileFormatTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.FileFormatTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.FileFormatTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.FileFormatTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.FileFormatTypeDAOTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.FileFormatTypeDAOTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql;
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.FileFormatTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.FileFormatTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.FileFormatTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.FileFormatTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.FileFormatTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.FileFormatTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.FileFormatTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.FileFormatTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.FileFormatTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.FileFormatTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.FileFormatTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.FileFormatTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.FileFormatTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.FileFormatTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.FileFormatTypeDAOTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.FileFormatTypeDAOTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql;
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.FileFormatTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.FileFormatTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.FileFormatTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.FileFormatTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.FileFormatTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.FileFormatTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.FileFormatTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.FileFormatTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.FileFormatTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.FileFormatTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.FileFormatTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.FileFormatTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.FileFormatTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.FileFormatTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.FileFormatTypeDAOTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.FileFormatTypeDAOTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql;
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.FileFormatTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.FileFormatTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.FileFormatTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.FileFormatTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.FileFormatTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.FileFormatTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.FileFormatTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.FileFormatTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.FileFormatTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.FileFormatTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.FileFormatTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.FileFormatTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.FileFormatTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.FileFormatTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.FileFormatTypeDAOTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.FileFormatTypeDAOTest.xml:Caused by: org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.FileFormatTypeDAOTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql;
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.FileFormatTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.FileFormatTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.FileFormatTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.FileFormatTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.FileFormatTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.FileFormatTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.FileFormatTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.FileFormatTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.FileFormatTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.FileFormatTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.FileFormatTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.FileFormatTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.FileFormatTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.FileFormatTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.FileFormatTypeDAOTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.FileFormatTypeDAOTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql;
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.FileFormatTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.FileFormatTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.FileFormatTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.FileFormatTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.FileFormatTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.FileFormatTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.FileFormatTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.FileFormatTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.FileFormatTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.FileFormatTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.FileFormatTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.FileFormatTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.FileFormatTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.FileFormatTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.FileFormatTypeDAOTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.FileFormatTypeDAOTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql;
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.FileFormatTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.FileFormatTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.FileFormatTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.FileFormatTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.FileFormatTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.FileFormatTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.FileFormatTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.FileFormatTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.FileFormatTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.FileFormatTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.FileFormatTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.FileFormatTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.FileFormatTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.FileFormatTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.FileFormatTypeDAOTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.FileFormatTypeDAOTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql;
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.FileFormatTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.FileFormatTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.FileFormatTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.FileFormatTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.FileFormatTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.FileFormatTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.FileFormatTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.FileFormatTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.FileFormatTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.FileFormatTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.FileFormatTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.FileFormatTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.FileFormatTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.FileFormatTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.FileFormatTypeDAOTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.FileFormatTypeDAOTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql;
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.FileFormatTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.FileFormatTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.FileFormatTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.FileFormatTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.FileFormatTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.FileFormatTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.FileFormatTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.FileFormatTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.FileFormatTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.FileFormatTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.FileFormatTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.FileFormatTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.FileFormatTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.FileFormatTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.FileFormatTypeDAOTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.FileFormatTypeDAOTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql;
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.FileFormatTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.FileFormatTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.FileFormatTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.FileFormatTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.FileFormatTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.FileFormatTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.FileFormatTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.FileFormatTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.FileFormatTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.FileFormatTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.FileFormatTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.FileFormatTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.FileFormatTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.FileFormatTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.FileFormatTypeDAOTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.FileFormatTypeDAOTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql;
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.FileFormatTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.FileFormatTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.FileFormatTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.FileFormatTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.FileFormatTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.FileFormatTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.FileFormatTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.FileFormatTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.FileFormatTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.FileFormatTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.FileFormatTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.FileFormatTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.FileFormatTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.FileFormatTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.FileFormatTypeDAOTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.FileFormatTypeDAOTest.xml:Caused by: org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.GridCustomColumnDAOTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql;
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.GridCustomColumnDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.GridCustomColumnDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.GridCustomColumnDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.GridCustomColumnDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.GridCustomColumnDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.GridCustomColumnDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.GridCustomColumnDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.GridCustomColumnDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.GridCustomColumnDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.GridCustomColumnDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.GridCustomColumnDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.GridCustomColumnDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.GridCustomColumnDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.GridCustomColumnDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.GridCustomColumnDAOTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.GridCustomColumnDAOTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql;
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.GridCustomColumnDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.GridCustomColumnDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.GridCustomColumnDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.GridCustomColumnDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.GridCustomColumnDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.GridCustomColumnDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.GridCustomColumnDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.GridCustomColumnDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.GridCustomColumnDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.GridCustomColumnDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.GridCustomColumnDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.GridCustomColumnDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.GridCustomColumnDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.GridCustomColumnDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.GridCustomColumnDAOTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.GridCustomColumnDAOTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql;
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.GridCustomColumnDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.GridCustomColumnDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.GridCustomColumnDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.GridCustomColumnDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.GridCustomColumnDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.GridCustomColumnDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.GridCustomColumnDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.GridCustomColumnDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.GridCustomColumnDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.GridCustomColumnDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.GridCustomColumnDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.GridCustomColumnDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.GridCustomColumnDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.GridCustomColumnDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.GridCustomColumnDAOTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.GridCustomColumnDAOTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql;
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.GridCustomColumnDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.GridCustomColumnDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.GridCustomColumnDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.GridCustomColumnDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.GridCustomColumnDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.GridCustomColumnDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.GridCustomColumnDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.GridCustomColumnDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.GridCustomColumnDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.GridCustomColumnDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.GridCustomColumnDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.GridCustomColumnDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.GridCustomColumnDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.GridCustomColumnDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.GridCustomColumnDAOTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.GridCustomColumnDAOTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql;
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.GridCustomColumnDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.GridCustomColumnDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.GridCustomColumnDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.GridCustomColumnDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.GridCustomColumnDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.GridCustomColumnDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.GridCustomColumnDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.GridCustomColumnDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.GridCustomColumnDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.GridCustomColumnDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.GridCustomColumnDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.GridCustomColumnDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.GridCustomColumnDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.GridCustomColumnDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.GridCustomColumnDAOTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.GridCustomColumnDAOTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql;
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.GridCustomColumnDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.GridCustomColumnDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.GridCustomColumnDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.GridCustomColumnDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.GridCustomColumnDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.GridCustomColumnDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.GridCustomColumnDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.GridCustomColumnDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.GridCustomColumnDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.GridCustomColumnDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.GridCustomColumnDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.GridCustomColumnDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.GridCustomColumnDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.GridCustomColumnDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.GridCustomColumnDAOTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.GridCustomColumnDAOTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql;
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.GridCustomColumnDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.GridCustomColumnDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.GridCustomColumnDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.GridCustomColumnDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.GridCustomColumnDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.GridCustomColumnDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.GridCustomColumnDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.GridCustomColumnDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.GridCustomColumnDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.GridCustomColumnDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.GridCustomColumnDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.GridCustomColumnDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.GridCustomColumnDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.GridCustomColumnDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.GridCustomColumnDAOTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.GridCustomColumnDAOTest.xml:Caused by: org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.GridCustomFilterDAOTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql;
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.GridCustomFilterDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.GridCustomFilterDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.GridCustomFilterDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.GridCustomFilterDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.GridCustomFilterDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.GridCustomFilterDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.GridCustomFilterDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.GridCustomFilterDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.GridCustomFilterDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.GridCustomFilterDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.GridCustomFilterDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.GridCustomFilterDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.GridCustomFilterDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.GridCustomFilterDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.GridCustomFilterDAOTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.GridCustomFilterDAOTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql;
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.GridCustomFilterDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.GridCustomFilterDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.GridCustomFilterDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.GridCustomFilterDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.GridCustomFilterDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.GridCustomFilterDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.GridCustomFilterDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.GridCustomFilterDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.GridCustomFilterDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.GridCustomFilterDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.GridCustomFilterDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.GridCustomFilterDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.GridCustomFilterDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.GridCustomFilterDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.GridCustomFilterDAOTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.GridCustomFilterDAOTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql;
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.GridCustomFilterDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.GridCustomFilterDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.GridCustomFilterDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.GridCustomFilterDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.GridCustomFilterDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.GridCustomFilterDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.GridCustomFilterDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.GridCustomFilterDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.GridCustomFilterDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.GridCustomFilterDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.GridCustomFilterDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.GridCustomFilterDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.GridCustomFilterDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.GridCustomFilterDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.GridCustomFilterDAOTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.GridCustomFilterDAOTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql;
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.GridCustomFilterDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.GridCustomFilterDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.GridCustomFilterDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.GridCustomFilterDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.GridCustomFilterDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.GridCustomFilterDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.GridCustomFilterDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.GridCustomFilterDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.GridCustomFilterDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.GridCustomFilterDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.GridCustomFilterDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.GridCustomFilterDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.GridCustomFilterDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.GridCustomFilterDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.GridCustomFilterDAOTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.GridCustomFilterDAOTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql;
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.GridCustomFilterDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.GridCustomFilterDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.GridCustomFilterDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.GridCustomFilterDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.GridCustomFilterDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.GridCustomFilterDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.GridCustomFilterDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.GridCustomFilterDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.GridCustomFilterDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.GridCustomFilterDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.GridCustomFilterDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.GridCustomFilterDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.GridCustomFilterDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.GridCustomFilterDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.GridCustomFilterDAOTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.GridCustomFilterDAOTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql;
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.GridCustomFilterDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.GridCustomFilterDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.GridCustomFilterDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.GridCustomFilterDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.GridCustomFilterDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.GridCustomFilterDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.GridCustomFilterDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.GridCustomFilterDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.GridCustomFilterDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.GridCustomFilterDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.GridCustomFilterDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.GridCustomFilterDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.GridCustomFilterDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.GridCustomFilterDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.GridCustomFilterDAOTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.GridCustomFilterDAOTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql;
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.GridCustomFilterDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.GridCustomFilterDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.GridCustomFilterDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.GridCustomFilterDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.GridCustomFilterDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.GridCustomFilterDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.GridCustomFilterDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.GridCustomFilterDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.GridCustomFilterDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.GridCustomFilterDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.GridCustomFilterDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.GridCustomFilterDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.GridCustomFilterDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.GridCustomFilterDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.GridCustomFilterDAOTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.GridCustomFilterDAOTest.xml:Caused by: org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.GridCustomFilterDAOTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql;
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.GridCustomFilterDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.GridCustomFilterDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.GridCustomFilterDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.GridCustomFilterDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.GridCustomFilterDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.GridCustomFilterDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.GridCustomFilterDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.GridCustomFilterDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.GridCustomFilterDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.GridCustomFilterDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.GridCustomFilterDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.GridCustomFilterDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.GridCustomFilterDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.GridCustomFilterDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.GridCustomFilterDAOTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.GridCustomFilterDAOTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql;
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.GridCustomFilterDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.GridCustomFilterDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.GridCustomFilterDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.GridCustomFilterDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.GridCustomFilterDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.GridCustomFilterDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.GridCustomFilterDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.GridCustomFilterDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.GridCustomFilterDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.GridCustomFilterDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.GridCustomFilterDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.GridCustomFilterDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.GridCustomFilterDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.GridCustomFilterDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.GridCustomFilterDAOTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.GridCustomFilterDAOTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql;
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.GridCustomFilterDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.GridCustomFilterDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.GridCustomFilterDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.GridCustomFilterDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.GridCustomFilterDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.GridCustomFilterDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.GridCustomFilterDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.GridCustomFilterDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.GridCustomFilterDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.GridCustomFilterDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.GridCustomFilterDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.GridCustomFilterDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.GridCustomFilterDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.GridCustomFilterDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.GridCustomFilterDAOTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.GridCustomFilterDAOTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql;
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.GridCustomFilterDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.GridCustomFilterDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.GridCustomFilterDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.GridCustomFilterDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.GridCustomFilterDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.GridCustomFilterDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.GridCustomFilterDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.GridCustomFilterDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.GridCustomFilterDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.GridCustomFilterDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.GridCustomFilterDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.GridCustomFilterDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.GridCustomFilterDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.GridCustomFilterDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.GridCustomFilterDAOTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.GridCustomFilterDAOTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql;
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.GridCustomFilterDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.GridCustomFilterDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.GridCustomFilterDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.GridCustomFilterDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.GridCustomFilterDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.GridCustomFilterDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.GridCustomFilterDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.GridCustomFilterDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.GridCustomFilterDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.GridCustomFilterDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.GridCustomFilterDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.GridCustomFilterDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.GridCustomFilterDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.GridCustomFilterDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.GridCustomFilterDAOTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.GridCustomFilterDAOTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql;
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.GridCustomFilterDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.GridCustomFilterDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.GridCustomFilterDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.GridCustomFilterDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.GridCustomFilterDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.GridCustomFilterDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.GridCustomFilterDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.GridCustomFilterDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.GridCustomFilterDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.GridCustomFilterDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.GridCustomFilterDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.GridCustomFilterDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.GridCustomFilterDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.GridCustomFilterDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.GridCustomFilterDAOTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.GridCustomFilterDAOTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql;
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.GridCustomFilterDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.GridCustomFilterDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.GridCustomFilterDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.GridCustomFilterDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.GridCustomFilterDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.GridCustomFilterDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.GridCustomFilterDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.GridCustomFilterDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.GridCustomFilterDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.GridCustomFilterDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.GridCustomFilterDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.GridCustomFilterDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.GridCustomFilterDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.GridCustomFilterDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.GridCustomFilterDAOTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.GridCustomFilterDAOTest.xml:Caused by: org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.GridCustomFilterDAOTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql;
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.GridCustomFilterDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.GridCustomFilterDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.GridCustomFilterDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.GridCustomFilterDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.GridCustomFilterDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.GridCustomFilterDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.GridCustomFilterDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.GridCustomFilterDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.GridCustomFilterDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.GridCustomFilterDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.GridCustomFilterDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.GridCustomFilterDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.GridCustomFilterDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.GridCustomFilterDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.GridCustomFilterDAOTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.GridCustomFilterDAOTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql;
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.GridCustomFilterDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.GridCustomFilterDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.GridCustomFilterDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.GridCustomFilterDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.GridCustomFilterDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.GridCustomFilterDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.GridCustomFilterDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.GridCustomFilterDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.GridCustomFilterDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.GridCustomFilterDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.GridCustomFilterDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.GridCustomFilterDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.GridCustomFilterDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.GridCustomFilterDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.GridCustomFilterDAOTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.GridCustomFilterDAOTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql;
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.GridCustomFilterDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.GridCustomFilterDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.GridCustomFilterDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.GridCustomFilterDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.GridCustomFilterDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.GridCustomFilterDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.GridCustomFilterDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.GridCustomFilterDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.GridCustomFilterDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.GridCustomFilterDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.GridCustomFilterDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.GridCustomFilterDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.GridCustomFilterDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.GridCustomFilterDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.GridCustomFilterDAOTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.GridCustomFilterDAOTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql;
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.GridCustomFilterDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.GridCustomFilterDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.GridCustomFilterDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.GridCustomFilterDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.GridCustomFilterDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.GridCustomFilterDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.GridCustomFilterDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.GridCustomFilterDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.GridCustomFilterDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.GridCustomFilterDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.GridCustomFilterDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.GridCustomFilterDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.GridCustomFilterDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.GridCustomFilterDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.GridCustomFilterDAOTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.GridCustomFilterDAOTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql;
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.GridCustomFilterDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.GridCustomFilterDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.GridCustomFilterDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.GridCustomFilterDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.GridCustomFilterDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.GridCustomFilterDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.GridCustomFilterDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.GridCustomFilterDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.GridCustomFilterDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.GridCustomFilterDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.GridCustomFilterDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.GridCustomFilterDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.GridCustomFilterDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.GridCustomFilterDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.GridCustomFilterDAOTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.GridCustomFilterDAOTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql;
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.GridCustomFilterDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.GridCustomFilterDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.GridCustomFilterDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.GridCustomFilterDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.GridCustomFilterDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.GridCustomFilterDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.GridCustomFilterDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.GridCustomFilterDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.GridCustomFilterDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.GridCustomFilterDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.GridCustomFilterDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.GridCustomFilterDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.GridCustomFilterDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.GridCustomFilterDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.GridCustomFilterDAOTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.GridCustomFilterDAOTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql;
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.GridCustomFilterDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.GridCustomFilterDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.GridCustomFilterDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.GridCustomFilterDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.GridCustomFilterDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.GridCustomFilterDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.GridCustomFilterDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.GridCustomFilterDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.GridCustomFilterDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.GridCustomFilterDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.GridCustomFilterDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.GridCustomFilterDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.GridCustomFilterDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.GridCustomFilterDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.GridCustomFilterDAOTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.GridCustomFilterDAOTest.xml:Caused by: org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.GroupDAOTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql;
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.GroupDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.GroupDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.GroupDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.GroupDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.GroupDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.GroupDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.GroupDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.GroupDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.GroupDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.GroupDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.GroupDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.GroupDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.GroupDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.GroupDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.GroupDAOTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.GroupDAOTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql;
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.GroupDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.GroupDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.GroupDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.GroupDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.GroupDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.GroupDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.GroupDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.GroupDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.GroupDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.GroupDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.GroupDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.GroupDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.GroupDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.GroupDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.GroupDAOTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.GroupDAOTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql;
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.GroupDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.GroupDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.GroupDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.GroupDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.GroupDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.GroupDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.GroupDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.GroupDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.GroupDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.GroupDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.GroupDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.GroupDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.GroupDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.GroupDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.GroupDAOTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.GroupDAOTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql;
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.GroupDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.GroupDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.GroupDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.GroupDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.GroupDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.GroupDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.GroupDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.GroupDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.GroupDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.GroupDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.GroupDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.GroupDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.GroupDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.GroupDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.GroupDAOTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.GroupDAOTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql;
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.GroupDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.GroupDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.GroupDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.GroupDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.GroupDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.GroupDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.GroupDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.GroupDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.GroupDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.GroupDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.GroupDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.GroupDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.GroupDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.GroupDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.GroupDAOTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.GroupDAOTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql;
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.GroupDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.GroupDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.GroupDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.GroupDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.GroupDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.GroupDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.GroupDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.GroupDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.GroupDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.GroupDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.GroupDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.GroupDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.GroupDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.GroupDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.GroupDAOTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.GroupDAOTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql;
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.GroupDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.GroupDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.GroupDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.GroupDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.GroupDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.GroupDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.GroupDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.GroupDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.GroupDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.GroupDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.GroupDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.GroupDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.GroupDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.GroupDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.GroupDAOTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.GroupDAOTest.xml:Caused by: org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.GroupDAOTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql;
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.GroupDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.GroupDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.GroupDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.GroupDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.GroupDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.GroupDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.GroupDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.GroupDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.GroupDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.GroupDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.GroupDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.GroupDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.GroupDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.GroupDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.GroupDAOTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.GroupDAOTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql;
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.GroupDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.GroupDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.GroupDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.GroupDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.GroupDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.GroupDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.GroupDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.GroupDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.GroupDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.GroupDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.GroupDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.GroupDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.GroupDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.GroupDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.GroupDAOTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.GroupDAOTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql;
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.GroupDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.GroupDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.GroupDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.GroupDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.GroupDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.GroupDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.GroupDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.GroupDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.GroupDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.GroupDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.GroupDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.GroupDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.GroupDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.GroupDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.GroupDAOTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.GroupDAOTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql;
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.GroupDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.GroupDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.GroupDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.GroupDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.GroupDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.GroupDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.GroupDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.GroupDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.GroupDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.GroupDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.GroupDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.GroupDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.GroupDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.GroupDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.GroupDAOTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.GroupDAOTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql;
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.GroupDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.GroupDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.GroupDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.GroupDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.GroupDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.GroupDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.GroupDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.GroupDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.GroupDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.GroupDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.GroupDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.GroupDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.GroupDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.GroupDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.GroupDAOTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.GroupDAOTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql;
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.GroupDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.GroupDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.GroupDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.GroupDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.GroupDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.GroupDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.GroupDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.GroupDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.GroupDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.GroupDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.GroupDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.GroupDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.GroupDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.GroupDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.GroupDAOTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.GroupDAOTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql;
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.GroupDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.GroupDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.GroupDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.GroupDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.GroupDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.GroupDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.GroupDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.GroupDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.GroupDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.GroupDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.GroupDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.GroupDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.GroupDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.GroupDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.GroupDAOTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.GroupDAOTest.xml:Caused by: org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.GroupDAOTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql;
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.GroupDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.GroupDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.GroupDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.GroupDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.GroupDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.GroupDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.GroupDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.GroupDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.GroupDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.GroupDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.GroupDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.GroupDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.GroupDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.GroupDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.GroupDAOTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.GroupDAOTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql;
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.GroupDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.GroupDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.GroupDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.GroupDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.GroupDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.GroupDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.GroupDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.GroupDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.GroupDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.GroupDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.GroupDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.GroupDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.GroupDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.GroupDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.GroupDAOTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.GroupDAOTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql;
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.GroupDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.GroupDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.GroupDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.GroupDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.GroupDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.GroupDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.GroupDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.GroupDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.GroupDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.GroupDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.GroupDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.GroupDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.GroupDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.GroupDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.GroupDAOTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.GroupDAOTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql;
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.GroupDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.GroupDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.GroupDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.GroupDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.GroupDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.GroupDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.GroupDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.GroupDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.GroupDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.GroupDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.GroupDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.GroupDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.GroupDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.GroupDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.GroupDAOTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.GroupDAOTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql;
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.GroupDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.GroupDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.GroupDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.GroupDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.GroupDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.GroupDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.GroupDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.GroupDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.GroupDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.GroupDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.GroupDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.GroupDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.GroupDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.GroupDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.GroupDAOTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.GroupDAOTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql;
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.GroupDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.GroupDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.GroupDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.GroupDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.GroupDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.GroupDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.GroupDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.GroupDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.GroupDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.GroupDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.GroupDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.GroupDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.GroupDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.GroupDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.GroupDAOTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.GroupDAOTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql;
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.GroupDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.GroupDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.GroupDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.GroupDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.GroupDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.GroupDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.GroupDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.GroupDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.GroupDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.GroupDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.GroupDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.GroupDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.GroupDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.GroupDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.GroupDAOTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.GroupDAOTest.xml:Caused by: org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.GroupDAOTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql;
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.GroupDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.GroupDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.GroupDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.GroupDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.GroupDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.GroupDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.GroupDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.GroupDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.GroupDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.GroupDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.GroupDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.GroupDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.GroupDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.GroupDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.GroupDAOTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.GroupDAOTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql;
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.GroupDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.GroupDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.GroupDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.GroupDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.GroupDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.GroupDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.GroupDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.GroupDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.GroupDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.GroupDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.GroupDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.GroupDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.GroupDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.GroupDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.GroupDAOTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.GroupDAOTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql;
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.GroupDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.GroupDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.GroupDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.GroupDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.GroupDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.GroupDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.GroupDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.GroupDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.GroupDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.GroupDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.GroupDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.GroupDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.GroupDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.GroupDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.GroupDAOTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.GroupDAOTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql;
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.GroupDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.GroupDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.GroupDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.GroupDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.GroupDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.GroupDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.GroupDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.GroupDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.GroupDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.GroupDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.GroupDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.GroupDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.GroupDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.GroupDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.GroupDAOTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.GroupDAOTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql;
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.GroupDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.GroupDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.GroupDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.GroupDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.GroupDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.GroupDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.GroupDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.GroupDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.GroupDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.GroupDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.GroupDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.GroupDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.GroupDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.GroupDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.GroupDAOTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.GroupDAOTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql;
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.GroupDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.GroupDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.GroupDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.GroupDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.GroupDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.GroupDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.GroupDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.GroupDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.GroupDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.GroupDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.GroupDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.GroupDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.GroupDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.GroupDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.GroupDAOTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.GroupDAOTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql;
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.GroupDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.GroupDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.GroupDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.GroupDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.GroupDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.GroupDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.GroupDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.GroupDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.GroupDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.GroupDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.GroupDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.GroupDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.GroupDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.GroupDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.GroupDAOTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.GroupDAOTest.xml:Caused by: org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.GroupDAOTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql;
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.GroupDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.GroupDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.GroupDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.GroupDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.GroupDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.GroupDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.GroupDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.GroupDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.GroupDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.GroupDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.GroupDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.GroupDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.GroupDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.GroupDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.GroupDAOTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.GroupDAOTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql;
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.GroupDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.GroupDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.GroupDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.GroupDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.GroupDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.GroupDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.GroupDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.GroupDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.GroupDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.GroupDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.GroupDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.GroupDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.GroupDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.GroupDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.GroupDAOTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.GroupDAOTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql;
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.GroupDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.GroupDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.GroupDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.GroupDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.GroupDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.GroupDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.GroupDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.GroupDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.GroupDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.GroupDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.GroupDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.GroupDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.GroupDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.GroupDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.GroupDAOTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.GroupDAOTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql;
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.GroupDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.GroupDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.GroupDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.GroupDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.GroupDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.GroupDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.GroupDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.GroupDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.GroupDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.GroupDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.GroupDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.GroupDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.GroupDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.GroupDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.GroupDAOTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.GroupDAOTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql;
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.GroupDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.GroupDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.GroupDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.GroupDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.GroupDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.GroupDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.GroupDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.GroupDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.GroupDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.GroupDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.GroupDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.GroupDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.GroupDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.GroupDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.GroupDAOTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.GroupDAOTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql;
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.GroupDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.GroupDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.GroupDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.GroupDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.GroupDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.GroupDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.GroupDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.GroupDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.GroupDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.GroupDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.GroupDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.GroupDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.GroupDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.GroupDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.GroupDAOTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.GroupDAOTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql;
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.GroupDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.GroupDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.GroupDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.GroupDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.GroupDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.GroupDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.GroupDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.GroupDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.GroupDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.GroupDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.GroupDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.GroupDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.GroupDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.GroupDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.GroupDAOTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.GroupDAOTest.xml:Caused by: org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql;
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql;
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql;
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql;
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql;
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql;
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql;
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml:Caused by: org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql;
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql;
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql;
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql;
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql;
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql;
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql;
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml:Caused by: org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql;
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql;
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql;
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql;
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql;
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql;
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql;
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml:Caused by: org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql;
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql;
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql;
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql;
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql;
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql;
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql;
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml:Caused by: org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql;
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql;
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql;
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql;
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql;
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql;
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql;
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml:Caused by: org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql;
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql;
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql;
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql;
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql;
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql;
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql;
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml:Caused by: org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql;
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql;
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql;
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql;
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql;
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql;
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql;
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml:Caused by: org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql;
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql;
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql;
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql;
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql;
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql;
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql;
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml:Caused by: org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql;
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql;
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql;
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql;
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql;
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql;
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql;
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml:Caused by: org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql;
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql;
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql;
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql;
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql;
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql;
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql;
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml:Caused by: org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql;
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql;
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql;
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql;
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql;
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql;
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql;
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml:Caused by: org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql;
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql;
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql;
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql;
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql;
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql;
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql;
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml:Caused by: org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql;
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql;
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql;
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql;
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql;
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql;
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql;
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.HibernateSearchDAOTest.xml:Caused by: org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.MaterialDAOTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql;
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.MaterialDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.MaterialDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.MaterialDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.MaterialDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.MaterialDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.MaterialDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.MaterialDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.MaterialDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.MaterialDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.MaterialDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.MaterialDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.MaterialDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.MaterialDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.MaterialDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.MaterialDAOTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.MaterialDAOTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql;
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.MaterialDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.MaterialDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.MaterialDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.MaterialDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.MaterialDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.MaterialDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.MaterialDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.MaterialDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.MaterialDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.MaterialDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.MaterialDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.MaterialDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.MaterialDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.MaterialDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.MaterialDAOTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.MaterialDAOTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql;
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.MaterialDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.MaterialDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.MaterialDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.MaterialDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.MaterialDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.MaterialDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.MaterialDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.MaterialDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.MaterialDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.MaterialDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.MaterialDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.MaterialDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.MaterialDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.MaterialDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.MaterialDAOTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.MaterialDAOTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql;
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.MaterialDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.MaterialDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.MaterialDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.MaterialDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.MaterialDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.MaterialDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.MaterialDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.MaterialDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.MaterialDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.MaterialDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.MaterialDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.MaterialDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.MaterialDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.MaterialDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.MaterialDAOTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.MaterialDAOTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql;
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.MaterialDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.MaterialDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.MaterialDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.MaterialDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.MaterialDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.MaterialDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.MaterialDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.MaterialDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.MaterialDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.MaterialDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.MaterialDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.MaterialDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.MaterialDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.MaterialDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.MaterialDAOTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.MaterialDAOTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql;
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.MaterialDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.MaterialDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.MaterialDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.MaterialDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.MaterialDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.MaterialDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.MaterialDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.MaterialDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.MaterialDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.MaterialDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.MaterialDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.MaterialDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.MaterialDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.MaterialDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.MaterialDAOTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.MaterialDAOTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql;
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.MaterialDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.MaterialDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.MaterialDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.MaterialDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.MaterialDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.MaterialDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.MaterialDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.MaterialDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.MaterialDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.MaterialDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.MaterialDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.MaterialDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.MaterialDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.MaterialDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.MaterialDAOTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.MaterialDAOTest.xml:Caused by: org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.MaterialDAOTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql;
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.MaterialDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.MaterialDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.MaterialDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.MaterialDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.MaterialDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.MaterialDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.MaterialDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.MaterialDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.MaterialDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.MaterialDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.MaterialDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.MaterialDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.MaterialDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.MaterialDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.MaterialDAOTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.MaterialDAOTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql;
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.MaterialDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.MaterialDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.MaterialDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.MaterialDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.MaterialDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.MaterialDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.MaterialDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.MaterialDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.MaterialDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.MaterialDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.MaterialDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.MaterialDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.MaterialDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.MaterialDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.MaterialDAOTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.MaterialDAOTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql;
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.MaterialDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.MaterialDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.MaterialDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.MaterialDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.MaterialDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.MaterialDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.MaterialDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.MaterialDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.MaterialDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.MaterialDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.MaterialDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.MaterialDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.MaterialDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.MaterialDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.MaterialDAOTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.MaterialDAOTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql;
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.MaterialDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.MaterialDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.MaterialDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.MaterialDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.MaterialDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.MaterialDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.MaterialDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.MaterialDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.MaterialDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.MaterialDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.MaterialDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.MaterialDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.MaterialDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.MaterialDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.MaterialDAOTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.MaterialDAOTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql;
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.MaterialDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.MaterialDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.MaterialDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.MaterialDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.MaterialDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.MaterialDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.MaterialDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.MaterialDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.MaterialDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.MaterialDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.MaterialDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.MaterialDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.MaterialDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.MaterialDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.MaterialDAOTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.MaterialDAOTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql;
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.MaterialDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.MaterialDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.MaterialDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.MaterialDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.MaterialDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.MaterialDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.MaterialDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.MaterialDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.MaterialDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.MaterialDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.MaterialDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.MaterialDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.MaterialDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.MaterialDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.MaterialDAOTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.MaterialDAOTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql;
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.MaterialDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.MaterialDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.MaterialDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.MaterialDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.MaterialDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.MaterialDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.MaterialDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.MaterialDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.MaterialDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.MaterialDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.MaterialDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.MaterialDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.MaterialDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.MaterialDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.MaterialDAOTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.MaterialDAOTest.xml:Caused by: org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.MaterialDAOTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql;
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.MaterialDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.MaterialDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.MaterialDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.MaterialDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.MaterialDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.MaterialDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.MaterialDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.MaterialDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.MaterialDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.MaterialDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.MaterialDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.MaterialDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.MaterialDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.MaterialDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.MaterialDAOTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.MaterialDAOTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql;
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.MaterialDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.MaterialDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.MaterialDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.MaterialDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.MaterialDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.MaterialDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.MaterialDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.MaterialDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.MaterialDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.MaterialDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.MaterialDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.MaterialDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.MaterialDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.MaterialDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.MaterialDAOTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.MaterialDAOTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql;
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.MaterialDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.MaterialDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.MaterialDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.MaterialDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.MaterialDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.MaterialDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.MaterialDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.MaterialDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.MaterialDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.MaterialDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.MaterialDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.MaterialDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.MaterialDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.MaterialDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.MaterialDAOTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.MaterialDAOTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql;
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.MaterialDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.MaterialDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.MaterialDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.MaterialDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.MaterialDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.MaterialDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.MaterialDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.MaterialDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.MaterialDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.MaterialDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.MaterialDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.MaterialDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.MaterialDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.MaterialDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.MaterialDAOTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.MaterialDAOTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql;
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.MaterialDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.MaterialDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.MaterialDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.MaterialDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.MaterialDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.MaterialDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.MaterialDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.MaterialDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.MaterialDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.MaterialDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.MaterialDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.MaterialDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.MaterialDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.MaterialDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.MaterialDAOTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.MaterialDAOTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql;
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.MaterialDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.MaterialDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.MaterialDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.MaterialDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.MaterialDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.MaterialDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.MaterialDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.MaterialDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.MaterialDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.MaterialDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.MaterialDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.MaterialDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.MaterialDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.MaterialDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.MaterialDAOTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.MaterialDAOTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql;
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.MaterialDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.MaterialDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.MaterialDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.MaterialDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.MaterialDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.MaterialDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.MaterialDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.MaterialDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.MaterialDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.MaterialDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.MaterialDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.MaterialDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.MaterialDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.MaterialDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.MaterialDAOTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.MaterialDAOTest.xml:Caused by: org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.MaterialDAOTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql;
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.MaterialDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.MaterialDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.MaterialDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.MaterialDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.MaterialDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.MaterialDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.MaterialDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.MaterialDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.MaterialDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.MaterialDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.MaterialDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.MaterialDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.MaterialDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.MaterialDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.MaterialDAOTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.MaterialDAOTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql;
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.MaterialDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.MaterialDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.MaterialDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.MaterialDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.MaterialDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.MaterialDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.MaterialDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.MaterialDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.MaterialDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.MaterialDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.MaterialDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.MaterialDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.MaterialDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.MaterialDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.MaterialDAOTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.MaterialDAOTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql;
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.MaterialDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.MaterialDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.MaterialDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.MaterialDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.MaterialDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.MaterialDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.MaterialDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.MaterialDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.MaterialDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.MaterialDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.MaterialDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.MaterialDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.MaterialDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.MaterialDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.MaterialDAOTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.MaterialDAOTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql;
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.MaterialDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.MaterialDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.MaterialDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.MaterialDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.MaterialDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.MaterialDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.MaterialDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.MaterialDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.MaterialDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.MaterialDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.MaterialDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.MaterialDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.MaterialDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.MaterialDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.MaterialDAOTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.MaterialDAOTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql;
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.MaterialDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.MaterialDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.MaterialDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.MaterialDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.MaterialDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.MaterialDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.MaterialDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.MaterialDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.MaterialDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.MaterialDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.MaterialDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.MaterialDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.MaterialDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.MaterialDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.MaterialDAOTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.MaterialDAOTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql;
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.MaterialDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.MaterialDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.MaterialDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.MaterialDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.MaterialDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.MaterialDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.MaterialDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.MaterialDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.MaterialDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.MaterialDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.MaterialDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.MaterialDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.MaterialDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.MaterialDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.MaterialDAOTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.MaterialDAOTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql;
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.MaterialDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.MaterialDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.MaterialDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.MaterialDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.MaterialDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.MaterialDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.MaterialDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.MaterialDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.MaterialDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.MaterialDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.MaterialDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.MaterialDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.MaterialDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.MaterialDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.MaterialDAOTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.MaterialDAOTest.xml:Caused by: org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.MaterialDAOTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql;
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.MaterialDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.MaterialDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.MaterialDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.MaterialDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.MaterialDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.MaterialDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.MaterialDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.MaterialDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.MaterialDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.MaterialDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.MaterialDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.MaterialDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.MaterialDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.MaterialDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.MaterialDAOTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.MaterialDAOTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql;
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.MaterialDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.MaterialDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.MaterialDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.MaterialDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.MaterialDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.MaterialDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.MaterialDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.MaterialDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.MaterialDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.MaterialDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.MaterialDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.MaterialDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.MaterialDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.MaterialDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.MaterialDAOTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.MaterialDAOTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql;
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.MaterialDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.MaterialDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.MaterialDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.MaterialDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.MaterialDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.MaterialDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.MaterialDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.MaterialDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.MaterialDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.MaterialDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.MaterialDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.MaterialDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.MaterialDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.MaterialDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.MaterialDAOTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.MaterialDAOTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql;
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.MaterialDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.MaterialDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.MaterialDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.MaterialDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.MaterialDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.MaterialDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.MaterialDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.MaterialDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.MaterialDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.MaterialDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.MaterialDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.MaterialDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.MaterialDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.MaterialDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.MaterialDAOTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.MaterialDAOTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql;
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.MaterialDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.MaterialDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.MaterialDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.MaterialDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.MaterialDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.MaterialDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.MaterialDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.MaterialDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.MaterialDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.MaterialDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.MaterialDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.MaterialDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.MaterialDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.MaterialDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.MaterialDAOTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.MaterialDAOTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql;
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.MaterialDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.MaterialDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.MaterialDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.MaterialDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.MaterialDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.MaterialDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.MaterialDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.MaterialDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.MaterialDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.MaterialDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.MaterialDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.MaterialDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.MaterialDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.MaterialDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.MaterialDAOTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.MaterialDAOTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql;
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.MaterialDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.MaterialDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.MaterialDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.MaterialDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.MaterialDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.MaterialDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.MaterialDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.MaterialDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.MaterialDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.MaterialDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.MaterialDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.MaterialDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.MaterialDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.MaterialDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.MaterialDAOTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.MaterialDAOTest.xml:Caused by: org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.MaterialDAOTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql;
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.MaterialDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.MaterialDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.MaterialDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.MaterialDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.MaterialDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.MaterialDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.MaterialDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.MaterialDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.MaterialDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.MaterialDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.MaterialDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.MaterialDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.MaterialDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.MaterialDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.MaterialDAOTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.MaterialDAOTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql;
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.MaterialDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.MaterialDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.MaterialDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.MaterialDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.MaterialDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.MaterialDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.MaterialDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.MaterialDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.MaterialDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.MaterialDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.MaterialDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.MaterialDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.MaterialDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.MaterialDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.MaterialDAOTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.MaterialDAOTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql;
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.MaterialDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.MaterialDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.MaterialDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.MaterialDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.MaterialDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.MaterialDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.MaterialDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.MaterialDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.MaterialDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.MaterialDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.MaterialDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.MaterialDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.MaterialDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.MaterialDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.MaterialDAOTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.MaterialDAOTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql;
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.MaterialDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.MaterialDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.MaterialDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.MaterialDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.MaterialDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.MaterialDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.MaterialDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.MaterialDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.MaterialDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.MaterialDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.MaterialDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.MaterialDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.MaterialDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.MaterialDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.MaterialDAOTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.MaterialDAOTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql;
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.MaterialDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.MaterialDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.MaterialDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.MaterialDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.MaterialDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.MaterialDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.MaterialDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.MaterialDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.MaterialDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.MaterialDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.MaterialDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.MaterialDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.MaterialDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.MaterialDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.MaterialDAOTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.MaterialDAOTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql;
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.MaterialDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.MaterialDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.MaterialDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.MaterialDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.MaterialDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.MaterialDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.MaterialDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.MaterialDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.MaterialDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.MaterialDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.MaterialDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.MaterialDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.MaterialDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.MaterialDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.MaterialDAOTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.MaterialDAOTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql;
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.MaterialDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.MaterialDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.MaterialDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.MaterialDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.MaterialDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.MaterialDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.MaterialDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.MaterialDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.MaterialDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.MaterialDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.MaterialDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.MaterialDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.MaterialDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.MaterialDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.MaterialDAOTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.MaterialDAOTest.xml:Caused by: org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PermIdDAOTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql;
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PermIdDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PermIdDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PermIdDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PermIdDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PermIdDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PermIdDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PermIdDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PermIdDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PermIdDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PermIdDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PermIdDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PermIdDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PermIdDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PermIdDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PermIdDAOTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PermIdDAOTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql;
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PermIdDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PermIdDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PermIdDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PermIdDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PermIdDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PermIdDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PermIdDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PermIdDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PermIdDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PermIdDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PermIdDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PermIdDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PermIdDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PermIdDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PermIdDAOTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PermIdDAOTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql;
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PermIdDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PermIdDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PermIdDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PermIdDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PermIdDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PermIdDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PermIdDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PermIdDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PermIdDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PermIdDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PermIdDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PermIdDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PermIdDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PermIdDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PermIdDAOTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PermIdDAOTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql;
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PermIdDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PermIdDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PermIdDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PermIdDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PermIdDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PermIdDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PermIdDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PermIdDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PermIdDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PermIdDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PermIdDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PermIdDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PermIdDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PermIdDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PermIdDAOTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PermIdDAOTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql;
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PermIdDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PermIdDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PermIdDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PermIdDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PermIdDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PermIdDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PermIdDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PermIdDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PermIdDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PermIdDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PermIdDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PermIdDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PermIdDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PermIdDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PermIdDAOTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PermIdDAOTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql;
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PermIdDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PermIdDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PermIdDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PermIdDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PermIdDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PermIdDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PermIdDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PermIdDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PermIdDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PermIdDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PermIdDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PermIdDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PermIdDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PermIdDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PermIdDAOTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PermIdDAOTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql;
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PermIdDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PermIdDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PermIdDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PermIdDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PermIdDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PermIdDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PermIdDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PermIdDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PermIdDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PermIdDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PermIdDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PermIdDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PermIdDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PermIdDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PermIdDAOTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PermIdDAOTest.xml:Caused by: org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PersonDAOTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql;
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PersonDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PersonDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PersonDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PersonDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PersonDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PersonDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PersonDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PersonDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PersonDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PersonDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PersonDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PersonDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PersonDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PersonDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PersonDAOTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PersonDAOTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql;
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PersonDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PersonDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PersonDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PersonDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PersonDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PersonDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PersonDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PersonDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PersonDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PersonDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PersonDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PersonDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PersonDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PersonDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PersonDAOTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PersonDAOTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql;
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PersonDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PersonDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PersonDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PersonDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PersonDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PersonDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PersonDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PersonDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PersonDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PersonDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PersonDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PersonDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PersonDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PersonDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PersonDAOTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PersonDAOTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql;
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PersonDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PersonDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PersonDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PersonDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PersonDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PersonDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PersonDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PersonDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PersonDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PersonDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PersonDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PersonDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PersonDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PersonDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PersonDAOTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PersonDAOTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql;
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PersonDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PersonDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PersonDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PersonDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PersonDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PersonDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PersonDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PersonDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PersonDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PersonDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PersonDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PersonDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PersonDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PersonDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PersonDAOTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PersonDAOTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql;
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PersonDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PersonDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PersonDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PersonDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PersonDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PersonDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PersonDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PersonDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PersonDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PersonDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PersonDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PersonDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PersonDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PersonDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PersonDAOTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PersonDAOTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql;
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PersonDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PersonDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PersonDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PersonDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PersonDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PersonDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PersonDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PersonDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PersonDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PersonDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PersonDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PersonDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PersonDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PersonDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PersonDAOTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PersonDAOTest.xml:Caused by: org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PersonDAOTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql;
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PersonDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PersonDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PersonDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PersonDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PersonDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PersonDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PersonDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PersonDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PersonDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PersonDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PersonDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PersonDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PersonDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PersonDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PersonDAOTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PersonDAOTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql;
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PersonDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PersonDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PersonDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PersonDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PersonDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PersonDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PersonDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PersonDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PersonDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PersonDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PersonDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PersonDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PersonDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PersonDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PersonDAOTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PersonDAOTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql;
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PersonDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PersonDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PersonDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PersonDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PersonDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PersonDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PersonDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PersonDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PersonDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PersonDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PersonDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PersonDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PersonDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PersonDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PersonDAOTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PersonDAOTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql;
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PersonDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PersonDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PersonDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PersonDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PersonDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PersonDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PersonDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PersonDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PersonDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PersonDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PersonDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PersonDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PersonDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PersonDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PersonDAOTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PersonDAOTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql;
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PersonDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PersonDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PersonDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PersonDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PersonDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PersonDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PersonDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PersonDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PersonDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PersonDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PersonDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PersonDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PersonDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PersonDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PersonDAOTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PersonDAOTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql;
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PersonDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PersonDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PersonDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PersonDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PersonDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PersonDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PersonDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PersonDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PersonDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PersonDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PersonDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PersonDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PersonDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PersonDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PersonDAOTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PersonDAOTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql;
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PersonDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PersonDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PersonDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PersonDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PersonDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PersonDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PersonDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PersonDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PersonDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PersonDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PersonDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PersonDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PersonDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PersonDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PersonDAOTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PersonDAOTest.xml:Caused by: org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PersonDAOTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql;
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PersonDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PersonDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PersonDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PersonDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PersonDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PersonDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PersonDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PersonDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PersonDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PersonDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PersonDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PersonDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PersonDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PersonDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PersonDAOTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PersonDAOTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql;
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PersonDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PersonDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PersonDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PersonDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PersonDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PersonDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PersonDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PersonDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PersonDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PersonDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PersonDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PersonDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PersonDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PersonDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PersonDAOTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PersonDAOTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql;
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PersonDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PersonDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PersonDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PersonDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PersonDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PersonDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PersonDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PersonDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PersonDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PersonDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PersonDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PersonDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PersonDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PersonDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PersonDAOTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PersonDAOTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql;
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PersonDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PersonDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PersonDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PersonDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PersonDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PersonDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PersonDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PersonDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PersonDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PersonDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PersonDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PersonDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PersonDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PersonDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PersonDAOTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PersonDAOTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql;
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PersonDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PersonDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PersonDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PersonDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PersonDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PersonDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PersonDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PersonDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PersonDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PersonDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PersonDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PersonDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PersonDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PersonDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PersonDAOTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PersonDAOTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql;
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PersonDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PersonDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PersonDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PersonDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PersonDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PersonDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PersonDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PersonDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PersonDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PersonDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PersonDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PersonDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PersonDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PersonDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PersonDAOTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PersonDAOTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql;
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PersonDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PersonDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PersonDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PersonDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PersonDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PersonDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PersonDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PersonDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PersonDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PersonDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PersonDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PersonDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PersonDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PersonDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PersonDAOTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PersonDAOTest.xml:Caused by: org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PersonDAOTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql;
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PersonDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PersonDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PersonDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PersonDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PersonDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PersonDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PersonDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PersonDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PersonDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PersonDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PersonDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PersonDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PersonDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PersonDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PersonDAOTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PersonDAOTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql;
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PersonDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PersonDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PersonDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PersonDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PersonDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PersonDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PersonDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PersonDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PersonDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PersonDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PersonDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PersonDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PersonDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PersonDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PersonDAOTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PersonDAOTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql;
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PersonDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PersonDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PersonDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PersonDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PersonDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PersonDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PersonDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PersonDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PersonDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PersonDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PersonDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PersonDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PersonDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PersonDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PersonDAOTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PersonDAOTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql;
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PersonDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PersonDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PersonDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PersonDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PersonDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PersonDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PersonDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PersonDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PersonDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PersonDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PersonDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PersonDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PersonDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PersonDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PersonDAOTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PersonDAOTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql;
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PersonDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PersonDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PersonDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PersonDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PersonDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PersonDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PersonDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PersonDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PersonDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PersonDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PersonDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PersonDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PersonDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PersonDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PersonDAOTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PersonDAOTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql;
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PersonDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PersonDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PersonDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PersonDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PersonDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PersonDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PersonDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PersonDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PersonDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PersonDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PersonDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PersonDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PersonDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PersonDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PersonDAOTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PersonDAOTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql;
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PersonDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PersonDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PersonDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PersonDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PersonDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PersonDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PersonDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PersonDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PersonDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PersonDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PersonDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PersonDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PersonDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PersonDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PersonDAOTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PersonDAOTest.xml:Caused by: org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PersonDAOTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql;
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PersonDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PersonDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PersonDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PersonDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PersonDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PersonDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PersonDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PersonDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PersonDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PersonDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PersonDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PersonDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PersonDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PersonDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PersonDAOTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PersonDAOTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql;
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PersonDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PersonDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PersonDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PersonDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PersonDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PersonDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PersonDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PersonDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PersonDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PersonDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PersonDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PersonDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PersonDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PersonDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PersonDAOTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PersonDAOTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql;
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PersonDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PersonDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PersonDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PersonDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PersonDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PersonDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PersonDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PersonDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PersonDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PersonDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PersonDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PersonDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PersonDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PersonDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PersonDAOTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PersonDAOTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql;
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PersonDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PersonDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PersonDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PersonDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PersonDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PersonDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PersonDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PersonDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PersonDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PersonDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PersonDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PersonDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PersonDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PersonDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PersonDAOTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PersonDAOTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql;
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PersonDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PersonDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PersonDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PersonDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PersonDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PersonDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PersonDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PersonDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PersonDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PersonDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PersonDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PersonDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PersonDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PersonDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PersonDAOTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PersonDAOTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql;
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PersonDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PersonDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PersonDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PersonDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PersonDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PersonDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PersonDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PersonDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PersonDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PersonDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PersonDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PersonDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PersonDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PersonDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PersonDAOTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PersonDAOTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql;
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PersonDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PersonDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PersonDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PersonDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PersonDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PersonDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PersonDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PersonDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PersonDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PersonDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PersonDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PersonDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PersonDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PersonDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PersonDAOTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PersonDAOTest.xml:Caused by: org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PersonDAOTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql;
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PersonDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PersonDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PersonDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PersonDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PersonDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PersonDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PersonDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PersonDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PersonDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PersonDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PersonDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PersonDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PersonDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PersonDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PersonDAOTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PersonDAOTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql;
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PersonDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PersonDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PersonDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PersonDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PersonDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PersonDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PersonDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PersonDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PersonDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PersonDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PersonDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PersonDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PersonDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PersonDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PersonDAOTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PersonDAOTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql;
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PersonDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PersonDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PersonDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PersonDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PersonDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PersonDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PersonDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PersonDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PersonDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PersonDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PersonDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PersonDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PersonDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PersonDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PersonDAOTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PersonDAOTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql;
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PersonDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PersonDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PersonDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PersonDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PersonDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PersonDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PersonDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PersonDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PersonDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PersonDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PersonDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PersonDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PersonDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PersonDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PersonDAOTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PersonDAOTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql;
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PersonDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PersonDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PersonDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PersonDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PersonDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PersonDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PersonDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PersonDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PersonDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PersonDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PersonDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PersonDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PersonDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PersonDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PersonDAOTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PersonDAOTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql;
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PersonDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PersonDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PersonDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PersonDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PersonDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PersonDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PersonDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PersonDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PersonDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PersonDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PersonDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PersonDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PersonDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PersonDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PersonDAOTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PersonDAOTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql;
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PersonDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PersonDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PersonDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PersonDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PersonDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PersonDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PersonDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PersonDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PersonDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PersonDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PersonDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PersonDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PersonDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PersonDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PersonDAOTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PersonDAOTest.xml:Caused by: org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PersonDAOTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql;
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PersonDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PersonDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PersonDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PersonDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PersonDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PersonDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PersonDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PersonDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PersonDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PersonDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PersonDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PersonDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PersonDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PersonDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PersonDAOTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PersonDAOTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql;
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PersonDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PersonDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PersonDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PersonDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PersonDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PersonDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PersonDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PersonDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PersonDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PersonDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PersonDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PersonDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PersonDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PersonDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PersonDAOTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PersonDAOTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql;
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PersonDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PersonDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PersonDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PersonDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PersonDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PersonDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PersonDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PersonDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PersonDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PersonDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PersonDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PersonDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PersonDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PersonDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PersonDAOTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PersonDAOTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql;
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PersonDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PersonDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PersonDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PersonDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PersonDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PersonDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PersonDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PersonDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PersonDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PersonDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PersonDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PersonDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PersonDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PersonDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PersonDAOTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PersonDAOTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql;
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PersonDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PersonDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PersonDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PersonDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PersonDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PersonDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PersonDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PersonDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PersonDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PersonDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PersonDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PersonDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PersonDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PersonDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PersonDAOTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PersonDAOTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql;
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PersonDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PersonDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PersonDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PersonDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PersonDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PersonDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PersonDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PersonDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PersonDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PersonDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PersonDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PersonDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PersonDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PersonDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PersonDAOTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PersonDAOTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql;
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PersonDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PersonDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PersonDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PersonDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PersonDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PersonDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PersonDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PersonDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PersonDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PersonDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PersonDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PersonDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PersonDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PersonDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PersonDAOTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PersonDAOTest.xml:Caused by: org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PersonDAOTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql;
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PersonDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PersonDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PersonDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PersonDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PersonDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PersonDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PersonDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PersonDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PersonDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PersonDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PersonDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PersonDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PersonDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PersonDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PersonDAOTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PersonDAOTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql;
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PersonDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PersonDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PersonDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PersonDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PersonDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PersonDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PersonDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PersonDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PersonDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PersonDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PersonDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PersonDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PersonDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PersonDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PersonDAOTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PersonDAOTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql;
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PersonDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PersonDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PersonDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PersonDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PersonDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PersonDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PersonDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PersonDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PersonDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PersonDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PersonDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PersonDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PersonDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PersonDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PersonDAOTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PersonDAOTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql;
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PersonDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PersonDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PersonDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PersonDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PersonDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PersonDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PersonDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PersonDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PersonDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PersonDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PersonDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PersonDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PersonDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PersonDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PersonDAOTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PersonDAOTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql;
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PersonDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PersonDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PersonDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PersonDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PersonDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PersonDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PersonDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PersonDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PersonDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PersonDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PersonDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PersonDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PersonDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PersonDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PersonDAOTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PersonDAOTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql;
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PersonDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PersonDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PersonDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PersonDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PersonDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PersonDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PersonDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PersonDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PersonDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PersonDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PersonDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PersonDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PersonDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PersonDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PersonDAOTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PersonDAOTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql;
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PersonDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PersonDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PersonDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PersonDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PersonDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PersonDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PersonDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PersonDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PersonDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PersonDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PersonDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PersonDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PersonDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PersonDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PersonDAOTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PersonDAOTest.xml:Caused by: org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PersonDAOTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql;
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PersonDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PersonDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PersonDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PersonDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PersonDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PersonDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PersonDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PersonDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PersonDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PersonDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PersonDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PersonDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PersonDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PersonDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PersonDAOTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PersonDAOTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql;
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PersonDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PersonDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PersonDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PersonDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PersonDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PersonDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PersonDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PersonDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PersonDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PersonDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PersonDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PersonDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PersonDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PersonDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PersonDAOTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PersonDAOTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql;
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PersonDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PersonDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PersonDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PersonDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PersonDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PersonDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PersonDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PersonDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PersonDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PersonDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PersonDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PersonDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PersonDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PersonDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PersonDAOTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PersonDAOTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql;
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PersonDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PersonDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PersonDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PersonDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PersonDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PersonDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PersonDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PersonDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PersonDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PersonDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PersonDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PersonDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PersonDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PersonDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PersonDAOTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PersonDAOTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql;
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PersonDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PersonDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PersonDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PersonDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PersonDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PersonDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PersonDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PersonDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PersonDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PersonDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PersonDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PersonDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PersonDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PersonDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PersonDAOTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PersonDAOTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql;
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PersonDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PersonDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PersonDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PersonDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PersonDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PersonDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PersonDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PersonDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PersonDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PersonDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PersonDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PersonDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PersonDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PersonDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PersonDAOTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PersonDAOTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql;
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PersonDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PersonDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PersonDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PersonDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PersonDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PersonDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PersonDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PersonDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PersonDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PersonDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PersonDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PersonDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PersonDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PersonDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PersonDAOTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PersonDAOTest.xml:Caused by: org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ProjectDAOTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql;
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ProjectDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ProjectDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ProjectDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ProjectDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ProjectDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ProjectDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ProjectDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ProjectDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ProjectDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ProjectDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ProjectDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ProjectDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ProjectDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ProjectDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ProjectDAOTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ProjectDAOTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql;
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ProjectDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ProjectDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ProjectDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ProjectDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ProjectDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ProjectDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ProjectDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ProjectDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ProjectDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ProjectDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ProjectDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ProjectDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ProjectDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ProjectDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ProjectDAOTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ProjectDAOTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql;
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ProjectDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ProjectDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ProjectDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ProjectDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ProjectDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ProjectDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ProjectDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ProjectDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ProjectDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ProjectDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ProjectDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ProjectDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ProjectDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ProjectDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ProjectDAOTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ProjectDAOTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql;
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ProjectDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ProjectDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ProjectDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ProjectDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ProjectDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ProjectDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ProjectDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ProjectDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ProjectDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ProjectDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ProjectDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ProjectDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ProjectDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ProjectDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ProjectDAOTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ProjectDAOTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql;
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ProjectDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ProjectDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ProjectDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ProjectDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ProjectDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ProjectDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ProjectDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ProjectDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ProjectDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ProjectDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ProjectDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ProjectDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ProjectDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ProjectDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ProjectDAOTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ProjectDAOTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql;
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ProjectDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ProjectDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ProjectDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ProjectDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ProjectDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ProjectDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ProjectDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ProjectDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ProjectDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ProjectDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ProjectDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ProjectDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ProjectDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ProjectDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ProjectDAOTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ProjectDAOTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql;
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ProjectDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ProjectDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ProjectDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ProjectDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ProjectDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ProjectDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ProjectDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ProjectDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ProjectDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ProjectDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ProjectDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ProjectDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ProjectDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ProjectDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ProjectDAOTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ProjectDAOTest.xml:Caused by: org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ProjectDAOTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql;
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ProjectDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ProjectDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ProjectDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ProjectDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ProjectDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ProjectDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ProjectDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ProjectDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ProjectDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ProjectDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ProjectDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ProjectDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ProjectDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ProjectDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ProjectDAOTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ProjectDAOTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql;
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ProjectDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ProjectDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ProjectDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ProjectDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ProjectDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ProjectDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ProjectDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ProjectDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ProjectDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ProjectDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ProjectDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ProjectDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ProjectDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ProjectDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ProjectDAOTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ProjectDAOTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql;
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ProjectDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ProjectDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ProjectDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ProjectDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ProjectDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ProjectDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ProjectDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ProjectDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ProjectDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ProjectDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ProjectDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ProjectDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ProjectDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ProjectDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ProjectDAOTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ProjectDAOTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql;
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ProjectDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ProjectDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ProjectDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ProjectDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ProjectDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ProjectDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ProjectDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ProjectDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ProjectDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ProjectDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ProjectDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ProjectDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ProjectDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ProjectDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ProjectDAOTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ProjectDAOTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql;
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ProjectDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ProjectDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ProjectDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ProjectDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ProjectDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ProjectDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ProjectDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ProjectDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ProjectDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ProjectDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ProjectDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ProjectDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ProjectDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ProjectDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ProjectDAOTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ProjectDAOTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql;
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ProjectDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ProjectDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ProjectDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ProjectDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ProjectDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ProjectDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ProjectDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ProjectDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ProjectDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ProjectDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ProjectDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ProjectDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ProjectDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ProjectDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ProjectDAOTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ProjectDAOTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql;
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ProjectDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ProjectDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ProjectDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ProjectDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ProjectDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ProjectDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ProjectDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ProjectDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ProjectDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ProjectDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ProjectDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ProjectDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ProjectDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ProjectDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ProjectDAOTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ProjectDAOTest.xml:Caused by: org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ProjectDAOTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql;
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ProjectDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ProjectDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ProjectDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ProjectDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ProjectDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ProjectDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ProjectDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ProjectDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ProjectDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ProjectDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ProjectDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ProjectDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ProjectDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ProjectDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ProjectDAOTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ProjectDAOTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql;
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ProjectDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ProjectDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ProjectDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ProjectDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ProjectDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ProjectDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ProjectDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ProjectDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ProjectDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ProjectDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ProjectDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ProjectDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ProjectDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ProjectDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ProjectDAOTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ProjectDAOTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql;
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ProjectDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ProjectDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ProjectDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ProjectDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ProjectDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ProjectDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ProjectDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ProjectDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ProjectDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ProjectDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ProjectDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ProjectDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ProjectDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ProjectDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ProjectDAOTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ProjectDAOTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql;
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ProjectDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ProjectDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ProjectDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ProjectDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ProjectDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ProjectDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ProjectDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ProjectDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ProjectDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ProjectDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ProjectDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ProjectDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ProjectDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ProjectDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ProjectDAOTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ProjectDAOTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql;
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ProjectDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ProjectDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ProjectDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ProjectDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ProjectDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ProjectDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ProjectDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ProjectDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ProjectDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ProjectDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ProjectDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ProjectDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ProjectDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ProjectDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ProjectDAOTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ProjectDAOTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql;
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ProjectDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ProjectDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ProjectDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ProjectDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ProjectDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ProjectDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ProjectDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ProjectDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ProjectDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ProjectDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ProjectDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ProjectDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ProjectDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ProjectDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ProjectDAOTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ProjectDAOTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql;
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ProjectDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ProjectDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ProjectDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ProjectDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ProjectDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ProjectDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ProjectDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ProjectDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ProjectDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ProjectDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ProjectDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ProjectDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ProjectDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ProjectDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ProjectDAOTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ProjectDAOTest.xml:Caused by: org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ProjectDAOTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql;
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ProjectDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ProjectDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ProjectDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ProjectDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ProjectDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ProjectDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ProjectDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ProjectDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ProjectDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ProjectDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ProjectDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ProjectDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ProjectDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ProjectDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ProjectDAOTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ProjectDAOTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql;
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ProjectDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ProjectDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ProjectDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ProjectDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ProjectDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ProjectDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ProjectDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ProjectDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ProjectDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ProjectDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ProjectDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ProjectDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ProjectDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ProjectDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ProjectDAOTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ProjectDAOTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql;
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ProjectDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ProjectDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ProjectDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ProjectDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ProjectDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ProjectDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ProjectDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ProjectDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ProjectDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ProjectDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ProjectDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ProjectDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ProjectDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ProjectDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ProjectDAOTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ProjectDAOTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql;
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ProjectDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ProjectDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ProjectDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ProjectDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ProjectDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ProjectDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ProjectDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ProjectDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ProjectDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ProjectDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ProjectDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ProjectDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ProjectDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ProjectDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ProjectDAOTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ProjectDAOTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql;
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ProjectDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ProjectDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ProjectDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ProjectDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ProjectDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ProjectDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ProjectDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ProjectDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ProjectDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ProjectDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ProjectDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ProjectDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ProjectDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ProjectDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ProjectDAOTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ProjectDAOTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql;
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ProjectDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ProjectDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ProjectDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ProjectDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ProjectDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ProjectDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ProjectDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ProjectDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ProjectDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ProjectDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ProjectDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ProjectDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ProjectDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ProjectDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ProjectDAOTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ProjectDAOTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql;
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ProjectDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ProjectDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ProjectDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ProjectDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ProjectDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ProjectDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ProjectDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ProjectDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ProjectDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ProjectDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ProjectDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ProjectDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ProjectDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ProjectDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ProjectDAOTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ProjectDAOTest.xml:Caused by: org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ProjectDAOTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql;
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ProjectDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ProjectDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ProjectDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ProjectDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ProjectDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ProjectDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ProjectDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ProjectDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ProjectDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ProjectDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ProjectDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ProjectDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ProjectDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ProjectDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ProjectDAOTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ProjectDAOTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql;
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ProjectDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ProjectDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ProjectDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ProjectDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ProjectDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ProjectDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ProjectDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ProjectDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ProjectDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ProjectDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ProjectDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ProjectDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ProjectDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ProjectDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ProjectDAOTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ProjectDAOTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql;
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ProjectDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ProjectDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ProjectDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ProjectDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ProjectDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ProjectDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ProjectDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ProjectDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ProjectDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ProjectDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ProjectDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ProjectDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ProjectDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ProjectDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ProjectDAOTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ProjectDAOTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql;
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ProjectDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ProjectDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ProjectDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ProjectDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ProjectDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ProjectDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ProjectDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ProjectDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ProjectDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ProjectDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ProjectDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ProjectDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ProjectDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ProjectDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ProjectDAOTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ProjectDAOTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql;
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ProjectDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ProjectDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ProjectDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ProjectDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ProjectDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ProjectDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ProjectDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ProjectDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ProjectDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ProjectDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ProjectDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ProjectDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ProjectDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ProjectDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ProjectDAOTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ProjectDAOTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql;
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ProjectDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ProjectDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ProjectDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ProjectDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ProjectDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ProjectDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ProjectDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ProjectDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ProjectDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ProjectDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ProjectDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ProjectDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ProjectDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ProjectDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ProjectDAOTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ProjectDAOTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql;
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ProjectDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ProjectDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ProjectDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ProjectDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ProjectDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ProjectDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ProjectDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ProjectDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ProjectDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ProjectDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ProjectDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ProjectDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ProjectDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ProjectDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ProjectDAOTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ProjectDAOTest.xml:Caused by: org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ProjectDAOTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql;
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ProjectDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ProjectDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ProjectDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ProjectDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ProjectDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ProjectDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ProjectDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ProjectDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ProjectDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ProjectDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ProjectDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ProjectDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ProjectDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ProjectDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ProjectDAOTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ProjectDAOTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql;
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ProjectDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ProjectDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ProjectDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ProjectDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ProjectDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ProjectDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ProjectDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ProjectDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ProjectDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ProjectDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ProjectDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ProjectDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ProjectDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ProjectDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ProjectDAOTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ProjectDAOTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql;
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ProjectDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ProjectDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ProjectDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ProjectDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ProjectDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ProjectDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ProjectDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ProjectDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ProjectDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ProjectDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ProjectDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ProjectDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ProjectDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ProjectDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ProjectDAOTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ProjectDAOTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql;
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ProjectDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ProjectDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ProjectDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ProjectDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ProjectDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ProjectDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ProjectDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ProjectDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ProjectDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ProjectDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ProjectDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ProjectDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ProjectDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ProjectDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ProjectDAOTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ProjectDAOTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql;
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ProjectDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ProjectDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ProjectDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ProjectDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ProjectDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ProjectDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ProjectDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ProjectDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ProjectDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ProjectDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ProjectDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ProjectDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ProjectDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ProjectDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ProjectDAOTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ProjectDAOTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql;
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ProjectDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ProjectDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ProjectDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ProjectDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ProjectDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ProjectDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ProjectDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ProjectDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ProjectDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ProjectDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ProjectDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ProjectDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ProjectDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ProjectDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ProjectDAOTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ProjectDAOTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql;
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ProjectDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ProjectDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ProjectDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ProjectDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ProjectDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ProjectDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ProjectDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ProjectDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ProjectDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ProjectDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ProjectDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ProjectDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ProjectDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ProjectDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ProjectDAOTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ProjectDAOTest.xml:Caused by: org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ProjectDAOTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql;
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ProjectDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ProjectDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ProjectDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ProjectDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ProjectDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ProjectDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ProjectDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ProjectDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ProjectDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ProjectDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ProjectDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ProjectDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ProjectDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ProjectDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ProjectDAOTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ProjectDAOTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql;
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ProjectDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ProjectDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ProjectDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ProjectDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ProjectDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ProjectDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ProjectDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ProjectDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ProjectDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ProjectDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ProjectDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ProjectDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ProjectDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ProjectDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ProjectDAOTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ProjectDAOTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql;
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ProjectDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ProjectDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ProjectDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ProjectDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ProjectDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ProjectDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ProjectDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ProjectDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ProjectDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ProjectDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ProjectDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ProjectDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ProjectDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ProjectDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ProjectDAOTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ProjectDAOTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql;
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ProjectDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ProjectDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ProjectDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ProjectDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ProjectDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ProjectDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ProjectDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ProjectDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ProjectDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ProjectDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ProjectDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ProjectDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ProjectDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ProjectDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ProjectDAOTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ProjectDAOTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql;
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ProjectDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ProjectDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ProjectDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ProjectDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ProjectDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ProjectDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ProjectDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ProjectDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ProjectDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ProjectDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ProjectDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ProjectDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ProjectDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ProjectDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ProjectDAOTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ProjectDAOTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql;
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ProjectDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ProjectDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ProjectDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ProjectDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ProjectDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ProjectDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ProjectDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ProjectDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ProjectDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ProjectDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ProjectDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ProjectDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ProjectDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ProjectDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ProjectDAOTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ProjectDAOTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql;
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ProjectDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ProjectDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ProjectDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ProjectDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ProjectDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ProjectDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ProjectDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ProjectDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ProjectDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ProjectDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ProjectDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ProjectDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ProjectDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ProjectDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ProjectDAOTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ProjectDAOTest.xml:Caused by: org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ProjectDAOTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql;
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ProjectDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ProjectDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ProjectDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ProjectDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ProjectDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ProjectDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ProjectDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ProjectDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ProjectDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ProjectDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ProjectDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ProjectDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ProjectDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ProjectDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ProjectDAOTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ProjectDAOTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql;
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ProjectDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ProjectDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ProjectDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ProjectDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ProjectDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ProjectDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ProjectDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ProjectDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ProjectDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ProjectDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ProjectDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ProjectDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ProjectDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ProjectDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ProjectDAOTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ProjectDAOTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql;
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ProjectDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ProjectDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ProjectDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ProjectDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ProjectDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ProjectDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ProjectDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ProjectDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ProjectDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ProjectDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ProjectDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ProjectDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ProjectDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ProjectDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ProjectDAOTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ProjectDAOTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql;
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ProjectDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ProjectDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ProjectDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ProjectDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ProjectDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ProjectDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ProjectDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ProjectDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ProjectDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ProjectDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ProjectDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ProjectDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ProjectDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ProjectDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ProjectDAOTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ProjectDAOTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql;
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ProjectDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ProjectDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ProjectDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ProjectDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ProjectDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ProjectDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ProjectDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ProjectDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ProjectDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ProjectDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ProjectDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ProjectDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ProjectDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ProjectDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ProjectDAOTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ProjectDAOTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql;
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ProjectDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ProjectDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ProjectDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ProjectDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ProjectDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ProjectDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ProjectDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ProjectDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ProjectDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ProjectDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ProjectDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ProjectDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ProjectDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ProjectDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ProjectDAOTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ProjectDAOTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql;
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ProjectDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ProjectDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ProjectDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ProjectDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ProjectDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ProjectDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ProjectDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ProjectDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ProjectDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ProjectDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ProjectDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ProjectDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ProjectDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ProjectDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ProjectDAOTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ProjectDAOTest.xml:Caused by: org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PropertyTypeDAOTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql;
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PropertyTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PropertyTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PropertyTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PropertyTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PropertyTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PropertyTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PropertyTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PropertyTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PropertyTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PropertyTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PropertyTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PropertyTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PropertyTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PropertyTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PropertyTypeDAOTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PropertyTypeDAOTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql;
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PropertyTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PropertyTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PropertyTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PropertyTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PropertyTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PropertyTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PropertyTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PropertyTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PropertyTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PropertyTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PropertyTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PropertyTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PropertyTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PropertyTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PropertyTypeDAOTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PropertyTypeDAOTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql;
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PropertyTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PropertyTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PropertyTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PropertyTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PropertyTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PropertyTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PropertyTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PropertyTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PropertyTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PropertyTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PropertyTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PropertyTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PropertyTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PropertyTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PropertyTypeDAOTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PropertyTypeDAOTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql;
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PropertyTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PropertyTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PropertyTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PropertyTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PropertyTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PropertyTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PropertyTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PropertyTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PropertyTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PropertyTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PropertyTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PropertyTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PropertyTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PropertyTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PropertyTypeDAOTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PropertyTypeDAOTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql;
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PropertyTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PropertyTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PropertyTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PropertyTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PropertyTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PropertyTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PropertyTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PropertyTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PropertyTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PropertyTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PropertyTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PropertyTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PropertyTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PropertyTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PropertyTypeDAOTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PropertyTypeDAOTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql;
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PropertyTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PropertyTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PropertyTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PropertyTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PropertyTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PropertyTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PropertyTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PropertyTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PropertyTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PropertyTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PropertyTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PropertyTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PropertyTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PropertyTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PropertyTypeDAOTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PropertyTypeDAOTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql;
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PropertyTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PropertyTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PropertyTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PropertyTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PropertyTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PropertyTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PropertyTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PropertyTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PropertyTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PropertyTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PropertyTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PropertyTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PropertyTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PropertyTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PropertyTypeDAOTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PropertyTypeDAOTest.xml:Caused by: org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PropertyTypeDAOTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql;
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PropertyTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PropertyTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PropertyTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PropertyTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PropertyTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PropertyTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PropertyTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PropertyTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PropertyTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PropertyTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PropertyTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PropertyTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PropertyTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PropertyTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PropertyTypeDAOTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PropertyTypeDAOTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql;
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PropertyTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PropertyTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PropertyTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PropertyTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PropertyTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PropertyTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PropertyTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PropertyTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PropertyTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PropertyTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PropertyTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PropertyTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PropertyTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PropertyTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PropertyTypeDAOTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PropertyTypeDAOTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql;
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PropertyTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PropertyTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PropertyTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PropertyTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PropertyTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PropertyTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PropertyTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PropertyTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PropertyTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PropertyTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PropertyTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PropertyTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PropertyTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PropertyTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PropertyTypeDAOTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PropertyTypeDAOTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql;
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PropertyTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PropertyTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PropertyTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PropertyTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PropertyTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PropertyTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PropertyTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PropertyTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PropertyTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PropertyTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PropertyTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PropertyTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PropertyTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PropertyTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PropertyTypeDAOTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PropertyTypeDAOTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql;
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PropertyTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PropertyTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PropertyTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PropertyTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PropertyTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PropertyTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PropertyTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PropertyTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PropertyTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PropertyTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PropertyTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PropertyTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PropertyTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PropertyTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PropertyTypeDAOTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PropertyTypeDAOTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql;
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PropertyTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PropertyTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PropertyTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PropertyTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PropertyTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PropertyTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PropertyTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PropertyTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PropertyTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PropertyTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PropertyTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PropertyTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PropertyTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PropertyTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PropertyTypeDAOTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PropertyTypeDAOTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql;
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PropertyTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PropertyTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PropertyTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PropertyTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PropertyTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PropertyTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PropertyTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PropertyTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PropertyTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PropertyTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PropertyTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PropertyTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PropertyTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PropertyTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PropertyTypeDAOTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PropertyTypeDAOTest.xml:Caused by: org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PropertyTypeDAOTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql;
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PropertyTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PropertyTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PropertyTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PropertyTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PropertyTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PropertyTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PropertyTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PropertyTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PropertyTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PropertyTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PropertyTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PropertyTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PropertyTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PropertyTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PropertyTypeDAOTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PropertyTypeDAOTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql;
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PropertyTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PropertyTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PropertyTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PropertyTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PropertyTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PropertyTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PropertyTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PropertyTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PropertyTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PropertyTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PropertyTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PropertyTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PropertyTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PropertyTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PropertyTypeDAOTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PropertyTypeDAOTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql;
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PropertyTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PropertyTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PropertyTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PropertyTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PropertyTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PropertyTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PropertyTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PropertyTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PropertyTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PropertyTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PropertyTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PropertyTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PropertyTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PropertyTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PropertyTypeDAOTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PropertyTypeDAOTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql;
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PropertyTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PropertyTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PropertyTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PropertyTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PropertyTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PropertyTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PropertyTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PropertyTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PropertyTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PropertyTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PropertyTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PropertyTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PropertyTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PropertyTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PropertyTypeDAOTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PropertyTypeDAOTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql;
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PropertyTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PropertyTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PropertyTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PropertyTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PropertyTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PropertyTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PropertyTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PropertyTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PropertyTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PropertyTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PropertyTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PropertyTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PropertyTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PropertyTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PropertyTypeDAOTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PropertyTypeDAOTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql;
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PropertyTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PropertyTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PropertyTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PropertyTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PropertyTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PropertyTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PropertyTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PropertyTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PropertyTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PropertyTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PropertyTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PropertyTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PropertyTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PropertyTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PropertyTypeDAOTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PropertyTypeDAOTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql;
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PropertyTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PropertyTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PropertyTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PropertyTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PropertyTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PropertyTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PropertyTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PropertyTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PropertyTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PropertyTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PropertyTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PropertyTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PropertyTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PropertyTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PropertyTypeDAOTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PropertyTypeDAOTest.xml:Caused by: org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PropertyTypeDAOTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql;
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PropertyTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PropertyTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PropertyTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PropertyTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PropertyTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PropertyTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PropertyTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PropertyTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PropertyTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PropertyTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PropertyTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PropertyTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PropertyTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PropertyTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PropertyTypeDAOTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PropertyTypeDAOTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql;
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PropertyTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PropertyTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PropertyTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PropertyTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PropertyTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PropertyTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PropertyTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PropertyTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PropertyTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PropertyTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PropertyTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PropertyTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PropertyTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PropertyTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PropertyTypeDAOTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PropertyTypeDAOTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql;
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PropertyTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PropertyTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PropertyTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PropertyTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PropertyTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PropertyTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PropertyTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PropertyTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PropertyTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PropertyTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PropertyTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PropertyTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PropertyTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PropertyTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PropertyTypeDAOTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PropertyTypeDAOTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql;
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PropertyTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PropertyTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PropertyTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PropertyTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PropertyTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PropertyTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PropertyTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PropertyTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PropertyTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PropertyTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PropertyTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PropertyTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PropertyTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PropertyTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PropertyTypeDAOTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PropertyTypeDAOTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql;
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PropertyTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PropertyTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PropertyTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PropertyTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PropertyTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PropertyTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PropertyTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PropertyTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PropertyTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PropertyTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PropertyTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PropertyTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PropertyTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PropertyTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PropertyTypeDAOTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PropertyTypeDAOTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql;
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PropertyTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PropertyTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PropertyTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PropertyTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PropertyTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PropertyTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PropertyTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PropertyTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PropertyTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PropertyTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PropertyTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PropertyTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PropertyTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PropertyTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PropertyTypeDAOTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PropertyTypeDAOTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql;
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PropertyTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PropertyTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PropertyTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PropertyTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PropertyTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PropertyTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PropertyTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PropertyTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PropertyTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PropertyTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PropertyTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PropertyTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PropertyTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PropertyTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PropertyTypeDAOTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PropertyTypeDAOTest.xml:Caused by: org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PropertyTypeDAOTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql;
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PropertyTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PropertyTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PropertyTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PropertyTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PropertyTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PropertyTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PropertyTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PropertyTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PropertyTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PropertyTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PropertyTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PropertyTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PropertyTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PropertyTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PropertyTypeDAOTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PropertyTypeDAOTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql;
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PropertyTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PropertyTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PropertyTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PropertyTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PropertyTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PropertyTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PropertyTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PropertyTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PropertyTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PropertyTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PropertyTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PropertyTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PropertyTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PropertyTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PropertyTypeDAOTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PropertyTypeDAOTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql;
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PropertyTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PropertyTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PropertyTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PropertyTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PropertyTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PropertyTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PropertyTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PropertyTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PropertyTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PropertyTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PropertyTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PropertyTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PropertyTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PropertyTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PropertyTypeDAOTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PropertyTypeDAOTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql;
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PropertyTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PropertyTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PropertyTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PropertyTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PropertyTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PropertyTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PropertyTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PropertyTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PropertyTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PropertyTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PropertyTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PropertyTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PropertyTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PropertyTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PropertyTypeDAOTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PropertyTypeDAOTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql;
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PropertyTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PropertyTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PropertyTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PropertyTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PropertyTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PropertyTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PropertyTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PropertyTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PropertyTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PropertyTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PropertyTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PropertyTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PropertyTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PropertyTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PropertyTypeDAOTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PropertyTypeDAOTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql;
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PropertyTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PropertyTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PropertyTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PropertyTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PropertyTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PropertyTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PropertyTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PropertyTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PropertyTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PropertyTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PropertyTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PropertyTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PropertyTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PropertyTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PropertyTypeDAOTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PropertyTypeDAOTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql;
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PropertyTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PropertyTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PropertyTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PropertyTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PropertyTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PropertyTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PropertyTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PropertyTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PropertyTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PropertyTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PropertyTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PropertyTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PropertyTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PropertyTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PropertyTypeDAOTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PropertyTypeDAOTest.xml:Caused by: org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PropertyTypeDAOTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql;
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PropertyTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PropertyTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PropertyTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PropertyTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PropertyTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PropertyTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PropertyTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PropertyTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PropertyTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PropertyTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PropertyTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PropertyTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PropertyTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PropertyTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PropertyTypeDAOTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PropertyTypeDAOTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql;
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PropertyTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PropertyTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PropertyTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PropertyTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PropertyTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PropertyTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PropertyTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PropertyTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PropertyTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PropertyTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PropertyTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PropertyTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PropertyTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PropertyTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PropertyTypeDAOTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PropertyTypeDAOTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql;
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PropertyTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PropertyTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PropertyTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PropertyTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PropertyTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PropertyTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PropertyTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PropertyTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PropertyTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PropertyTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PropertyTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PropertyTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PropertyTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PropertyTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PropertyTypeDAOTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PropertyTypeDAOTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql;
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PropertyTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PropertyTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PropertyTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PropertyTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PropertyTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PropertyTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PropertyTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PropertyTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PropertyTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PropertyTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PropertyTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PropertyTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PropertyTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PropertyTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PropertyTypeDAOTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PropertyTypeDAOTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql;
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PropertyTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PropertyTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PropertyTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PropertyTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PropertyTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PropertyTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PropertyTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PropertyTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PropertyTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PropertyTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PropertyTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PropertyTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PropertyTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PropertyTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PropertyTypeDAOTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PropertyTypeDAOTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql;
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PropertyTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PropertyTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PropertyTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PropertyTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PropertyTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PropertyTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PropertyTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PropertyTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PropertyTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PropertyTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PropertyTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PropertyTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PropertyTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PropertyTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PropertyTypeDAOTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PropertyTypeDAOTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql;
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PropertyTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PropertyTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PropertyTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PropertyTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PropertyTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PropertyTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PropertyTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PropertyTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PropertyTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PropertyTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PropertyTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PropertyTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PropertyTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PropertyTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PropertyTypeDAOTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PropertyTypeDAOTest.xml:Caused by: org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PropertyTypeDAOTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql;
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PropertyTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PropertyTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PropertyTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PropertyTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PropertyTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PropertyTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PropertyTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PropertyTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PropertyTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PropertyTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PropertyTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PropertyTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PropertyTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PropertyTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PropertyTypeDAOTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PropertyTypeDAOTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql;
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PropertyTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PropertyTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PropertyTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PropertyTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PropertyTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PropertyTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PropertyTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PropertyTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PropertyTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PropertyTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PropertyTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PropertyTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PropertyTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PropertyTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PropertyTypeDAOTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PropertyTypeDAOTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql;
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PropertyTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PropertyTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PropertyTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PropertyTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PropertyTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PropertyTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PropertyTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PropertyTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PropertyTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PropertyTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PropertyTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PropertyTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PropertyTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PropertyTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PropertyTypeDAOTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PropertyTypeDAOTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql;
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PropertyTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PropertyTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PropertyTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PropertyTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PropertyTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PropertyTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PropertyTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PropertyTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PropertyTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PropertyTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PropertyTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PropertyTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PropertyTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PropertyTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PropertyTypeDAOTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PropertyTypeDAOTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql;
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PropertyTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PropertyTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PropertyTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PropertyTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PropertyTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PropertyTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PropertyTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PropertyTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PropertyTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PropertyTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PropertyTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PropertyTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PropertyTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PropertyTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PropertyTypeDAOTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PropertyTypeDAOTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql;
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PropertyTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PropertyTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PropertyTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PropertyTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PropertyTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PropertyTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PropertyTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PropertyTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PropertyTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PropertyTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PropertyTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PropertyTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PropertyTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PropertyTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PropertyTypeDAOTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PropertyTypeDAOTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql;
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PropertyTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PropertyTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PropertyTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PropertyTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PropertyTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PropertyTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PropertyTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PropertyTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PropertyTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PropertyTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PropertyTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PropertyTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PropertyTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PropertyTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PropertyTypeDAOTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PropertyTypeDAOTest.xml:Caused by: org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PropertyTypeDAOTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql;
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PropertyTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PropertyTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PropertyTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PropertyTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PropertyTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PropertyTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PropertyTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PropertyTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PropertyTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PropertyTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PropertyTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PropertyTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PropertyTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PropertyTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PropertyTypeDAOTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PropertyTypeDAOTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql;
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PropertyTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PropertyTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PropertyTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PropertyTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PropertyTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PropertyTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PropertyTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PropertyTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PropertyTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PropertyTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PropertyTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PropertyTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PropertyTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PropertyTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PropertyTypeDAOTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PropertyTypeDAOTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql;
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PropertyTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PropertyTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PropertyTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PropertyTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PropertyTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PropertyTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PropertyTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PropertyTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PropertyTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PropertyTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PropertyTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PropertyTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PropertyTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PropertyTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PropertyTypeDAOTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PropertyTypeDAOTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql;
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PropertyTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PropertyTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PropertyTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PropertyTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PropertyTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PropertyTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PropertyTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PropertyTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PropertyTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PropertyTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PropertyTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PropertyTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PropertyTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PropertyTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PropertyTypeDAOTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PropertyTypeDAOTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql;
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PropertyTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PropertyTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PropertyTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PropertyTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PropertyTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PropertyTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PropertyTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PropertyTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PropertyTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PropertyTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PropertyTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PropertyTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PropertyTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PropertyTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PropertyTypeDAOTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PropertyTypeDAOTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql;
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PropertyTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PropertyTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PropertyTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PropertyTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PropertyTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PropertyTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PropertyTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PropertyTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PropertyTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PropertyTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PropertyTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PropertyTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PropertyTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PropertyTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PropertyTypeDAOTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PropertyTypeDAOTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql;
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PropertyTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PropertyTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PropertyTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PropertyTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PropertyTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PropertyTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PropertyTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PropertyTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PropertyTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PropertyTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PropertyTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PropertyTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PropertyTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PropertyTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PropertyTypeDAOTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PropertyTypeDAOTest.xml:Caused by: org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PropertyTypeDAOTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql;
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PropertyTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PropertyTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PropertyTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PropertyTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PropertyTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PropertyTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PropertyTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PropertyTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PropertyTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PropertyTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PropertyTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PropertyTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PropertyTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PropertyTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PropertyTypeDAOTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PropertyTypeDAOTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql;
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PropertyTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PropertyTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PropertyTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PropertyTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PropertyTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PropertyTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PropertyTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PropertyTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PropertyTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PropertyTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PropertyTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PropertyTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PropertyTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PropertyTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PropertyTypeDAOTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PropertyTypeDAOTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql;
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PropertyTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PropertyTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PropertyTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PropertyTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PropertyTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PropertyTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PropertyTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PropertyTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PropertyTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PropertyTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PropertyTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PropertyTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PropertyTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PropertyTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PropertyTypeDAOTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PropertyTypeDAOTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql;
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PropertyTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PropertyTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PropertyTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PropertyTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PropertyTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PropertyTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PropertyTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PropertyTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PropertyTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PropertyTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PropertyTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PropertyTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PropertyTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PropertyTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PropertyTypeDAOTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PropertyTypeDAOTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql;
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PropertyTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PropertyTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PropertyTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PropertyTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PropertyTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PropertyTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PropertyTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PropertyTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PropertyTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PropertyTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PropertyTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PropertyTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PropertyTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PropertyTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PropertyTypeDAOTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PropertyTypeDAOTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql;
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PropertyTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PropertyTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PropertyTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PropertyTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PropertyTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PropertyTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PropertyTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PropertyTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PropertyTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PropertyTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PropertyTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PropertyTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PropertyTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PropertyTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PropertyTypeDAOTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PropertyTypeDAOTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql;
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PropertyTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PropertyTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PropertyTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PropertyTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PropertyTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PropertyTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PropertyTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PropertyTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PropertyTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PropertyTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PropertyTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PropertyTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PropertyTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PropertyTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PropertyTypeDAOTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PropertyTypeDAOTest.xml:Caused by: org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PropertyTypeDAOTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql;
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PropertyTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PropertyTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PropertyTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PropertyTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PropertyTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PropertyTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PropertyTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PropertyTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PropertyTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PropertyTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PropertyTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PropertyTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PropertyTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PropertyTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PropertyTypeDAOTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PropertyTypeDAOTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql;
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PropertyTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PropertyTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PropertyTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PropertyTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PropertyTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PropertyTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PropertyTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PropertyTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PropertyTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PropertyTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PropertyTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PropertyTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PropertyTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PropertyTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PropertyTypeDAOTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PropertyTypeDAOTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql;
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PropertyTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PropertyTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PropertyTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PropertyTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PropertyTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PropertyTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PropertyTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PropertyTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PropertyTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PropertyTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PropertyTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PropertyTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PropertyTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PropertyTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PropertyTypeDAOTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PropertyTypeDAOTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql;
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PropertyTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PropertyTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PropertyTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PropertyTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PropertyTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PropertyTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PropertyTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PropertyTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PropertyTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PropertyTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PropertyTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PropertyTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PropertyTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PropertyTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PropertyTypeDAOTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PropertyTypeDAOTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql;
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PropertyTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PropertyTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PropertyTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PropertyTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PropertyTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PropertyTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PropertyTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PropertyTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PropertyTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PropertyTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PropertyTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PropertyTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PropertyTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PropertyTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PropertyTypeDAOTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PropertyTypeDAOTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql;
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PropertyTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PropertyTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PropertyTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PropertyTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PropertyTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PropertyTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PropertyTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PropertyTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PropertyTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PropertyTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PropertyTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PropertyTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PropertyTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PropertyTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PropertyTypeDAOTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PropertyTypeDAOTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql;
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PropertyTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PropertyTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PropertyTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PropertyTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PropertyTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PropertyTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PropertyTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PropertyTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PropertyTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PropertyTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PropertyTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PropertyTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PropertyTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PropertyTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PropertyTypeDAOTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.PropertyTypeDAOTest.xml:Caused by: org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.QueryDAOTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql;
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.QueryDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.QueryDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.QueryDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.QueryDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.QueryDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.QueryDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.QueryDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.QueryDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.QueryDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.QueryDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.QueryDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.QueryDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.QueryDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.QueryDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.QueryDAOTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.QueryDAOTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql;
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.QueryDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.QueryDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.QueryDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.QueryDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.QueryDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.QueryDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.QueryDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.QueryDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.QueryDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.QueryDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.QueryDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.QueryDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.QueryDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.QueryDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.QueryDAOTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.QueryDAOTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql;
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.QueryDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.QueryDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.QueryDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.QueryDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.QueryDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.QueryDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.QueryDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.QueryDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.QueryDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.QueryDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.QueryDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.QueryDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.QueryDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.QueryDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.QueryDAOTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.QueryDAOTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql;
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.QueryDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.QueryDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.QueryDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.QueryDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.QueryDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.QueryDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.QueryDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.QueryDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.QueryDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.QueryDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.QueryDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.QueryDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.QueryDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.QueryDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.QueryDAOTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.QueryDAOTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql;
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.QueryDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.QueryDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.QueryDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.QueryDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.QueryDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.QueryDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.QueryDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.QueryDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.QueryDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.QueryDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.QueryDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.QueryDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.QueryDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.QueryDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.QueryDAOTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.QueryDAOTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql;
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.QueryDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.QueryDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.QueryDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.QueryDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.QueryDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.QueryDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.QueryDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.QueryDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.QueryDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.QueryDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.QueryDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.QueryDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.QueryDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.QueryDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.QueryDAOTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.QueryDAOTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql;
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.QueryDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.QueryDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.QueryDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.QueryDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.QueryDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.QueryDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.QueryDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.QueryDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.QueryDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.QueryDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.QueryDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.QueryDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.QueryDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.QueryDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.QueryDAOTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.QueryDAOTest.xml:Caused by: org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.RoleAssignmentDAOTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql;
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.RoleAssignmentDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.RoleAssignmentDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.RoleAssignmentDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.RoleAssignmentDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.RoleAssignmentDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.RoleAssignmentDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.RoleAssignmentDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.RoleAssignmentDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.RoleAssignmentDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.RoleAssignmentDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.RoleAssignmentDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.RoleAssignmentDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.RoleAssignmentDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.RoleAssignmentDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.RoleAssignmentDAOTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.RoleAssignmentDAOTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql;
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.RoleAssignmentDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.RoleAssignmentDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.RoleAssignmentDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.RoleAssignmentDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.RoleAssignmentDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.RoleAssignmentDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.RoleAssignmentDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.RoleAssignmentDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.RoleAssignmentDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.RoleAssignmentDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.RoleAssignmentDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.RoleAssignmentDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.RoleAssignmentDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.RoleAssignmentDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.RoleAssignmentDAOTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.RoleAssignmentDAOTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql;
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.RoleAssignmentDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.RoleAssignmentDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.RoleAssignmentDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.RoleAssignmentDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.RoleAssignmentDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.RoleAssignmentDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.RoleAssignmentDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.RoleAssignmentDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.RoleAssignmentDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.RoleAssignmentDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.RoleAssignmentDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.RoleAssignmentDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.RoleAssignmentDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.RoleAssignmentDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.RoleAssignmentDAOTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.RoleAssignmentDAOTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql;
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.RoleAssignmentDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.RoleAssignmentDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.RoleAssignmentDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.RoleAssignmentDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.RoleAssignmentDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.RoleAssignmentDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.RoleAssignmentDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.RoleAssignmentDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.RoleAssignmentDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.RoleAssignmentDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.RoleAssignmentDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.RoleAssignmentDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.RoleAssignmentDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.RoleAssignmentDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.RoleAssignmentDAOTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.RoleAssignmentDAOTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql;
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.RoleAssignmentDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.RoleAssignmentDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.RoleAssignmentDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.RoleAssignmentDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.RoleAssignmentDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.RoleAssignmentDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.RoleAssignmentDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.RoleAssignmentDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.RoleAssignmentDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.RoleAssignmentDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.RoleAssignmentDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.RoleAssignmentDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.RoleAssignmentDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.RoleAssignmentDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.RoleAssignmentDAOTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.RoleAssignmentDAOTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql;
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.RoleAssignmentDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.RoleAssignmentDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.RoleAssignmentDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.RoleAssignmentDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.RoleAssignmentDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.RoleAssignmentDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.RoleAssignmentDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.RoleAssignmentDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.RoleAssignmentDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.RoleAssignmentDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.RoleAssignmentDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.RoleAssignmentDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.RoleAssignmentDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.RoleAssignmentDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.RoleAssignmentDAOTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.RoleAssignmentDAOTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql;
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.RoleAssignmentDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.RoleAssignmentDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.RoleAssignmentDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.RoleAssignmentDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.RoleAssignmentDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.RoleAssignmentDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.RoleAssignmentDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.RoleAssignmentDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.RoleAssignmentDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.RoleAssignmentDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.RoleAssignmentDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.RoleAssignmentDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.RoleAssignmentDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.RoleAssignmentDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.RoleAssignmentDAOTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.RoleAssignmentDAOTest.xml:Caused by: org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.RoleAssignmentDAOTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql;
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.RoleAssignmentDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.RoleAssignmentDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.RoleAssignmentDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.RoleAssignmentDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.RoleAssignmentDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.RoleAssignmentDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.RoleAssignmentDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.RoleAssignmentDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.RoleAssignmentDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.RoleAssignmentDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.RoleAssignmentDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.RoleAssignmentDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.RoleAssignmentDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.RoleAssignmentDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.RoleAssignmentDAOTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.RoleAssignmentDAOTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql;
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.RoleAssignmentDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.RoleAssignmentDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.RoleAssignmentDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.RoleAssignmentDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.RoleAssignmentDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.RoleAssignmentDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.RoleAssignmentDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.RoleAssignmentDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.RoleAssignmentDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.RoleAssignmentDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.RoleAssignmentDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.RoleAssignmentDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.RoleAssignmentDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.RoleAssignmentDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.RoleAssignmentDAOTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.RoleAssignmentDAOTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql;
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.RoleAssignmentDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.RoleAssignmentDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.RoleAssignmentDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.RoleAssignmentDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.RoleAssignmentDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.RoleAssignmentDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.RoleAssignmentDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.RoleAssignmentDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.RoleAssignmentDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.RoleAssignmentDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.RoleAssignmentDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.RoleAssignmentDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.RoleAssignmentDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.RoleAssignmentDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.RoleAssignmentDAOTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.RoleAssignmentDAOTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql;
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.RoleAssignmentDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.RoleAssignmentDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.RoleAssignmentDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.RoleAssignmentDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.RoleAssignmentDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.RoleAssignmentDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.RoleAssignmentDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.RoleAssignmentDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.RoleAssignmentDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.RoleAssignmentDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.RoleAssignmentDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.RoleAssignmentDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.RoleAssignmentDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.RoleAssignmentDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.RoleAssignmentDAOTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.RoleAssignmentDAOTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql;
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.RoleAssignmentDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.RoleAssignmentDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.RoleAssignmentDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.RoleAssignmentDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.RoleAssignmentDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.RoleAssignmentDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.RoleAssignmentDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.RoleAssignmentDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.RoleAssignmentDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.RoleAssignmentDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.RoleAssignmentDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.RoleAssignmentDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.RoleAssignmentDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.RoleAssignmentDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.RoleAssignmentDAOTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.RoleAssignmentDAOTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql;
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.RoleAssignmentDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.RoleAssignmentDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.RoleAssignmentDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.RoleAssignmentDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.RoleAssignmentDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.RoleAssignmentDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.RoleAssignmentDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.RoleAssignmentDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.RoleAssignmentDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.RoleAssignmentDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.RoleAssignmentDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.RoleAssignmentDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.RoleAssignmentDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.RoleAssignmentDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.RoleAssignmentDAOTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.RoleAssignmentDAOTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql;
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.RoleAssignmentDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.RoleAssignmentDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.RoleAssignmentDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.RoleAssignmentDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.RoleAssignmentDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.RoleAssignmentDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.RoleAssignmentDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.RoleAssignmentDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.RoleAssignmentDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.RoleAssignmentDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.RoleAssignmentDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.RoleAssignmentDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.RoleAssignmentDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.RoleAssignmentDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.RoleAssignmentDAOTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.RoleAssignmentDAOTest.xml:Caused by: org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql;
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql;
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql;
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql;
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql;
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql;
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql;
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml:Caused by: org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql;
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql;
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql;
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql;
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql;
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql;
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql;
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml:Caused by: org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql;
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql;
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql;
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql;
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql;
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql;
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql;
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml:Caused by: org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql;
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql;
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql;
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql;
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql;
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql;
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql;
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml:Caused by: org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql;
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql;
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql;
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql;
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql;
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql;
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql;
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml:Caused by: org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql;
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql;
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql;
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql;
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql;
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql;
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql;
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml:Caused by: org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql;
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql;
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql;
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql;
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql;
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql;
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql;
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml:Caused by: org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql;
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql;
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql;
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql;
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql;
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql;
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql;
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml:Caused by: org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql;
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql;
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql;
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql;
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql;
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql;
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql;
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml:Caused by: org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql;
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql;
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql;
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql;
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql;
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql;
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql;
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml:Caused by: org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql;
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql;
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql;
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql;
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql;
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql;
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql;
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml:Caused by: org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql;
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql;
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql;
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql;
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql;
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql;
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql;
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml:Caused by: org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql;
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql;
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql;
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql;
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql;
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql;
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql;
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml:Caused by: org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql;
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql;
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql;
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql;
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql;
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql;
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql;
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml:Caused by: org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql;
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql;
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql;
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql;
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql;
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql;
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql;
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml:Caused by: org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql;
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql;
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql;
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql;
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql;
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql;
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql;
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml:Caused by: org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql;
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql;
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql;
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql;
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql;
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql;
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql;
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleDAOTest.xml:Caused by: org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleTypeDAOTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql;
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleTypeDAOTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleTypeDAOTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql;
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleTypeDAOTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleTypeDAOTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql;
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleTypeDAOTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleTypeDAOTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql;
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleTypeDAOTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleTypeDAOTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql;
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleTypeDAOTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleTypeDAOTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql;
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleTypeDAOTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleTypeDAOTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql;
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleTypeDAOTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleTypeDAOTest.xml:Caused by: org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleTypeDAOTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql;
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleTypeDAOTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleTypeDAOTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql;
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleTypeDAOTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleTypeDAOTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql;
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleTypeDAOTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleTypeDAOTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql;
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleTypeDAOTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleTypeDAOTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql;
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleTypeDAOTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleTypeDAOTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql;
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleTypeDAOTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleTypeDAOTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql;
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleTypeDAOTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleTypeDAOTest.xml:Caused by: org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleTypeDAOTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql;
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleTypeDAOTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleTypeDAOTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql;
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleTypeDAOTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleTypeDAOTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql;
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleTypeDAOTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleTypeDAOTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql;
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleTypeDAOTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleTypeDAOTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql;
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleTypeDAOTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleTypeDAOTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql;
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleTypeDAOTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleTypeDAOTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql;
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleTypeDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleTypeDAOTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.SampleTypeDAOTest.xml:Caused by: org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ScriptDAOTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql;
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ScriptDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ScriptDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ScriptDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ScriptDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ScriptDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ScriptDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ScriptDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ScriptDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ScriptDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ScriptDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ScriptDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ScriptDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ScriptDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ScriptDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ScriptDAOTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ScriptDAOTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql;
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ScriptDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ScriptDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ScriptDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ScriptDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ScriptDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ScriptDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ScriptDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ScriptDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ScriptDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ScriptDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ScriptDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ScriptDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ScriptDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ScriptDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ScriptDAOTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ScriptDAOTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql;
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ScriptDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ScriptDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ScriptDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ScriptDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ScriptDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ScriptDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ScriptDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ScriptDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ScriptDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ScriptDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ScriptDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ScriptDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ScriptDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ScriptDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ScriptDAOTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ScriptDAOTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql;
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ScriptDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ScriptDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ScriptDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ScriptDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ScriptDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ScriptDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ScriptDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ScriptDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ScriptDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ScriptDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ScriptDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ScriptDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ScriptDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ScriptDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ScriptDAOTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ScriptDAOTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql;
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ScriptDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ScriptDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ScriptDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ScriptDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ScriptDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ScriptDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ScriptDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ScriptDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ScriptDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ScriptDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ScriptDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ScriptDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ScriptDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ScriptDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ScriptDAOTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ScriptDAOTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql;
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ScriptDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ScriptDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ScriptDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ScriptDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ScriptDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ScriptDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ScriptDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ScriptDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ScriptDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ScriptDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ScriptDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ScriptDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ScriptDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ScriptDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ScriptDAOTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ScriptDAOTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql;
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ScriptDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ScriptDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ScriptDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ScriptDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ScriptDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ScriptDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ScriptDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ScriptDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ScriptDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ScriptDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ScriptDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ScriptDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ScriptDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ScriptDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ScriptDAOTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ScriptDAOTest.xml:Caused by: org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ScriptDAOTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql;
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ScriptDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ScriptDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ScriptDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ScriptDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ScriptDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ScriptDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ScriptDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ScriptDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ScriptDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ScriptDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ScriptDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ScriptDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ScriptDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ScriptDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ScriptDAOTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ScriptDAOTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql;
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ScriptDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ScriptDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ScriptDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ScriptDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ScriptDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ScriptDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ScriptDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ScriptDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ScriptDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ScriptDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ScriptDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ScriptDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ScriptDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ScriptDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ScriptDAOTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ScriptDAOTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql;
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ScriptDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ScriptDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ScriptDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ScriptDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ScriptDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ScriptDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ScriptDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ScriptDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ScriptDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ScriptDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ScriptDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ScriptDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ScriptDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ScriptDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ScriptDAOTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ScriptDAOTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql;
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ScriptDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ScriptDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ScriptDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ScriptDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ScriptDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ScriptDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ScriptDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ScriptDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ScriptDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ScriptDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ScriptDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ScriptDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ScriptDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ScriptDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ScriptDAOTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ScriptDAOTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql;
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ScriptDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ScriptDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ScriptDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ScriptDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ScriptDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ScriptDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ScriptDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ScriptDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ScriptDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ScriptDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ScriptDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ScriptDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ScriptDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ScriptDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ScriptDAOTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ScriptDAOTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql;
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ScriptDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ScriptDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ScriptDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ScriptDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ScriptDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ScriptDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ScriptDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ScriptDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ScriptDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ScriptDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ScriptDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ScriptDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ScriptDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ScriptDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ScriptDAOTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ScriptDAOTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql;
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ScriptDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ScriptDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ScriptDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ScriptDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ScriptDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ScriptDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ScriptDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ScriptDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ScriptDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ScriptDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ScriptDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ScriptDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ScriptDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ScriptDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ScriptDAOTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ScriptDAOTest.xml:Caused by: org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ScriptDAOTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql;
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ScriptDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ScriptDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ScriptDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ScriptDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ScriptDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ScriptDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ScriptDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ScriptDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ScriptDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ScriptDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ScriptDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ScriptDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ScriptDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ScriptDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ScriptDAOTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ScriptDAOTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql;
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ScriptDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ScriptDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ScriptDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ScriptDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ScriptDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ScriptDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ScriptDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ScriptDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ScriptDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ScriptDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ScriptDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ScriptDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ScriptDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ScriptDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ScriptDAOTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ScriptDAOTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql;
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ScriptDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ScriptDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ScriptDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ScriptDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ScriptDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ScriptDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ScriptDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ScriptDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ScriptDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ScriptDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ScriptDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ScriptDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ScriptDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ScriptDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ScriptDAOTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ScriptDAOTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql;
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ScriptDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ScriptDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ScriptDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ScriptDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ScriptDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ScriptDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ScriptDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ScriptDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ScriptDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ScriptDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ScriptDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ScriptDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ScriptDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ScriptDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ScriptDAOTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ScriptDAOTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql;
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ScriptDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ScriptDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ScriptDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ScriptDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ScriptDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ScriptDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ScriptDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ScriptDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ScriptDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ScriptDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ScriptDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ScriptDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ScriptDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ScriptDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ScriptDAOTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ScriptDAOTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql;
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ScriptDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ScriptDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ScriptDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ScriptDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ScriptDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ScriptDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ScriptDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ScriptDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ScriptDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ScriptDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ScriptDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ScriptDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ScriptDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ScriptDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ScriptDAOTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ScriptDAOTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql;
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ScriptDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ScriptDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ScriptDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ScriptDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ScriptDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ScriptDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ScriptDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ScriptDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ScriptDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ScriptDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ScriptDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ScriptDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ScriptDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ScriptDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ScriptDAOTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ScriptDAOTest.xml:Caused by: org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ScriptDAOTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql;
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ScriptDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ScriptDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ScriptDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ScriptDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ScriptDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ScriptDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ScriptDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ScriptDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ScriptDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ScriptDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ScriptDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ScriptDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ScriptDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ScriptDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ScriptDAOTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ScriptDAOTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql;
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ScriptDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ScriptDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ScriptDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ScriptDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ScriptDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ScriptDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ScriptDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ScriptDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ScriptDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ScriptDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ScriptDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ScriptDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ScriptDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ScriptDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ScriptDAOTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ScriptDAOTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql;
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ScriptDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ScriptDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ScriptDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ScriptDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ScriptDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ScriptDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ScriptDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ScriptDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ScriptDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ScriptDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ScriptDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ScriptDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ScriptDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ScriptDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ScriptDAOTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ScriptDAOTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql;
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ScriptDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ScriptDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ScriptDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ScriptDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ScriptDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ScriptDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ScriptDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ScriptDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ScriptDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ScriptDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ScriptDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ScriptDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ScriptDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ScriptDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ScriptDAOTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ScriptDAOTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql;
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ScriptDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ScriptDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ScriptDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ScriptDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ScriptDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ScriptDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ScriptDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ScriptDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ScriptDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ScriptDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ScriptDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ScriptDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ScriptDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ScriptDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ScriptDAOTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ScriptDAOTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql;
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ScriptDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ScriptDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ScriptDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ScriptDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ScriptDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ScriptDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ScriptDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ScriptDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ScriptDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ScriptDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ScriptDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ScriptDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ScriptDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ScriptDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ScriptDAOTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ScriptDAOTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql;
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ScriptDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ScriptDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ScriptDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ScriptDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ScriptDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ScriptDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ScriptDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ScriptDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ScriptDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ScriptDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ScriptDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ScriptDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ScriptDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ScriptDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ScriptDAOTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ScriptDAOTest.xml:Caused by: org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ScriptDAOTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql;
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ScriptDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ScriptDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ScriptDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ScriptDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ScriptDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ScriptDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ScriptDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ScriptDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ScriptDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ScriptDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ScriptDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ScriptDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ScriptDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ScriptDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ScriptDAOTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ScriptDAOTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql;
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ScriptDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ScriptDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ScriptDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ScriptDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ScriptDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ScriptDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ScriptDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ScriptDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ScriptDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ScriptDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ScriptDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ScriptDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ScriptDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ScriptDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ScriptDAOTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ScriptDAOTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql;
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ScriptDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ScriptDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ScriptDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ScriptDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ScriptDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ScriptDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ScriptDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ScriptDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ScriptDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ScriptDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ScriptDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ScriptDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ScriptDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ScriptDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ScriptDAOTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ScriptDAOTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql;
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ScriptDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ScriptDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ScriptDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ScriptDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ScriptDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ScriptDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ScriptDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ScriptDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ScriptDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ScriptDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ScriptDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ScriptDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ScriptDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ScriptDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ScriptDAOTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ScriptDAOTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql;
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ScriptDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ScriptDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ScriptDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ScriptDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ScriptDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ScriptDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ScriptDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ScriptDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ScriptDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ScriptDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ScriptDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ScriptDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ScriptDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ScriptDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ScriptDAOTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ScriptDAOTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql;
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ScriptDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ScriptDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ScriptDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ScriptDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ScriptDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ScriptDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ScriptDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ScriptDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ScriptDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ScriptDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ScriptDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ScriptDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ScriptDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ScriptDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ScriptDAOTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ScriptDAOTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql;
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ScriptDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ScriptDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ScriptDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ScriptDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ScriptDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ScriptDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ScriptDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ScriptDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ScriptDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ScriptDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ScriptDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ScriptDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ScriptDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ScriptDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ScriptDAOTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ScriptDAOTest.xml:Caused by: org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ScriptDAOTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql;
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ScriptDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ScriptDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ScriptDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ScriptDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ScriptDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ScriptDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ScriptDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ScriptDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ScriptDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ScriptDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ScriptDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ScriptDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ScriptDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ScriptDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ScriptDAOTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ScriptDAOTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql;
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ScriptDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ScriptDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ScriptDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ScriptDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ScriptDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ScriptDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ScriptDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ScriptDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ScriptDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ScriptDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ScriptDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ScriptDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ScriptDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ScriptDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ScriptDAOTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ScriptDAOTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql;
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ScriptDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ScriptDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ScriptDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ScriptDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ScriptDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ScriptDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ScriptDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ScriptDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ScriptDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ScriptDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ScriptDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ScriptDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ScriptDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ScriptDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ScriptDAOTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ScriptDAOTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql;
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ScriptDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ScriptDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ScriptDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ScriptDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ScriptDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ScriptDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ScriptDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ScriptDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ScriptDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ScriptDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ScriptDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ScriptDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ScriptDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ScriptDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ScriptDAOTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ScriptDAOTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql;
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ScriptDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ScriptDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ScriptDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ScriptDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ScriptDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ScriptDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ScriptDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ScriptDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ScriptDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ScriptDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ScriptDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ScriptDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ScriptDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ScriptDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ScriptDAOTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ScriptDAOTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql;
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ScriptDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ScriptDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ScriptDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ScriptDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ScriptDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ScriptDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ScriptDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ScriptDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ScriptDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ScriptDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ScriptDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ScriptDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ScriptDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ScriptDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ScriptDAOTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ScriptDAOTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql;
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ScriptDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ScriptDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ScriptDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ScriptDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ScriptDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ScriptDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ScriptDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ScriptDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ScriptDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ScriptDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ScriptDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ScriptDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ScriptDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ScriptDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ScriptDAOTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ScriptDAOTest.xml:Caused by: org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ScriptDAOTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql;
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ScriptDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ScriptDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ScriptDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ScriptDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ScriptDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ScriptDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ScriptDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ScriptDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ScriptDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ScriptDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ScriptDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ScriptDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ScriptDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ScriptDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ScriptDAOTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ScriptDAOTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql;
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ScriptDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ScriptDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ScriptDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ScriptDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ScriptDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ScriptDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ScriptDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ScriptDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ScriptDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ScriptDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ScriptDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ScriptDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ScriptDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ScriptDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ScriptDAOTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ScriptDAOTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql;
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ScriptDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ScriptDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ScriptDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ScriptDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ScriptDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ScriptDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ScriptDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ScriptDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ScriptDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ScriptDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ScriptDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ScriptDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ScriptDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ScriptDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ScriptDAOTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ScriptDAOTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql;
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ScriptDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ScriptDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ScriptDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ScriptDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ScriptDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ScriptDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ScriptDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ScriptDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ScriptDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ScriptDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ScriptDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ScriptDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ScriptDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ScriptDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ScriptDAOTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ScriptDAOTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql;
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ScriptDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ScriptDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ScriptDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ScriptDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ScriptDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ScriptDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ScriptDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ScriptDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ScriptDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ScriptDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ScriptDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ScriptDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ScriptDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ScriptDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ScriptDAOTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ScriptDAOTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql;
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ScriptDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ScriptDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ScriptDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ScriptDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ScriptDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ScriptDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ScriptDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ScriptDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ScriptDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ScriptDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ScriptDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ScriptDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ScriptDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ScriptDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ScriptDAOTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ScriptDAOTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql;
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ScriptDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ScriptDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ScriptDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ScriptDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ScriptDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ScriptDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ScriptDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ScriptDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ScriptDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ScriptDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ScriptDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ScriptDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ScriptDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ScriptDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ScriptDAOTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ScriptDAOTest.xml:Caused by: org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ScriptDAOTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql;
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ScriptDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ScriptDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ScriptDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ScriptDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ScriptDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ScriptDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ScriptDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ScriptDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ScriptDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ScriptDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ScriptDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ScriptDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ScriptDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ScriptDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ScriptDAOTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ScriptDAOTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql;
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ScriptDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ScriptDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ScriptDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ScriptDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ScriptDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ScriptDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ScriptDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ScriptDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ScriptDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ScriptDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ScriptDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ScriptDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ScriptDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ScriptDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ScriptDAOTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ScriptDAOTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql;
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ScriptDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ScriptDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ScriptDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ScriptDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ScriptDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ScriptDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ScriptDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ScriptDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ScriptDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ScriptDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ScriptDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ScriptDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ScriptDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ScriptDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ScriptDAOTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ScriptDAOTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql;
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ScriptDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ScriptDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ScriptDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ScriptDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ScriptDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ScriptDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ScriptDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ScriptDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ScriptDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ScriptDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ScriptDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ScriptDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ScriptDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ScriptDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ScriptDAOTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ScriptDAOTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql;
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ScriptDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ScriptDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ScriptDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ScriptDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ScriptDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ScriptDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ScriptDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ScriptDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ScriptDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ScriptDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ScriptDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ScriptDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ScriptDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ScriptDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ScriptDAOTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ScriptDAOTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql;
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ScriptDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ScriptDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ScriptDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ScriptDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ScriptDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ScriptDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ScriptDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ScriptDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ScriptDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ScriptDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ScriptDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ScriptDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ScriptDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ScriptDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ScriptDAOTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ScriptDAOTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql;
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ScriptDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ScriptDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ScriptDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ScriptDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ScriptDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ScriptDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ScriptDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ScriptDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ScriptDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ScriptDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ScriptDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ScriptDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ScriptDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ScriptDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ScriptDAOTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ScriptDAOTest.xml:Caused by: org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ScriptDAOTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql;
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ScriptDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ScriptDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ScriptDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ScriptDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ScriptDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ScriptDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ScriptDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ScriptDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ScriptDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ScriptDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ScriptDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ScriptDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ScriptDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ScriptDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ScriptDAOTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ScriptDAOTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql;
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ScriptDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ScriptDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ScriptDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ScriptDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ScriptDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ScriptDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ScriptDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ScriptDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ScriptDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ScriptDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ScriptDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ScriptDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ScriptDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ScriptDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ScriptDAOTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ScriptDAOTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql;
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ScriptDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ScriptDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ScriptDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ScriptDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ScriptDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ScriptDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ScriptDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ScriptDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ScriptDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ScriptDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ScriptDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ScriptDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ScriptDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ScriptDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ScriptDAOTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ScriptDAOTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql;
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ScriptDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ScriptDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ScriptDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ScriptDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ScriptDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ScriptDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ScriptDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ScriptDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ScriptDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ScriptDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ScriptDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ScriptDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ScriptDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ScriptDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ScriptDAOTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ScriptDAOTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql;
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ScriptDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ScriptDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ScriptDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ScriptDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ScriptDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ScriptDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ScriptDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ScriptDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ScriptDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ScriptDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ScriptDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ScriptDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ScriptDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ScriptDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ScriptDAOTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ScriptDAOTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql;
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ScriptDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ScriptDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ScriptDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ScriptDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ScriptDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ScriptDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ScriptDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ScriptDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ScriptDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ScriptDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ScriptDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ScriptDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ScriptDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ScriptDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ScriptDAOTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ScriptDAOTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql;
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ScriptDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ScriptDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ScriptDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ScriptDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ScriptDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ScriptDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ScriptDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ScriptDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ScriptDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ScriptDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ScriptDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ScriptDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ScriptDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ScriptDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ScriptDAOTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ScriptDAOTest.xml:Caused by: org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ScriptDAOTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql;
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ScriptDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ScriptDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ScriptDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ScriptDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ScriptDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ScriptDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ScriptDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ScriptDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ScriptDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ScriptDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ScriptDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ScriptDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ScriptDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ScriptDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ScriptDAOTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ScriptDAOTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql;
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ScriptDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ScriptDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ScriptDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ScriptDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ScriptDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ScriptDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ScriptDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ScriptDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ScriptDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ScriptDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ScriptDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ScriptDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ScriptDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ScriptDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ScriptDAOTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ScriptDAOTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql;
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ScriptDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ScriptDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ScriptDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ScriptDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ScriptDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ScriptDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ScriptDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ScriptDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ScriptDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ScriptDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ScriptDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ScriptDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ScriptDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ScriptDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ScriptDAOTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ScriptDAOTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql;
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ScriptDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ScriptDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ScriptDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ScriptDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ScriptDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ScriptDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ScriptDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ScriptDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ScriptDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ScriptDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ScriptDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ScriptDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ScriptDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ScriptDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ScriptDAOTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ScriptDAOTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql;
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ScriptDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ScriptDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ScriptDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ScriptDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ScriptDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ScriptDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ScriptDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ScriptDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ScriptDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ScriptDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ScriptDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ScriptDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ScriptDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ScriptDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ScriptDAOTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ScriptDAOTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql;
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ScriptDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ScriptDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ScriptDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ScriptDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ScriptDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ScriptDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ScriptDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ScriptDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ScriptDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ScriptDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ScriptDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ScriptDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ScriptDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ScriptDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ScriptDAOTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ScriptDAOTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql;
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ScriptDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ScriptDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ScriptDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ScriptDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ScriptDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ScriptDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ScriptDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ScriptDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ScriptDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ScriptDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ScriptDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ScriptDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ScriptDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ScriptDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ScriptDAOTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.ScriptDAOTest.xml:Caused by: org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.VocabularyDAOTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql;
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.VocabularyDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.VocabularyDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.VocabularyDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.VocabularyDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.VocabularyDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.VocabularyDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.VocabularyDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.VocabularyDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.VocabularyDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.VocabularyDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.VocabularyDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.VocabularyDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.VocabularyDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.VocabularyDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.VocabularyDAOTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.VocabularyDAOTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql;
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.VocabularyDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.VocabularyDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.VocabularyDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.VocabularyDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.VocabularyDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.VocabularyDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.VocabularyDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.VocabularyDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.VocabularyDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.VocabularyDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.VocabularyDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.VocabularyDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.VocabularyDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.VocabularyDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.VocabularyDAOTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.VocabularyDAOTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql;
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.VocabularyDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.VocabularyDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.VocabularyDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.VocabularyDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.VocabularyDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.VocabularyDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.VocabularyDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.VocabularyDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.VocabularyDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.VocabularyDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.VocabularyDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.VocabularyDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.VocabularyDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.VocabularyDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.VocabularyDAOTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.VocabularyDAOTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql;
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.VocabularyDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.VocabularyDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.VocabularyDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.VocabularyDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.VocabularyDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.VocabularyDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.VocabularyDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.VocabularyDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.VocabularyDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.VocabularyDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.VocabularyDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.VocabularyDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.VocabularyDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.VocabularyDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.VocabularyDAOTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.VocabularyDAOTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql;
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.VocabularyDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.VocabularyDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.VocabularyDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.VocabularyDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.VocabularyDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.VocabularyDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.VocabularyDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.VocabularyDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.VocabularyDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.VocabularyDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.VocabularyDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.VocabularyDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.VocabularyDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.VocabularyDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.VocabularyDAOTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.VocabularyDAOTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql;
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.VocabularyDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.VocabularyDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.VocabularyDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.VocabularyDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.VocabularyDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.VocabularyDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.VocabularyDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.VocabularyDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.VocabularyDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.VocabularyDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.VocabularyDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.VocabularyDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.VocabularyDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.VocabularyDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.VocabularyDAOTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.VocabularyDAOTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql;
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.VocabularyDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.VocabularyDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.VocabularyDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.VocabularyDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.VocabularyDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.VocabularyDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.VocabularyDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.VocabularyDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.VocabularyDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.VocabularyDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.VocabularyDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.VocabularyDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.VocabularyDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.VocabularyDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.VocabularyDAOTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.VocabularyDAOTest.xml:Caused by: org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.VocabularyDAOTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql;
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.VocabularyDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.VocabularyDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.VocabularyDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.VocabularyDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.VocabularyDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.VocabularyDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.VocabularyDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.VocabularyDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.VocabularyDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.VocabularyDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.VocabularyDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.VocabularyDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.VocabularyDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.VocabularyDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.VocabularyDAOTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.VocabularyDAOTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql;
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.VocabularyDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.VocabularyDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.VocabularyDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.VocabularyDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.VocabularyDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.VocabularyDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.VocabularyDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.VocabularyDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.VocabularyDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.VocabularyDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.VocabularyDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.VocabularyDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.VocabularyDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.VocabularyDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.VocabularyDAOTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.VocabularyDAOTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql;
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.VocabularyDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.VocabularyDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.VocabularyDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.VocabularyDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.VocabularyDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.VocabularyDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.VocabularyDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.VocabularyDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.VocabularyDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.VocabularyDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.VocabularyDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.VocabularyDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.VocabularyDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.VocabularyDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.VocabularyDAOTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.VocabularyDAOTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql;
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.VocabularyDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.VocabularyDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.VocabularyDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.VocabularyDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.VocabularyDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.VocabularyDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.VocabularyDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.VocabularyDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.VocabularyDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.VocabularyDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.VocabularyDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.VocabularyDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.VocabularyDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.VocabularyDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.VocabularyDAOTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.VocabularyDAOTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql;
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.VocabularyDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.VocabularyDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.VocabularyDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.VocabularyDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.VocabularyDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.VocabularyDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.VocabularyDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.VocabularyDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.VocabularyDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.VocabularyDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.VocabularyDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.VocabularyDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.VocabularyDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.VocabularyDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.VocabularyDAOTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.VocabularyDAOTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql;
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.VocabularyDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.VocabularyDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.VocabularyDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.VocabularyDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.VocabularyDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.VocabularyDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.VocabularyDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.VocabularyDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.VocabularyDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.VocabularyDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.VocabularyDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.VocabularyDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.VocabularyDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.VocabularyDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.VocabularyDAOTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.VocabularyDAOTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql;
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.VocabularyDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.VocabularyDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.VocabularyDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.VocabularyDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.VocabularyDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.VocabularyDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.VocabularyDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.VocabularyDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.VocabularyDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.VocabularyDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.VocabularyDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.VocabularyDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.VocabularyDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.VocabularyDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.VocabularyDAOTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.VocabularyDAOTest.xml:Caused by: org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.VocabularyDAOTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql;
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.VocabularyDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.VocabularyDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.VocabularyDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.VocabularyDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.VocabularyDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.VocabularyDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.VocabularyDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.VocabularyDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.VocabularyDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.VocabularyDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.VocabularyDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.VocabularyDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.VocabularyDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.VocabularyDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.VocabularyDAOTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.VocabularyDAOTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql;
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.VocabularyDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.VocabularyDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.VocabularyDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.VocabularyDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.VocabularyDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.VocabularyDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.VocabularyDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.VocabularyDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.VocabularyDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.VocabularyDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.VocabularyDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.VocabularyDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.VocabularyDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.VocabularyDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.VocabularyDAOTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.VocabularyDAOTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql;
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.VocabularyDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.VocabularyDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.VocabularyDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.VocabularyDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.VocabularyDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.VocabularyDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.VocabularyDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.VocabularyDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.VocabularyDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.VocabularyDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.VocabularyDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.VocabularyDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.VocabularyDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.VocabularyDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.VocabularyDAOTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.VocabularyDAOTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql;
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.VocabularyDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.VocabularyDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.VocabularyDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.VocabularyDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.VocabularyDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.VocabularyDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.VocabularyDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.VocabularyDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.VocabularyDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.VocabularyDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.VocabularyDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.VocabularyDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.VocabularyDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.VocabularyDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.VocabularyDAOTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.VocabularyDAOTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql;
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.VocabularyDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.VocabularyDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.VocabularyDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.VocabularyDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.VocabularyDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.VocabularyDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.VocabularyDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.VocabularyDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.VocabularyDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.VocabularyDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.VocabularyDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.VocabularyDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.VocabularyDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.VocabularyDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.VocabularyDAOTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.VocabularyDAOTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql;
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.VocabularyDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.VocabularyDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.VocabularyDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.VocabularyDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.VocabularyDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.VocabularyDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.VocabularyDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.VocabularyDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.VocabularyDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.VocabularyDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.VocabularyDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.VocabularyDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.VocabularyDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.VocabularyDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.VocabularyDAOTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.VocabularyDAOTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql;
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.VocabularyDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.VocabularyDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.VocabularyDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.VocabularyDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.VocabularyDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.VocabularyDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.VocabularyDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.VocabularyDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.VocabularyDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.VocabularyDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.VocabularyDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.VocabularyDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.VocabularyDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.VocabularyDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.VocabularyDAOTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.VocabularyDAOTest.xml:Caused by: org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.VocabularyDAOTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql;
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.VocabularyDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.VocabularyDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.VocabularyDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.VocabularyDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.VocabularyDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.VocabularyDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.VocabularyDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.VocabularyDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.VocabularyDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.VocabularyDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.VocabularyDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.VocabularyDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.VocabularyDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.VocabularyDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.VocabularyDAOTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.VocabularyDAOTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql;
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.VocabularyDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.VocabularyDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.VocabularyDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.VocabularyDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.VocabularyDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.VocabularyDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.VocabularyDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.VocabularyDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.VocabularyDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.VocabularyDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.VocabularyDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.VocabularyDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.VocabularyDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.VocabularyDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.VocabularyDAOTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.VocabularyDAOTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql;
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.VocabularyDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.VocabularyDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.VocabularyDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.VocabularyDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.VocabularyDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.VocabularyDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.VocabularyDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.VocabularyDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.VocabularyDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.VocabularyDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.VocabularyDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.VocabularyDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.VocabularyDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.VocabularyDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.VocabularyDAOTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.VocabularyDAOTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql;
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.VocabularyDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.VocabularyDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.VocabularyDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.VocabularyDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.VocabularyDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.VocabularyDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.VocabularyDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.VocabularyDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.VocabularyDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.VocabularyDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.VocabularyDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.VocabularyDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.VocabularyDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.VocabularyDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.VocabularyDAOTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.VocabularyDAOTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql;
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.VocabularyDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.VocabularyDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.VocabularyDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.VocabularyDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.VocabularyDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.VocabularyDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.VocabularyDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.VocabularyDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.VocabularyDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.VocabularyDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.VocabularyDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.VocabularyDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.VocabularyDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.VocabularyDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.VocabularyDAOTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.VocabularyDAOTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql;
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.VocabularyDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.VocabularyDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.VocabularyDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.VocabularyDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.VocabularyDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.VocabularyDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.VocabularyDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.VocabularyDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.VocabularyDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.VocabularyDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.VocabularyDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.VocabularyDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.VocabularyDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.VocabularyDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.VocabularyDAOTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.VocabularyDAOTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql;
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.VocabularyDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.VocabularyDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.VocabularyDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.VocabularyDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.VocabularyDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.VocabularyDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.VocabularyDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.VocabularyDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.VocabularyDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.VocabularyDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.VocabularyDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.VocabularyDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.VocabularyDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.VocabularyDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.VocabularyDAOTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.VocabularyDAOTest.xml:Caused by: org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.VocabularyDAOTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql;
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.VocabularyDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.VocabularyDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.VocabularyDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.VocabularyDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.VocabularyDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.VocabularyDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.VocabularyDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.VocabularyDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.VocabularyDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.VocabularyDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.VocabularyDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.VocabularyDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.VocabularyDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.VocabularyDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.VocabularyDAOTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.VocabularyDAOTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql;
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.VocabularyDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.VocabularyDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.VocabularyDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.VocabularyDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.VocabularyDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.VocabularyDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.VocabularyDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.VocabularyDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.VocabularyDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.VocabularyDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.VocabularyDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.VocabularyDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.VocabularyDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.VocabularyDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.VocabularyDAOTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.VocabularyDAOTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql;
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.VocabularyDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.VocabularyDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.VocabularyDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.VocabularyDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.VocabularyDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.VocabularyDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.VocabularyDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.VocabularyDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.VocabularyDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.VocabularyDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.VocabularyDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.VocabularyDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.VocabularyDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.VocabularyDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.VocabularyDAOTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.VocabularyDAOTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql;
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.VocabularyDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.VocabularyDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.VocabularyDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.VocabularyDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.VocabularyDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.VocabularyDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.VocabularyDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.VocabularyDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.VocabularyDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.VocabularyDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.VocabularyDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.VocabularyDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.VocabularyDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.VocabularyDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.VocabularyDAOTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.VocabularyDAOTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql;
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.VocabularyDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.VocabularyDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.VocabularyDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.VocabularyDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.VocabularyDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.VocabularyDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.VocabularyDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.VocabularyDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.VocabularyDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.VocabularyDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.VocabularyDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.VocabularyDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.VocabularyDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.VocabularyDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.VocabularyDAOTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.VocabularyDAOTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql;
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.VocabularyDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.VocabularyDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.VocabularyDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.VocabularyDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.VocabularyDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.VocabularyDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.VocabularyDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.VocabularyDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.VocabularyDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.VocabularyDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.VocabularyDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.VocabularyDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.VocabularyDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.VocabularyDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.VocabularyDAOTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.VocabularyDAOTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql;
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.VocabularyDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.VocabularyDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.VocabularyDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.VocabularyDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.VocabularyDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.VocabularyDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.VocabularyDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.VocabularyDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.VocabularyDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.VocabularyDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.VocabularyDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.VocabularyDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.VocabularyDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.VocabularyDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.VocabularyDAOTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.VocabularyDAOTest.xml:Caused by: org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.VocabularyDAOTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql;
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.VocabularyDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.VocabularyDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.VocabularyDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.VocabularyDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.VocabularyDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.VocabularyDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.VocabularyDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.VocabularyDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.VocabularyDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.VocabularyDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.VocabularyDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.VocabularyDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.VocabularyDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.VocabularyDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.VocabularyDAOTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.VocabularyDAOTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql;
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.VocabularyDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.VocabularyDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.VocabularyDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.VocabularyDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.VocabularyDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.VocabularyDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.VocabularyDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.VocabularyDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.VocabularyDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.VocabularyDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.VocabularyDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.VocabularyDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.VocabularyDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.VocabularyDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.VocabularyDAOTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.VocabularyDAOTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql;
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.VocabularyDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.VocabularyDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.VocabularyDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.VocabularyDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.VocabularyDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.VocabularyDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.VocabularyDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.VocabularyDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.VocabularyDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.VocabularyDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.VocabularyDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.VocabularyDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.VocabularyDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.VocabularyDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.VocabularyDAOTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.VocabularyDAOTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql;
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.VocabularyDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.VocabularyDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.VocabularyDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.VocabularyDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.VocabularyDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.VocabularyDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.VocabularyDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.VocabularyDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.VocabularyDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.VocabularyDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.VocabularyDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.VocabularyDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.VocabularyDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.VocabularyDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.VocabularyDAOTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.VocabularyDAOTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql;
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.VocabularyDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.VocabularyDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.VocabularyDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.VocabularyDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.VocabularyDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.VocabularyDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.VocabularyDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.VocabularyDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.VocabularyDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.VocabularyDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.VocabularyDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.VocabularyDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.VocabularyDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.VocabularyDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.VocabularyDAOTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.VocabularyDAOTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql;
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.VocabularyDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.VocabularyDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.VocabularyDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.VocabularyDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.VocabularyDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.VocabularyDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.VocabularyDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.VocabularyDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.VocabularyDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.VocabularyDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.VocabularyDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.VocabularyDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.VocabularyDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.VocabularyDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.VocabularyDAOTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.VocabularyDAOTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql;
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.VocabularyDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.VocabularyDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.VocabularyDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.VocabularyDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.VocabularyDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.VocabularyDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.VocabularyDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.VocabularyDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.VocabularyDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.VocabularyDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.VocabularyDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.VocabularyDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.VocabularyDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.VocabularyDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.VocabularyDAOTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.VocabularyDAOTest.xml:Caused by: org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.VocabularyDAOTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql;
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.VocabularyDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.VocabularyDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.VocabularyDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.VocabularyDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.VocabularyDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.VocabularyDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.VocabularyDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.VocabularyDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.VocabularyDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.VocabularyDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.VocabularyDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.VocabularyDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.VocabularyDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.VocabularyDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.VocabularyDAOTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.VocabularyDAOTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql;
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.VocabularyDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.VocabularyDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.VocabularyDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.VocabularyDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.VocabularyDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.VocabularyDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.VocabularyDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.VocabularyDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.VocabularyDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.VocabularyDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.VocabularyDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.VocabularyDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.VocabularyDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.VocabularyDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.VocabularyDAOTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.VocabularyDAOTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql;
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.VocabularyDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.VocabularyDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.VocabularyDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.VocabularyDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.VocabularyDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.VocabularyDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.VocabularyDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.VocabularyDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.VocabularyDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.VocabularyDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.VocabularyDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.VocabularyDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.VocabularyDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.VocabularyDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.VocabularyDAOTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.VocabularyDAOTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql;
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.VocabularyDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.VocabularyDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.VocabularyDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.VocabularyDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.VocabularyDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.VocabularyDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.VocabularyDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.VocabularyDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.VocabularyDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.VocabularyDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.VocabularyDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.VocabularyDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.VocabularyDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.VocabularyDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.VocabularyDAOTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.VocabularyDAOTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql;
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.VocabularyDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.VocabularyDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.VocabularyDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.VocabularyDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.VocabularyDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.VocabularyDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.VocabularyDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.VocabularyDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.VocabularyDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.VocabularyDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.VocabularyDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.VocabularyDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.VocabularyDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.VocabularyDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.VocabularyDAOTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.VocabularyDAOTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql;
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.VocabularyDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.VocabularyDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.VocabularyDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.VocabularyDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.VocabularyDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.VocabularyDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.VocabularyDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.VocabularyDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.VocabularyDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.VocabularyDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.VocabularyDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.VocabularyDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.VocabularyDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.VocabularyDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.VocabularyDAOTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.VocabularyDAOTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql;
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.VocabularyDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.VocabularyDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.VocabularyDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.VocabularyDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.VocabularyDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.VocabularyDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.VocabularyDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.VocabularyDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.VocabularyDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.VocabularyDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.VocabularyDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.VocabularyDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.VocabularyDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.VocabularyDAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.VocabularyDAOTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.generic.server.dataaccess.db.VocabularyDAOTest.xml:Caused by: org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.plugin.query.server.DAOTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql;
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.plugin.query.server.DAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.plugin.query.server.DAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.plugin.query.server.DAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.plugin.query.server.DAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.plugin.query.server.DAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.plugin.query.server.DAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.plugin.query.server.DAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.plugin.query.server.DAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.plugin.query.server.DAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.plugin.query.server.DAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.plugin.query.server.DAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.plugin.query.server.DAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.plugin.query.server.DAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.plugin.query.server.DAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.plugin.query.server.DAOTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.plugin.query.server.DAOTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql;
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.plugin.query.server.DAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.plugin.query.server.DAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.plugin.query.server.DAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.plugin.query.server.DAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.plugin.query.server.DAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.plugin.query.server.DAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.plugin.query.server.DAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.plugin.query.server.DAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.plugin.query.server.DAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.plugin.query.server.DAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.plugin.query.server.DAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.plugin.query.server.DAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.plugin.query.server.DAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.plugin.query.server.DAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.plugin.query.server.DAOTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.plugin.query.server.DAOTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql;
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.plugin.query.server.DAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.plugin.query.server.DAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.plugin.query.server.DAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.plugin.query.server.DAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.plugin.query.server.DAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.plugin.query.server.DAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.plugin.query.server.DAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.plugin.query.server.DAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.plugin.query.server.DAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.plugin.query.server.DAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.plugin.query.server.DAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.plugin.query.server.DAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.plugin.query.server.DAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.plugin.query.server.DAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.plugin.query.server.DAOTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.plugin.query.server.DAOTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql;
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.plugin.query.server.DAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.plugin.query.server.DAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.plugin.query.server.DAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.plugin.query.server.DAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.plugin.query.server.DAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.plugin.query.server.DAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.plugin.query.server.DAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.plugin.query.server.DAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.plugin.query.server.DAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.plugin.query.server.DAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.plugin.query.server.DAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.plugin.query.server.DAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.plugin.query.server.DAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.plugin.query.server.DAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.plugin.query.server.DAOTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.plugin.query.server.DAOTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql;
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.plugin.query.server.DAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.plugin.query.server.DAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.plugin.query.server.DAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.plugin.query.server.DAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.plugin.query.server.DAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.plugin.query.server.DAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.plugin.query.server.DAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.plugin.query.server.DAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.plugin.query.server.DAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.plugin.query.server.DAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.plugin.query.server.DAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.plugin.query.server.DAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.plugin.query.server.DAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.plugin.query.server.DAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.plugin.query.server.DAOTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.plugin.query.server.DAOTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql;
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.plugin.query.server.DAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.plugin.query.server.DAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.plugin.query.server.DAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.plugin.query.server.DAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.plugin.query.server.DAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.plugin.query.server.DAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.plugin.query.server.DAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.plugin.query.server.DAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.plugin.query.server.DAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.plugin.query.server.DAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.plugin.query.server.DAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.plugin.query.server.DAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.plugin.query.server.DAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.plugin.query.server.DAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.plugin.query.server.DAOTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.plugin.query.server.DAOTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql;
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.plugin.query.server.DAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.plugin.query.server.DAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.plugin.query.server.DAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.plugin.query.server.DAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.plugin.query.server.DAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.plugin.query.server.DAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.plugin.query.server.DAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.plugin.query.server.DAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.plugin.query.server.DAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.plugin.query.server.DAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.plugin.query.server.DAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.plugin.query.server.DAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.plugin.query.server.DAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.plugin.query.server.DAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.plugin.query.server.DAOTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.plugin.query.server.DAOTest.xml:Caused by: org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.plugin.query.server.DAOTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql;
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.plugin.query.server.DAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.plugin.query.server.DAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.plugin.query.server.DAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.plugin.query.server.DAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.plugin.query.server.DAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.plugin.query.server.DAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.plugin.query.server.DAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.plugin.query.server.DAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.plugin.query.server.DAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.plugin.query.server.DAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.plugin.query.server.DAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.plugin.query.server.DAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.plugin.query.server.DAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.plugin.query.server.DAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.plugin.query.server.DAOTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.plugin.query.server.DAOTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql;
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.plugin.query.server.DAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.plugin.query.server.DAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.plugin.query.server.DAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.plugin.query.server.DAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.plugin.query.server.DAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.plugin.query.server.DAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.plugin.query.server.DAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.plugin.query.server.DAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.plugin.query.server.DAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.plugin.query.server.DAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.plugin.query.server.DAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.plugin.query.server.DAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.plugin.query.server.DAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.plugin.query.server.DAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.plugin.query.server.DAOTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.plugin.query.server.DAOTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql;
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.plugin.query.server.DAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.plugin.query.server.DAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.plugin.query.server.DAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.plugin.query.server.DAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.plugin.query.server.DAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.plugin.query.server.DAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.plugin.query.server.DAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.plugin.query.server.DAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.plugin.query.server.DAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.plugin.query.server.DAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.plugin.query.server.DAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.plugin.query.server.DAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.plugin.query.server.DAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.plugin.query.server.DAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.plugin.query.server.DAOTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.plugin.query.server.DAOTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql;
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.plugin.query.server.DAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.plugin.query.server.DAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.plugin.query.server.DAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.plugin.query.server.DAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.plugin.query.server.DAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.plugin.query.server.DAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.plugin.query.server.DAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.plugin.query.server.DAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.plugin.query.server.DAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.plugin.query.server.DAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.plugin.query.server.DAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.plugin.query.server.DAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.plugin.query.server.DAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.plugin.query.server.DAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.plugin.query.server.DAOTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.plugin.query.server.DAOTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql;
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.plugin.query.server.DAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.plugin.query.server.DAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.plugin.query.server.DAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.plugin.query.server.DAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.plugin.query.server.DAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.plugin.query.server.DAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.plugin.query.server.DAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.plugin.query.server.DAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.plugin.query.server.DAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.plugin.query.server.DAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.plugin.query.server.DAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.plugin.query.server.DAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.plugin.query.server.DAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.plugin.query.server.DAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.plugin.query.server.DAOTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.plugin.query.server.DAOTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql;
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.plugin.query.server.DAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.plugin.query.server.DAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.plugin.query.server.DAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.plugin.query.server.DAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.plugin.query.server.DAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.plugin.query.server.DAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.plugin.query.server.DAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.plugin.query.server.DAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.plugin.query.server.DAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.plugin.query.server.DAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.plugin.query.server.DAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.plugin.query.server.DAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.plugin.query.server.DAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.plugin.query.server.DAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.plugin.query.server.DAOTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.plugin.query.server.DAOTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql;
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.plugin.query.server.DAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.plugin.query.server.DAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.plugin.query.server.DAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.plugin.query.server.DAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.plugin.query.server.DAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.plugin.query.server.DAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.plugin.query.server.DAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.plugin.query.server.DAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.plugin.query.server.DAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.plugin.query.server.DAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.plugin.query.server.DAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.plugin.query.server.DAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.plugin.query.server.DAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.plugin.query.server.DAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.plugin.query.server.DAOTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.plugin.query.server.DAOTest.xml:Caused by: org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.plugin.query.server.DAOTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql;
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.plugin.query.server.DAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.plugin.query.server.DAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.plugin.query.server.DAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.plugin.query.server.DAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.plugin.query.server.DAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.plugin.query.server.DAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.plugin.query.server.DAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.plugin.query.server.DAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.plugin.query.server.DAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.plugin.query.server.DAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.plugin.query.server.DAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.plugin.query.server.DAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.plugin.query.server.DAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.plugin.query.server.DAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.plugin.query.server.DAOTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.plugin.query.server.DAOTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql;
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.plugin.query.server.DAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.plugin.query.server.DAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.plugin.query.server.DAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.plugin.query.server.DAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.plugin.query.server.DAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.plugin.query.server.DAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.plugin.query.server.DAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.plugin.query.server.DAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.plugin.query.server.DAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.plugin.query.server.DAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.plugin.query.server.DAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.plugin.query.server.DAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.plugin.query.server.DAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.plugin.query.server.DAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.plugin.query.server.DAOTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.plugin.query.server.DAOTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql;
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.plugin.query.server.DAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.plugin.query.server.DAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.plugin.query.server.DAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.plugin.query.server.DAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.plugin.query.server.DAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.plugin.query.server.DAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.plugin.query.server.DAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.plugin.query.server.DAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.plugin.query.server.DAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.plugin.query.server.DAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.plugin.query.server.DAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.plugin.query.server.DAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.plugin.query.server.DAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.plugin.query.server.DAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.plugin.query.server.DAOTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.plugin.query.server.DAOTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql;
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.plugin.query.server.DAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.plugin.query.server.DAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.plugin.query.server.DAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.plugin.query.server.DAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.plugin.query.server.DAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.plugin.query.server.DAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.plugin.query.server.DAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.plugin.query.server.DAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.plugin.query.server.DAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.plugin.query.server.DAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.plugin.query.server.DAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.plugin.query.server.DAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.plugin.query.server.DAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.plugin.query.server.DAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.plugin.query.server.DAOTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.plugin.query.server.DAOTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql;
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.plugin.query.server.DAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.plugin.query.server.DAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.plugin.query.server.DAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.plugin.query.server.DAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.plugin.query.server.DAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.plugin.query.server.DAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.plugin.query.server.DAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.plugin.query.server.DAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.plugin.query.server.DAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.plugin.query.server.DAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.plugin.query.server.DAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.plugin.query.server.DAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.plugin.query.server.DAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.plugin.query.server.DAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.plugin.query.server.DAOTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.plugin.query.server.DAOTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql;
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.plugin.query.server.DAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.plugin.query.server.DAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.plugin.query.server.DAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.plugin.query.server.DAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.plugin.query.server.DAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.plugin.query.server.DAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.plugin.query.server.DAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.plugin.query.server.DAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.plugin.query.server.DAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.plugin.query.server.DAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.plugin.query.server.DAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.plugin.query.server.DAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.plugin.query.server.DAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.plugin.query.server.DAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.plugin.query.server.DAOTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.plugin.query.server.DAOTest.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql;
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.plugin.query.server.DAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.plugin.query.server.DAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.plugin.query.server.DAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.plugin.query.server.DAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.plugin.query.server.DAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.plugin.query.server.DAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.plugin.query.server.DAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.plugin.query.server.DAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.plugin.query.server.DAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.plugin.query.server.DAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.plugin.query.server.DAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.plugin.query.server.DAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.plugin.query.server.DAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.plugin.query.server.DAOTest.xml:    LANGUAGE plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.plugin.query.server.DAOTest.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql
+./test-output/junitreports/TEST-ch.systemsx.cisd.openbis.plugin.query.server.DAOTest.xml:Caused by: org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql
+./test-output/testng-results.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql;
+./test-output/testng-results.xml:    LANGUAGE plpgsql
+./test-output/testng-results.xml:    LANGUAGE plpgsql
+./test-output/testng-results.xml:    LANGUAGE plpgsql
+./test-output/testng-results.xml:    LANGUAGE plpgsql
+./test-output/testng-results.xml:    LANGUAGE plpgsql
+./test-output/testng-results.xml:    LANGUAGE plpgsql
+./test-output/testng-results.xml:    LANGUAGE plpgsql
+./test-output/testng-results.xml:    LANGUAGE plpgsql
+./test-output/testng-results.xml:    LANGUAGE plpgsql
+./test-output/testng-results.xml:    LANGUAGE plpgsql
+./test-output/testng-results.xml:    LANGUAGE plpgsql
+./test-output/testng-results.xml:    LANGUAGE plpgsql
+./test-output/testng-results.xml:    LANGUAGE plpgsql
+./test-output/testng-results.xml:    LANGUAGE plpgsql
+./test-output/testng-results.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql
+./test-output/testng-results.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql;
+./test-output/testng-results.xml:    LANGUAGE plpgsql
+./test-output/testng-results.xml:    LANGUAGE plpgsql
+./test-output/testng-results.xml:    LANGUAGE plpgsql
+./test-output/testng-results.xml:    LANGUAGE plpgsql
+./test-output/testng-results.xml:    LANGUAGE plpgsql
+./test-output/testng-results.xml:    LANGUAGE plpgsql
+./test-output/testng-results.xml:    LANGUAGE plpgsql
+./test-output/testng-results.xml:    LANGUAGE plpgsql
+./test-output/testng-results.xml:    LANGUAGE plpgsql
+./test-output/testng-results.xml:    LANGUAGE plpgsql
+./test-output/testng-results.xml:    LANGUAGE plpgsql
+./test-output/testng-results.xml:    LANGUAGE plpgsql
+./test-output/testng-results.xml:    LANGUAGE plpgsql
+./test-output/testng-results.xml:    LANGUAGE plpgsql
+./test-output/testng-results.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql
+./test-output/testng-results.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql;
+./test-output/testng-results.xml:    LANGUAGE plpgsql
+./test-output/testng-results.xml:    LANGUAGE plpgsql
+./test-output/testng-results.xml:    LANGUAGE plpgsql
+./test-output/testng-results.xml:    LANGUAGE plpgsql
+./test-output/testng-results.xml:    LANGUAGE plpgsql
+./test-output/testng-results.xml:    LANGUAGE plpgsql
+./test-output/testng-results.xml:    LANGUAGE plpgsql
+./test-output/testng-results.xml:    LANGUAGE plpgsql
+./test-output/testng-results.xml:    LANGUAGE plpgsql
+./test-output/testng-results.xml:    LANGUAGE plpgsql
+./test-output/testng-results.xml:    LANGUAGE plpgsql
+./test-output/testng-results.xml:    LANGUAGE plpgsql
+./test-output/testng-results.xml:    LANGUAGE plpgsql
+./test-output/testng-results.xml:    LANGUAGE plpgsql
+./test-output/testng-results.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql
+./test-output/testng-results.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql;
+./test-output/testng-results.xml:    LANGUAGE plpgsql
+./test-output/testng-results.xml:    LANGUAGE plpgsql
+./test-output/testng-results.xml:    LANGUAGE plpgsql
+./test-output/testng-results.xml:    LANGUAGE plpgsql
+./test-output/testng-results.xml:    LANGUAGE plpgsql
+./test-output/testng-results.xml:    LANGUAGE plpgsql
+./test-output/testng-results.xml:    LANGUAGE plpgsql
+./test-output/testng-results.xml:    LANGUAGE plpgsql
+./test-output/testng-results.xml:    LANGUAGE plpgsql
+./test-output/testng-results.xml:    LANGUAGE plpgsql
+./test-output/testng-results.xml:    LANGUAGE plpgsql
+./test-output/testng-results.xml:    LANGUAGE plpgsql
+./test-output/testng-results.xml:    LANGUAGE plpgsql
+./test-output/testng-results.xml:    LANGUAGE plpgsql
+./test-output/testng-results.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql
+./test-output/testng-results.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql;
+./test-output/testng-results.xml:    LANGUAGE plpgsql
+./test-output/testng-results.xml:    LANGUAGE plpgsql
+./test-output/testng-results.xml:    LANGUAGE plpgsql
+./test-output/testng-results.xml:    LANGUAGE plpgsql
+./test-output/testng-results.xml:    LANGUAGE plpgsql
+./test-output/testng-results.xml:    LANGUAGE plpgsql
+./test-output/testng-results.xml:    LANGUAGE plpgsql
+./test-output/testng-results.xml:    LANGUAGE plpgsql
+./test-output/testng-results.xml:    LANGUAGE plpgsql
+./test-output/testng-results.xml:    LANGUAGE plpgsql
+./test-output/testng-results.xml:    LANGUAGE plpgsql
+./test-output/testng-results.xml:    LANGUAGE plpgsql
+./test-output/testng-results.xml:    LANGUAGE plpgsql
+./test-output/testng-results.xml:    LANGUAGE plpgsql
+./test-output/testng-results.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql
+./test-output/testng-results.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql;
+./test-output/testng-results.xml:    LANGUAGE plpgsql
+./test-output/testng-results.xml:    LANGUAGE plpgsql
+./test-output/testng-results.xml:    LANGUAGE plpgsql
+./test-output/testng-results.xml:    LANGUAGE plpgsql
+./test-output/testng-results.xml:    LANGUAGE plpgsql
+./test-output/testng-results.xml:    LANGUAGE plpgsql
+./test-output/testng-results.xml:    LANGUAGE plpgsql
+./test-output/testng-results.xml:    LANGUAGE plpgsql
+./test-output/testng-results.xml:    LANGUAGE plpgsql
+./test-output/testng-results.xml:    LANGUAGE plpgsql
+./test-output/testng-results.xml:    LANGUAGE plpgsql
+./test-output/testng-results.xml:    LANGUAGE plpgsql
+./test-output/testng-results.xml:    LANGUAGE plpgsql
+./test-output/testng-results.xml:    LANGUAGE plpgsql
+./test-output/testng-results.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql
+./test-output/testng-results.xml:CREATE OR REPLACE PROCEDURAL LANGUAGE plpgsql;
+./test-output/testng-results.xml:    LANGUAGE plpgsql
+./test-output/testng-results.xml:    LANGUAGE plpgsql
+./test-output/testng-results.xml:    LANGUAGE plpgsql
+./test-output/testng-results.xml:    LANGUAGE plpgsql
+./test-output/testng-results.xml:    LANGUAGE plpgsql
+./test-output/testng-results.xml:    LANGUAGE plpgsql
+./test-output/testng-results.xml:    LANGUAGE plpgsql
+./test-output/testng-results.xml:    LANGUAGE plpgsql
+./test-output/testng-results.xml:    LANGUAGE plpgsql
+./test-output/testng-results.xml:    LANGUAGE plpgsql
+./test-output/testng-results.xml:    LANGUAGE plpgsql
+./test-output/testng-results.xml:    LANGUAGE plpgsql
+./test-output/testng-results.xml:    LANGUAGE plpgsql
+./test-output/testng-results.xml:    LANGUAGE plpgsql
+./test-output/testng-results.xml:]; nested exception is org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql
+./test-output/testng-results.xml:Caused by: org.postgresql.util.PSQLException: ERROR: must be owner of language plpgsql
diff --git a/openbis/source/java/ch/systemsx/cisd/openbis/generic/shared/parser/ExcelFileSection.java b/openbis/source/java/ch/systemsx/cisd/openbis/generic/shared/parser/ExcelFileSection.java
index 4fd83c4b8f5c6cfc45a4d5e02225266f3b36661a..8ce9d8033ffee2394e40bd8aafe374e93f2da38f 100644
--- a/openbis/source/java/ch/systemsx/cisd/openbis/generic/shared/parser/ExcelFileSection.java
+++ b/openbis/source/java/ch/systemsx/cisd/openbis/generic/shared/parser/ExcelFileSection.java
@@ -90,14 +90,33 @@ public class ExcelFileSection
         }
     }
 
-    public static List<ExcelFileSection> extractSections(InputStream stream)
+    public static List<ExcelFileSection> extractSections(InputStream stream, String excelSheetName)
     {
         List<ExcelFileSection> sections = new ArrayList<ExcelFileSection>();
         try
         {
             POIFSFileSystem poifsFileSystem = new POIFSFileSystem(stream);
             Workbook wb = new HSSFWorkbook(poifsFileSystem);
-            Sheet sheet = wb.getSheetAt(0);
+
+            Sheet sheet = null;
+            if (excelSheetName == null)
+            {
+                sheet = wb.getSheetAt(0);
+            } else
+            {
+                for (int i = 0; i < wb.getNumberOfSheets(); i++)
+                {
+                    if (excelSheetName.equalsIgnoreCase(wb.getSheetName(i)))
+                    {
+                        sheet = wb.getSheetAt(i);
+                        break;
+                    }
+                }
+                if (sheet == null)
+                {
+                    return sections;
+                }
+            }
             String sectionName = null;
             Integer begin = null;
             for (Row row : sheet)
diff --git a/openbis/source/java/ch/systemsx/cisd/openbis/generic/shared/parser/SampleUploadSectionsParser.java b/openbis/source/java/ch/systemsx/cisd/openbis/generic/shared/parser/SampleUploadSectionsParser.java
index a7ca423d9e4002201e3bb28b44666f4847a808c6..0e4c2c8c9672cf61bd6ccaf8eab1ded116fda1be 100644
--- a/openbis/source/java/ch/systemsx/cisd/openbis/generic/shared/parser/SampleUploadSectionsParser.java
+++ b/openbis/source/java/ch/systemsx/cisd/openbis/generic/shared/parser/SampleUploadSectionsParser.java
@@ -86,13 +86,13 @@ public class SampleUploadSectionsParser
     public static BatchSamplesOperation prepareSamples(final SampleType sampleType,
             final Collection<NamedInputStream> files, String defaultGroupIdentifier,
             final SampleCodeGenerator sampleCodeGeneratorOrNull, final boolean allowExperiments,
-            BatchOperationKind operationKind)
+            String excelSheetName, BatchOperationKind operationKind)
     {
         final List<NewSamplesWithTypes> newSamples = new ArrayList<NewSamplesWithTypes>();
         boolean isAutoGenerateCodes = (sampleCodeGeneratorOrNull != null);
         final List<BatchRegistrationResult> results =
                 loadSamplesFromFiles(files, sampleType, isAutoGenerateCodes, newSamples,
-                        allowExperiments, operationKind);
+                        allowExperiments, excelSheetName, operationKind);
 
         if (defaultGroupIdentifier != null)
         {
@@ -185,7 +185,7 @@ public class SampleUploadSectionsParser
     private static List<BatchRegistrationResult> loadSamplesFromFiles(
             Collection<NamedInputStream> uploadedFiles, SampleType sampleType,
             boolean isAutoGenerateCodes, final List<NewSamplesWithTypes> newSamples,
-            boolean allowExperiments, BatchOperationKind operationKind)
+            boolean allowExperiments, String excelSheetName, BatchOperationKind operationKind)
     {
         final List<BatchRegistrationResult> results =
                 new ArrayList<BatchRegistrationResult>(uploadedFiles.size());
@@ -196,8 +196,8 @@ public class SampleUploadSectionsParser
                 List<ExcelFileSection> sampleSections = new ArrayList<ExcelFileSection>();
                 if (sampleType.isDefinedInFileEntityTypeCode())
                 {
-                    sampleSections.addAll(ExcelFileSection.extractSections(multipartFile
-                            .getInputStream()));
+                    sampleSections.addAll(ExcelFileSection.extractSections(
+                            multipartFile.getInputStream(), excelSheetName));
                 } else
                 {
                     sampleSections.add(ExcelFileSection.createFromInputStream(
diff --git a/openbis/source/java/ch/systemsx/cisd/openbis/plugin/generic/client/web/client/IGenericClientService.java b/openbis/source/java/ch/systemsx/cisd/openbis/plugin/generic/client/web/client/IGenericClientService.java
index 4a6960dfc61b8067d10b41046a5771be8883d9b5..2d0774bafe83f31e2f35a53e6e12617ffb7d6bd4 100644
--- a/openbis/source/java/ch/systemsx/cisd/openbis/plugin/generic/client/web/client/IGenericClientService.java
+++ b/openbis/source/java/ch/systemsx/cisd/openbis/plugin/generic/client/web/client/IGenericClientService.java
@@ -173,4 +173,11 @@ public interface IGenericClientService extends IClientService
      */
     public List<BatchRegistrationResult> updateDataSets(final DataSetType dataSetType,
             final String sessionKey) throws UserFailureException;
+
+    /**
+     * Updates samples and materials from excel files which have been previously uploaded.
+     */
+    public List<BatchRegistrationResult> registerOrUpdateSamplesAndMaterials(
+            final String sessionKey, final String defaultGroupIdentifier, boolean updateExisting);
+
 }
diff --git a/openbis/source/java/ch/systemsx/cisd/openbis/plugin/generic/client/web/client/IGenericClientServiceAsync.java b/openbis/source/java/ch/systemsx/cisd/openbis/plugin/generic/client/web/client/IGenericClientServiceAsync.java
index 4382a23d55a7d7e7783cb2c160e81f374635721d..f2ddcb45d7b0717d611bf5fd1e6632fee76892ee 100644
--- a/openbis/source/java/ch/systemsx/cisd/openbis/plugin/generic/client/web/client/IGenericClientServiceAsync.java
+++ b/openbis/source/java/ch/systemsx/cisd/openbis/plugin/generic/client/web/client/IGenericClientServiceAsync.java
@@ -150,4 +150,11 @@ public interface IGenericClientServiceAsync extends IClientServiceAsync
     public void registerExperiments(ExperimentType experimentType, String sessionKey,
             AsyncCallback<List<BatchRegistrationResult>> registerExperimentsCallback);
 
+    /**
+     * @see IGenericClientService#registerOrUpdateSamplesAndMaterials(String, String, boolean)
+     */
+    public void registerOrUpdateSamplesAndMaterials(final String sessionKey,
+            final String defaultGroupIdentifier, boolean updateExisting,
+            AsyncCallback<List<BatchRegistrationResult>> registerSamplesAndMaterialsCallback);
+
 }
diff --git a/openbis/source/java/ch/systemsx/cisd/openbis/plugin/generic/client/web/server/GenericClientService.java b/openbis/source/java/ch/systemsx/cisd/openbis/plugin/generic/client/web/server/GenericClientService.java
index bec666c423905f0dcc361452892e9f35aa83fd6b..f211c0a6e33452b1c24ebaa2923d7e64c8887260 100644
--- a/openbis/source/java/ch/systemsx/cisd/openbis/plugin/generic/client/web/server/GenericClientService.java
+++ b/openbis/source/java/ch/systemsx/cisd/openbis/plugin/generic/client/web/server/GenericClientService.java
@@ -159,7 +159,7 @@ public class GenericClientService extends AbstractClientService implements IGene
                 updateExisting ? BatchOperationKind.UPDATE : BatchOperationKind.REGISTRATION;
         BatchSamplesOperation info =
                 parseSamples(sampleType, sessionKey, defaultGroupIdentifier,
-                        defaultGroupIdentifier != null, true, operationKind);
+                        defaultGroupIdentifier != null, true, null, operationKind);
         try
         {
             final String sessionToken = getSessionToken();
@@ -171,11 +171,51 @@ public class GenericClientService extends AbstractClientService implements IGene
         }
     }
 
+    public final List<BatchRegistrationResult> registerOrUpdateSamplesAndMaterials(
+            final String sessionKey, final String defaultGroupIdentifier, boolean updateExisting)
+    {
+        BatchOperationKind operationKind =
+                updateExisting ? BatchOperationKind.UPDATE : BatchOperationKind.REGISTRATION;
+
+        final SampleType sampleType = new SampleType();
+        sampleType.setCode(SampleType.DEFINED_IN_FILE);
+
+        HttpSession session = getHttpSession();
+        UploadedFilesBean uploadedFiles = null;
+        try
+        {
+            uploadedFiles = getUploadedFiles(sessionKey, session);
+            BatchSamplesOperation samplesInfo =
+                    parseSamples(sampleType, session, uploadedFiles, defaultGroupIdentifier,
+                            defaultGroupIdentifier != null, true, "SAMPLES", operationKind);
+
+            final MaterialType materialType = new MaterialType();
+            materialType.setCode(SampleType.DEFINED_IN_FILE);
+            BatchMaterialsOperation materialsInfo =
+                    parseMaterials(session, uploadedFiles, materialType, "MATERIALS",
+                            updateExisting);
+            final String sessionToken = getSessionToken();
+            genericServer.registerOrUpdateSamplesAndMaterials(sessionToken,
+                    samplesInfo.getSamples(), materialsInfo.getMaterials());
+
+            List<BatchRegistrationResult> results = new ArrayList<BatchRegistrationResult>();
+            results.addAll(materialsInfo.getResultList());
+            results.addAll(samplesInfo.getResultList());
+            return results;
+        } catch (final ch.systemsx.cisd.common.exceptions.UserFailureException e)
+        {
+            throw UserFailureExceptionTranslator.translate(e);
+        } finally
+        {
+            cleanUploadedFiles(sessionKey, session, uploadedFiles);
+        }
+    }
+
     public final List<BatchRegistrationResult> updateSamples(final SampleType sampleType,
             final String sessionKey, final String defaultGroupIdentifier)
     {
         BatchSamplesOperation info =
-                parseSamples(sampleType, sessionKey, defaultGroupIdentifier, false, true,
+                parseSamples(sampleType, sessionKey, defaultGroupIdentifier, false, true, null,
                         BatchOperationKind.UPDATE);
         try
         {
@@ -217,7 +257,7 @@ public class GenericClientService extends AbstractClientService implements IGene
                             samplesSessionKey,
                             new GroupIdentifier(identifier.getDatabaseInstanceCode(), identifier
                                     .getSpaceCode()).toString(), experiment.isGenerateCodes(),
-                            false, BatchOperationKind.REGISTRATION);
+                            false, null, BatchOperationKind.REGISTRATION);
             experiment.setNewSamples(result.getSamples());
             experiment.setSamples(result.getCodes());
         }
@@ -231,31 +271,40 @@ public class GenericClientService extends AbstractClientService implements IGene
             }.process(attachmentsSessionKey, getHttpSession(), experiment.getAttachments());
     }
 
+    private BatchSamplesOperation parseSamples(final SampleType sampleType,
+            HttpSession httpSession, UploadedFilesBean uploadedFiles,
+            String defaultGroupIdentifier, final boolean isAutoGenerateCodes,
+            final boolean allowExperiments, String excelSheetName, BatchOperationKind operationKind)
+    {
+        boolean updateExisting = (operationKind == BatchOperationKind.UPDATE);
+        SampleCodeGenerator sampleCodeGeneratorOrNull =
+                tryGetSampleCodeGenerator(isAutoGenerateCodes);
+        Collection<NamedInputStream> files = new ArrayList<NamedInputStream>(uploadedFiles.size());
+        for (IUncheckedMultipartFile f : uploadedFiles.iterable())
+        {
+            files.add(new NamedInputStream(f.getInputStream(), f.getOriginalFilename()));
+        }
+        BatchSamplesOperation batchSamplesOperation =
+                SampleUploadSectionsParser.prepareSamples(sampleType, files,
+                        defaultGroupIdentifier, sampleCodeGeneratorOrNull, allowExperiments,
+                        excelSheetName, operationKind);
+        setUpdatePossibility(batchSamplesOperation.getSamples(), updateExisting);
+        return batchSamplesOperation;
+
+    }
+
     private BatchSamplesOperation parseSamples(final SampleType sampleType,
             final String sessionKey, String defaultGroupIdentifier,
             final boolean isAutoGenerateCodes, final boolean allowExperiments,
-            BatchOperationKind operationKind)
+            String excelSheetName, BatchOperationKind operationKind)
     {
         HttpSession httpSession = getHttpSession();
         UploadedFilesBean uploadedFiles = null;
-        boolean updateExisting = (operationKind == BatchOperationKind.UPDATE);
         try
         {
-            SampleCodeGenerator sampleCodeGeneratorOrNull =
-                    tryGetSampleCodeGenerator(isAutoGenerateCodes);
             uploadedFiles = getUploadedFiles(sessionKey, httpSession);
-            Collection<NamedInputStream> files =
-                    new ArrayList<NamedInputStream>(uploadedFiles.size());
-            for (IUncheckedMultipartFile f : uploadedFiles.iterable())
-            {
-                files.add(new NamedInputStream(f.getInputStream(), f.getOriginalFilename()));
-            }
-            BatchSamplesOperation batchSamplesOperation =
-                    SampleUploadSectionsParser.prepareSamples(sampleType, files,
-                            defaultGroupIdentifier, sampleCodeGeneratorOrNull, allowExperiments,
-                            operationKind);
-            setUpdatePossibility(batchSamplesOperation.getSamples(), updateExisting);
-            return batchSamplesOperation;
+            return parseSamples(sampleType, httpSession, uploadedFiles, defaultGroupIdentifier,
+                    isAutoGenerateCodes, allowExperiments, excelSheetName, operationKind);
         } finally
         {
             cleanUploadedFiles(sessionKey, httpSession, uploadedFiles);
@@ -292,7 +341,8 @@ public class GenericClientService extends AbstractClientService implements IGene
             boolean updateExisting, final String sessionKey)
     {
         String sessionToken = getSessionToken();
-        BatchMaterialsOperation results = parseMaterials(sessionKey, materialType, updateExisting);
+        BatchMaterialsOperation results =
+                parseMaterials(sessionKey, materialType, null, updateExisting);
         List<NewMaterialsWithTypes> materials = results.getMaterials();
         genericServer.registerOrUpdateMaterials(sessionToken, materials);
         return results.getResultList();
@@ -315,7 +365,7 @@ public class GenericClientService extends AbstractClientService implements IGene
     {
         String sessionToken = getSessionToken();
 
-        BatchMaterialsOperation results = parseMaterials(sessionKey, materialType, true);
+        BatchMaterialsOperation results = parseMaterials(sessionKey, materialType, null, true);
         int updateCount =
                 genericServer.updateMaterials(sessionToken, results.getMaterials(),
                         ignoreUnregisteredMaterials);
@@ -364,25 +414,33 @@ public class GenericClientService extends AbstractClientService implements IGene
         }
     }
 
-    private BatchMaterialsOperation parseMaterials(String sessionKey, MaterialType materialType,
+    private BatchMaterialsOperation parseMaterials(HttpSession session,
+            UploadedFilesBean uploadedFiles, MaterialType materialType, String excelSheetName,
             boolean updateExisting)
+    {
+        Collection<NamedInputStream> files = new ArrayList<NamedInputStream>(uploadedFiles.size());
+        for (IUncheckedMultipartFile f : uploadedFiles.iterable())
+        {
+            files.add(new NamedInputStream(f.getInputStream(), f.getOriginalFilename()));
+        }
+
+        BatchMaterialsOperation batchMaterialsOperation =
+                MaterialUploadSectionsParser.prepareMaterials(materialType, files, excelSheetName);
+        setUpdatePossibility(batchMaterialsOperation.getMaterials(), updateExisting);
+        return batchMaterialsOperation;
+    }
+
+    private BatchMaterialsOperation parseMaterials(String sessionKey, MaterialType materialType,
+            String excelSheetName, boolean updateExisting)
     {
         HttpSession session = getHttpSession();
         UploadedFilesBean uploadedFiles = null;
         try
         {
             uploadedFiles = getUploadedFiles(sessionKey, session);
-            Collection<NamedInputStream> files =
-                    new ArrayList<NamedInputStream>(uploadedFiles.size());
-            for (IUncheckedMultipartFile f : uploadedFiles.iterable())
-            {
-                files.add(new NamedInputStream(f.getInputStream(), f.getOriginalFilename()));
-            }
 
-            BatchMaterialsOperation batchMaterialsOperation =
-                    MaterialUploadSectionsParser.prepareMaterials(materialType, files);
-            setUpdatePossibility(batchMaterialsOperation.getMaterials(), updateExisting);
-            return batchMaterialsOperation;
+            return parseMaterials(session, uploadedFiles, materialType, excelSheetName,
+                    updateExisting);
         } finally
         {
             cleanUploadedFiles(sessionKey, session, uploadedFiles);
@@ -453,7 +511,7 @@ public class GenericClientService extends AbstractClientService implements IGene
                             updates.getSamplesSessionKey(),
                             new GroupIdentifier(newProject.getDatabaseInstanceCode(), newProject
                                     .getSpaceCode()).toString(), updates.isGenerateCodes(), false,
-                            BatchOperationKind.REGISTRATION);
+                            null, BatchOperationKind.REGISTRATION);
             updates.setNewSamples(info.getSamples());
             updates.setSampleCodes(info.getCodes());
         }
diff --git a/openbis/source/java/ch/systemsx/cisd/openbis/plugin/generic/client/web/server/parser/MaterialUploadSectionsParser.java b/openbis/source/java/ch/systemsx/cisd/openbis/plugin/generic/client/web/server/parser/MaterialUploadSectionsParser.java
index 678bdbd2152b2e332ab5201cf0215e3ee2e5e684..427de31285332bd7d956cd4fdf17c65865615192 100644
--- a/openbis/source/java/ch/systemsx/cisd/openbis/plugin/generic/client/web/server/parser/MaterialUploadSectionsParser.java
+++ b/openbis/source/java/ch/systemsx/cisd/openbis/plugin/generic/client/web/server/parser/MaterialUploadSectionsParser.java
@@ -78,11 +78,11 @@ public class MaterialUploadSectionsParser
     }
 
     public static BatchMaterialsOperation prepareMaterials(final MaterialType materialType,
-            final Collection<NamedInputStream> files)
+            final Collection<NamedInputStream> files, String excelSheetName)
     {
         final List<NewMaterialsWithTypes> newSamples = new ArrayList<NewMaterialsWithTypes>();
         final List<BatchRegistrationResult> results =
-                loadMaterialsFromFiles(files, materialType, newSamples);
+                loadMaterialsFromFiles(files, materialType, newSamples, excelSheetName);
 
         return new BatchMaterialsOperation(newSamples, results, parseCodes(newSamples));
     }
@@ -102,7 +102,7 @@ public class MaterialUploadSectionsParser
 
     private static List<BatchRegistrationResult> loadMaterialsFromFiles(
             Collection<NamedInputStream> uploadedFiles, MaterialType materialType,
-            final List<NewMaterialsWithTypes> newMaterials)
+            final List<NewMaterialsWithTypes> newMaterials, String excelSheetName)
     {
         final List<BatchRegistrationResult> results =
                 new ArrayList<BatchRegistrationResult>(uploadedFiles.size());
@@ -113,8 +113,8 @@ public class MaterialUploadSectionsParser
                 List<ExcelFileSection> materialSections = new ArrayList<ExcelFileSection>();
                 if (materialType.isDefinedInFileEntityTypeCode())
                 {
-                    materialSections.addAll(ExcelFileSection.extractSections(multipartFile
-                            .getInputStream()));
+                    materialSections.addAll(ExcelFileSection.extractSections(
+                            multipartFile.getInputStream(), excelSheetName));
                 } else
                 {
                     materialSections.add(ExcelFileSection.createFromInputStream(
diff --git a/openbis/source/java/ch/systemsx/cisd/openbis/plugin/generic/server/GenericServer.java b/openbis/source/java/ch/systemsx/cisd/openbis/plugin/generic/server/GenericServer.java
index 4b8869559048400ea5d959f44b15855db67c8b9e..2ec3d7a6f1f2c4d978a6c844a7aa945eec0ad8e6 100644
--- a/openbis/source/java/ch/systemsx/cisd/openbis/plugin/generic/server/GenericServer.java
+++ b/openbis/source/java/ch/systemsx/cisd/openbis/plugin/generic/server/GenericServer.java
@@ -776,4 +776,11 @@ public final class GenericServer extends AbstractServer<IGenericServer> implemen
         return materialHelper;
     }
 
+    public void registerOrUpdateSamplesAndMaterials(final String sessionToken,
+            final List<NewSamplesWithTypes> newSamplesWithType,
+            List<NewMaterialsWithTypes> newMaterialsWithType) throws UserFailureException
+    {
+        registerOrUpdateMaterials(sessionToken, newMaterialsWithType);
+        registerOrUpdateSamples(sessionToken, newSamplesWithType);
+    }
 }
diff --git a/openbis/source/java/ch/systemsx/cisd/openbis/plugin/generic/server/GenericServerLogger.java b/openbis/source/java/ch/systemsx/cisd/openbis/plugin/generic/server/GenericServerLogger.java
index 3962c33bd376af7f9cbc49ea787df7c535664ba3..9c1a2f1d88e26e2dde4e17bbcd70b252e0107ee9 100644
--- a/openbis/source/java/ch/systemsx/cisd/openbis/plugin/generic/server/GenericServerLogger.java
+++ b/openbis/source/java/ch/systemsx/cisd/openbis/plugin/generic/server/GenericServerLogger.java
@@ -275,4 +275,30 @@ final class GenericServerLogger extends AbstractServerLogger implements IGeneric
                 .getExperimentType().getCode(), experiments.getUpdatedExperiments().size());
     }
 
+    public void registerOrUpdateSamplesAndMaterials(final String sessionToken,
+            final List<NewSamplesWithTypes> newSamplesWithType,
+            List<NewMaterialsWithTypes> newMaterialsWithType) throws UserFailureException
+    {
+        StringBuilder samples = new StringBuilder();
+        for (NewSamplesWithTypes s : newSamplesWithType)
+        {
+            if (samples.length() > 0)
+            {
+                samples.append(",");
+            }
+            samples.append(s.getEntityType().getCode() + ":" + s.getNewEntities().size());
+        }
+
+        StringBuilder materials = new StringBuilder();
+        for (NewMaterialsWithTypes s : newMaterialsWithType)
+        {
+            if (materials.length() > 0)
+            {
+                materials.append(",");
+            }
+            materials.append(s.getEntityType().getCode() + ":" + s.getNewEntities().size());
+        }
+        logTracking(sessionToken, "register_or_update_samples_and_materials",
+                "SAMPLES(%s) MATERIALS(%s)", samples.toString(), materials.toString());
+    }
 }
diff --git a/openbis/source/java/ch/systemsx/cisd/openbis/plugin/generic/shared/IGenericServer.java b/openbis/source/java/ch/systemsx/cisd/openbis/plugin/generic/shared/IGenericServer.java
index fe6a1c50295b98855b96422b7e68ba446226edec..7507775d932599857f3da6a517e52d68dcf62b3f 100644
--- a/openbis/source/java/ch/systemsx/cisd/openbis/plugin/generic/shared/IGenericServer.java
+++ b/openbis/source/java/ch/systemsx/cisd/openbis/plugin/generic/shared/IGenericServer.java
@@ -139,6 +139,17 @@ public interface IGenericServer extends IServer
             @AuthorizationGuard(guardClass = NewSamplesWithTypePredicate.class) final List<NewSamplesWithTypes> newSamplesWithType)
             throws UserFailureException;
 
+    /**
+     * Registers or updates samples and materials of different types in batches.
+     */
+    @Transactional
+    @RolesAllowed(RoleWithHierarchy.INSTANCE_ADMIN)
+    @DatabaseCreateOrDeleteModification(value =
+        { ObjectKind.SAMPLE, ObjectKind.MATERIAL })
+    public void registerOrUpdateSamplesAndMaterials(final String sessionToken,
+            final List<NewSamplesWithTypes> newSamplesWithType,
+            List<NewMaterialsWithTypes> newMaterialsWithType) throws UserFailureException;
+
     /**
      * Updates samples of different types in batches.
      */
@@ -212,7 +223,8 @@ public interface IGenericServer extends IServer
     @Transactional
     @RolesAllowed(RoleWithHierarchy.INSTANCE_ADMIN)
     @DatabaseCreateOrDeleteModification(value = ObjectKind.MATERIAL)
-    public void registerOrUpdateMaterials(String sessionToken, List<NewMaterialsWithTypes> materials) throws UserFailureException;
+    public void registerOrUpdateMaterials(String sessionToken, List<NewMaterialsWithTypes> materials)
+            throws UserFailureException;
 
     /**
      * Returns attachment described by given sample identifier, filename and version.
diff --git a/openbis/sourceTest/java/ch/systemsx/cisd/openbis/plugin/generic/shared/IGenericServer.java.expected b/openbis/sourceTest/java/ch/systemsx/cisd/openbis/plugin/generic/shared/IGenericServer.java.expected
index fe6a1c50295b98855b96422b7e68ba446226edec..7507775d932599857f3da6a517e52d68dcf62b3f 100644
--- a/openbis/sourceTest/java/ch/systemsx/cisd/openbis/plugin/generic/shared/IGenericServer.java.expected
+++ b/openbis/sourceTest/java/ch/systemsx/cisd/openbis/plugin/generic/shared/IGenericServer.java.expected
@@ -139,6 +139,17 @@ public interface IGenericServer extends IServer
             @AuthorizationGuard(guardClass = NewSamplesWithTypePredicate.class) final List<NewSamplesWithTypes> newSamplesWithType)
             throws UserFailureException;
 
+    /**
+     * Registers or updates samples and materials of different types in batches.
+     */
+    @Transactional
+    @RolesAllowed(RoleWithHierarchy.INSTANCE_ADMIN)
+    @DatabaseCreateOrDeleteModification(value =
+        { ObjectKind.SAMPLE, ObjectKind.MATERIAL })
+    public void registerOrUpdateSamplesAndMaterials(final String sessionToken,
+            final List<NewSamplesWithTypes> newSamplesWithType,
+            List<NewMaterialsWithTypes> newMaterialsWithType) throws UserFailureException;
+
     /**
      * Updates samples of different types in batches.
      */
@@ -212,7 +223,8 @@ public interface IGenericServer extends IServer
     @Transactional
     @RolesAllowed(RoleWithHierarchy.INSTANCE_ADMIN)
     @DatabaseCreateOrDeleteModification(value = ObjectKind.MATERIAL)
-    public void registerOrUpdateMaterials(String sessionToken, List<NewMaterialsWithTypes> materials) throws UserFailureException;
+    public void registerOrUpdateMaterials(String sessionToken, List<NewMaterialsWithTypes> materials)
+            throws UserFailureException;
 
     /**
      * Returns attachment described by given sample identifier, filename and version.
diff --git a/screening/source/java/ch/systemsx/cisd/openbis/plugin/screening/client/web/client/application/Dict.java b/screening/source/java/ch/systemsx/cisd/openbis/plugin/screening/client/web/client/application/Dict.java
index a5b26bc80809413e6ca481fad8e7cb79f7105e2a..8d8b043e29b174996a94eb3619d6584b4b2e6be3 100644
--- a/screening/source/java/ch/systemsx/cisd/openbis/plugin/screening/client/web/client/application/Dict.java
+++ b/screening/source/java/ch/systemsx/cisd/openbis/plugin/screening/client/web/client/application/Dict.java
@@ -85,6 +85,10 @@ public final class Dict extends ch.systemsx.cisd.openbis.generic.client.web.clie
 
     public static final String EXACT_MATCH_ONLY = "EXACT_MATCH_ONLY";
 
+    public static final String LIBRARY_IMPORT_MENU_ITEM = "LIBRARY_IMPORT_MENU_ITEM";
+
+    public static final String LIBRARY_IMPORT_TAB_TITLE = "LIBRARY_IMPORT_TAB_TITLE";
+
     public static final String WELLS_SEARCH_MENU_ITEM = "WELLS_SEARCH";
 
     public static final String WELLS_SEARCH_SHOW_COMBINED_RESULTS =
diff --git a/screening/source/java/ch/systemsx/cisd/openbis/plugin/screening/client/web/client/application/ScreeningModule.java b/screening/source/java/ch/systemsx/cisd/openbis/plugin/screening/client/web/client/application/ScreeningModule.java
index 19314c9b8b5a27ef80bc0189a8957596088d20df..bdd80dece9a79b70f929df1bad74035cceebdd34 100644
--- a/screening/source/java/ch/systemsx/cisd/openbis/plugin/screening/client/web/client/application/ScreeningModule.java
+++ b/screening/source/java/ch/systemsx/cisd/openbis/plugin/screening/client/web/client/application/ScreeningModule.java
@@ -17,8 +17,8 @@
 package ch.systemsx.cisd.openbis.plugin.screening.client.web.client.application;
 
 import java.util.ArrayList;
+import java.util.Arrays;
 import java.util.Collection;
-import java.util.Collections;
 import java.util.List;
 
 import com.extjs.gxt.ui.client.widget.menu.MenuItem;
@@ -37,6 +37,7 @@ import ch.systemsx.cisd.openbis.generic.shared.basic.dto.EntityKind;
 import ch.systemsx.cisd.openbis.plugin.screening.client.web.client.IScreeningClientServiceAsync;
 import ch.systemsx.cisd.openbis.plugin.screening.client.web.client.application.detailviewers.ExperimentAnalysisSummarySection;
 import ch.systemsx.cisd.openbis.plugin.screening.client.web.client.application.detailviewers.ExperimentWellMaterialsSection;
+import ch.systemsx.cisd.openbis.plugin.screening.client.web.client.application.detailviewers.LibraryImportComponent;
 import ch.systemsx.cisd.openbis.plugin.screening.client.web.client.application.detailviewers.WellSearchComponent;
 import ch.systemsx.cisd.openbis.plugin.screening.client.web.client.application.locator.GlobalWellSearchLocatorResolver;
 
@@ -62,7 +63,9 @@ public class ScreeningModule implements IModule
         ActionMenu globalWellSearch =
                 TabActionMenuItemFactory
                         .createActionMenu(viewContext, ID, createGlobalWellSearch());
-        return Collections.singletonList(globalWellSearch);
+        ActionMenu globalLibraryImport =
+                TabActionMenuItemFactory.createActionMenu(viewContext, ID, createLibraryImport());
+        return Arrays.asList(globalWellSearch, globalLibraryImport);
     }
 
     private ITabActionMenuItemDefinition<IScreeningClientServiceAsync> createGlobalWellSearch()
@@ -95,6 +98,35 @@ public class ScreeningModule implements IModule
             };
     }
 
+    private ITabActionMenuItemDefinition<IScreeningClientServiceAsync> createLibraryImport()
+    {
+        return new ITabActionMenuItemDefinition<IScreeningClientServiceAsync>()
+            {
+
+                public String getName()
+                {
+                    return Dict.LIBRARY_IMPORT_MENU_ITEM;
+                }
+
+                public String getHelpPageTitle()
+                {
+                    return "Global Library Import";
+                }
+
+                public String tryGetLink()
+                {
+                    return null;
+                }
+
+                public DatabaseModificationAwareComponent createComponent(
+                        @SuppressWarnings("hiding") IViewContext<IScreeningClientServiceAsync> viewContext)
+                {
+                    TabContent libraryImportTab = new LibraryImportComponent(viewContext);
+                    return DatabaseModificationAwareComponent.wrapUnaware(libraryImportTab);
+                }
+            };
+    }
+
     public String getName()
     {
         return viewContext.getMessage(Dict.SCREENING_MODULE_TITLE);
diff --git a/screening/source/java/ch/systemsx/cisd/openbis/plugin/screening/client/web/client/application/detailviewers/LibraryImportComponent.java b/screening/source/java/ch/systemsx/cisd/openbis/plugin/screening/client/web/client/application/detailviewers/LibraryImportComponent.java
new file mode 100644
index 0000000000000000000000000000000000000000..cc7cf5a40878f9bed3d8f5aad762229ca2dde617
--- /dev/null
+++ b/screening/source/java/ch/systemsx/cisd/openbis/plugin/screening/client/web/client/application/detailviewers/LibraryImportComponent.java
@@ -0,0 +1,199 @@
+package ch.systemsx.cisd.openbis.plugin.screening.client.web.client.application.detailviewers;
+
+import static ch.systemsx.cisd.openbis.generic.client.web.client.application.framework.DatabaseModificationAwareField.wrapUnaware;
+
+import java.util.List;
+
+import com.extjs.gxt.ui.client.Style.Scroll;
+import com.extjs.gxt.ui.client.event.ButtonEvent;
+import com.extjs.gxt.ui.client.event.Events;
+import com.extjs.gxt.ui.client.event.SelectionListener;
+import com.extjs.gxt.ui.client.widget.form.Field;
+import com.extjs.gxt.ui.client.widget.form.FileUploadField;
+import com.google.gwt.user.client.Element;
+
+import ch.systemsx.cisd.openbis.generic.client.web.client.application.FormPanelListener;
+import ch.systemsx.cisd.openbis.generic.client.web.client.application.IViewContext;
+import ch.systemsx.cisd.openbis.generic.client.web.client.application.TabContent;
+import ch.systemsx.cisd.openbis.generic.client.web.client.application.ui.AbstractRegistrationForm;
+import ch.systemsx.cisd.openbis.generic.client.web.client.application.ui.file.BasicFileFieldManager;
+import ch.systemsx.cisd.openbis.generic.shared.basic.dto.BatchRegistrationResult;
+import ch.systemsx.cisd.openbis.plugin.generic.client.web.client.IGenericClientServiceAsync;
+import ch.systemsx.cisd.openbis.plugin.generic.client.web.client.application.GenericViewContext;
+import ch.systemsx.cisd.openbis.plugin.screening.client.web.client.IScreeningClientServiceAsync;
+import ch.systemsx.cisd.openbis.plugin.screening.client.web.client.application.Dict;
+import ch.systemsx.cisd.openbis.plugin.screening.client.web.client.application.ScreeningModule;
+import ch.systemsx.cisd.openbis.plugin.screening.shared.basic.dto.WellSearchCriteria.ExperimentSearchCriteria;
+
+/**
+ * Allows to specify search criteria for materials contained in wells. Used in experiment section
+ * panel or as a standalone module.
+ * 
+ * @author Tomasz Pylak
+ */
+public class LibraryImportComponent extends TabContent
+{
+
+    private static class LibraryImportForm extends AbstractRegistrationForm
+    {
+        protected final class RegisterOrUpdateSamplesAndMaterialsCallback
+                extends
+                AbstractRegistrationForm.AbstractRegistrationCallback<List<BatchRegistrationResult>>
+        {
+            RegisterOrUpdateSamplesAndMaterialsCallback(
+                    final IViewContext<IGenericClientServiceAsync> viewContext)
+            {
+                super(viewContext);
+            }
+
+            @Override
+            protected String createSuccessfullRegistrationInfo(
+                    final List<BatchRegistrationResult> result)
+            {
+                final StringBuilder builder = new StringBuilder();
+                for (final BatchRegistrationResult batchRegistrationResult : result)
+                {
+                    builder.append("<b>" + batchRegistrationResult.getFileName() + "</b>: ");
+                    builder.append(batchRegistrationResult.getMessage());
+                    builder.append("<br />");
+                }
+                return builder.toString();
+            }
+        }
+
+        private static final String PREFIX = "library-import";
+
+        private static final String SESSION_KEY = PREFIX;
+
+        private static final String FIELD_LABEL_TEMPLATE = "File";
+
+        private static final int NUMBER_OF_FIELDS = 1;
+
+        private final BasicFileFieldManager fileFieldsManager;
+
+        private final IViewContext<IGenericClientServiceAsync> genericViewContext;
+
+        private static String createId(String sessionKey)
+        {
+            return ScreeningModule.ID + sessionKey;
+        }
+
+        /**
+         * @param viewContext
+         */
+        protected LibraryImportForm(IViewContext<IGenericClientServiceAsync> viewContext)
+        {
+            super(viewContext, createId(SESSION_KEY));
+
+            this.genericViewContext = viewContext;
+            setScrollMode(Scroll.AUTO);
+            fileFieldsManager =
+                    new BasicFileFieldManager(SESSION_KEY, NUMBER_OF_FIELDS, FIELD_LABEL_TEMPLATE);
+            fileFieldsManager.setMandatory();
+            addUploadFeatures(SESSION_KEY);
+        }
+
+        @Override
+        protected final void onRender(final Element target, final int index)
+        {
+            super.onRender(target, index);
+            addFormFields();
+        }
+
+        @Override
+        protected void submitValidForm()
+        {
+        }
+
+        @Override
+        protected void resetFieldsAfterSave()
+        {
+            for (FileUploadField attachmentField : fileFieldsManager.getFields())
+            {
+                attachmentField.reset();
+            }
+        }
+
+        private final void addFormFields()
+        {
+            for (FileUploadField attachmentField : fileFieldsManager.getFields())
+            {
+                formPanel.add(wrapUnaware((Field<?>) attachmentField).get());
+            }
+            formPanel.addListener(Events.Submit, new FormPanelListener(infoBox)
+                {
+                    @Override
+                    protected void onSuccessfullUpload()
+                    {
+                        save();
+                    }
+
+                    @Override
+                    protected void setUploadEnabled()
+                    {
+                        LibraryImportForm.this.setUploadEnabled(true);
+                    }
+                });
+            redefineSaveListeners();
+        }
+
+        void redefineSaveListeners()
+        {
+            saveButton.removeAllListeners();
+            saveButton.addSelectionListener(new SelectionListener<ButtonEvent>()
+                {
+                    @Override
+                    public final void componentSelected(final ButtonEvent ce)
+                    {
+                        if (formPanel.isValid())
+                        {
+                            if (fileFieldsManager.filesDefined() > 0)
+                            {
+                                setUploadEnabled(false);
+                                formPanel.submit();
+                            } else
+                            {
+                                save();
+                            }
+                        }
+                    }
+                });
+        }
+
+        protected void save()
+        {
+            genericViewContext.getService().registerOrUpdateSamplesAndMaterials(SESSION_KEY, null,
+                    true, new RegisterOrUpdateSamplesAndMaterialsCallback(genericViewContext));
+        }
+    }
+
+    private final IViewContext<IGenericClientServiceAsync> genericViewContext;
+
+    public static String getTabTitle(IViewContext<IScreeningClientServiceAsync> viewContext)
+    {
+        return viewContext.getMessage(Dict.LIBRARY_IMPORT_TAB_TITLE);
+    }
+
+    public LibraryImportComponent(IViewContext<IScreeningClientServiceAsync> screeningViewContext)
+    {
+        this(screeningViewContext, ExperimentSearchCriteria.createAllExperiments());
+
+        setContentVisible(true);
+    }
+
+    public LibraryImportComponent(IViewContext<IScreeningClientServiceAsync> screeningViewContext,
+            ExperimentSearchCriteria experimentSearchCriteria)
+    {
+        super(getTabTitle(screeningViewContext), screeningViewContext, null);
+        this.genericViewContext =
+                new GenericViewContext(screeningViewContext.getCommonViewContext());
+    }
+
+    @Override
+    protected void showContent()
+    {
+        removeAll();
+        add(new LibraryImportForm(genericViewContext));
+        layout();
+    }
+}
\ No newline at end of file
diff --git a/screening/source/java/ch/systemsx/cisd/openbis/plugin/screening/client/web/public/screening-dictionary.js b/screening/source/java/ch/systemsx/cisd/openbis/plugin/screening/client/web/public/screening-dictionary.js
index ae30526965b0e29393ba003f57699b96cebf3756..2ebd7a10645d18b6b4999e087d35ae9914787682 100644
--- a/screening/source/java/ch/systemsx/cisd/openbis/plugin/screening/client/web/public/screening-dictionary.js
+++ b/screening/source/java/ch/systemsx/cisd/openbis/plugin/screening/client/web/public/screening-dictionary.js
@@ -28,7 +28,8 @@ ANALYSIS_PROCEDURE: "Analysis Procedure",
 //
 WELLS_SEARCH_menu_item: "Wells Search",  
 WELLS_SEARCH_tab_label: "Wells Search",  
-
+LIBRARY_IMPORT_MENU_ITEM_menu_item: "Library Import",
+LIBRARY_IMPORT_MENU_ITEM_tab_label: "Library Import",
 //
 // Experiment Viewer
 //
diff --git a/screening/source/java/ch/systemsx/cisd/openbis/plugin/screening/client/web/server/LibraryExtractor.java b/screening/source/java/ch/systemsx/cisd/openbis/plugin/screening/client/web/server/LibraryExtractor.java
index 7cb80dd1fb53213cb468e1351c8121fdba4be830..0cfe4e51c42731bc780244c699000edb3714a61d 100644
--- a/screening/source/java/ch/systemsx/cisd/openbis/plugin/screening/client/web/server/LibraryExtractor.java
+++ b/screening/source/java/ch/systemsx/cisd/openbis/plugin/screening/client/web/server/LibraryExtractor.java
@@ -109,7 +109,8 @@ class LibraryExtractor
         BatchSamplesOperation prepared =
                 SampleUploadSectionsParser.prepareSamples(typeInFile, Arrays
                         .asList(new NamedInputStream(new FileInputStream(platesFile), platesFile
-                                .getName())), null, null, true, BatchOperationKind.REGISTRATION);
+                                .getName())), null, null, true, null,
+                        BatchOperationKind.REGISTRATION);
         List<NewSamplesWithTypes> samples = prepared.getSamples();
         setUpdatableTypes(samples);
         return samples;