Ser*_*pia 3 arrays postgresql validation model ruby-on-rails
如何验证Note模型的标签数量?我的模特目前:
# == Schema Information
#
# Table name: notes
#
# id :integer not null, primary key
# title :text
# body :text
# organization_id :integer
# created_at :datetime not null
# updated_at :datetime not null
# tags :string default([]), is an Array
#
# Note represents a saved Note that belongs to an organization.
class Note < ApplicationRecord
belongs_to :organization
validates :title, :body, presence: true
end
Run Code Online (Sandbox Code Playgroud)
tags 是数据库中的pg数组.
Rails将在内部处理转换,因此您只需要担心使用Ruby数组对象.
验证看起来像这样:
class Note < ApplicationRecord
validates :tags, length: {
maximum: 10,
message: 'A note can only have a maximum of 10 tags'
}
end
it 'is invalid with more than 10 tags' do
tags = %w(1 2 3 4 5 6 7 8 9 10 11)
note = build(:note, tags: tags)
note.valid?
expect(note.errors[:tags])
.to include('A note can only have a maximum of 10 tags')
end
Run Code Online (Sandbox Code Playgroud)