publisci 0.1.2

Sign up to get free protection for your applications and to get access to all the features.
Files changed (220) hide show
  1. checksums.yaml +7 -0
  2. data/.document +5 -0
  3. data/.rspec +1 -0
  4. data/.travis.yml +13 -0
  5. data/Gemfile +36 -0
  6. data/LICENSE.txt +20 -0
  7. data/README.md +51 -0
  8. data/README.rdoc +48 -0
  9. data/Rakefile +68 -0
  10. data/bin/bio-publisci +106 -0
  11. data/bin/bio-publisci-server +50 -0
  12. data/examples/bio-band_integration.rb +9 -0
  13. data/examples/no_magic.prov +58 -0
  14. data/examples/no_magic.rb +58 -0
  15. data/examples/orm.prov +48 -0
  16. data/examples/primer-full.prov +120 -0
  17. data/examples/primer.prov +66 -0
  18. data/examples/prov_dsl.prov +85 -0
  19. data/examples/safe_gen.rb +7 -0
  20. data/examples/visualization/primer.prov +66 -0
  21. data/examples/visualization/prov_viz.rb +140 -0
  22. data/examples/visualization/viz.rb +35 -0
  23. data/features/create_generator.feature +21 -0
  24. data/features/integration.feature +12 -0
  25. data/features/integration_steps.rb +10 -0
  26. data/features/metadata.feature +37 -0
  27. data/features/metadata_steps.rb +40 -0
  28. data/features/orm.feature +60 -0
  29. data/features/orm_steps.rb +74 -0
  30. data/features/prov_dsl.feature +14 -0
  31. data/features/prov_dsl_steps.rb +11 -0
  32. data/features/reader.feature +25 -0
  33. data/features/reader_steps.rb +61 -0
  34. data/features/step_definitions/bio-publisci_steps.rb +0 -0
  35. data/features/store.feature +27 -0
  36. data/features/store_steps.rb +42 -0
  37. data/features/support/env.rb +13 -0
  38. data/features/writer.feature +14 -0
  39. data/features/writer_steps.rb +24 -0
  40. data/lib/bio-publisci.rb +64 -0
  41. data/lib/bio-publisci/analyzer.rb +57 -0
  42. data/lib/bio-publisci/datacube_model.rb +111 -0
  43. data/lib/bio-publisci/dataset/ORM/data_cube_orm.rb +240 -0
  44. data/lib/bio-publisci/dataset/ORM/observation.rb +20 -0
  45. data/lib/bio-publisci/dataset/configuration.rb +31 -0
  46. data/lib/bio-publisci/dataset/data_cube.rb +418 -0
  47. data/lib/bio-publisci/dataset/dataset.rb +11 -0
  48. data/lib/bio-publisci/dataset/dataset_for.rb +186 -0
  49. data/lib/bio-publisci/dataset/interactive.rb +72 -0
  50. data/lib/bio-publisci/dsl/config.rb +34 -0
  51. data/lib/bio-publisci/dsl/dataset_dsl.rb +93 -0
  52. data/lib/bio-publisci/dsl/dsl.rb +72 -0
  53. data/lib/bio-publisci/dsl/metadata_dsl.rb +85 -0
  54. data/lib/bio-publisci/dsl/prov_dsl.rb +143 -0
  55. data/lib/bio-publisci/metadata/generator.rb +323 -0
  56. data/lib/bio-publisci/metadata/metadata.rb +5 -0
  57. data/lib/bio-publisci/metadata/metadata_model.rb +25 -0
  58. data/lib/bio-publisci/metadata/prov/activity.rb +88 -0
  59. data/lib/bio-publisci/metadata/prov/agent.rb +100 -0
  60. data/lib/bio-publisci/metadata/prov/association.rb +107 -0
  61. data/lib/bio-publisci/metadata/prov/config.rb +34 -0
  62. data/lib/bio-publisci/metadata/prov/derivation.rb +60 -0
  63. data/lib/bio-publisci/metadata/prov/element.rb +120 -0
  64. data/lib/bio-publisci/metadata/prov/entity.rb +64 -0
  65. data/lib/bio-publisci/metadata/prov/model/prov_models.rb +109 -0
  66. data/lib/bio-publisci/metadata/prov/plan.rb +32 -0
  67. data/lib/bio-publisci/metadata/prov/prov.rb +78 -0
  68. data/lib/bio-publisci/metadata/prov/role.rb +40 -0
  69. data/lib/bio-publisci/metadata/prov/usage.rb +64 -0
  70. data/lib/bio-publisci/metadata/publisher.rb +25 -0
  71. data/lib/bio-publisci/mixins/custom_predicate.rb +38 -0
  72. data/lib/bio-publisci/mixins/dereferencable.rb +34 -0
  73. data/lib/bio-publisci/mixins/registry.rb +27 -0
  74. data/lib/bio-publisci/mixins/vocabulary.rb +8 -0
  75. data/lib/bio-publisci/output.rb +27 -0
  76. data/lib/bio-publisci/parser.rb +266 -0
  77. data/lib/bio-publisci/post_processor.rb +95 -0
  78. data/lib/bio-publisci/query/query_helper.rb +123 -0
  79. data/lib/bio-publisci/r_client.rb +54 -0
  80. data/lib/bio-publisci/readers/arff.rb +49 -0
  81. data/lib/bio-publisci/readers/base.rb +57 -0
  82. data/lib/bio-publisci/readers/csv.rb +88 -0
  83. data/lib/bio-publisci/readers/dataframe.rb +67 -0
  84. data/lib/bio-publisci/readers/maf.rb +199 -0
  85. data/lib/bio-publisci/readers/r_cross.rb +112 -0
  86. data/lib/bio-publisci/readers/r_matrix.rb +176 -0
  87. data/lib/bio-publisci/store.rb +56 -0
  88. data/lib/bio-publisci/writers/arff.rb +91 -0
  89. data/lib/bio-publisci/writers/base.rb +93 -0
  90. data/lib/bio-publisci/writers/csv.rb +31 -0
  91. data/lib/bio-publisci/writers/dataframe.rb +81 -0
  92. data/lib/bio-publisci/writers/json.rb +18 -0
  93. data/lib/r2rdf.rb +226 -0
  94. data/lib/template_bak.rb +12 -0
  95. data/lib/template_bak/publisci.rb +3 -0
  96. data/lib/vocabs/cc.rb +18 -0
  97. data/lib/vocabs/cert.rb +13 -0
  98. data/lib/vocabs/dc.rb +63 -0
  99. data/lib/vocabs/dc11.rb +23 -0
  100. data/lib/vocabs/doap.rb +45 -0
  101. data/lib/vocabs/exif.rb +168 -0
  102. data/lib/vocabs/foaf.rb +69 -0
  103. data/lib/vocabs/geo.rb +13 -0
  104. data/lib/vocabs/http.rb +26 -0
  105. data/lib/vocabs/ma.rb +78 -0
  106. data/lib/vocabs/owl.rb +59 -0
  107. data/lib/vocabs/rdfs.rb +17 -0
  108. data/lib/vocabs/rsa.rb +12 -0
  109. data/lib/vocabs/rss.rb +14 -0
  110. data/lib/vocabs/sioc.rb +93 -0
  111. data/lib/vocabs/skos.rb +36 -0
  112. data/lib/vocabs/wot.rb +21 -0
  113. data/lib/vocabs/xhtml.rb +9 -0
  114. data/lib/vocabs/xsd.rb +58 -0
  115. data/resources/maf_example.maf +10 -0
  116. data/resources/maf_rdf.ttl +1173 -0
  117. data/resources/primer.ttl +38 -0
  118. data/resources/queries/code_resources.rq +10 -0
  119. data/resources/queries/codes.rq +18 -0
  120. data/resources/queries/dataset.rq +7 -0
  121. data/resources/queries/dimension_ranges.rq +8 -0
  122. data/resources/queries/dimensions.rq +12 -0
  123. data/resources/queries/gene.rq +16 -0
  124. data/resources/queries/hugo_to_ensembl.rq +7 -0
  125. data/resources/queries/maf_column.rq +26 -0
  126. data/resources/queries/measures.rq +12 -0
  127. data/resources/queries/observation_labels.rq +8 -0
  128. data/resources/queries/observations.rq +13 -0
  129. data/resources/queries/patient.rq +11 -0
  130. data/resources/queries/patient_list.rq +11 -0
  131. data/resources/queries/patients_with_mutation.rq +18 -0
  132. data/resources/queries/properties.rq +8 -0
  133. data/resources/queries/test.rq +3 -0
  134. data/resources/weather.numeric.arff +28 -0
  135. data/scripts/get_gene_lengths.rb +50 -0
  136. data/scripts/islet_mlratio.rb +6 -0
  137. data/scripts/scan_islet.rb +6 -0
  138. data/scripts/update_reference.rb +25 -0
  139. data/server/helpers.rb +215 -0
  140. data/server/public/src-min-noconflict/LICENSE +24 -0
  141. data/server/public/src-min-noconflict/ace.js +11 -0
  142. data/server/public/src-min-noconflict/ext-chromevox.js +1 -0
  143. data/server/public/src-min-noconflict/ext-elastic_tabstops_lite.js +1 -0
  144. data/server/public/src-min-noconflict/ext-emmet.js +1 -0
  145. data/server/public/src-min-noconflict/ext-keybinding_menu.js +1 -0
  146. data/server/public/src-min-noconflict/ext-language_tools.js +1 -0
  147. data/server/public/src-min-noconflict/ext-modelist.js +1 -0
  148. data/server/public/src-min-noconflict/ext-old_ie.js +1 -0
  149. data/server/public/src-min-noconflict/ext-searchbox.js +1 -0
  150. data/server/public/src-min-noconflict/ext-settings_menu.js +1 -0
  151. data/server/public/src-min-noconflict/ext-spellcheck.js +1 -0
  152. data/server/public/src-min-noconflict/ext-split.js +1 -0
  153. data/server/public/src-min-noconflict/ext-static_highlight.js +1 -0
  154. data/server/public/src-min-noconflict/ext-statusbar.js +1 -0
  155. data/server/public/src-min-noconflict/ext-textarea.js +1 -0
  156. data/server/public/src-min-noconflict/ext-themelist.js +1 -0
  157. data/server/public/src-min-noconflict/ext-whitespace.js +1 -0
  158. data/server/public/src-min-noconflict/keybinding-emacs.js +1 -0
  159. data/server/public/src-min-noconflict/keybinding-vim.js +1 -0
  160. data/server/public/src-min-noconflict/mode-ruby.js +1 -0
  161. data/server/public/src-min-noconflict/snippets/ruby.js +1 -0
  162. data/server/public/src-min-noconflict/theme-twilight.js +1 -0
  163. data/server/public/src-min-noconflict/worker-coffee.js +1 -0
  164. data/server/public/src-min-noconflict/worker-css.js +1 -0
  165. data/server/public/src-min-noconflict/worker-javascript.js +1 -0
  166. data/server/public/src-min-noconflict/worker-json.js +1 -0
  167. data/server/public/src-min-noconflict/worker-lua.js +1 -0
  168. data/server/public/src-min-noconflict/worker-php.js +1 -0
  169. data/server/public/src-min-noconflict/worker-xquery.js +1 -0
  170. data/server/routes.rb +123 -0
  171. data/server/views/dsl.haml +65 -0
  172. data/server/views/dump.haml +3 -0
  173. data/server/views/import.haml +35 -0
  174. data/server/views/new_repository.haml +25 -0
  175. data/server/views/query.haml +28 -0
  176. data/server/views/repository.haml +25 -0
  177. data/spec/ORM/data_cube_orm_spec.rb +33 -0
  178. data/spec/ORM/prov_model_spec.rb +72 -0
  179. data/spec/analyzer_spec.rb +36 -0
  180. data/spec/bnode_spec.rb +66 -0
  181. data/spec/csv/bacon.csv +4 -0
  182. data/spec/csv/moar_bacon.csv +11 -0
  183. data/spec/data_cube_spec.rb +169 -0
  184. data/spec/dataset_for_spec.rb +77 -0
  185. data/spec/dsl_spec.rb +134 -0
  186. data/spec/generators/csv_spec.rb +44 -0
  187. data/spec/generators/dataframe_spec.rb +44 -0
  188. data/spec/generators/maf_spec.rb +40 -0
  189. data/spec/generators/r_cross_spec.rb +51 -0
  190. data/spec/generators/r_matrix_spec.rb +44 -0
  191. data/spec/length_lookup_spec.rb +0 -0
  192. data/spec/maf_query_spec.rb +343 -0
  193. data/spec/metadata/metadata_dsl_spec.rb +68 -0
  194. data/spec/prov/activity_spec.rb +74 -0
  195. data/spec/prov/agent_spec.rb +54 -0
  196. data/spec/prov/association_spec.rb +55 -0
  197. data/spec/prov/config_spec.rb +28 -0
  198. data/spec/prov/derivation_spec.rb +30 -0
  199. data/spec/prov/entity_spec.rb +52 -0
  200. data/spec/prov/role_spec.rb +94 -0
  201. data/spec/prov/usage_spec.rb +98 -0
  202. data/spec/queries/integrity/1.rq +21 -0
  203. data/spec/queries/integrity/11.rq +29 -0
  204. data/spec/queries/integrity/12.rq +37 -0
  205. data/spec/queries/integrity/14.rq +25 -0
  206. data/spec/queries/integrity/19_1.rq +21 -0
  207. data/spec/queries/integrity/19_2.rq +15 -0
  208. data/spec/queries/integrity/2.rq +22 -0
  209. data/spec/queries/integrity/3.rq +19 -0
  210. data/spec/queries/integrity/4.rq +13 -0
  211. data/spec/queries/integrity/5.rq +14 -0
  212. data/spec/r_builder_spec.rb +33 -0
  213. data/spec/resource/.RData +0 -0
  214. data/spec/resource/example.Rhistory +3 -0
  215. data/spec/spec_helper.rb +17 -0
  216. data/spec/turtle/bacon +147 -0
  217. data/spec/turtle/reference +2064 -0
  218. data/spec/turtle/weather +275 -0
  219. data/spec/writer_spec.rb +75 -0
  220. metadata +589 -0
