# encoding: UTF-8 require 'spec_helper' describe JsonWriteStream::YieldingWriter do let(:stream) do StringIO.new.tap do |io| io.set_encoding(Encoding::UTF_8) end end let(:stream_writer) { JsonWriteStream::YieldingWriter.new(stream) } def check_roundtrip(obj) YieldingRoundtripChecker.check_roundtrip(obj) end def utf8(str) str.encode(Encoding::UTF_8) end it_behaves_like 'a json stream' it 'respects the "before" option' do stream_writer.write_object do |object_writer| object_writer.write_key_value('foo', 'bar', before: "\n ") end expect(stream.string).to eq("{\n \"foo\":\"bar\"}") end it 'respects the "between" option' do stream_writer.write_object do |object_writer| object_writer.write_key_value('foo', 'bar', between: ' ') end expect(stream.string).to eq('{"foo": "bar"}') end describe '#write_key_value' do it 'converts all keys to strings' do stream_writer.write_object do |object_writer| object_writer.write_key_value(123, 'abc') end expect(stream.string).to eq(utf8('{"123":"abc"}')) end it 'supports non-string values' do stream_writer.write_object do |object_writer| object_writer.write_key_value('abc', 123) object_writer.write_key_value('def', true) end expect(stream.string).to eq(utf8('{"abc":123,"def":true}')) end end describe '#close' do it 'closes the underlying stream' do stream_writer.close expect(stream).to be_closed end end end