CMDBrew/adminterface

View on GitHub
test/lib/extensions/inputs/number_input_test.rb

Summary

Maintainability
A
2 hrs
Test Coverage
require "test_helper"

module NumberInputScenarios
  extend ActiveSupport::Concern

  def find_wrapper(form)
    @wrapper ||= form.find(".input.number")
  end

  included do
    test "wrapper" do
      assert find_wrapper(@form).present?
    end

    test "label" do
      assert find_wrapper(@form)
        .has_selector?('label.form-label[for="active_admin_input_test_case_form_object_quantity"]')
    end

    test "input" do
      assert find_wrapper(@form).has_selector?(
        'input.form-control[type="number"]'\
          '[id="active_admin_input_test_case_form_object_quantity"]'\
          '[name="active_admin_input_test_case_form_object[quantity]"]'
      )
    end
  end
end

class NumberInputTest < ActiveAdmin::InputTestCase
  include NumberInputScenarios

  setup do
    @form = build_form do |f|
      f.inputs do
        f.input :quantity, as: :number
      end
    end
  end
end

class NumberInputGroupingTest < ActiveAdmin::InputTestCase
  test "renders prepend" do
    form = build_form do |f|
      f.inputs do
        f.input :quantity, as: :number, prepend: content_tag(:span, "prepend text", class: "input-group-text")
      end
    end

    assert form.has_selector?('.input-group span.input-group-text + input.form-control[type="number"]')
  end

  test "renders append" do
    form = build_form do |f|
      f.inputs do
        f.input :quantity, as: :number, append: content_tag(:span, "append text", class: "input-group-text")
      end
    end

    assert form.has_selector?('.input-group input.form-control[type="number"] + span.input-group-text')
  end
end