active-fedora 6.8.0 → 7.0.0.pre1

Sign up to get free protection for your applications and to get access to all the features.
Files changed (215) hide show
  1. checksums.yaml +4 -4
  2. data/.gitignore +1 -0
  3. data/.travis.yml +15 -5
  4. data/CONTRIBUTING.md +2 -0
  5. data/Gemfile +0 -2
  6. data/History.txt +2 -32
  7. data/README.md +143 -0
  8. data/Rakefile +5 -7
  9. data/active-fedora.gemspec +9 -9
  10. data/gemfiles/rails3.gemfile +11 -0
  11. data/gemfiles/rails4.gemfile +10 -0
  12. data/lib/active_fedora.rb +31 -4
  13. data/lib/active_fedora/association_relation.rb +18 -0
  14. data/lib/active_fedora/associations.rb +38 -171
  15. data/lib/active_fedora/associations/association.rb +163 -0
  16. data/lib/active_fedora/associations/association_scope.rb +39 -0
  17. data/lib/active_fedora/associations/belongs_to_association.rb +47 -25
  18. data/lib/active_fedora/associations/builder/association.rb +55 -0
  19. data/lib/active_fedora/associations/builder/belongs_to.rb +100 -0
  20. data/lib/active_fedora/associations/builder/collection_association.rb +56 -0
  21. data/lib/active_fedora/associations/builder/has_and_belongs_to_many.rb +30 -0
  22. data/lib/active_fedora/associations/builder/has_many.rb +63 -0
  23. data/lib/active_fedora/associations/builder/singular_association.rb +32 -0
  24. data/lib/active_fedora/associations/{association_collection.rb → collection_association.rb} +203 -53
  25. data/lib/active_fedora/associations/collection_proxy.rb +862 -0
  26. data/lib/active_fedora/associations/has_and_belongs_to_many_association.rb +35 -25
  27. data/lib/active_fedora/associations/has_many_association.rb +36 -11
  28. data/lib/active_fedora/associations/singular_association.rb +62 -0
  29. data/lib/active_fedora/attributes.rb +43 -139
  30. data/lib/active_fedora/autosave_association.rb +317 -0
  31. data/lib/active_fedora/base.rb +10 -327
  32. data/lib/active_fedora/callbacks.rb +1 -3
  33. data/lib/active_fedora/content_model.rb +16 -0
  34. data/lib/active_fedora/core.rb +151 -0
  35. data/lib/active_fedora/datastream_attribute.rb +76 -0
  36. data/lib/active_fedora/datastream_hash.rb +8 -13
  37. data/lib/active_fedora/datastreams.rb +39 -26
  38. data/lib/active_fedora/digital_object.rb +2 -2
  39. data/lib/active_fedora/fedora_attributes.rb +45 -0
  40. data/lib/active_fedora/fixture_loader.rb +1 -1
  41. data/lib/active_fedora/indexing.rb +6 -1
  42. data/lib/active_fedora/model.rb +0 -17
  43. data/lib/active_fedora/nested_attributes.rb +2 -2
  44. data/lib/active_fedora/null_relation.rb +7 -0
  45. data/lib/active_fedora/om_datastream.rb +3 -4
  46. data/lib/active_fedora/persistence.rb +41 -29
  47. data/lib/active_fedora/querying.rb +2 -163
  48. data/lib/active_fedora/rdf.rb +1 -0
  49. data/lib/active_fedora/rdf/indexing.rb +67 -0
  50. data/lib/active_fedora/rdf_datastream.rb +2 -50
  51. data/lib/active_fedora/rdf_node.rb +12 -7
  52. data/lib/active_fedora/rdf_node/term_proxy.rb +30 -21
  53. data/lib/active_fedora/rdfxml_rdf_datastream.rb +1 -1
  54. data/lib/active_fedora/reflection.rb +163 -20
  55. data/lib/active_fedora/relation.rb +33 -130
  56. data/lib/active_fedora/relation/calculations.rb +19 -0
  57. data/lib/active_fedora/relation/delegation.rb +22 -0
  58. data/lib/active_fedora/relation/finder_methods.rb +247 -0
  59. data/lib/active_fedora/relation/merger.rb +22 -0
  60. data/lib/active_fedora/relation/query_methods.rb +58 -0
  61. data/lib/active_fedora/relation/spawn_methods.rb +46 -0
  62. data/lib/active_fedora/relationship_graph.rb +0 -2
  63. data/lib/active_fedora/rels_ext_datastream.rb +1 -4
  64. data/lib/active_fedora/rubydora_connection.rb +1 -1
  65. data/lib/active_fedora/scoping.rb +20 -0
  66. data/lib/active_fedora/scoping/default.rb +38 -0
  67. data/lib/active_fedora/scoping/named.rb +32 -0
  68. data/lib/active_fedora/semantic_node.rb +54 -106
  69. data/lib/active_fedora/serialization.rb +19 -0
  70. data/lib/active_fedora/sharding.rb +58 -0
  71. data/lib/active_fedora/solr_digital_object.rb +15 -5
  72. data/lib/active_fedora/solr_instance_loader.rb +1 -1
  73. data/lib/active_fedora/solr_service.rb +1 -1
  74. data/lib/active_fedora/unsaved_digital_object.rb +6 -4
  75. data/lib/active_fedora/version.rb +1 -1
  76. data/lib/tasks/active_fedora.rake +3 -0
  77. data/lib/tasks/active_fedora_dev.rake +6 -5
  78. data/spec/config_helper.rb +14 -14
  79. data/spec/integration/associations_spec.rb +168 -455
  80. data/spec/integration/attributes_spec.rb +12 -11
  81. data/spec/integration/auditable_spec.rb +11 -11
  82. data/spec/integration/autosave_association_spec.rb +25 -0
  83. data/spec/integration/base_spec.rb +163 -163
  84. data/spec/integration/belongs_to_association_spec.rb +166 -0
  85. data/spec/integration/bug_spec.rb +7 -7
  86. data/spec/integration/collection_association_spec.rb +58 -0
  87. data/spec/integration/complex_rdf_datastream_spec.rb +88 -88
  88. data/spec/integration/datastream_collections_spec.rb +69 -69
  89. data/spec/integration/datastream_spec.rb +43 -43
  90. data/spec/integration/datastreams_spec.rb +63 -63
  91. data/spec/integration/delete_all_spec.rb +46 -39
  92. data/spec/integration/fedora_solr_sync_spec.rb +5 -5
  93. data/spec/integration/field_to_solr_name_spec.rb +34 -0
  94. data/spec/integration/full_featured_model_spec.rb +100 -101
  95. data/spec/integration/has_and_belongs_to_many_associations_spec.rb +341 -0
  96. data/spec/integration/has_many_associations_spec.rb +172 -24
  97. data/spec/integration/json_serialization_spec.rb +31 -0
  98. data/spec/integration/load_from_solr_spec.rb +48 -0
  99. data/spec/integration/model_spec.rb +35 -40
  100. data/spec/integration/nested_attribute_spec.rb +42 -43
  101. data/spec/integration/ntriples_datastream_spec.rb +131 -113
  102. data/spec/integration/om_datastream_spec.rb +67 -67
  103. data/spec/integration/persistence_spec.rb +7 -7
  104. data/spec/integration/rdf_nested_attributes_spec.rb +56 -56
  105. data/spec/integration/relation_delegation_spec.rb +26 -25
  106. data/spec/integration/relation_spec.rb +42 -0
  107. data/spec/integration/rels_ext_datastream_spec.rb +20 -20
  108. data/spec/integration/scoped_query_spec.rb +61 -51
  109. data/spec/integration/solr_instance_loader_spec.rb +5 -5
  110. data/spec/integration/solr_service_spec.rb +46 -46
  111. data/spec/samples/hydra-mods_article_datastream.rb +334 -334
  112. data/spec/samples/hydra-rights_metadata_datastream.rb +57 -57
  113. data/spec/samples/marpa-dc_datastream.rb +17 -17
  114. data/spec/samples/models/audio_record.rb +16 -16
  115. data/spec/samples/models/image.rb +2 -2
  116. data/spec/samples/models/mods_article.rb +5 -5
  117. data/spec/samples/models/oral_history.rb +18 -18
  118. data/spec/samples/models/seminar.rb +24 -24
  119. data/spec/samples/models/seminar_audio_file.rb +17 -17
  120. data/spec/samples/oral_history_sample_model.rb +21 -21
  121. data/spec/samples/special_thing.rb +14 -14
  122. data/spec/spec_helper.rb +11 -7
  123. data/spec/support/an_active_model.rb +2 -8
  124. data/spec/support/freeze_mocks.rb +12 -0
  125. data/spec/support/mock_fedora.rb +17 -16
  126. data/spec/unit/active_fedora_spec.rb +58 -60
  127. data/spec/unit/attributes_spec.rb +314 -0
  128. data/spec/unit/base_active_model_spec.rb +28 -27
  129. data/spec/unit/base_cma_spec.rb +5 -5
  130. data/spec/unit/base_datastream_management_spec.rb +27 -27
  131. data/spec/unit/base_extra_spec.rb +76 -48
  132. data/spec/unit/base_spec.rb +277 -348
  133. data/spec/unit/callback_spec.rb +18 -19
  134. data/spec/unit/code_configurator_spec.rb +17 -17
  135. data/spec/unit/config_spec.rb +8 -16
  136. data/spec/unit/content_model_spec.rb +79 -60
  137. data/spec/unit/datastream_collections_spec.rb +229 -229
  138. data/spec/unit/datastream_spec.rb +51 -63
  139. data/spec/unit/datastreams_spec.rb +87 -87
  140. data/spec/unit/file_configurator_spec.rb +217 -217
  141. data/spec/unit/has_and_belongs_to_many_collection_spec.rb +44 -25
  142. data/spec/unit/has_many_collection_spec.rb +26 -8
  143. data/spec/unit/inheritance_spec.rb +13 -12
  144. data/spec/unit/model_spec.rb +39 -45
  145. data/spec/unit/nom_datastream_spec.rb +15 -15
  146. data/spec/unit/ntriples_datastream_spec.rb +123 -118
  147. data/spec/unit/om_datastream_spec.rb +227 -233
  148. data/spec/unit/persistence_spec.rb +34 -15
  149. data/spec/unit/predicates_spec.rb +73 -73
  150. data/spec/unit/property_spec.rb +17 -9
  151. data/spec/unit/qualified_dublin_core_datastream_spec.rb +33 -33
  152. data/spec/unit/query_spec.rb +222 -198
  153. data/spec/unit/rdf_datastream_spec.rb +21 -28
  154. data/spec/unit/rdf_list_nested_attributes_spec.rb +34 -34
  155. data/spec/unit/rdf_list_spec.rb +65 -64
  156. data/spec/unit/rdf_node_spec.rb +7 -7
  157. data/spec/unit/rdf_xml_writer_spec.rb +10 -10
  158. data/spec/unit/rdfxml_rdf_datastream_spec.rb +27 -27
  159. data/spec/unit/relationship_graph_spec.rb +51 -51
  160. data/spec/unit/rels_ext_datastream_spec.rb +68 -74
  161. data/spec/unit/rspec_matchers/belong_to_associated_active_fedora_object_matcher_spec.rb +15 -15
  162. data/spec/unit/rspec_matchers/have_many_associated_active_fedora_objects_matcher_spec.rb +15 -15
  163. data/spec/unit/rspec_matchers/have_predicate_matcher_spec.rb +15 -15
  164. data/spec/unit/rspec_matchers/match_fedora_datastream_matcher_spec.rb +12 -12
  165. data/spec/unit/rubydora_connection_spec.rb +5 -5
  166. data/spec/unit/semantic_node_spec.rb +48 -107
  167. data/spec/unit/serializers_spec.rb +4 -4
  168. data/spec/unit/service_definitions_spec.rb +26 -26
  169. data/spec/unit/simple_datastream_spec.rb +17 -17
  170. data/spec/unit/solr_config_options_spec.rb +29 -28
  171. data/spec/unit/solr_digital_object_spec.rb +17 -25
  172. data/spec/unit/solr_service_spec.rb +95 -82
  173. data/spec/unit/unsaved_digital_object_spec.rb +24 -23
  174. data/spec/unit/validations_spec.rb +21 -21
  175. metadata +110 -159
  176. data/.rspec +0 -1
  177. data/.rubocop.yml +0 -1
  178. data/.rubocop_todo.yml +0 -938
  179. data/CONSOLE_GETTING_STARTED.textile +0 -1
  180. data/NOKOGIRI_DATASTREAMS.textile +0 -1
  181. data/README.textile +0 -116
  182. data/lib/active_fedora/associations/association_proxy.rb +0 -178
  183. data/lib/active_fedora/delegating.rb +0 -72
  184. data/lib/active_fedora/nokogiri_datastream.rb +0 -11
  185. data/spec/integration/delegating_spec.rb +0 -59
  186. data/spec/rails3_test_app/.gitignore +0 -4
  187. data/spec/rails3_test_app/.rspec +0 -1
  188. data/spec/rails3_test_app/Gemfile +0 -40
  189. data/spec/rails3_test_app/Rakefile +0 -7
  190. data/spec/rails3_test_app/app/controllers/application_controller.rb +0 -3
  191. data/spec/rails3_test_app/app/helpers/application_helper.rb +0 -2
  192. data/spec/rails3_test_app/app/views/layouts/application.html.erb +0 -14
  193. data/spec/rails3_test_app/config.ru +0 -4
  194. data/spec/rails3_test_app/config/application.rb +0 -42
  195. data/spec/rails3_test_app/config/boot.rb +0 -6
  196. data/spec/rails3_test_app/config/database.yml +0 -22
  197. data/spec/rails3_test_app/config/environment.rb +0 -5
  198. data/spec/rails3_test_app/config/environments/development.rb +0 -25
  199. data/spec/rails3_test_app/config/environments/production.rb +0 -49
  200. data/spec/rails3_test_app/config/environments/test.rb +0 -35
  201. data/spec/rails3_test_app/config/initializers/backtrace_silencers.rb +0 -7
  202. data/spec/rails3_test_app/config/initializers/inflections.rb +0 -10
  203. data/spec/rails3_test_app/config/initializers/mime_types.rb +0 -5
  204. data/spec/rails3_test_app/config/initializers/secret_token.rb +0 -7
  205. data/spec/rails3_test_app/config/initializers/session_store.rb +0 -8
  206. data/spec/rails3_test_app/config/locales/en.yml +0 -5
  207. data/spec/rails3_test_app/config/routes.rb +0 -58
  208. data/spec/rails3_test_app/db/seeds.rb +0 -7
  209. data/spec/rails3_test_app/run_tests +0 -3
  210. data/spec/rails3_test_app/script/rails +0 -6
  211. data/spec/rails3_test_app/spec/spec_helper.rb +0 -27
  212. data/spec/rails3_test_app/spec/unit/rails_3_init.rb +0 -15
  213. data/spec/unit/association_proxy_spec.rb +0 -12
  214. data/spec/unit/base_delegate_spec.rb +0 -197
  215. data/spec/unit/base_delegate_to_spec.rb +0 -73
