omf_sfa 0.1.1

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
Files changed (152) hide show
  1. data/.gitignore +24 -0
  2. data/Gemfile +6 -0
  3. data/README.md +211 -0
  4. data/Rakefile +23 -0
  5. data/bin/parse_rspec.rb +167 -0
  6. data/etc/omf-sfa/omf-sfa-am.yaml +12 -0
  7. data/examples/exogeni5nodemanifest.rspec +105 -0
  8. data/examples/instageni5nodemanifest.rspec +150 -0
  9. data/lib/omf-sfa/am/am-rest/REST_API.md +301 -0
  10. data/lib/omf-sfa/am/am-rest/account_handler.rb +145 -0
  11. data/lib/omf-sfa/am/am-rest/am_rest_server.rb +255 -0
  12. data/lib/omf-sfa/am/am-rest/api_template.html +48 -0
  13. data/lib/omf-sfa/am/am-rest/config.ru +110 -0
  14. data/lib/omf-sfa/am/am-rest/resource_handler.rb +178 -0
  15. data/lib/omf-sfa/am/am-rest/rest_handler.rb +573 -0
  16. data/lib/omf-sfa/am/am-rest/session_authenticator.rb +130 -0
  17. data/lib/omf-sfa/am/am-rpc/abstract_rpc_service.rb +60 -0
  18. data/lib/omf-sfa/am/am-rpc/am_authorizer.rb +161 -0
  19. data/lib/omf-sfa/am/am-rpc/am_rpc_api.rb +450 -0
  20. data/lib/omf-sfa/am/am-rpc/am_rpc_service.rb +402 -0
  21. data/lib/omf-sfa/am/am_liaison.rb +93 -0
  22. data/lib/omf-sfa/am/am_manager.rb +859 -0
  23. data/lib/omf-sfa/am/am_runner.rb +108 -0
  24. data/lib/omf-sfa/am/am_scheduler.rb +146 -0
  25. data/lib/omf-sfa/am/am_server.rb +194 -0
  26. data/lib/omf-sfa/am/config.ru +122 -0
  27. data/lib/omf-sfa/am/credential.rb +145 -0
  28. data/lib/omf-sfa/am/default_authorizer.rb +44 -0
  29. data/lib/omf-sfa/am/privilege_credential.rb +76 -0
  30. data/lib/omf-sfa/am/signature.rb +37 -0
  31. data/lib/omf-sfa/am/user_credential.rb +56 -0
  32. data/lib/omf-sfa/am.rb +7 -0
  33. data/lib/omf-sfa/model/abstract_prop_description.rb +87 -0
  34. data/lib/omf-sfa/model/model_class_description.rb +145 -0
  35. data/lib/omf-sfa/model/model_data_prop_description.rb +28 -0
  36. data/lib/omf-sfa/model/model_obj_prop_description.rb +49 -0
  37. data/lib/omf-sfa/model/ontology.rb +169 -0
  38. data/lib/omf-sfa/resource/README.md +24 -0
  39. data/lib/omf-sfa/resource/channel.rb +49 -0
  40. data/lib/omf-sfa/resource/comp_group.rb +41 -0
  41. data/lib/omf-sfa/resource/component_lease.rb +10 -0
  42. data/lib/omf-sfa/resource/constants.rb +24 -0
  43. data/lib/omf-sfa/resource/group_component.rb +35 -0
  44. data/lib/omf-sfa/resource/group_membership.rb +17 -0
  45. data/lib/omf-sfa/resource/gurn.rb +187 -0
  46. data/lib/omf-sfa/resource/interface.rb +78 -0
  47. data/lib/omf-sfa/resource/ip.rb +48 -0
  48. data/lib/omf-sfa/resource/link.rb +29 -0
  49. data/lib/omf-sfa/resource/node.rb +75 -0
  50. data/lib/omf-sfa/resource/oaccount.rb +94 -0
  51. data/lib/omf-sfa/resource/ocomponent.rb +134 -0
  52. data/lib/omf-sfa/resource/ogroup.rb +106 -0
  53. data/lib/omf-sfa/resource/olease.rb +61 -0
  54. data/lib/omf-sfa/resource/oproperty.rb +178 -0
  55. data/lib/omf-sfa/resource/oreference.rb +15 -0
  56. data/lib/omf-sfa/resource/oresource.rb +491 -0
  57. data/lib/omf-sfa/resource/project.rb +28 -0
  58. data/lib/omf-sfa/resource/project_membership.rb +13 -0
  59. data/lib/omf-sfa/resource/sfa_base.rb +544 -0
  60. data/lib/omf-sfa/resource/user.rb +25 -0
  61. data/lib/omf-sfa/resource.rb +20 -0
  62. data/lib/omf-sfa/util/create_sample_testbed.rb +68 -0
  63. data/lib/omf-sfa/util/load_from_sfa_xml.rb +65 -0
  64. data/lib/omf-sfa/version.rb +4 -0
  65. data/lib/omf_sfa.rb +5 -0
  66. data/omf_sfa.gemspec +46 -0
  67. data/owl/README +3 -0
  68. data/owl/ben-6509.rdf +1377 -0
  69. data/owl/ben-dell.rdf +586 -0
  70. data/owl/ben-dtn.rdf +1698 -0
  71. data/owl/ben.rdf +1335 -0
  72. data/owl/collections.owl +309 -0
  73. data/owl/compute.owl +1486 -0
  74. data/owl/domain.owl +444 -0
  75. data/owl/dtn.owl +1165 -0
  76. data/owl/ec2.owl +385 -0
  77. data/owl/ethernet.owl +466 -0
  78. data/owl/eucalyptus.owl +431 -0
  79. data/owl/id-mp-Request1.rdf +247 -0
  80. data/owl/itu-grid.owl +147 -0
  81. data/owl/kansei.owl +511 -0
  82. data/owl/layer.owl +645 -0
  83. data/owl/location.owl +117 -0
  84. data/owl/mass.rdf +608 -0
  85. data/owl/nlr.rdf +901 -0
  86. data/owl/orca.owl +181 -0
  87. data/owl/planetlab.owl +124 -0
  88. data/owl/protogeni.owl +467 -0
  89. data/owl/request-6509-2.rdf +150 -0
  90. data/owl/request-6509-3.rdf +158 -0
  91. data/owl/request-6509.rdf +199 -0
  92. data/owl/request.owl +222 -0
  93. data/owl/storage.owl +511 -0
  94. data/owl/topology.owl +608 -0
  95. data/schema/rspec-v3/ad-common.xsd +269 -0
  96. data/schema/rspec-v3/ad-reservation.rnc +12 -0
  97. data/schema/rspec-v3/ad-reservation.rng +28 -0
  98. data/schema/rspec-v3/ad-reservation.xsd +13 -0
  99. data/schema/rspec-v3/ad.rnc +151 -0
  100. data/schema/rspec-v3/ad.xsd +77 -0
  101. data/schema/rspec-v3/any-extension-schema.xsd +38 -0
  102. data/schema/rspec-v3/any-extension.rnc +30 -0
  103. data/schema/rspec-v3/common.rnc +185 -0
  104. data/schema/rspec-v3/manifest-common.xsd +244 -0
  105. data/schema/rspec-v3/manifest-request.xsd +95 -0
  106. data/schema/rspec-v3/manifest.rnc +62 -0
  107. data/schema/rspec-v3/manifest.xsd +34 -0
  108. data/schema/rspec-v3/request-common.xsd +219 -0
  109. data/schema/rspec-v3/request-reservation.rnc +12 -0
  110. data/schema/rspec-v3/request-reservation.xsd +13 -0
  111. data/schema/rspec-v3/request.rnc +118 -0
  112. data/schema/rspec-v3/request.xsd +94 -0
  113. data/share/assets/css/default.css +147 -0
  114. data/share/assets/css/rest_api.css +0 -0
  115. data/share/assets/network.html +28 -0
  116. data/share/assets/network.js +82 -0
  117. data/spec/am/am-rest/common.rb +29 -0
  118. data/spec/am/am-rest/resource_group_handler_XspecX.rb +97 -0
  119. data/spec/am/am-rest/resource_handler_spec.rb +204 -0
  120. data/spec/am/am-rpc/sfa_methods_spec.rb +150 -0
  121. data/spec/am/am_manager_spec.rb +307 -0
  122. data/spec/am/am_scheduler_spec.rb +57 -0
  123. data/spec/am/common.rb +24 -0
  124. data/spec/resource/common.rb +31 -0
  125. data/spec/resource/node_spec.rb +171 -0
  126. data/spec/resource/oaccount_spec.rb +92 -0
  127. data/spec/resource/ocomponent_spec.rb +225 -0
  128. data/spec/resource/ogroup_spec.rb +93 -0
  129. data/spec/resource/oresource_spec.rb +208 -0
  130. data/spec/resource_and_leases_spec.rb +377 -0
  131. data/test/OLD_FILES/assertion1.xml +117 -0
  132. data/test/OLD_FILES/greeter_spec.rb +15 -0
  133. data/test/OLD_FILES/mongo_test.rb +45 -0
  134. data/test/OLD_FILES/req-sfa-2.xml +6 -0
  135. data/test/OLD_FILES/req-sfa-g.xml +8 -0
  136. data/test/OLD_FILES/req-sfa-g2.xml +10 -0
  137. data/test/OLD_FILES/req-sfa-g3.xml +14 -0
  138. data/test/OLD_FILES/req-sfa.xml +6 -0
  139. data/test/OLD_FILES/req1.xml +22 -0
  140. data/test/OLD_FILES/req1b.xml +15 -0
  141. data/test/OLD_FILES/rspec-test.xml +1867 -0
  142. data/test/OLD_FILES/test.rb +67 -0
  143. data/test/OLD_FILES/test2.rb +32 -0
  144. data/test/am/am_manager_rspec_tests.rb +378 -0
  145. data/test/am/am_manager_tests.rb +518 -0
  146. data/test/am/am_scheduler_tests.rb +173 -0
  147. data/test/resource/olease_test.rb +74 -0
  148. data/test/sfa_requests/request.xml +5 -0
  149. data/test/sfa_requests/request1.xml +5 -0
  150. data/test/sfa_requests/request2.xml +5 -0
  151. data/test/sfa_requests/request3.xml +5 -0
  152. metadata +601 -0
