require 'test_helper'
class ItemRepresenter
include AttributesContructor
include Roar::Representer::XML
self.representation_wrap= :item
property :value
attr_accessor :value
end
class PositionRepresenter
include AttributesContructor
include Roar::Representer::XML
self.representation_wrap= :position
property :id
property :item, :class => ItemRepresenter
attr_accessor :id, :item
end
class XMLRepresenterFunctionalTest < MiniTest::Spec
class Order
include AttributesContructor
attr_accessor :id, :items
end
class GreedyOrder < Order
end
class TestXmlRepresenter
include Roar::Representer::XML
self.representation_wrap= :order
property :id
attr_accessor :id
end
describe "XMLRepresenter" do
before do
@m = {"id" => "1"}
@o = Order.new(@m)
@r = TestXmlRepresenter.new
@i = ItemRepresenter.new
@i.value = "Beer"
end
describe "#to_xml" do
it "serializes the model" do
assert_xml_equal "", @r.to_xml
@r.id = 1
assert_xml_equal "1", @r.to_xml
@r.id = 2
assert_xml_equal "2", @r.to_xml(:wrap => :rap)
end
it "is aliased by #serialize" do
assert_equal @r.to_xml, @r.serialize
end
it "accepts :include and :except" do
assert_equal '', @r.to_xml(:except => [:id])
end
end
describe "#from_xml" do
it "deserializes object" do
@order = Order.new.from_xml("1")
assert_equal "1", @order.id
end
it "is aliased by #deserialize" do
@order = Order.new.deserialize("1")
assert_equal "1", @order.id
end
it "accepts :include and :except" do
@order = Order.new.deserialize("1", :except => [:id])
assert_equal nil, @order.id
end
end
describe "XML.from_xml" do
class Order
include Roar::Representer::XML
property :id
property :pending
attr_accessor :id, :pending
end
it "is aliased to #deserialize" do
assert_equal TestXmlRepresenter.from_xml("").id, TestXmlRepresenter.deserialize("").id
end
it "accepts :except option" do
order = Order.from_xml(%{11}, :except => [:id])
assert_equal nil, order.id
assert_equal "1", order.pending
end
it "accepts :include option" do
order = Order.from_xml(%{11}, :include => [:id])
assert_equal "1", order.id
assert_equal nil, order.pending
end
end
describe "without options" do
it ".from_xml returns the deserialized model" do
@m = TestXmlRepresenter.from_xml("1")
assert_equal "1", @m.id
end
#it ".from_xml still works with nil" do
# assert TestXmlRepresenter.from_xml(nil)
#end
end
describe "with a typed attribute" do
before do
@r = PositionRepresenter.new("id" => "1")
end
it "#serialize skips empty :item" do
assert_xml_equal "1", @r.to_xml
end
it "#to_xml delegates to ItemRepresenter#to_xml" do
@r.item = @i
assert_xml_equal "1Beer", @r.to_xml
end
it ".from_xml typecasts :item" do
@m = PositionRepresenter.from_xml("1beer\n")
assert_equal "1", @m.id
assert_equal "beer", @m.item.value
end
end
describe "with a typed list" do
before do
@c = Class.new do
include AttributesContructor
include Roar::Representer::XML
self.representation_wrap= :order
property :id
collection :items, :class => ItemRepresenter, :from => :item
attr_accessor :id, :items
end
@r = @c.new("id" => 1)
end
it "#serialize_model skips empty :item" do
assert_xml_equal "1", @r.to_xml
end
it "#serialize delegates to ItemXmlRepresenter#to_xml in list" do
@r.items = [ItemRepresenter.new("value" => "Bier")]
assert_xml_equal "1Bier",
@r.to_xml
end
it ".from_xml typecasts list" do
@m = @c.from_xml("1beer\n")
assert_equal "1", @m.id
assert_equal 1, @m.items.size
assert_equal "beer", @m.items.first.value
end
end
end
end
class XmlHyperlinkRepresenterTest < MiniTest::Spec
describe "API" do
before do
@link = Roar::Representer::Feature::Hypermedia::Hyperlink.new.extend(Roar::Representer::XML::HyperlinkRepresenter).from_xml(%{})
end
it "responds to #rel" do
assert_equal "self", @link.rel
end
it "responds to #href" do
assert_equal "http://roar.apotomo.de", @link.href
end
it "responds to #media" do
assert_equal "web", @link.media
end
it "responds to #to_xml" do
assert_xml_equal %{}, @link.to_xml
end
end
end