@@ -1,28 +1,22 @@
1
1
  require 'spec_helper'
2
2
 
3
- require 'active_fedora'
4
- require 'nokogiri'
5
-
6
3
  describe ActiveFedora::Datastream do
7
-
4
+
8
5
  before(:each) do
9
6
  @test_object = ActiveFedora::Base.new
10
7
  @test_datastream = ActiveFedora::Datastream.new(@test_object.inner_object, 'abcd')
11
- @test_datastream.content = 'hi there'
8
+ @test_datastream.content = "hi there"
12
9
  end
13
10
 
14
- describe '#metadata?' do
15
- subject { super().metadata? }
16
- it { is_expected.to be_falsey}
17
- end
11
+ its(:metadata?) { should be_false}
18
12
 
19
- it 'should escape dots in to_param' do
20
- allow(@test_datastream).to receive(:dsid).and_return('foo.bar')
21
- expect(@test_datastream.to_param).to eq('foo%2ebar')
13
+ it "should escape dots in to_param" do
14
+ @test_datastream.stub(:dsid).and_return('foo.bar')
15
+ @test_datastream.to_param.should == 'foo%2ebar'
22
16
  end
23
-
24
- it 'should be inspectable' do
25
- expect(@test_datastream.inspect).to match /#<ActiveFedora::Datastream @pid=\"\" @dsid=\"abcd\" @controlGroup=\"M\" changed=\"true\" @mimeType=\"\" >/
17
+
18
+ it "should be inspectable" do
19
+ @test_datastream.inspect.should match /#<ActiveFedora::Datastream @pid=\"\" @dsid=\"abcd\" @controlGroup=\"M\" changed=\"true\" @mimeType=\"\" >/
26
20
  end
