如何在Ruby on Rails 5中验证pg数组长度?

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数组.

Ser*_*pia 6

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)