module ActionDispatch::Assertions::DomAssertions

def assert_dom_equal(expected, actual, message = "")


assert_dom_equal 'Apples', link_to("Apples", "http://www.example.com")
# assert that the referenced method generates the appropriate HTML string

==== Examples

\Test two HTML strings for equivalency (e.g., identical up to reordering of attributes)
def assert_dom_equal(expected, actual, message = "")
  expected_dom = HTML::Document.new(expected).root
  actual_dom   = HTML::Document.new(actual).root
  full_message = build_message(message, "<?> expected to be == to\n<?>.", expected_dom.to_s, actual_dom.to_s)
  assert_block(full_message) { expected_dom == actual_dom }
end

def assert_dom_not_equal(expected, actual, message = "")


assert_dom_not_equal 'Apples', link_to("Oranges", "http://www.example.com")
# assert that the referenced method does not generate the specified HTML string

==== Examples

The negated form of +assert_dom_equivalent+.
def assert_dom_not_equal(expected, actual, message = "")
  expected_dom = HTML::Document.new(expected).root
  actual_dom   = HTML::Document.new(actual).root
  full_message = build_message(message, "<?> expected to be != to\n<?>.", expected_dom.to_s, actual_dom.to_s)
  assert_block(full_message) { expected_dom != actual_dom }
end