27
21
 
28
22
  describe '#validate_content_present' do
@@ -31,65 +25,59 @@ describe ActiveFedora::Datastream do
31
25
  @test_datastream.dsLocation = nil
32
26
  end
33
27
 
34
- it 'should expect content on an Inline (X) datastream' do
28
+ it "should expect content on an Inline (X) datastream" do
35
29
  @test_datastream.controlGroup = 'X'
36
- @test_datastream.dsLocation = 'http://example.com/test/content/abcd'
37
- expect(@test_datastream.validate_content_present).to be_falsey
38
- @test_datastream.content = '<foo><xmlelement/></foo>'
39
- expect(@test_datastream.validate_content_present).to be_truthy
30
+ @test_datastream.dsLocation = "http://example.com/test/content/abcd"
31
+ @test_datastream.validate_content_present.should be_false
32
+ @test_datastream.content = "<foo><xmlelement/></foo>"
33
+ @test_datastream.validate_content_present.should be_true
40
34
  end
41
35
 
42
- context 'on a Managed (M) datastream' do
43
- before { @test_datastream.controlGroup = 'M' }
44
- it 'should be false when neither dsLocation nor content is present' do
45
- expect(@test_datastream.validate_content_present).to be_falsey
46
- end
47
- it 'should be true when dsLocation is present' do
48
- @test_datastream.dsLocation = 'http://example.com/test/content/abcd'
49
- expect(@test_datastream.validate_content_present).to be_truthy
50
- end
51
- it 'should be true when content is present' do
52
- @test_datastream.content = '<foo><xmlelement/></foo>'
53
- expect(@test_datastream.validate_content_present).to be_truthy
54
- end
36
+ it "should expect content on a Managed (M) datastream" do
37
+ @test_datastream.controlGroup = 'M'
38
+ @test_datastream.dsLocation = "http://example.com/test/content/abcd"
39
+ @test_datastream.validate_content_present.should be_false
40
+ @test_datastream.content = "<foo><xmlelement/></foo>"
41
+ @test_datastream.validate_content_present.should be_true
42
+ @test_datastream.should_not be_external
55
43
  end