@@ -0,0 +1,140 @@
1
+ require 'bio-publisci'
2
+ require 'graphviz'
3
+
4
+ def entity_node(label)
5
+ ent = @g.add_nodes(label)
6
+ ent.color = "#F3F781"
7
+ ent.style = "filled"
8
+ ent
9
+ end
10
+
11
+ def agent_node(label)
12
+ ag = @g.add_nodes(label)
13
+ ag.color = "#FE9A2E"
14
+ ag.style = "filled"
15
+ ag.shape = "box"
16
+ ag
17
+ end
18
+
19
+ def activity_node(label)
20
+ act = @g.add_nodes(label)
21
+ act.color = "#5858FA"
22
+ act.style = "filled"
23
+ act.shape = "box"
24
+ act
25
+ end
26
+
27
+ def generic_node(label)
28
+ act = @g.add_nodes(label)
29
+ # act.color = "#5858FA"
30
+ # act.style = "filled"
31
+ act.shape = "box"
32
+ act
33
+ end
34
+
35
+ def make_edges(from_obj,to_class,predicate)
36
+ # from_class.enum_for.to_a.map{|from_obj|
37
+ raise "Unknown From Node: #{from_obj.subject}" unless @nodemap[from_obj.subject]
38
+ relation = from_obj.send(predicate)
39
+ if relation
40
+ if relation.is_a? Array
41
+ relation.map{|r|
42
+ other = to_class.for(r)
43
+ raise "Unknown To Node: #{other.subject}" unless @nodemap[other.subject]
44
+ @g.add_edges(@nodemap[from_obj.subject],@nodemap[other.subject]).label=predicate.to_s
45
+ }
46
+ else
47
+ other = to_class.for(relation)
48
+ raise "Unknown To Node: #{other.subject}" unless @nodemap[other.subject]
49
+ @g.add_edges(@nodemap[from_obj.subject],@nodemap[other.subject]).label=predicate.to_s
50
+ end
51
+ end
52
+ # }
53
+ end
54
+
55
+ @nodemap={}
56
+ @g = GraphViz.new(:G, type: :digraph)
57
+ infile = ARGV[0] || 'primer.prov'
58
+ runner = PubliSci::Prov::DSL::Instance.new
59
+ runner.instance_eval(IO.read(infile),infile)
60
+ repo = runner.to_repository
61
+ Spira.add_repository :default, repo
62
+
63
+ include PubliSci::Prov::Model
64
+
65
+ Entity.enum_for.to_a.map{|e|
66
+ @nodemap[e.subject]=entity_node(e.label)
67
+ }
68
+
69
+ Agent.enum_for.to_a.map{|agent|
70
+ @nodemap[agent.subject]=agent_node(agent.label)
71
+ }
72
+
73
+ Activity.enum_for.to_a.map{|act|
74
+ @nodemap[act.subject]=activity_node(act.label)
75
+ }
76
+
77
+ Association.enum_for.to_a.map{|association|
78
+ @nodemap[association.subject]=generic_node(association.label)
79
+ }
80
+
81
+ Plan.enum_for.to_a.map{|plan|
82
+ @nodemap[plan.subject]=generic_node(plan.label)
83
+ }
84
+
85
+
86
+ # Derivation.enum_for.to_a.map{|deriv|
87
+ # @nodemap[deriv.subject]=generic_node(deriv.label)
88
+ # }
89
+
90
+ Entity.enum_for.to_a.map{|e|
91
+ attribs ={
92
+ "wasAttributedTo" => Agent,
93
+ "wasGeneratedBy" => Activity,
94
+ "wasDerivedFrom" => Entity,
95
+ }
96
+ attribs.each{|predicate,range| make_edges(e,range,predicate)}
97
+ }
98
+
99
+ Activity.enum_for.to_a.map{|act|
100
+ attribs ={
101
+ "generated" => Entity,
102
+ "used" => Entity,
103
+ "wasAssociatedWith" => Agent,
104
+ "qualifiedAssociation" => Agent,
105
+ }
106
+ attribs.each{|predicate,range| make_edges(act,range,predicate)}
107
+ }
108
+
109
+ Agent.enum_for.to_a.map{|agent|
110
+ attribs = {
111
+ "actedOnBehalfOf" => Agent
112
+ }
113
+ attribs.each{|predicate,range| make_edges(agent,range,predicate)}
114
+ }
115
+
116
+ Association.enum_for.to_a.map{|assoc|
117
+ attribs ={
118
+ "agent" => Agent,
119
+ "hadPlan" => Plan
120
+ }
121
+ attribs.each{|predicate,range| make_edges(assoc,range,predicate)}
122
+ }
123
+
124
+ # Association.enum_for.to_a.map{|assoc|
125
+ # attribs ={
126
+ # "agent" => Agent
127
+ # "hadPlan" => Plan
128
+ # }
129
+ # attribs.each{|predicate,range| make_edges(assoc,range,predicate)}
130
+ # }
131
+
132
+ # Derivation.enum_for.to_a.map{|assoc|
133
+ # attribs ={
134
+ # "agent" => Entity
135
+ # }
136
+ # attribs.each{|predicate,range| make_edges(assoc,range,predicate)}
137
+ # }
138
+
139
+ @g.output(png: "out.png")
140
+ begin `eog out.png` rescue nil end
@@ -0,0 +1,35 @@
1
+ require 'graphviz'
2
+
3
+ def entity_node(label)
4
+ ent = @g.add_nodes(label)
5
+ ent.color = "#F3F781"
6
+ ent.style = "filled"
7
+ ent
8
+ end
9
+
10
+ def agent_node(label)
11
+ ag = @g.add_nodes(label)
12
+ ag.color = "#FE9A2E"
13
+ ag.style = "filled"
14
+ ag.shape = "box"
15
+ ag
16
+ end
17
+
18
+ def activity_node(label)
19
+ act = @g.add_nodes(label)
20
+ act.color = "#5858FA"
21
+ act.style = "filled"
22
+ act.shape = "box"
23
+ act
24
+ end
25
+
26
+ @g = GraphViz.new(:G, type: :digraph)
27
+ g = @g
28
+
29
+ ent_n = entity_node("entity") #g.add_nodes("entity")
30
+ ag_n = activity_node("activity")
31
+
32
+ g.add_edges(ent_n,ag_n).label="attributed"
33
+
34
+ g.output(png: "out.png")
35
+ `eog out.png`
@@ -0,0 +1,21 @@
1
+ Feature: create generators
2
+
3
+ In order to check that objects conform to a common interface
4
+ I want to be able to call a generate method on various classes
5
+
6
+ Scenario: create a Dataframe generator
7
+ Given a Dataframe generator
8
+ Then I should be able to call its generate_n3 method
9
+
10
+ Scenario: create a CSV generator
11
+ Given a CSV generator
12
+ Then I should be able to call its generate_n3 method
13
+
14
+ Scenario: create a RMatrix generator
15
+ Given a RMatrix generator
16
+ Then I should be able to call its generate_n3 method
17
+
18
+ Scenario: create a RCross generator
19
+ Given a RCross generator
20
+ Then I should be able to call its generate_n3 method
21
+
@@ -0,0 +1,12 @@
1
+ Feature: Integrate with other GSOC projects
2
+
3
+ In order to leverage the data sharing and comprehension power of RDF
4
+ I want to integrate my code with that of other GSOC students
5
+
6
+ Scenario: Integrate with Ruby Mining
7
+ Given a CSV generator
8
+ When I provide the reference file spec/csv/moar_bacon.csv and the label "moar_bacon" and the options {dimensions:["producer","pricerange"]}
9
+ And generate a turtle string from it
10
+ Given a ARFF writer
11
+ When I call its from_turtle method on the turtle string
12
+ Then I should be able to cluster the result and print statistics
@@ -0,0 +1,10 @@
1
+ Then(/^I should be able to cluster the result and print statistics$/) do
2
+ pending
3
+ # f=Tempfile.open('arff'); f.write @result; f.close
4
+ # clustering = Weka::Clusterer::SimpleKMeans::Base
5
+ # clustering.set_options "-N 5"
6
+ # clustering.set_data(Core::Parser::parse_ARFF(f.path))
7
+ # f.unlink
8
+ # clustered = clustering.new
9
+ # puts clustered
10
+ end
@@ -0,0 +1,37 @@
1
+ Feature: Receive metadata as user input or extract from data sources
2
+
3
+ In order to publish and share data about my datasets
4
+ I want to be able to attach metadata
5
+
6
+ Scenario: Attach basic DC Terms info
7
+ Given a class which includes the Metadata module
8
+ When I call its basic method with the hash {var: "example", title: "example dataset", creator: "Will Strinz", description: "an example dataset", date: "1-10-2010"}
9
+ Then I should receive a metadata string
10
+
11
+ Scenario: Auto Generate some fields
12
+ Given a class which includes the Metadata module
13
+ When I call its basic method with the hash {var: "example", title: "example dataset", description: "an example dataset"}
14
+ Then I should receive a metadata string
15
+
16
+ Scenario: Generate process information
17
+ Given a class which includes the Metadata module
18
+ And the source object {resource: 'http://example.org/software/R/var/ex', software:'http://r-project.org', process: 'spec/resource/example.Rhistory'}
19
+ And the rdf dataset {resource:'http://example.org/data'}
20
+ When I call its provenance method with the source object and the rdf object
21
+ Then I should receive a metadata string
22
+
23
+ Scenario: Generate organizational provenance information
24
+ Given a class which includes the Metadata module
25
+ And the source object {resource: 'http://example.org/software/R/var/ex', author: 'http://example.org/people/jrs', author_name: "J Random Scientist", organization: 'http://example.org/org/science', organization_name: "The League of Science" }
26
+ And the rdf dataset {resource:'http://example.org/data', author: 'http://gsocsemantic.wordpress.com/me', author_name: "Will Strinz", organization: 'http://sciruby.com/'}
27
+ When I call its provenance method with the source object and the rdf object
28
+ Then I should receive a metadata string
29
+
30
+ Scenario: Generate a provenance chain
31
+ Given a class which includes the Metadata module
32
+ And the source object {resource: 'http://example.org/software/R/var/ex', software:'http://r-project.org'}
33
+ And the rdf dataset {resource:'http://example.org/data'}
34
+ And the chain object {resource: 'http://example.org/lab_results/1', author: 'http://example.org/people/brl', author_name: "B Random Labtech"}
35
+ And the chain object {resource: 'http://example.org/field_work/1', author: 'http://example.org/people/arn', organization: 'http://example.org/org/science'}
36
+ When I call its provenance method with the source object, the rdf object, and the chain
37
+ Then I should receive a metadata string
@@ -0,0 +1,40 @@
1
+ Given(/^a class which includes the Metadata module$/) do
2
+
3
+ @klass = Class.new {include PubliSci::Metadata::Generator}
4
+ end
5
+
6
+ Given(/^the source object (\{.+\})$/) do |fields|
7
+ @original = eval(fields)
8
+ end
9
+
10
+ Given(/^the rdf dataset (\{.+\})$/) do |fields|
11
+ @rdf = eval(fields)
12
+ end
13
+
14
+ Given(/^the chain object (\{.+\})$/) do |fields|
15
+ (@chain ||= []) << eval(fields)
16
+ end
17
+
18
+ When(/^I call its provenance method with the source object, the rdf object, and the chain$/) do
19
+ @response = @klass.new.provenance(@original, @rdf, @chain)
20
+ end
21
+
22
+
23
+ When(/^I call its provenance method with the source object and the rdf object$/) do
24
+ @response = @klass.new.provenance(@original, @rdf, nil)
25
+ end
26
+
27
+ When(/^I call its basic method with the hash (\{.+\})$/) do |fields|
28
+ fields = eval(fields)
29
+ @response = @klass.new.basic(fields)
30
+ end
31
+
32
+ When(/^I call its provenance method with the hash (\{.+\})$/) do |fields|
33
+ fields = eval(fields)
34
+ @response = @klass.new.provenance(fields)
35
+ end
36
+
37
+ Then(/^I should receive a metadata string$/) do
38
+ @response.is_a?(String).should be true
39
+ puts @response
40
+ end
@@ -0,0 +1,60 @@
1
+ Feature: generate data using ORM
2
+
3
+ In order to make the generator simpler and more accessible to ruby users
4
+ I want to implement an ORM (OTM? OGM?) to assist creation of datacube objects
5
+
6
+ Scenario: build data cube and export turtle
7
+ Given an ORM::DataCube entitled "cats"
8
+ When I add a "size" dimension
9
+ And I add a "breed" dimension
10
+ And I add a "fluffiness" measure
11
+ And I add the observation {size: "big", breed: "American Shorthair", fluffiness: 100}
12
+ And I add the observation {size: "huge", breed: "Maine Coon", fluffiness: 9001}
13
+ And I add the observation {size: "little", breed: "American Shorthair", fluffiness: 15}
14
+ Then the to_n3 method should return a string
15
+
16
+ Scenario: load from turtle string
17
+ Given a turtle string from file spec/turtle/bacon
18
+ When I call the ORM::DataCube class method load on it
19
+ Then I should receive an ORM::DataCube object
20
+ And the to_n3 method should return a string
21
+
22
+ Scenario: load from endpoint
23
+ Given the URI string "http://localhost:8080"
24
+ When I call the ORM::DataCube class method load on it
25
+ Then I should receive an ORM::DataCube object
26
+ And the to_n3 method should return a string
27
+
28
+ Scenario: raise error when unknown components are used
29
+ Given an ORM::DataCube entitled "animals"
30
+ When I add a "robustness" dimension
31
+ And I add a "species" measure
32
+ And I add the observation {species: "Balaenoptera musculus", robustness: 25}
33
+ And I add the observation {species: "Hypsibius dujardini", robustness: 9001}
34
+ Then the to_n3 method should return a string
35
+ When I add the observation {species: "Deinococcus radiodurans", robustness: 350, chunkiness: 9}
36
+ Then the to_n3 method should raise error UnknownProperty ["chunkiness"]
37
+
38
+ Scenario: raise error when components are missing
39
+ Given an ORM::DataCube entitled "animals"
40
+ When I add a "robustness" dimension
41
+ And I add a "species" measure
42
+ And I add the observation {species: "Felis catus"}
43
+ Then the to_n3 method should raise error MissingValues for ["robustness"]
44
+
45
+ Scenario: raise error when components are missing
46
+ Given an ORM::DataCube entitled "animals" with the following options:
47
+ | key | value |
48
+ | :validate_each | true |
49
+ When I add a "robustness" dimension
50
+ And I add a "species" measure
51
+ Then adding the observation {species: "Caenorhabditis elegans"} should raise error MissingValues for ["robustness"]
52
+
53
+ Scenario: add metadata
54
+ Given an ORM::DataCube entitled "meta"
55
+ When I add a "robustness" dimension
56
+ And I add a "species" measure
57
+ And I add the observation {species: "Hypsibius dujardini", robustness: 9001}
58
+ And I call the cubes add_publisher method with the arguments "Moss Piglets Unlimited", "http://mosspiglet.org/"
59
+ Then the to_n3 method should return a string with a "dct:publisher"
60
+
@@ -0,0 +1,74 @@
1
+ require_relative '../lib/bio-publisci.rb'
2
+
3
+ Given /^an ORM::DataCube entitled "(.*?)"$/ do |name|
4
+ @cube = PubliSci::DataSet::ORM::DataCube.new(name: name)
5
+ end
6
+
7
+ Given /^an ORM::DataCube entitled "(.*?)" with the following options:$/ do |name, opts|
8
+ options_hash = {name: name}
9
+ opts.hashes.map{|hash|
10
+ k = hash["key"]
11
+ k = k[1..-1].to_sym if k[0] == ":"
12
+
13
+ v = hash["value"]
14
+ v = v[1..-1].to_sym if k[0] == ":"
15
+
16
+ v = true if v =="true"
17
+ v = false if v =="false"
18
+
19
+ options_hash[k] = v
20
+ }
21
+ @cube = PubliSci::DataSet::ORM::DataCube.new(options_hash)
22
+ end
23
+
24
+ Given(/^a turtle string from file (.*)$/) do |file|
25
+ @string = IO.read(file)
26
+ end
27
+
28
+ Given(/^the URI string "(.*?)"$/) do |uri|
29
+ @string = uri
30
+ end
31
+
32
+ When(/^I call the ORM::DataCube class method load on it$/) do
33
+ @cube = PubliSci::DataSet::ORM::DataCube.load(@string)
34
+ end
35
+
36
+ When /^I add a "(.*?)" dimension$/ do |dim|
37
+ @cube.add_dimension(dim)
38
+ end
39
+
40
+ When /^I add a "(.*?)" measure$/ do |meas|
41
+ @cube.add_measure(meas)
42
+ end
43
+
44
+ When /^I add the observation (.*)$/ do |obs|
45
+ data = eval(obs)
46
+ # obs.split(',').map{|entry| data[entry.chomp.strip.split(':')[0].to_s] = eval(entry.chomp.strip.split(':')[1])}
47
+ @cube.add_observation(data)
48
+ end
49
+
50
+ When /^adding the observation (.*) should raise error (.*)$/ do |obs,err|
51
+ data = eval(obs)
52
+ expect { @cube.add_observation(data) }.to raise_error(err)
53
+ end
54
+
55
+ When /^I call the cubes (.*) method with the arguments (.*)$/ do |method,args|
56
+ eval("args = #{args}")
57
+ @cube.send(method.to_sym, *args)
58
+ end
59
+
60
+ Then /^the to_n3 method should return a string$/ do
61
+ @cube.to_n3.is_a?(String).should be true
62
+ end
63
+
64
+ Then /^the to_n3 method should raise error (.*?)$/ do |err|
65
+ expect { @cube.to_n3 }.to raise_error(err)
66
+ end
67
+
68
+ Then /^the to_n3 method should return a string with a "(.*?)"$/ do |search|
69
+ @cube.to_n3[search].should_not be nil
70
+ end
71
+
72
+ Then(/^I should receive an ORM::DataCube object$/) do
73
+ @cube.is_a?(PubliSci::DataSet::ORM::DataCube).should == true
74
+ end
@@ -0,0 +1,14 @@
1
+ Feature: Receive metadata as user input or extract from data sources
2
+
3
+ To generate clean provenance strings through a friendly interface
4
+ I want to use a DSL for the PROV ontology
5
+
6
+ Scenario: Generate based on example for w3.org
7
+ Given the prov DSL string from file examples/primer-full.prov
8
+ When I call Prov.run on it
9
+ Then I should receive a provenance string
10
+
11
+ Scenario: Generate from file
12
+ Given the prov DSL string from file examples/prov_dsl.prov
13
+ When I call Prov.run on it
14
+ Then I should receive a provenance string