| 123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347348349350351352353354355356357358359360361362363364365366367368369370371372373374375376377378379380381382383384385386387388389390391392393394395396397398399400401402403404405406407408409410411412413414415416417418419420421422423424425426427428429430431432433434435436437438439440441442443444445446447448449450451452453454455456457458459460461462463464465466467468469470471472473474475476477478 |
- //
- // XmlDictionaryWriterTest.cs
- //
- // Author:
- // Jonathan Pryor <[email protected]>
- //
- // Copyright (C) 2009 Novell, Inc. http://www.novell.com
- //
- // Permission is hereby granted, free of charge, to any person obtaining
- // a copy of this software and associated documentation files (the
- // "Software"), to deal in the Software without restriction, including
- // without limitation the rights to use, copy, modify, merge, publish,
- // distribute, sublicense, and/or sell copies of the Software, and to
- // permit persons to whom the Software is furnished to do so, subject to
- // the following conditions:
- //
- // The above copyright notice and this permission notice shall be
- // included in all copies or substantial portions of the Software.
- //
- // THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND,
- // EXPRESS OR IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF
- // MERCHANTABILITY, FITNESS FOR A PARTICULAR PURPOSE AND
- // NONINFRINGEMENT. IN NO EVENT SHALL THE AUTHORS OR COPYRIGHT HOLDERS BE
- // LIABLE FOR ANY CLAIM, DAMAGES OR OTHER LIABILITY, WHETHER IN AN ACTION
- // OF CONTRACT, TORT OR OTHERWISE, ARISING FROM, OUT OF OR IN CONNECTION
- // WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN THE SOFTWARE.
- //
- #define TRACE
- using System;
- using System.Diagnostics;
- using System.IO;
- using System.Text;
- using System.Xml;
- using NUnit.Framework;
- namespace MonoTests.System.Xml
- {
- class WriteTextNodeEventArgs : EventArgs {
- public XmlDictionaryReader Reader;
- public bool IsAttribute;
- }
- class DelegatingXmlDictionaryWriter : XmlDictionaryWriter
- {
- XmlWriter d;
- public DelegatingXmlDictionaryWriter (XmlWriter delegateTo)
- {
- d = delegateTo;
- }
- //
- // XmlWriter Methods
- //
- public override WriteState WriteState {
- get {return d.WriteState;}
- }
- public override void Close ()
- {
- d.Close ();
- }
- public override void Flush ()
- {
- d.Flush ();
- }
- public override string LookupPrefix (string ns)
- {
- return d.LookupPrefix (ns);
- }
- public override void WriteBase64 (byte[] buffer, int index, int count)
- {
- var e = WriteBase64Event;
- if (e != null)
- e (this, new EventArgs ());
- d.WriteBase64 (buffer, index, count);
- }
- public override void WriteCData (string text)
- {
- d.WriteCData (text);
- }
- public override void WriteCharEntity (char ch)
- {
- d.WriteCharEntity (ch);
- }
- public override void WriteChars (char[] buffer, int index, int count)
- {
- d.WriteChars (buffer, index, count);
- }
- public override void WriteComment (string text)
- {
- d.WriteComment (text);
- }
- public override void WriteDocType (string name, string pubid, string sysid, string subset)
- {
- d.WriteDocType (name, pubid, sysid, subset);
- }
- public override void WriteEndAttribute ()
- {
- d.WriteEndAttribute ();
- }
- public override void WriteEndDocument ()
- {
- d.WriteEndDocument ();
- }
- public override void WriteEndElement ()
- {
- d.WriteEndElement ();
- }
- public override void WriteEntityRef (string name)
- {
- d.WriteEntityRef (name);
- }
- public override void WriteFullEndElement ()
- {
- d.WriteFullEndElement ();
- }
- public override void WriteProcessingInstruction (string name, string text)
- {
- d.WriteProcessingInstruction (name, text);
- }
- public override void WriteRaw (char[] buffer, int index, int count)
- {
- d.WriteRaw (buffer, index, count);
- }
- public override void WriteRaw (string data)
- {
- d.WriteRaw (data);
- }
- public override void WriteStartAttribute (string prefix, string localName, string ns)
- {
- d.WriteStartAttribute (prefix, localName, ns);
- }
- public override void WriteStartDocument ()
- {
- d.WriteStartDocument ();
- }
- public override void WriteStartDocument (bool standalone)
- {
- d.WriteStartDocument (standalone);
- }
- public override void WriteStartElement (string prefix, string localName, string ns)
- {
- d.WriteStartElement (prefix, localName, ns);
- }
- public override void WriteString (string text)
- {
- d.WriteString (text);
- }
- public override void WriteSurrogateCharEntity (char lowChar, char highChar)
- {
- d.WriteSurrogateCharEntity (lowChar, highChar);
- }
- public override void WriteWhitespace (string ws)
- {
- d.WriteWhitespace (ws);
- }
- //
- // XmlDictionaryWriter methods
- //
- protected override void WriteTextNode (XmlDictionaryReader reader, bool isAttribute)
- {
- var e = WriteTextNodeEvent;
- if (e != null)
- e (this, new WriteTextNodeEventArgs { Reader = reader, IsAttribute = isAttribute });
- base.WriteTextNode (reader, isAttribute);
- }
- public void TestWriteTextNode (XmlDictionaryReader reader, bool isAttribute)
- {
- base.WriteTextNode (reader, isAttribute);
- }
- public event EventHandler<EventArgs> WriteBase64Event;
- public event EventHandler<WriteTextNodeEventArgs> WriteTextNodeEvent;
- }
- class ReleaseStreamEventArgs : EventArgs {
- public Stream Stream;
- }
- class DummyStreamProvider : IStreamProvider {
- public Stream Stream;
- public Stream GetStream ()
- {
- var e = GetStreamEvent;
- if (e != null)
- e (this, new EventArgs ());
- return Stream;
- }
- public void ReleaseStream (Stream stream)
- {
- var e = ReleaseStreamEvent;
- if (e != null)
- e (this, new ReleaseStreamEventArgs { Stream = stream });
- }
- public event EventHandler<EventArgs> GetStreamEvent;
- public event EventHandler<ReleaseStreamEventArgs> ReleaseStreamEvent;
- }
- [TestFixture]
- public class XmlDictionaryWriterTest
- {
- DelegatingXmlDictionaryWriter writer;
- StringBuilder contents;
- [SetUp]
- public void Setup()
- {
- var s = new XmlWriterSettings ();
- s.ConformanceLevel = ConformanceLevel.Fragment;
- s.OmitXmlDeclaration = true;
- writer = new DelegatingXmlDictionaryWriter (
- XmlWriter.Create (contents = new StringBuilder (), s));
- }
- [TearDown]
- public void TearDown()
- {
- contents = null;
- writer = null;
- }
- [Test, ExpectedException (typeof (ArgumentException))]
- public void WriteElementString_localNameNull ()
- {
- XmlDictionaryString localName = null, namespaceUri = null;
- string prefix = null, value = null;
- writer.WriteElementString (prefix, localName, namespaceUri, value);
- }
- [Test, ExpectedException (typeof (ArgumentException))]
- public void WriteElementString_PrefixWithEmptyNamespace ()
- {
- XmlDictionary d = new XmlDictionary ();
- XmlDictionaryString localName = d.Add ("foo"), namespaceUri = null;
- string prefix = "ns", value = null;
- writer.WriteElementString (prefix, localName, namespaceUri, value);
- }
- [Test]
- public void WriteElementString ()
- {
- XmlDictionary d = new XmlDictionary ();
- XmlDictionaryString foo = d.Add ("foo");
- XmlDictionaryString fooUri = d.Add ("urn:bar");
- string ns = "ns";
- //
- // Skipping empty string values because Mono & .NET generate
- // different XML: <foo /> (Mono) vs. <foo></foo> (.NET).
- //
- writer.WriteElementString (null, foo, null, "data");
- // writer.WriteElementString (null, foo, null, "");
- writer.WriteElementString (null, foo, null, null);
- writer.WriteElementString (null, foo, fooUri, "data");
- // writer.WriteElementString (null, foo, fooUri, "");
- writer.WriteElementString (null, foo, fooUri, null);
- writer.WriteElementString (ns, foo, fooUri, "data");
- // writer.WriteElementString (ns, foo, fooUri, "");
- writer.WriteElementString (ns, foo, fooUri, null);
- writer.Flush ();
- Assert.AreEqual (
- "<foo>data</foo><foo />" +
- "<foo xmlns=\"urn:bar\">data</foo><foo xmlns=\"urn:bar\" />" +
- "<ns:foo xmlns:ns=\"urn:bar\">data</ns:foo><ns:foo xmlns:ns=\"urn:bar\" />",
- contents.ToString ());
- }
- [Test, ExpectedException (typeof (ArgumentNullException))]
- public void WriteNode_XmlDictionaryReader_ReaderNull ()
- {
- XmlDictionaryReader reader = null;
- writer.WriteNode (reader, true);
- }
- [Test]
- public void WriteNode_XmlDictionaryReader ()
- {
- string xml = "<outer attr='a'>data<inner attr='b'>more-data</inner>end</outer>";
- XmlDictionaryReader reader = XmlDictionaryReader.CreateDictionaryReader (
- XmlReader.Create (new StringReader (xml)));
- int writeTextNodeCount = 0;
- writer.WriteTextNodeEvent += (o, e) => {
- ++writeTextNodeCount;
- writer.WriteString ("[text]");
- };
- writer.WriteNode (reader, false);
- writer.Flush ();
- Assert.AreEqual (5, writeTextNodeCount);
- Assert.AreEqual (
- "<outer attr=\"[text]a\">[text]data<inner attr=\"[text]b\">[text]more-data</inner>[text]end</outer>",
- contents.ToString ());
- }
- [Test, ExpectedException (typeof (ArgumentNullException))]
- public void WriteNode_XmlReader_ReaderNull ()
- {
- XmlReader reader = null;
- writer.WriteNode (reader, true);
- }
- [Test]
- public void WriteNode_XmlReader ()
- {
- string xml = "<outer attr='a'>data<inner attr='b'>more-data</inner>end</outer>";
- XmlReader reader = XmlReader.Create (new StringReader (xml));
- int writeTextNodeCount = 0;
- writer.WriteTextNodeEvent += (o, e) => {
- ++writeTextNodeCount;
- writer.WriteString ("[text]");
- };
- writer.WriteNode (reader, false);
- writer.Flush ();
- Assert.AreEqual (0, writeTextNodeCount);
- Assert.AreEqual (
- "<outer attr=\"a\">data<inner attr=\"b\">more-data</inner>end</outer>",
- contents.ToString ());
- }
- [Test, ExpectedException (typeof (NullReferenceException))]
- public void WriteTextNode_ReaderNull ()
- {
- writer.TestWriteTextNode (null, false);
- }
- [Test]
- public void WriteTextNode ()
- {
- string xml = "<foo attr='a'>data</foo>";
- XmlDictionaryReader reader = XmlDictionaryReader.CreateDictionaryReader (
- XmlReader.Create (new StringReader (xml)));
- reader.MoveToContent ();
- reader.MoveToFirstAttribute ();
- Assert.AreEqual (XmlNodeType.Attribute, reader.NodeType);
- writer.TestWriteTextNode (reader, true);
- writer.Flush ();
- Assert.AreEqual (XmlNodeType.Attribute, reader.NodeType);
- Assert.AreEqual ("a", contents.ToString ());
- contents.Length = 0;
- writer.TestWriteTextNode (reader, false);
- writer.Flush ();
- Assert.AreEqual ("a", contents.ToString ());
- Assert.AreEqual (XmlNodeType.Text, reader.NodeType);
- contents.Length = 0;
- writer.TestWriteTextNode (reader, true);
- writer.Flush ();
- Assert.AreEqual ("data", contents.ToString ());
- Assert.AreEqual (XmlNodeType.Text, reader.NodeType);
- contents.Length = 0;
- writer.TestWriteTextNode (reader, false);
- writer.Flush ();
- Assert.AreEqual ("data", contents.ToString ());
- Assert.AreNotEqual (XmlNodeType.Text, reader.NodeType);
- }
- [Test]
- public void WriteValue_Guid ()
- {
- writer.WriteValue (new Guid ());
- writer.Flush ();
- Assert.AreEqual (new Guid().ToString (), contents.ToString ());
- }
- [Test, ExpectedException (typeof (ArgumentNullException))]
- public void WriteValue_IStreamProvider_ValueNull ()
- {
- IStreamProvider value = null;
- writer.WriteValue (value);
- }
- [Test]
- public void WriteValue_IStreamProvider ()
- {
- byte[] data = Encoding.UTF8.GetBytes ("Hello, Worlds!!");
- int getStreamCount = 0;
- int releaseStreamCount = 0;
- var provider = new DummyStreamProvider {
- Stream = new MemoryStream (data)
- };
- provider.GetStreamEvent += (o, e) => { ++getStreamCount; };
- provider.ReleaseStreamEvent += (o, e) => {
- ++releaseStreamCount;
- Assert.IsTrue (object.ReferenceEquals (provider.Stream, e.Stream));
- };
- writer.WriteValue (provider);
- writer.Flush ();
- Assert.AreEqual (1, getStreamCount);
- Assert.AreEqual (1, releaseStreamCount);
- Assert.AreEqual (data.Length, provider.Stream.Position);
- Assert.AreEqual (Convert.ToBase64String (data), contents.ToString ());
- provider.Stream.Position = 0;
- writer.WriteBase64Event += (o, e) => {
- throw new Exception ("incomplete!");
- };
- getStreamCount = 0;
- releaseStreamCount = 0;
- Exception thrown = null;
- try {
- writer.WriteValue (provider);
- }
- catch (Exception e) {
- thrown = e;
- }
- Assert.IsNotNull (thrown);
- Assert.AreEqual (1, getStreamCount);
- Assert.AreEqual (0, releaseStreamCount);
- }
- [Test]
- public void WriteValue_TimeSpan ()
- {
- writer.WriteValue (new TimeSpan ());
- writer.Flush ();
- Assert.AreEqual (XmlConvert.ToString (new TimeSpan()), contents.ToString ());
- }
- [Test, ExpectedException (typeof (ArgumentNullException))]
- public void WriteValue_UniqueId_IdNull ()
- {
- UniqueId value = null;
- writer.WriteValue (value);
- }
- [Test]
- public void WriteValue_UniqueId ()
- {
- writer.WriteValue (new UniqueId (new Guid ()));
- writer.WriteValue (new UniqueId ("string"));
- writer.Flush ();
- Assert.AreEqual ("urn:uuid:" + new Guid ().ToString () + "string",
- contents.ToString ());
- }
- }
- }
|