56
44
 
57
- it 'should expect a dsLocation on an External (E) datastream' do
45
+ it "should expect a dsLocation on an External (E) datastream" do
58
46
  @test_datastream.controlGroup = 'E'
59
- @test_datastream.content = '<foo><xmlelement/></foo>'
60
- expect(@test_datastream.validate_content_present).to be_falsey
61
- @test_datastream.dsLocation = 'http://example.com/test/content/abcd'
62
- expect(@test_datastream.validate_content_present).to be_truthy
63
- expect(@test_datastream).to be_external
47
+ @test_datastream.content = "<foo><xmlelement/></foo>"
48
+ @test_datastream.validate_content_present.should be_false
49
+ @test_datastream.dsLocation = "http://example.com/test/content/abcd"
50
+ @test_datastream.validate_content_present.should be_true
51
+ @test_datastream.should be_external
64
52
  end
65
53
 
66
- it 'should expect a dsLocation on a Redirect (R) datastream' do
54
+ it "should expect a dsLocation on a Redirect (R) datastream" do
67
55
  @test_datastream.controlGroup = 'R'
68
- @test_datastream.content = '<foo><xmlelement/></foo>'
69
- expect(@test_datastream.validate_content_present).to be_falsey
70
- @test_datastream.dsLocation = 'http://example.com/test/content/abcd'
71
- expect(@test_datastream.validate_content_present).to be_truthy
56
+ @test_datastream.content = "<foo><xmlelement/></foo>"
57
+ @test_datastream.validate_content_present.should be_false
58
+ @test_datastream.dsLocation = "http://example.com/test/content/abcd"
59
+ @test_datastream.validate_content_present.should be_true
72
60
  end
