aboutsummaryrefslogtreecommitdiffstats
path: root/activerecord/test/cases/validations/absence_validation_test.rb
blob: 180acbcb6ada625e8fc53e8f9fba4af8c905ac70 (plain) (blame)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
require "cases/helper"
require 'models/face'
require 'models/interest'
require 'models/man'
require 'models/topic'

class AbsenceValidationTest < ActiveRecord::TestCase
  def test_non_association
    boy_klass = Class.new(Man) do
      def self.name; "Boy" end
      validates_absence_of :name
    end

    assert boy_klass.new.valid?
    assert_not boy_klass.new(name: "Alex").valid?
  end

  def test_has_one_marked_for_destruction
    boy_klass = Class.new(Man) do
      def self.name; "Boy" end
      validates_absence_of :face
    end

    boy = boy_klass.new(face: Face.new)
    assert_not boy.valid?, "should not be valid if has_one association is present"
    assert_equal 1, boy.errors[:face].size, "should only add one error"

    boy.face.mark_for_destruction
    assert boy.valid?, "should be valid if association is marked for destruction"
  end

  def test_has_many_marked_for_destruction
    boy_klass = Class.new(Man) do
      def self.name; "Boy" end
      validates_absence_of :interests
    end
    boy = boy_klass.new
    boy.interests << [i1 = Interest.new, i2 = Interest.new]
    assert_not boy.valid?, "should not be valid if has_many association is present"

    i1.mark_for_destruction
    assert_not boy.valid?, "should not be valid if has_many association is present"

    i2.mark_for_destruction
    assert boy.valid?
  end

  def test_does_not_call_to_a_on_associations
    boy_klass = Class.new(Man) do
      def self.name; "Boy" end
      validates_absence_of :face
    end

    face_with_to_a = Face.new
    def face_with_to_a.to_a; ['(/)', '(\)']; end

    assert_nothing_raised { boy_klass.new(face: face_with_to_a).valid? }
  end

  def test_does_not_validate_if_parent_record_is_validate_false
    repair_validations(Interest) do
      Interest.validates_absence_of(:topic)
      interest = Interest.new(topic: Topic.new(title: "Math"))
      interest.save!(validate: false)
      assert interest.persisted?

      man = Man.new(interest_ids: [interest.id])
      man.save!

      assert_equal man.interests.size, 1
      assert interest.valid?
      assert man.valid?
    end
  end

  def test_validates_absence_of_virtual_attribute_on_model
    repair_validations(Interest) do
      Interest.send(:attr_accessor, :token)
      Interest.validates_absence_of(:token)

      interest = Interest.create!(topic: 'Thought Leadering')
      assert interest.valid?

      interest.token = 'tl'

      assert interest.invalid?
    end
  end
end