data/owl/orca.owl ADDED
@@ -0,0 +1,181 @@
1
+ <?xml version="1.0"?>
2
+
3
+
4
+ <!DOCTYPE rdf:RDF [
5
+ <!ENTITY owl "http://www.w3.org/2002/07/owl#" >
6
+ <!ENTITY xsd "http://www.w3.org/2001/XMLSchema#" >
7
+ <!ENTITY owl2xml "http://www.w3.org/2006/12/owl2-xml#" >
8
+ <!ENTITY rdfs "http://www.w3.org/2000/01/rdf-schema#" >
9
+ <!ENTITY orca "http://geni-orca.renci.org/owl/orca.owl#" >
10
+ <!ENTITY storage "http://geni-orca.renci.org/owl/storage.owl#" >
11
+ <!ENTITY rdf "http://www.w3.org/1999/02/22-rdf-syntax-ns#" >
12
+ <!ENTITY compute "http://geni-orca.renci.org/owl/compute.owl#" >
13
+ ]>
14
+
15
+
16
+ <rdf:RDF xmlns="http://geni-orca.renci.org/owl/orca.owl#"
17
+ xml:base="http://geni-orca.renci.org/owl/orca.owl"
18
+ xmlns:orca="http://geni-orca.renci.org/owl/orca.owl#"
19
+ xmlns:rdfs="http://www.w3.org/2000/01/rdf-schema#"
20
+ xmlns:owl2xml="http://www.w3.org/2006/12/owl2-xml#"
21
+ xmlns:owl="http://www.w3.org/2002/07/owl#"
22
+ xmlns:xsd="http://www.w3.org/2001/XMLSchema#"
23
+ xmlns:rdf="http://www.w3.org/1999/02/22-rdf-syntax-ns#"
24
+ xmlns:compute="http://geni-orca.renci.org/owl/compute.owl#"
25
+ xmlns:storage="http://geni-orca.renci.org/owl/storage.owl#">
26
+ <owl:Ontology rdf:about="">
27
+ <owl:imports rdf:resource="http://geni-orca.renci.org/owl/storage.owl"/>
28
+ </owl:Ontology>
29
+
30
+
31
+
32
+ <!--
33
+ ///////////////////////////////////////////////////////////////////////////////////////
34
+ //
35
+ // Object Properties
36
+ //
37
+ ///////////////////////////////////////////////////////////////////////////////////////
38
+ -->
39
+
40
+
41
+
42
+
43
+ <!-- http://geni-orca.renci.org/owl/compute.owl#hasUnitServer -->
44
+
45
+ <owl:ObjectProperty rdf:about="&compute;hasUnitServer"/>
46
+
47
+
48
+
49
+ <!--
50
+ ///////////////////////////////////////////////////////////////////////////////////////
51
+ //
52
+ // Data properties
53
+ //
54
+ ///////////////////////////////////////////////////////////////////////////////////////
55
+ -->
56
+
57
+
58
+
59
+
60
+ <!-- http://geni-orca.renci.org/owl/compute.owl#cpuCapacity -->
61
+
62
+ <owl:DatatypeProperty rdf:about="&compute;cpuCapacity"/>
63
+
64
+
65
+
66
+ <!-- http://geni-orca.renci.org/owl/compute.owl#maxNumUnitServer -->
67
+
68
+ <owl:DatatypeProperty rdf:about="&compute;maxNumUnitServer"/>
69
+
70
+
71
+
72
+ <!-- http://geni-orca.renci.org/owl/compute.owl#memoryCapacity -->
73
+
74
+ <owl:DatatypeProperty rdf:about="&compute;memoryCapacity"/>
75
+
76
+
77
+
78
+ <!-- http://geni-orca.renci.org/owl/compute.owl#numUnitServer -->
79
+
80
+ <owl:DatatypeProperty rdf:about="&compute;numUnitServer"/>
81
+
82
+
83
+
84
+ <!-- http://geni-orca.renci.org/owl/orca.owl#maxNumORCAUnitServer -->
85
+
86
+ <owl:DatatypeProperty rdf:about="#maxNumORCAUnitServer">
87
+ <rdfs:subPropertyOf rdf:resource="&compute;maxNumUnitServer"/>
88
+ </owl:DatatypeProperty>
89
+
90
+
91
+
92
+ <!-- http://geni-orca.renci.org/owl/orca.owl#numORCAUnitServer -->
93
+
94
+ <owl:DatatypeProperty rdf:about="#numORCAUnitServer">
95
+ <rdfs:subPropertyOf rdf:resource="&compute;numUnitServer"/>
96
+ </owl:DatatypeProperty>
97
+
98
+
99
+
100
+ <!--
101
+ ///////////////////////////////////////////////////////////////////////////////////////
102
+ //
103
+ // Classes
104
+ //
105
+ ///////////////////////////////////////////////////////////////////////////////////////
106
+ -->
107
+
108
+
109
+
110
+
111
+ <!-- http://geni-orca.renci.org/owl/compute.owl#LargeServerSize -->
112
+
113
+ <owl:Class rdf:about="&compute;LargeServerSize"/>
114
+
115
+
116
+
117
+ <!-- http://geni-orca.renci.org/owl/compute.owl#MediumServerSize -->
118
+
119
+ <owl:Class rdf:about="&compute;MediumServerSize"/>
120
+
121
+
122
+
123
+ <!-- http://geni-orca.renci.org/owl/compute.owl#SmallServerSize -->
124
+
125
+ <owl:Class rdf:about="&compute;SmallServerSize"/>
126
+
127
+
128
+
129
+ <!-- http://geni-orca.renci.org/owl/compute.owl#UnitServer -->
130
+
131
+ <owl:Class rdf:about="&compute;UnitServer"/>
132
+
133
+
134
+
135
+ <!--
136
+ ///////////////////////////////////////////////////////////////////////////////////////
137
+ //
138
+ // Individuals
139
+ //
140
+ ///////////////////////////////////////////////////////////////////////////////////////
141
+ -->
142
+
143
+
144
+
145
+
146
+ <!-- http://geni-orca.renci.org/owl/orca.owl#ORCALargeServerSize -->
147
+
148
+ <compute:LargeServerSize rdf:about="#ORCALargeServerSize">
149
+ <compute:hasUnitServer rdf:resource="#ORCAUnitServer"/>
150
+ </compute:LargeServerSize>
151
+
152
+
153
+
154
+ <!-- http://geni-orca.renci.org/owl/orca.owl#ORCAMediumServerSize -->
155
+
156
+ <compute:MediumServerSize rdf:about="#ORCAMediumServerSize">
157
+ <compute:hasUnitServer rdf:resource="#ORCAUnitServer"/>
158
+ </compute:MediumServerSize>
159
+
160
+
161
+
162
+ <!-- http://geni-orca.renci.org/owl/orca.owl#ORCASmallServerSize -->
163
+
164
+ <compute:SmallServerSize rdf:about="#ORCASmallServerSize">
165
+ <compute:hasUnitServer rdf:resource="#ORCAUnitServer"/>
166
+ </compute:SmallServerSize>
167
+
168
+
169
+
170
+ <!-- http://geni-orca.renci.org/owl/orca.owl#ORCAUnitServer -->
171
+
172
+ <compute:UnitServer rdf:about="#ORCAUnitServer">
173
+ <compute:cpuCapacity rdf:datatype="&xsd;float">1.2</compute:cpuCapacity>
174
+ <compute:memoryCapacity rdf:datatype="&xsd;float">1.7</compute:memoryCapacity>
175
+ </compute:UnitServer>
176
+ </rdf:RDF>
177
+
178
+
179
+
180
+ <!-- Generated by the OWL API (version 2.2.1.1101) http://owlapi.sourceforge.net -->
181
+
data/owl/planetlab.owl ADDED
@@ -0,0 +1,124 @@
1
+ <?xml version="1.0"?>
2
+
3
+
4
+ <!DOCTYPE rdf:RDF [
5
+ <!ENTITY owl "http://www.w3.org/2002/07/owl#" >
6
+ <!ENTITY xsd "http://www.w3.org/2001/XMLSchema#" >
7
+ <!ENTITY rdfs "http://www.w3.org/2000/01/rdf-schema#" >
8
+ <!ENTITY rdf "http://www.w3.org/1999/02/22-rdf-syntax-ns#" >
9
+ <!ENTITY compute "http://geni-orca.renci.org/owl/compute.owl#" >
10
+ ]>
11
+
12
+
13
+ <rdf:RDF xmlns="http://www.semanticweb.org/ontologies/2011/8/planetlab.owl#"
14
+ xml:base="http://www.semanticweb.org/ontologies/2011/8/planetlab.owl"
15
+ xmlns:rdfs="http://www.w3.org/2000/01/rdf-schema#"
16
+ xmlns:owl="http://www.w3.org/2002/07/owl#"
17
+ xmlns:xsd="http://www.w3.org/2001/XMLSchema#"
18
+ xmlns:rdf="http://www.w3.org/1999/02/22-rdf-syntax-ns#"
19
+ xmlns:compute="http://geni-orca.renci.org/owl/compute.owl#">
20
+ <owl:Ontology rdf:about="http://geni-orca.renci.org/owl/planetlab.owl">
21
+ <rdfs:isDefinedBy>RENCI
22
+ UNC-Chapel Hill
23
+ Sep. 8 2011
24
+ ibaldin@renci.org</rdfs:isDefinedBy>
25
+ <rdfs:comment>PlanetLab compute element definitions</rdfs:comment>
26
+ <owl:imports rdf:resource="http://geni-orca.renci.org/owl/compute.owl"/>
27
+ <owl:versionIRI rdf:resource="http://geni-orca.renci.org/owl/planetlab-v1.owl"/>
28
+ <owl:imports rdf:resource="http://geni-orca.renci.org/owl/storage.owl"/>
29
+ </owl:Ontology>
30
+
31
+
32
+
33
+ <!--
34
+ ///////////////////////////////////////////////////////////////////////////////////////
35
+ //
36
+ // Annotation properties
37
+ //
38
+ ///////////////////////////////////////////////////////////////////////////////////////
39
+ -->
40
+
41
+
42
+
43
+
44
+ <!--
45
+ ///////////////////////////////////////////////////////////////////////////////////////
46
+ //
47
+ // Classes
48
+ //
49
+ ///////////////////////////////////////////////////////////////////////////////////////
50
+ -->
51
+
52
+
53
+
54
+
55
+ <!-- http://www.semanticweb.org/ontologies/2011/8/planetlab.owl#PlanetLabCE -->
56
+
57
+ <owl:Class rdf:about="http://www.semanticweb.org/ontologies/2011/8/planetlab.owl#PlanetLabCE">
58
+ <owl:equivalentClass>
59
+ <owl:Class>
60
+ <owl:intersectionOf rdf:parseType="Collection">
61
+ <owl:Class>
62
+ <owl:unionOf rdf:parseType="Collection">
63
+ <owl:Restriction>
64
+ <owl:onProperty rdf:resource="&compute;cpu"/>
65
+ <owl:hasValue rdf:resource="&compute;GenericX86"/>
66
+ </owl:Restriction>
67
+ <owl:Restriction>
68
+ <owl:onProperty rdf:resource="&compute;cpu"/>
69
+ <owl:hasValue rdf:resource="&compute;GenericX86-64"/>
70
+ </owl:Restriction>
71
+ </owl:unionOf>
72
+ </owl:Class>
73
+ <owl:Restriction>
74
+ <owl:onProperty rdf:resource="&compute;computeElementType"/>
75
+ <owl:hasValue rdf:resource="&compute;RackedServer"/>
76
+ </owl:Restriction>
77
+ <owl:Restriction>
78
+ <owl:onProperty rdf:resource="&compute;vmm"/>
79
+ <owl:hasValue rdf:resource="&compute;VServer"/>
80
+ </owl:Restriction>
81
+ </owl:intersectionOf>
82
+ </owl:Class>
83
+ </owl:equivalentClass>
84
+ <rdfs:subClassOf rdf:resource="&compute;ClassifiedComputeElement"/>
85
+ </owl:Class>
86
+
87
+
88
+
89
+ <!-- http://www.semanticweb.org/ontologies/2011/8/planetlab.owl#PlanetLabCluster -->
90
+
91
+ <owl:Class rdf:about="http://www.semanticweb.org/ontologies/2011/8/planetlab.owl#PlanetLabCluster">
92
+ <owl:equivalentClass>
93
+ <owl:Restriction>
94
+ <owl:onProperty rdf:resource="&compute;virtualize"/>
95
+ <owl:someValuesFrom rdf:resource="&compute;VServerCE"/>
96
+ </owl:Restriction>
97
+ </owl:equivalentClass>
98
+ <rdfs:subClassOf rdf:resource="&compute;ServerCloud"/>
99
+ </owl:Class>
100
+
101
+
102
+
103
+ <!--
104
+ ///////////////////////////////////////////////////////////////////////////////////////
105
+ //
106
+ // Individuals
107
+ //
108
+ ///////////////////////////////////////////////////////////////////////////////////////
109
+ -->
110
+
111
+
112
+
113
+
114
+ <!-- http://www.semanticweb.org/ontologies/2011/8/planetlab.owl#PlanetLabCE -->
115
+
116
+ <owl:NamedIndividual rdf:about="http://www.semanticweb.org/ontologies/2011/8/planetlab.owl#PlanetLabCE">
117
+ <rdf:type rdf:resource="&compute;ClassifiedComputeElementInstance"/>
118
+ </owl:NamedIndividual>
119
+ </rdf:RDF>
120
+
121
+
122
+
123
+ <!-- Generated by the OWL API (version 3.2.3.22702) http://owlapi.sourceforge.net -->
124
+