73
61
  end
74
-
75
- it 'should have mimeType accessors' do
62
+
63
+ it "should have mimeType accessors" do
76
64
  ds1 = ActiveFedora::Datastream.new
77
- ds1.mimeType = 'text/foo'
78
- expect(ds1.mimeType).to eq('text/foo')
65
+ ds1.mimeType = "text/foo"
66
+ ds1.mimeType.should == "text/foo"
79
67
  ds2 = ActiveFedora::Datastream.new
80
- ds2.mimeType = 'text/bar'
81
- expect(ds2.mimeType).to eq('text/bar')
68
+ ds2.mimeType = "text/bar"
69
+ ds2.mimeType.should == "text/bar"
82
70
  end
83
71
 
84
- describe '.size' do
85
- it 'should lazily load the datastream size attribute from the fedora repository' do
72
+ describe ".size" do
73
+ it "should lazily load the datastream size attribute from the fedora repository" do
86
74
  ds_profile = <<-EOS
87
- <datastreamProfile
88
- xmlns=\"http://www.fedora.info/definitions/1/0/management/\"
89
- xmlns:xsd=\"http://www.w3.org/2001/XMLSchema\"
90
- xmlns:xsi=\"http://www.w3.org/2001/XMLSchema-instance\"
91
- xsi:schemaLocation=\"http://www.fedora.info/definitions/1/0/management/ http://www.fedora.info/definitions/1/0/datastreamProfile.xsd\"
92
- pid=\"#{@test_object.pid}\"
75
+ <datastreamProfile
76
+ xmlns=\"http://www.fedora.info/definitions/1/0/management/\"
77
+ xmlns:xsd=\"http://www.w3.org/2001/XMLSchema\"
78
+ xmlns:xsi=\"http://www.w3.org/2001/XMLSchema-instance\"
79
+ xsi:schemaLocation=\"http://www.fedora.info/definitions/1/0/management/ http://www.fedora.info/definitions/1/0/datastreamProfile.xsd\"
80
+ pid=\"#{@test_object.pid}\"
93
81
  dsID=\"#{@test_datastream.dsid}\" >
94
82
  <dsLabel></dsLabel>
95
83
  <dsVersionID>#{@test_datastream.dsid}.1</dsVersionID>
@@ -109,13 +97,13 @@ describe ActiveFedora::Datastream do
109
97
  EOS
110
98
 
111
99
  mock_repo = Rubydora::Repository.new
112
- allow(@test_object.inner_object).to receive(:repository).and_return(mock_repo)
113
- expect(mock_repo.api).to receive(:datastream).with(:dsid => 'abcd', :pid => @test_object.pid).and_return(ds_profile)
114
- expect(@test_datastream.size).to eq(9999)
100
+ @test_object.inner_object.stub(:repository).and_return(mock_repo)
101
+ mock_repo.api.should_receive(:datastream).with(:dsid => 'abcd', :pid => @test_object.pid).and_return(ds_profile)
102
+ @test_datastream.size.should == 9999
115
103
  end
116
104
 
117
- it 'should default to an empty string if ds has not been saved' do
118
- expect(@test_datastream.size).to be_nil
105
+ it "should default to an empty string if ds has not been saved" do
106
+ @test_datastream.size.should be_nil
119
107
  end
120
108
  end
121
109
  end
@@ -6,21 +6,31 @@ describe ActiveFedora::Datastreams do
6
6
  describe '.has_metadata' do
7
7
  before do
8
8
  class FooHistory < ActiveFedora::Base
9
- has_metadata :name => 'dsid'
9
+ has_metadata :name => 'dsid', type: ActiveFedora::SimpleDatastream
10
10
  has_metadata 'complex_ds', :versionable => true, :autocreate => true, :type => 'Z', :label => 'My Label', :control_group => 'Z'
