# frozen_string_literal: true
RSpec.describe UserField do
describe "doesn't validate presence of name if field type is 'confirm'" do
subject(:confirm_field) { described_class.new(field_type: "confirm") }
it { is_expected.not_to validate_presence_of :name }
end
describe "validates presence of name for other field types" do
subject(:dropdown_field) { described_class.new(field_type: "dropdown") }
it { is_expected.to validate_presence_of :name }
end
it "sanitizes the description" do
xss = "click me!"
user_field = Fabricate(:user_field)
user_field.update!(description: xss)
expect(user_field.description).to eq("click me!alert('TEST');")
end
it "allows target attribute in the description" do
link = "elsewhere"
user_field = Fabricate(:user_field)
user_field.update!(description: link)
expect(user_field.description).to eq(link)
end
end