samlown-couchrest 0.37.2 → 1.0.0
Sign up to get free protection for your applications and to get access to all the features.
- data/README.md +10 -4
- data/Rakefile +1 -1
- data/history.txt +8 -0
- data/lib/couchrest.rb +27 -49
- data/lib/couchrest/{core/database.rb → database.rb} +6 -11
- data/lib/couchrest/{core/design.rb → design.rb} +2 -2
- data/lib/couchrest/{core/document.rb → document.rb} +1 -1
- data/lib/couchrest/helper/attachments.rb +29 -0
- data/lib/couchrest/middlewares/logger.rb +3 -3
- data/lib/couchrest/monkeypatches.rb +1 -71
- data/lib/couchrest/{core/response.rb → response.rb} +0 -0
- data/lib/couchrest/{core/rest_api.rb → rest_api.rb} +9 -6
- data/lib/couchrest/{core/server.rb → server.rb} +0 -0
- data/spec/couchrest/{core/couchrest_spec.rb → couchrest_spec.rb} +16 -3
- data/spec/couchrest/{core/database_spec.rb → database_spec.rb} +2 -2
- data/spec/couchrest/{core/design_spec.rb → design_spec.rb} +2 -2
- data/spec/couchrest/{core/document_spec.rb → document_spec.rb} +1 -1
- data/spec/couchrest/{core/server_spec.rb → server_spec.rb} +2 -2
- data/spec/spec.opts +0 -1
- data/spec/spec_helper.rb +0 -4
- metadata +24 -113
- data/couchrest.gemspec +0 -183
- data/examples/model/example.rb +0 -144
- data/lib/couchrest/core/adapters/restclient.rb +0 -35
- data/lib/couchrest/core/http_abstraction.rb +0 -48
- data/lib/couchrest/core/view.rb +0 -4
- data/lib/couchrest/mixins.rb +0 -4
- data/lib/couchrest/mixins/attachments.rb +0 -31
- data/lib/couchrest/mixins/attribute_protection.rb +0 -74
- data/lib/couchrest/mixins/callbacks.rb +0 -532
- data/lib/couchrest/mixins/class_proxy.rb +0 -124
- data/lib/couchrest/mixins/collection.rb +0 -260
- data/lib/couchrest/mixins/design_doc.rb +0 -103
- data/lib/couchrest/mixins/document_queries.rb +0 -80
- data/lib/couchrest/mixins/extended_attachments.rb +0 -70
- data/lib/couchrest/mixins/extended_document_mixins.rb +0 -9
- data/lib/couchrest/mixins/properties.rb +0 -154
- data/lib/couchrest/mixins/validation.rb +0 -246
- data/lib/couchrest/mixins/views.rb +0 -173
- data/lib/couchrest/more/casted_array.rb +0 -25
- data/lib/couchrest/more/casted_model.rb +0 -58
- data/lib/couchrest/more/extended_document.rb +0 -310
- data/lib/couchrest/more/property.rb +0 -50
- data/lib/couchrest/more/typecast.rb +0 -175
- data/lib/couchrest/support/blank.rb +0 -42
- data/lib/couchrest/support/rails.rb +0 -42
- data/lib/couchrest/validation/auto_validate.rb +0 -157
- data/lib/couchrest/validation/contextual_validators.rb +0 -78
- data/lib/couchrest/validation/validation_errors.rb +0 -125
- data/lib/couchrest/validation/validators/absent_field_validator.rb +0 -74
- data/lib/couchrest/validation/validators/confirmation_validator.rb +0 -107
- data/lib/couchrest/validation/validators/format_validator.rb +0 -122
- data/lib/couchrest/validation/validators/formats/email.rb +0 -66
- data/lib/couchrest/validation/validators/formats/url.rb +0 -43
- data/lib/couchrest/validation/validators/generic_validator.rb +0 -120
- data/lib/couchrest/validation/validators/length_validator.rb +0 -139
- data/lib/couchrest/validation/validators/method_validator.rb +0 -89
- data/lib/couchrest/validation/validators/numeric_validator.rb +0 -109
- data/lib/couchrest/validation/validators/required_field_validator.rb +0 -114
- data/spec/couchrest/more/attribute_protection_spec.rb +0 -150
- data/spec/couchrest/more/casted_extended_doc_spec.rb +0 -79
- data/spec/couchrest/more/casted_model_spec.rb +0 -406
- data/spec/couchrest/more/extended_doc_attachment_spec.rb +0 -135
- data/spec/couchrest/more/extended_doc_inherited_spec.rb +0 -40
- data/spec/couchrest/more/extended_doc_spec.rb +0 -808
- data/spec/couchrest/more/extended_doc_subclass_spec.rb +0 -98
- data/spec/couchrest/more/extended_doc_view_spec.rb +0 -462
- data/spec/couchrest/more/property_spec.rb +0 -628
- data/spec/fixtures/more/article.rb +0 -35
- data/spec/fixtures/more/card.rb +0 -22
- data/spec/fixtures/more/cat.rb +0 -20
- data/spec/fixtures/more/course.rb +0 -22
- data/spec/fixtures/more/event.rb +0 -8
- data/spec/fixtures/more/invoice.rb +0 -17
- data/spec/fixtures/more/person.rb +0 -9
- data/spec/fixtures/more/question.rb +0 -6
- data/spec/fixtures/more/service.rb +0 -12
- data/spec/fixtures/more/user.rb +0 -22
@@ -1,109 +0,0 @@
|
|
1
|
-
# Extracted from dm-validations 0.9.10
|
2
|
-
#
|
3
|
-
# Copyright (c) 2007 Guy van den Berg
|
4
|
-
#
|
5
|
-
# Permission is hereby granted, free of charge, to any person obtaining
|
6
|
-
# a copy of this software and associated documentation files (the
|
7
|
-
# "Software"), to deal in the Software without restriction, including
|
8
|
-
# without limitation the rights to use, copy, modify, merge, publish,
|
9
|
-
# distribute, sublicense, and/or sell copies of the Software, and to
|
10
|
-
# permit persons to whom the Software is furnished to do so, subject to
|
11
|
-
# the following conditions:
|
12
|
-
#
|
13
|
-
# The above copyright notice and this permission notice shall be
|
14
|
-
# included in all copies or substantial portions of the Software.
|
15
|
-
#
|
16
|
-
# THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND,
|
17
|
-
# EXPRESS OR IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF
|
18
|
-
# MERCHANTABILITY, FITNESS FOR A PARTICULAR PURPOSE AND
|
19
|
-
# NONINFRINGEMENT. IN NO EVENT SHALL THE AUTHORS OR COPYRIGHT HOLDERS BE
|
20
|
-
# LIABLE FOR ANY CLAIM, DAMAGES OR OTHER LIABILITY, WHETHER IN AN ACTION
|
21
|
-
# OF CONTRACT, TORT OR OTHERWISE, ARISING FROM, OUT OF OR IN CONNECTION
|
22
|
-
# WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN THE SOFTWARE.
|
23
|
-
|
24
|
-
module CouchRest
|
25
|
-
module Validation
|
26
|
-
|
27
|
-
##
|
28
|
-
#
|
29
|
-
# @author Guy van den Berg
|
30
|
-
# @since 0.9
|
31
|
-
class NumericValidator < GenericValidator
|
32
|
-
|
33
|
-
def initialize(field_name, options={})
|
34
|
-
super
|
35
|
-
@field_name, @options = field_name, options
|
36
|
-
@options[:integer_only] = false unless @options.has_key?(:integer_only)
|
37
|
-
end
|
38
|
-
|
39
|
-
def call(target)
|
40
|
-
value = target.send(field_name)
|
41
|
-
return true if @options[:allow_nil] && value.nil?
|
42
|
-
|
43
|
-
value = (defined?(BigDecimal) && value.kind_of?(BigDecimal)) ? value.to_s('F') : value.to_s
|
44
|
-
|
45
|
-
error_message = @options[:message]
|
46
|
-
precision = @options[:precision]
|
47
|
-
scale = @options[:scale]
|
48
|
-
|
49
|
-
if @options[:integer_only]
|
50
|
-
return true if value =~ /\A[+-]?\d+\z/
|
51
|
-
error_message ||= ValidationErrors.default_error_message(:not_an_integer, field_name)
|
52
|
-
else
|
53
|
-
# FIXME: if precision and scale are not specified, can we assume that it is an integer?
|
54
|
-
# probably not, as floating point numbers don't have hard
|
55
|
-
# defined scale. the scale floats with the length of the
|
56
|
-
# integral and precision. Ie. if precision = 10 and integral
|
57
|
-
# portion of the number is 9834 (4 digits), the max scale will
|
58
|
-
# be 6 (10 - 4). But if the integral length is 1, max scale
|
59
|
-
# will be (10 - 1) = 9, so 1.234567890.
|
60
|
-
if precision && scale
|
61
|
-
#handles both Float when it has scale specified and BigDecimal
|
62
|
-
if precision > scale && scale > 0
|
63
|
-
return true if value =~ /\A[+-]?(?:\d{1,#{precision - scale}}|\d{0,#{precision - scale}}\.\d{1,#{scale}})\z/
|
64
|
-
elsif precision > scale && scale == 0
|
65
|
-
return true if value =~ /\A[+-]?(?:\d{1,#{precision}}(?:\.0)?)\z/
|
66
|
-
elsif precision == scale
|
67
|
-
return true if value =~ /\A[+-]?(?:0(?:\.\d{1,#{scale}})?)\z/
|
68
|
-
else
|
69
|
-
raise ArgumentError, "Invalid precision #{precision.inspect} and scale #{scale.inspect} for #{field_name} (value: #{value.inspect} #{value.class})"
|
70
|
-
end
|
71
|
-
elsif precision && scale.nil?
|
72
|
-
# for floats, if scale is not set
|
73
|
-
|
74
|
-
#total number of digits is less or equal precision
|
75
|
-
return true if value.gsub(/[^\d]/, '').length <= precision
|
76
|
-
|
77
|
-
#number of digits before decimal == precision, and the number is x.0. same as scale = 0
|
78
|
-
return true if value =~ /\A[+-]?(?:\d{1,#{precision}}(?:\.0)?)\z/
|
79
|
-
else
|
80
|
-
return true if value =~ /\A[+-]?(?:\d+|\d*\.\d+)\z/
|
81
|
-
end
|
82
|
-
error_message ||= ValidationErrors.default_error_message(:not_a_number, field_name)
|
83
|
-
end
|
84
|
-
|
85
|
-
add_error(target, error_message, field_name)
|
86
|
-
|
87
|
-
# TODO: check the gt, gte, lt, lte, and eq options
|
88
|
-
|
89
|
-
return false
|
90
|
-
end
|
91
|
-
end # class NumericValidator
|
92
|
-
|
93
|
-
module ValidatesIsNumber
|
94
|
-
|
95
|
-
# Validate whether a field is numeric
|
96
|
-
#
|
97
|
-
def validates_numericality_of(*fields)
|
98
|
-
opts = opts_from_validator_args(fields)
|
99
|
-
add_validator_to_context(opts, fields, CouchRest::Validation::NumericValidator)
|
100
|
-
end
|
101
|
-
|
102
|
-
def validates_is_number(*fields)
|
103
|
-
warn "[DEPRECATION] `validates_is_number` is deprecated. Please use `validates_numericality_of` instead."
|
104
|
-
validates_numericality_of(*fields)
|
105
|
-
end
|
106
|
-
|
107
|
-
end # module ValidatesIsNumber
|
108
|
-
end # module Validation
|
109
|
-
end # module CouchRest
|
@@ -1,114 +0,0 @@
|
|
1
|
-
# Extracted from dm-validations 0.9.10
|
2
|
-
#
|
3
|
-
# Copyright (c) 2007 Guy van den Berg
|
4
|
-
#
|
5
|
-
# Permission is hereby granted, free of charge, to any person obtaining
|
6
|
-
# a copy of this software and associated documentation files (the
|
7
|
-
# "Software"), to deal in the Software without restriction, including
|
8
|
-
# without limitation the rights to use, copy, modify, merge, publish,
|
9
|
-
# distribute, sublicense, and/or sell copies of the Software, and to
|
10
|
-
# permit persons to whom the Software is furnished to do so, subject to
|
11
|
-
# the following conditions:
|
12
|
-
#
|
13
|
-
# The above copyright notice and this permission notice shall be
|
14
|
-
# included in all copies or substantial portions of the Software.
|
15
|
-
#
|
16
|
-
# THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND,
|
17
|
-
# EXPRESS OR IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF
|
18
|
-
# MERCHANTABILITY, FITNESS FOR A PARTICULAR PURPOSE AND
|
19
|
-
# NONINFRINGEMENT. IN NO EVENT SHALL THE AUTHORS OR COPYRIGHT HOLDERS BE
|
20
|
-
# LIABLE FOR ANY CLAIM, DAMAGES OR OTHER LIABILITY, WHETHER IN AN ACTION
|
21
|
-
# OF CONTRACT, TORT OR OTHERWISE, ARISING FROM, OUT OF OR IN CONNECTION
|
22
|
-
# WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN THE SOFTWARE.
|
23
|
-
|
24
|
-
module CouchRest
|
25
|
-
module Validation
|
26
|
-
|
27
|
-
##
|
28
|
-
#
|
29
|
-
# @author Guy van den Berg
|
30
|
-
# @since 0.9
|
31
|
-
class RequiredFieldValidator < GenericValidator
|
32
|
-
|
33
|
-
def initialize(field_name, options={})
|
34
|
-
super
|
35
|
-
@field_name, @options = field_name, options
|
36
|
-
end
|
37
|
-
|
38
|
-
def call(target)
|
39
|
-
value = target.validation_property_value(field_name)
|
40
|
-
property = target.validation_property(field_name.to_s)
|
41
|
-
return true if present?(value, property)
|
42
|
-
|
43
|
-
error_message = @options[:message] || default_error(property)
|
44
|
-
add_error(target, error_message, field_name)
|
45
|
-
|
46
|
-
false
|
47
|
-
end
|
48
|
-
|
49
|
-
protected
|
50
|
-
|
51
|
-
# Boolean property types are considered present if non-nil.
|
52
|
-
# Other property types are considered present if non-blank.
|
53
|
-
# Non-properties are considered present if non-blank.
|
54
|
-
def present?(value, property)
|
55
|
-
boolean_type?(property) ? !value.nil? : !value.blank?
|
56
|
-
end
|
57
|
-
|
58
|
-
def default_error(property)
|
59
|
-
actual = boolean_type?(property) ? :nil : :blank
|
60
|
-
ValidationErrors.default_error_message(actual, field_name)
|
61
|
-
end
|
62
|
-
|
63
|
-
# Is +property+ a boolean property?
|
64
|
-
#
|
65
|
-
# Returns true for Boolean, ParanoidBoolean, TrueClass, etc. properties.
|
66
|
-
# Returns false for other property types.
|
67
|
-
# Returns false for non-properties.
|
68
|
-
def boolean_type?(property)
|
69
|
-
property ? property.type == 'Boolean' : false
|
70
|
-
end
|
71
|
-
|
72
|
-
end # class RequiredFieldValidator
|
73
|
-
|
74
|
-
module ValidatesPresent
|
75
|
-
|
76
|
-
##
|
77
|
-
# Validates that the specified attribute is present.
|
78
|
-
#
|
79
|
-
# For most property types "being present" is the same as being "not
|
80
|
-
# blank" as determined by the attribute's #blank? method. However, in
|
81
|
-
# the case of Boolean, "being present" means not nil; i.e. true or
|
82
|
-
# false.
|
83
|
-
#
|
84
|
-
# @note
|
85
|
-
# dm-core's support lib adds the blank? method to many classes,
|
86
|
-
# @see lib/dm-core/support/blank.rb (dm-core) for more information.
|
87
|
-
#
|
88
|
-
# @example [Usage]
|
89
|
-
#
|
90
|
-
# class Page
|
91
|
-
#
|
92
|
-
# property :required_attribute, String
|
93
|
-
# property :another_required, String
|
94
|
-
# property :yet_again, String
|
95
|
-
#
|
96
|
-
# validates_presence_of :required_attribute
|
97
|
-
# validates_presence_of :another_required, :yet_again
|
98
|
-
#
|
99
|
-
# # a call to valid? will return false unless
|
100
|
-
# # all three attributes are !blank?
|
101
|
-
# end
|
102
|
-
def validates_presence_of(*fields)
|
103
|
-
opts = opts_from_validator_args(fields)
|
104
|
-
add_validator_to_context(opts, fields, CouchRest::Validation::RequiredFieldValidator)
|
105
|
-
end
|
106
|
-
|
107
|
-
def validates_present(*fields)
|
108
|
-
warn "[DEPRECATION] `validates_present` is deprecated. Please use `validates_presence_of` instead."
|
109
|
-
validates_presence_of(*fields)
|
110
|
-
end
|
111
|
-
|
112
|
-
end # module ValidatesPresent
|
113
|
-
end # module Validation
|
114
|
-
end # module CouchRest
|
@@ -1,150 +0,0 @@
|
|
1
|
-
require File.expand_path("../../../spec_helper", __FILE__)
|
2
|
-
|
3
|
-
describe "ExtendedDocument", "no declarations" do
|
4
|
-
class NoProtection < CouchRest::ExtendedDocument
|
5
|
-
use_database TEST_SERVER.default_database
|
6
|
-
property :name
|
7
|
-
property :phone
|
8
|
-
end
|
9
|
-
|
10
|
-
it "should not protect anything through new" do
|
11
|
-
user = NoProtection.new(:name => "will", :phone => "555-5555")
|
12
|
-
|
13
|
-
user.name.should == "will"
|
14
|
-
user.phone.should == "555-5555"
|
15
|
-
end
|
16
|
-
|
17
|
-
it "should not protect anything through attributes=" do
|
18
|
-
user = NoProtection.new
|
19
|
-
user.attributes = {:name => "will", :phone => "555-5555"}
|
20
|
-
|
21
|
-
user.name.should == "will"
|
22
|
-
user.phone.should == "555-5555"
|
23
|
-
end
|
24
|
-
|
25
|
-
it "should recreate from the database properly" do
|
26
|
-
user = NoProtection.new
|
27
|
-
user.name = "will"
|
28
|
-
user.phone = "555-5555"
|
29
|
-
user.save!
|
30
|
-
|
31
|
-
user = NoProtection.get(user.id)
|
32
|
-
user.name.should == "will"
|
33
|
-
user.phone.should == "555-5555"
|
34
|
-
end
|
35
|
-
end
|
36
|
-
|
37
|
-
describe "ExtendedDocument", "accessible flag" do
|
38
|
-
class WithAccessible < CouchRest::ExtendedDocument
|
39
|
-
use_database TEST_SERVER.default_database
|
40
|
-
property :name, :accessible => true
|
41
|
-
property :admin, :default => false
|
42
|
-
end
|
43
|
-
|
44
|
-
it "should recognize accessible properties" do
|
45
|
-
props = WithAccessible.accessible_properties.map { |prop| prop.name}
|
46
|
-
props.should include("name")
|
47
|
-
props.should_not include("admin")
|
48
|
-
end
|
49
|
-
|
50
|
-
it "should protect non-accessible properties set through new" do
|
51
|
-
user = WithAccessible.new(:name => "will", :admin => true)
|
52
|
-
|
53
|
-
user.name.should == "will"
|
54
|
-
user.admin.should == false
|
55
|
-
end
|
56
|
-
|
57
|
-
it "should protect non-accessible properties set through attributes=" do
|
58
|
-
user = WithAccessible.new
|
59
|
-
user.attributes = {:name => "will", :admin => true}
|
60
|
-
|
61
|
-
user.name.should == "will"
|
62
|
-
user.admin.should == false
|
63
|
-
end
|
64
|
-
end
|
65
|
-
|
66
|
-
describe "ExtendedDocument", "protected flag" do
|
67
|
-
class WithProtected < CouchRest::ExtendedDocument
|
68
|
-
use_database TEST_SERVER.default_database
|
69
|
-
property :name
|
70
|
-
property :admin, :default => false, :protected => true
|
71
|
-
end
|
72
|
-
|
73
|
-
it "should recognize protected properties" do
|
74
|
-
props = WithProtected.protected_properties.map { |prop| prop.name}
|
75
|
-
props.should_not include("name")
|
76
|
-
props.should include("admin")
|
77
|
-
end
|
78
|
-
|
79
|
-
it "should protect non-accessible properties set through new" do
|
80
|
-
user = WithProtected.new(:name => "will", :admin => true)
|
81
|
-
|
82
|
-
user.name.should == "will"
|
83
|
-
user.admin.should == false
|
84
|
-
end
|
85
|
-
|
86
|
-
it "should protect non-accessible properties set through attributes=" do
|
87
|
-
user = WithProtected.new
|
88
|
-
user.attributes = {:name => "will", :admin => true}
|
89
|
-
|
90
|
-
user.name.should == "will"
|
91
|
-
user.admin.should == false
|
92
|
-
end
|
93
|
-
end
|
94
|
-
|
95
|
-
describe "ExtendedDocument", "protected flag" do
|
96
|
-
class WithBoth < CouchRest::ExtendedDocument
|
97
|
-
use_database TEST_SERVER.default_database
|
98
|
-
property :name, :accessible => true
|
99
|
-
property :admin, :default => false, :protected => true
|
100
|
-
end
|
101
|
-
|
102
|
-
it "should raise an error when both are set" do
|
103
|
-
lambda { WithBoth.new }.should raise_error
|
104
|
-
end
|
105
|
-
end
|
106
|
-
|
107
|
-
describe "ExtendedDocument", "from database" do
|
108
|
-
class WithProtected < CouchRest::ExtendedDocument
|
109
|
-
use_database TEST_SERVER.default_database
|
110
|
-
property :name
|
111
|
-
property :admin, :default => false, :protected => true
|
112
|
-
view_by :name
|
113
|
-
end
|
114
|
-
|
115
|
-
before(:each) do
|
116
|
-
@user = WithProtected.new
|
117
|
-
@user.name = "will"
|
118
|
-
@user.admin = true
|
119
|
-
@user.save!
|
120
|
-
end
|
121
|
-
|
122
|
-
def verify_attrs(user)
|
123
|
-
user.name.should == "will"
|
124
|
-
user.admin.should == true
|
125
|
-
end
|
126
|
-
|
127
|
-
it "ExtendedDocument#get should not strip protected attributes" do
|
128
|
-
reloaded = WithProtected.get( @user.id )
|
129
|
-
verify_attrs reloaded
|
130
|
-
end
|
131
|
-
|
132
|
-
it "ExtendedDocument#get! should not strip protected attributes" do
|
133
|
-
reloaded = WithProtected.get!( @user.id )
|
134
|
-
verify_attrs reloaded
|
135
|
-
end
|
136
|
-
|
137
|
-
it "ExtendedDocument#all should not strip protected attributes" do
|
138
|
-
# all creates a CollectionProxy
|
139
|
-
docs = WithProtected.all(:key => @user.id)
|
140
|
-
docs.size.should == 1
|
141
|
-
reloaded = docs.first
|
142
|
-
verify_attrs reloaded
|
143
|
-
end
|
144
|
-
|
145
|
-
it "views should not strip protected attributes" do
|
146
|
-
docs = WithProtected.by_name(:startkey => "will", :endkey => "will")
|
147
|
-
reloaded = docs.first
|
148
|
-
verify_attrs reloaded
|
149
|
-
end
|
150
|
-
end
|
@@ -1,79 +0,0 @@
|
|
1
|
-
require File.expand_path('../../../spec_helper', __FILE__)
|
2
|
-
require File.join(FIXTURE_PATH, 'more', 'cat')
|
3
|
-
require File.join(FIXTURE_PATH, 'more', 'person')
|
4
|
-
require File.join(FIXTURE_PATH, 'more', 'card')
|
5
|
-
|
6
|
-
class Driver < CouchRest::ExtendedDocument
|
7
|
-
use_database TEST_SERVER.default_database
|
8
|
-
# You have to add a casted_by accessor if you want to reach a casted extended doc parent
|
9
|
-
attr_accessor :casted_by
|
10
|
-
|
11
|
-
property :name
|
12
|
-
end
|
13
|
-
|
14
|
-
class Car < CouchRest::ExtendedDocument
|
15
|
-
use_database TEST_SERVER.default_database
|
16
|
-
|
17
|
-
property :name
|
18
|
-
property :driver, :cast_as => 'Driver'
|
19
|
-
property :backseat_driver, :cast_as => Driver
|
20
|
-
end
|
21
|
-
|
22
|
-
describe "casting an extended document" do
|
23
|
-
|
24
|
-
before(:each) do
|
25
|
-
@driver = Driver.new(:name => 'Matt')
|
26
|
-
@car = Car.new(:name => 'Renault 306', :driver => @driver)
|
27
|
-
@car2 = Car.new(:name => 'Renault 306', :backseat_driver => @driver.dup)
|
28
|
-
end
|
29
|
-
|
30
|
-
it "should retain all properties of the casted attribute" do
|
31
|
-
@car.driver.should == @driver
|
32
|
-
@car2.backseat_driver.should == @driver
|
33
|
-
end
|
34
|
-
|
35
|
-
it "should let the casted document know who casted it" do
|
36
|
-
@car.driver.casted_by.should == @car
|
37
|
-
@car2.backseat_driver.casted_by.should == @car2
|
38
|
-
end
|
39
|
-
end
|
40
|
-
|
41
|
-
describe "assigning a value to casted attribute after initializing an object" do
|
42
|
-
|
43
|
-
before(:each) do
|
44
|
-
@car = Car.new(:name => 'Renault 306')
|
45
|
-
@driver = Driver.new(:name => 'Matt')
|
46
|
-
end
|
47
|
-
|
48
|
-
it "should not create an empty casted object" do
|
49
|
-
@car.driver.should be_nil
|
50
|
-
end
|
51
|
-
|
52
|
-
it "should let you assign the value" do
|
53
|
-
@car.driver = @driver
|
54
|
-
@car.driver.name.should == 'Matt'
|
55
|
-
end
|
56
|
-
|
57
|
-
it "should cast attribute" do
|
58
|
-
@car.driver = JSON.parse(@driver.to_json)
|
59
|
-
@car.driver.should be_instance_of(Driver)
|
60
|
-
end
|
61
|
-
|
62
|
-
end
|
63
|
-
|
64
|
-
describe "casting an extended document from parsed JSON" do
|
65
|
-
|
66
|
-
before(:each) do
|
67
|
-
@driver = Driver.new(:name => 'Matt')
|
68
|
-
@car = Car.new(:name => 'Renault 306', :driver => @driver)
|
69
|
-
@new_car = Car.new(JSON.parse(@car.to_json))
|
70
|
-
end
|
71
|
-
|
72
|
-
it "should cast casted attribute" do
|
73
|
-
@new_car.driver.should be_instance_of(Driver)
|
74
|
-
end
|
75
|
-
|
76
|
-
it "should retain all properties of the casted attribute" do
|
77
|
-
@new_car.driver.should == @driver
|
78
|
-
end
|
79
|
-
end
|