11
11
  end
12
12
  end
13
13
 
14
- it 'should have a ds_specs entry' do
15
- expect(FooHistory.ds_specs).to have_key('dsid')
14
+ it "should have a ds_specs entry" do
15
+ FooHistory.ds_specs.should have_key('dsid')
16
16
  end
17
17
 
18
- it 'should have reasonable defaults' do
19
- expect(FooHistory.ds_specs['dsid']).to include(:autocreate => false)
18
+ it "should have reasonable defaults" do
19
+ FooHistory.ds_specs['dsid'].should include(:autocreate => false)
20
20
  end
21
21
 
22
- it 'should let you override defaults' do
23
- expect(FooHistory.ds_specs['complex_ds']).to include(:versionable => true, :autocreate => true, :type => 'Z', :label => 'My Label', :control_group => 'Z')
22
+ it "should let you override defaults" do
23
+ FooHistory.ds_specs['complex_ds'].should include(:versionable => true, :autocreate => true, :type => 'Z', :label => 'My Label', :control_group => 'Z')
24
+ end
25
+
26
+ it "should raise an error if you don't give a type" do
27
+ expect{ FooHistory.has_metadata "bob" }.to raise_error ArgumentError,
28
+ "You must provide a :type property for the metadata datastream 'bob'"
29
+ end
30
+
31
+ it "should raise an error if you don't give a dsid" do
32
+ expect{ FooHistory.has_metadata type: ActiveFedora::SimpleDatastream }.to raise_error ArgumentError,
33
+ "You must provide a name (dsid) for the metadata datastream"
24
34
  end
25
35
  end
26
36
 
@@ -32,90 +42,86 @@ describe ActiveFedora::Datastreams do
32
42
  end
33
43
  end
34
44
 
35
- it 'should have reasonable defaults' do
36
- expect(FooHistory.ds_specs['dsid']).to include(:type => ActiveFedora::Datastream, :label => 'File Datastream', :control_group => 'M')
37
- expect(FooHistory.ds_specs['another']).to include(:type => ActiveFedora::Datastream, :label => 'File Datastream', :control_group => 'M')
45
+ it "should have reasonable defaults" do
46
+ FooHistory.ds_specs['dsid'].should include(:type => ActiveFedora::Datastream, :label => 'File Datastream', :control_group => 'M')
47
+ FooHistory.ds_specs['another'].should include(:type => ActiveFedora::Datastream, :label => 'File Datastream', :control_group => 'M')
38
48
  end
39
49
  end
40
50
 
41
- describe '#serialize_datastreams' do
42
- it 'should touch each datastream' do
51
+ describe "#serialize_datastreams" do
52
+ it "should touch each datastream" do
43
53
  m1 = double()
44
54
  m2 = double()
45
55
 
46
- expect(m1).to receive(:serialize!)
47
- expect(m2).to receive(:serialize!)
56
+ m1.should_receive(:serialize!)
57
+ m2.should_receive(:serialize!)
48
58
  subject.stub(:datastreams => { :m1 => m1, :m2 => m2})
49
59
  subject.serialize_datastreams
50
60
  end
51
61
  end
52
62
 
53
- describe '#add_disseminator_location_to_datastreams' do
54
- it 'should infer dsLocations for E datastreams without hitting Fedora' do
55
-
56
- mock_specs = {:e => { :disseminator => 'xyz' }}
63
+ describe "#add_disseminator_location_to_datastreams" do
64
+ it "should infer dsLocations for E datastreams without hitting Fedora" do
65
+
66
+ mock_specs = {'e' => { :disseminator => 'xyz' }}
57
67
  mock_ds = double(:controlGroup => 'E')
58
68
  ActiveFedora::Base.stub(:ds_specs => mock_specs)
59
69
  ActiveFedora.stub(:config_for_environment => { :url => 'http://localhost'})
60
- subject.stub(:pid => 'test:1', :datastreams => {:e => mock_ds})
61
- expect(mock_ds).to receive(:dsLocation=).with('http://localhost/objects/test:1/methods/xyz')
70
+ subject.stub(:pid => 'test:1', :datastreams => {'e' => mock_ds})
71
+ mock_ds.should_receive(:dsLocation=).with("http://localhost/objects/test:1/methods/xyz")
62
72
  subject.add_disseminator_location_to_datastreams
63
73
  end
64
74
  end
65
75
 
66
- describe '#corresponding_datastream_name' do
67
- before(:each) do
68
- subject.stub(:datastreams => { 'abc' => double(), 'a_b_c' => double(), 'a-b' => double()})
76
+ describe ".name_for_dsid" do
77
+ it "should use the name" do
78
+ ActiveFedora::Base.send(:name_for_dsid, 'abc').should == 'abc'
69
79
  end
70
80
 
71
- it 'should use the name, if it exists' do
72
- expect(subject.corresponding_datastream_name('abc')).to eq('abc')
81
+ it "should use the name" do
82
+ ActiveFedora::Base.send(:name_for_dsid, 'ARCHIVAL_XML').should == 'ARCHIVAL_XML'
73
83
  end
