1 ! Copyright (C) 2005, 2009 Daniel Ehrenberg
2 ! See http://factorcode.org/license.txt for BSD license.
3 USING: xml.data xml.writer tools.test fry xml kernel multiline
4 xml.writer.private io.streams.string xml.traversal sequences
5 io.encodings.utf8 io.files accessors io.directories ;
9 \ xml>string must-infer
10 \ pprint-xml must-infer
11 ! Add a test for pprint-xml with sensitive-tags
13 [ "foo" ] [ T{ name { main "foo" } } name>string ] unit-test
14 [ "foo" ] [ T{ name { space "" } { main "foo" } } name>string ] unit-test
15 [ "ns:foo" ] [ T{ name { space "ns" } { main "foo" } } name>string ] unit-test
17 : reprints-as ( to from -- )
18 [ ] [ string>xml xml>string ] bi-curry* unit-test ;
20 : pprint-reprints-as ( to from -- )
21 [ ] [ string>xml pprint-xml>string ] bi-curry* unit-test ;
23 : reprints-same ( string -- ) dup reprints-as ;
25 "<?xml version=\"1.0\" encoding=\"UTF-8\"?><x/>" reprints-same
27 {" <?xml version="1.0" encoding="UTF-8"?>
28 <!DOCTYPE foo [<!ENTITY foo "bar">]>
30 {" <?xml version="1.0" encoding="UTF-8"?>
31 <!DOCTYPE foo [<!ENTITY foo 'bar'>]>
32 <x>&foo;</x> "} reprints-as
34 {" <?xml version="1.0" encoding="UTF-8"?>
38 <!ATTLIST list type (bullets|ordered|glossary) "ordered">
40 <?baz bing bang bong?>
46 {" <?xml version="1.0" encoding="UTF-8"?>
47 <!DOCTYPE foo [ <!ENTITY foo 'bar'> <!ELEMENT br EMPTY>
49 type (bullets|ordered|glossary) "ordered">
50 <!NOTATION foo bar> <?baz bing bang bong?>
53 <x>&foo;</x>"} pprint-reprints-as
55 [ t ] [ "<!DOCTYPE html PUBLIC \"-//W3C//DTD XHTML 1.1//EN\" \"http://www.w3.org/TR/xhtml11/DTD/xhtml11.dtd\" >" dup string>xml-chunk xml>string = ] unit-test
56 [ "<?xml version=\"1.0\" encoding=\"UTF-8\"?><a b=\"c\"/>" ]
57 [ "<a b='c'/>" string>xml xml>string ] unit-test
58 [ "<?xml version=\"1.0\" encoding=\"UTF-8\"?><foo>bar baz</foo>" ]
59 [ "<foo>bar</foo>" string>xml [ " baz" append ] map xml>string ] unit-test
60 [ "<?xml version=\"1.0\" encoding=\"UTF-8\"?>\n<foo>\n bar\n</foo>" ]
61 [ "<foo> bar </foo>" string>xml pprint-xml>string ] unit-test
62 [ "<foo'>" ] [ "<foo'>" <unescaped> xml>string ] unit-test
64 : test-file "resource:basis/xml/writer/test.xml" ;
66 [ ] [ "<?xml version='1.0' encoding='UTF-16BE'?><x/>" string>xml test-file utf8 [ write-xml ] with-file-writer ] unit-test
67 [ "x" ] [ test-file file>xml body>> name>> main>> ] unit-test
68 [ ] [ test-file delete-file ] unit-test