74
84
 
75
- it 'should hash-erize underscores' do
76
- expect(subject.corresponding_datastream_name('a_b')).to eq('a-b')
85
+ it "should use the name" do
86
+ ActiveFedora::Base.send(:name_for_dsid, 'descMetadata').should == 'descMetadata'
77
87
  end
78
88
 
79
- it 'should return nil if nothing matches' do
80
- expect(subject.corresponding_datastream_name('xyz')).to be_nil
89
+ it "should hash-erize underscores" do
90
+ ActiveFedora::Base.send(:name_for_dsid, 'a-b').should == 'a_b'
81
91
  end
82
92
  end
83
-
84
- describe '#datastreams' do
85
- it 'should return the datastream hash proxy' do
86
- allow(subject).to receive(:load_datastreams)
87
- expect(subject.datastreams).to be_a_kind_of(ActiveFedora::DatastreamHash)
88
- end
89
-
90
- it 'should round-trip to/from YAML' do
91
- expect(YAML.load(subject.datastreams.to_yaml).inspect).to eq(subject.datastreams.inspect)
93
+
94
+ describe "#datastreams" do
95
+ it "should return the datastream hash proxy" do
96
+ subject.stub(:load_datastreams)
97
+ subject.datastreams.should be_a_kind_of(ActiveFedora::DatastreamHash)
92
98
  end
93
99
  end
94
100
 
95
- describe '#configure_datastream' do
96
- it 'should look up the ds_spec' do
101
+ describe "#configure_datastream" do
102
+ it "should look up the ds_spec" do
97
103
  mock_dsspec = { :type => nil }
98
104
  subject.stub(:ds_specs => {'abc' => mock_dsspec})
99
105
  subject.configure_datastream(double(:dsid => 'abc'))
100
106
  end
101
107
 
102
- it 'should be ok if there is no ds spec' do
108
+ it "should be ok if there is no ds spec" do
103
109
  mock_dsspec = double()
104
110
  subject.stub(:ds_specs => {})
105
111
  subject.configure_datastream(double(:dsid => 'abc'))
106
112
  end
107
113
 
108
- it 'should configure RelsExtDatastream' do
114
+ it "should configure RelsExtDatastream" do
109
115
  mock_dsspec = { :type => ActiveFedora::RelsExtDatastream }
110
116
  subject.stub(:ds_specs => {'abc' => mock_dsspec})
111
117
 
112
118
  ds = double(:dsid => 'abc')
113
- expect(ds).to receive(:model=).with(subject)
119
+ ds.should_receive(:model=).with(subject)
114
120
 
115
121
  subject.configure_datastream(ds)
116
122
  end
117
123
 
118
- it 'should run a Proc' do
124
+ it "should run a Proc" do
119
125
  ds = double(:dsid => 'abc')
120
126
  @count = 0
121
127
  mock_dsspec = { :block => lambda { |x| @count += 1 } }
@@ -128,110 +134,104 @@ describe ActiveFedora::Datastreams do
128
134
  end
129
135
  end
130
136
 
131
- describe '#datastream_from_spec' do
132
- it 'should fetch the rubydora datastream' do
133
- expect(subject.inner_object).to receive(:datastream_object_for).with('dsid', {}, {})
137
+ describe "#datastream_from_spec" do
138
+ it "should fetch the rubydora datastream" do
139
+ subject.inner_object.should_receive(:datastream_object_for).with('dsid', {})
134
140
  subject.datastream_from_spec({}, 'dsid')
135
141
  end
136
142
  end
137
143
 
138
- describe '#load_datastreams' do
139
- it 'should load and configure persisted datastreams and should add any datastreams left over in the ds specs' do
140
- skip
141
- end
142
- end
143
-
144
- describe '#add_datastream' do
145
- it 'should add the datastream to the object' do
144
+ describe "#add_datastream" do
145
+ it "should add the datastream to the object" do
146
146
  ds = double(:dsid => 'Abc')
147
147
  subject.add_datastream(ds)
148
- expect(subject.datastreams['Abc']).to eq(ds)
148
+ subject.datastreams['Abc'].should == ds
149
149
  end
150
150
 
151
- it 'should mint a dsid' do
151
+ it "should mint a dsid" do
152
152
  ds = ActiveFedora::Datastream.new
153
- expect(subject.add_datastream(ds)).to eq('DS1')
153
+ subject.add_datastream(ds).should == 'DS1'
154
154
  end
155
155
  end
156
156
 
157
- describe '#metadata_streams' do
158
- it 'should only be metadata datastreams' do
157
+ describe "#metadata_streams" do
158
+ it "should only be metadata datastreams" do
159
159
  ds1 = double(:metadata? => true)
160
160
  ds2 = double(:metadata? => true)
161
161
  ds3 = double(:metadata? => true)
162
162
  relsextds = ActiveFedora::RelsExtDatastream.new
163
163
  file_ds = double(:metadata? => false)
164
164
  subject.stub(:datastreams => {:a => ds1, :b => ds2, :c => ds3, :d => relsextds, :e => file_ds})
165
- expect(subject.metadata_streams).to include(ds1, ds2, ds3)
166
- expect(subject.metadata_streams).not_to include(relsextds)
167
- expect(subject.metadata_streams).not_to include(file_ds)
165
+ subject.metadata_streams.should include(ds1, ds2, ds3)
166
+ subject.metadata_streams.should_not include(relsextds)
167
+ subject.metadata_streams.should_not include(file_ds)
168
168
  end
169
169
  end
170
170
 
171
- describe '#generate_dsid' do
172
- it 'should create an autoincrementing dsid' do
173
- expect(subject.generate_dsid('FOO')).to eq('FOO1')
171
+ describe "#generate_dsid" do
172
+ it "should create an autoincrementing dsid" do
173
+ subject.generate_dsid('FOO').should == 'FOO1'
174
174
  end
175
175
 
176
- it 'should start from the highest existin dsid' do
176
+ it "should start from the highest existin dsid" do
177
177
  subject.stub(:datastreams => {'FOO56' => double()})
178
- expect(subject.generate_dsid('FOO')).to eq('FOO57')
178
+ subject.generate_dsid('FOO').should == 'FOO57'
179
179
  end
180
180
  end
181
181
 
182
- describe '#relsext' do
183
- it 'should be the RELS-EXT datastream' do
182
+ describe "#relsext" do
183
+ it "should be the RELS-EXT datastream" do
184
184
  m = double
185
185
  subject.stub(:datastreams => { 'RELS-EXT' => m})
186
- expect(subject.rels_ext).to eq(m)
186
+ subject.rels_ext.should == m
187
187
  end
188
188
 
189
- it 'should make one up otherwise' do
189
+ it "should make one up otherwise" do
190
190
  subject.stub(:datastreams => {})
191
191
 
192
- expect(subject.rels_ext).to be_a_kind_of(ActiveFedora::RelsExtDatastream)
192
+ subject.rels_ext.should be_a_kind_of(ActiveFedora::RelsExtDatastream)
193
193
  end
194
194
  end
195
195
 
196
- describe '#add_file_datastream' do
196
+ describe "#add_file_datastream" do
197
197
  # tested elsewhere :/
198
- end
198
+ end
199
199
 
200
- describe '#create_datastream' do
201
- it 'should mint a DSID' do
200
+ describe "#create_datastream" do
201
+ it "should mint a DSID" do
202
202
  ds = subject.create_datastream(ActiveFedora::Datastream, nil, {})
203
- expect(ds.dsid).to eq('DS1')
203
+ ds.dsid.should == 'DS1'
204
204
  end
205
205
 
206
- it 'should raise an argument error if the supplied dsid is nonsense' do
206
+ it "should raise an argument error if the supplied dsid is nonsense" do
207
207
  expect { subject.create_datastream(ActiveFedora::Datastream, 0) }.to raise_error(ArgumentError)
208
208
  end
209
209
 
210
- it 'should try to get a mime type from the blob' do
210
+ it "should try to get a mime type from the blob" do
211
211
  mock_file = double(:content_type => 'x-application/asdf')
212
212
  ds = subject.create_datastream(ActiveFedora::Datastream, nil, {:blob => mock_file})
213
- expect(ds.mimeType).to eq('x-application/asdf')
213
+ ds.mimeType.should == 'x-application/asdf'
214
214
  end
215
215
 
216
- it 'should provide a default mime type' do
216
+ it "should provide a default mime type" do
217
217
  mock_file = double()
218
218
  ds = subject.create_datastream(ActiveFedora::Datastream, nil, {:blob => mock_file})
219
- expect(ds.mimeType).to eq('application/octet-stream')
219
+ ds.mimeType.should == 'application/octet-stream'
220
220
  end
221
221
 
222
- it 'should use the filename as a default label' do
222
+ it "should use the filename as a default label" do
223
223
  mock_file = double(:path => '/asdf/fdsa')
224
224
  ds = subject.create_datastream(ActiveFedora::Datastream, nil, {:blob => mock_file})
225
- expect(ds.dsLabel).to eq('fdsa')
225
+ ds.dsLabel.should == 'fdsa'
226
226
  end
227
227
  end
228
228
 
229
- describe '#additional_attributes_for_external_and_redirect_control_groups' do
229
+ describe "#additional_attributes_for_external_and_redirect_control_groups" do
230
230
  before(:all) do
231
231
  @behavior = ActiveFedora::Datastreams.deprecation_behavior
232
232
  ActiveFedora::Datastreams.deprecation_behavior = :silence
233
233
  end
234
-
234
+
235
235
  after :all do
236
236
  ActiveFedora::Datastreams.deprecation_behavior = @behavior
237
237
  end