aboutsummaryrefslogtreecommitdiffhomepage
path: root/vendor/github.com/tdewolff/minify/svg/svg_test.go
diff options
context:
space:
mode:
Diffstat (limited to 'vendor/github.com/tdewolff/minify/svg/svg_test.go')
-rw-r--r--vendor/github.com/tdewolff/minify/svg/svg_test.go199
1 files changed, 0 insertions, 199 deletions
diff --git a/vendor/github.com/tdewolff/minify/svg/svg_test.go b/vendor/github.com/tdewolff/minify/svg/svg_test.go
deleted file mode 100644
index bc43b0c..0000000
--- a/vendor/github.com/tdewolff/minify/svg/svg_test.go
+++ /dev/null
@@ -1,199 +0,0 @@
-package svg // import "github.com/tdewolff/minify/svg"
-
-import (
- "bytes"
- "fmt"
- "io"
- "os"
- "testing"
-
- "github.com/tdewolff/minify"
- "github.com/tdewolff/minify/css"
- "github.com/tdewolff/test"
-)
-
-func TestSVG(t *testing.T) {
- svgTests := []struct {
- svg string
- expected string
- }{
- {`<!-- comment -->`, ``},
- {`<!DOCTYPE svg SYSTEM "foo.dtd">`, ``},
- {`<!DOCTYPE svg PUBLIC "-//W3C//DTD SVG 1.1//EN" "foo.dtd" [ <!ENTITY x "bar"> ]>`, `<!DOCTYPE svg PUBLIC "-//W3C//DTD SVG 1.1//EN" "foo.dtd" [ <!ENTITY x "bar"> ]>`},
- {`<!DOCTYPE svg SYSTEM "foo.dtd">`, ``},
- {`<?xml version="1.0" ?>`, ``},
- {`<style> <![CDATA[ x ]]> </style>`, `<style>x</style>`},
- {`<style> <![CDATA[ <<<< ]]> </style>`, `<style>&lt;&lt;&lt;&lt;</style>`},
- {`<style> <![CDATA[ <<<<< ]]> </style>`, `<style><![CDATA[ <<<<< ]]></style>`},
- {`<style/><![CDATA[ <<<<< ]]>`, `<style/><![CDATA[ <<<<< ]]>`},
- {`<svg version="1.0"></svg>`, `<svg version="1.0"/>`},
- {`<svg version="1.1" x="0" y="0px" width="100%" height="100%"><path/></svg>`, `<svg><path/></svg>`},
- {`<path x="a"> </path>`, `<path x="a"/>`},
- {`<path x=" a "/>`, `<path x="a"/>`},
- {"<path x=\" a \n b \"/>", `<path x="a b"/>`},
- {`<path x="5.0px" y="0%"/>`, `<path x="5" y="0"/>`},
- {`<svg viewBox="5.0px 5px 240IN px"><path/></svg>`, `<svg viewBox="5 5 240in px"><path/></svg>`},
- {`<svg viewBox="5.0!5px"><path/></svg>`, `<svg viewBox="5!5px"><path/></svg>`},
- {`<path d="M 100 100 L 300 100 L 200 100 z"/>`, `<path d="M1e2 1e2H3e2 2e2z"/>`},
- {`<path d="M100 -100M200 300z"/>`, `<path d="M1e2-1e2M2e2 3e2z"/>`},
- {`<path d="M0.5 0.6 M -100 0.5z"/>`, `<path d="M.5.6M-1e2.5z"/>`},
- {`<path d="M01.0 0.6 z"/>`, `<path d="M1 .6z"/>`},
- {`<path d="M20 20l-10-10z"/>`, `<path d="M20 20 10 10z"/>`},
- {`<?xml version="1.0" encoding="utf-8"?>`, ``},
- {`<svg viewbox="0 0 16 16"><path/></svg>`, `<svg viewbox="0 0 16 16"><path/></svg>`},
- {`<g></g>`, `<g/>`},
- {`<g><path/></g>`, `<g><path/></g>`},
- {`<g id="a"><g><path/></g></g>`, `<g id="a"><g><path/></g></g>`},
- {`<path fill="#ffffff"/>`, `<path fill="#fff"/>`},
- {`<path fill="#fff"/>`, `<path fill="#fff"/>`},
- {`<path fill="white"/>`, `<path fill="#fff"/>`},
- {`<path fill="#ff0000"/>`, `<path fill="red"/>`},
- {`<line x1="5" y1="10" x2="20" y2="40"/>`, `<path d="M5 10 20 40z"/>`},
- {`<rect x="5" y="10" width="20" height="40"/>`, `<path d="M5 10h20v40H5z"/>`},
- {`<rect x="-5.669" y="147.402" fill="#843733" width="252.279" height="14.177"/>`, `<path fill="#843733" d="M-5.669 147.402h252.279v14.177H-5.669z"/>`},
- {`<rect x="5" y="10" rx="2" ry="3"/>`, `<rect x="5" y="10" rx="2" ry="3"/>`},
- {`<rect x="5" y="10" height="40"/>`, ``},
- {`<rect x="5" y="10" width="30" height="0"/>`, ``},
- {`<polygon points="1,2 3,4"/>`, `<path d="M1 2 3 4z"/>`},
- {`<polyline points="1,2 3,4"/>`, `<path d="M1 2 3 4"/>`},
- {`<svg contentStyleType="text/json ; charset=iso-8859-1"><style>{a : true}</style></svg>`, `<svg contentStyleType="text/json;charset=iso-8859-1"><style>{a : true}</style></svg>`},
- {`<metadata><dc:title /></metadata>`, ``},
-
- // from SVGO
- {`<!DOCTYPE bla><?xml?><!-- comment --><metadata/>`, ``},
-
- {`<polygon fill="none" stroke="#000" points="-0.1,"/>`, `<polygon fill="none" stroke="#000" points="-0.1,"/>`}, // #45
- {`<path stroke="url(#UPPERCASE)"/>`, `<path stroke="url(#UPPERCASE)"/>`}, // #117
-
- // go fuzz
- {`<0 d=09e9.6e-9e0`, `<0 d=""`},
- {`<line`, `<line`},
- }
-
- m := minify.New()
- for _, tt := range svgTests {
- t.Run(tt.svg, func(t *testing.T) {
- r := bytes.NewBufferString(tt.svg)
- w := &bytes.Buffer{}
- err := Minify(m, w, r, nil)
- test.Minify(t, tt.svg, err, w.String(), tt.expected)
- })
- }
-}
-
-func TestSVGStyle(t *testing.T) {
- svgTests := []struct {
- svg string
- expected string
- }{
- {`<style> a > b {} </style>`, `<style>a>b{}</style>`},
- {`<style> <![CDATA[ @media x < y {} ]]> </style>`, `<style>@media x &lt; y{}</style>`},
- {`<style> <![CDATA[ * { content: '<<<<<'; } ]]> </style>`, `<style><![CDATA[*{content:'<<<<<'}]]></style>`},
- {`<style/><![CDATA[ * { content: '<<<<<'; ]]>`, `<style/><![CDATA[ * { content: '<<<<<'; ]]>`},
- {`<path style="fill: black; stroke: #ff0000;"/>`, `<path style="fill:#000;stroke:red"/>`},
- }
-
- m := minify.New()
- m.AddFunc("text/css", css.Minify)
- for _, tt := range svgTests {
- t.Run(tt.svg, func(t *testing.T) {
- r := bytes.NewBufferString(tt.svg)
- w := &bytes.Buffer{}
- err := Minify(m, w, r, nil)
- test.Minify(t, tt.svg, err, w.String(), tt.expected)
- })
- }
-}
-
-func TestSVGDecimals(t *testing.T) {
- var svgTests = []struct {
- svg string
- expected string
- }{
- {`<svg x="1.234" y="0.001" width="1.001"><path/></svg>`, `<svg x="1.2" width="1"><path/></svg>`},
- }
-
- m := minify.New()
- o := &Minifier{Decimals: 1}
- for _, tt := range svgTests {
- t.Run(tt.svg, func(t *testing.T) {
- r := bytes.NewBufferString(tt.svg)
- w := &bytes.Buffer{}
- err := o.Minify(m, w, r, nil)
- test.Minify(t, tt.svg, err, w.String(), tt.expected)
- })
- }
-}
-
-func TestReaderErrors(t *testing.T) {
- r := test.NewErrorReader(0)
- w := &bytes.Buffer{}
- m := minify.New()
- err := Minify(m, w, r, nil)
- test.T(t, err, test.ErrPlain, "return error at first read")
-}
-
-func TestWriterErrors(t *testing.T) {
- errorTests := []struct {
- svg string
- n []int
- }{
- {`<!DOCTYPE svg PUBLIC "-//W3C//DTD SVG 1.1//EN" "foo.dtd" [ <!ENTITY x "bar"> ]>`, []int{0}},
- {`abc`, []int{0}},
- {`<style>abc</style>`, []int{2}},
- {`<![CDATA[ <<<< ]]>`, []int{0}},
- {`<![CDATA[ <<<<< ]]>`, []int{0}},
- {`<path d="x"/>`, []int{0, 1, 2, 3, 4, 5}},
- {`<path></path>`, []int{1}},
- {`<svg>x</svg>`, []int{1, 3}},
- {`<svg>x</svg >`, []int{3}},
- }
-
- m := minify.New()
- for _, tt := range errorTests {
- for _, n := range tt.n {
- t.Run(fmt.Sprint(tt.svg, " ", tt.n), func(t *testing.T) {
- r := bytes.NewBufferString(tt.svg)
- w := test.NewErrorWriter(n)
- err := Minify(m, w, r, nil)
- test.T(t, err, test.ErrPlain)
- })
- }
- }
-}
-
-func TestMinifyErrors(t *testing.T) {
- errorTests := []struct {
- svg string
- err error
- }{
- {`<style>abc</style>`, test.ErrPlain},
- {`<style><![CDATA[abc]]></style>`, test.ErrPlain},
- {`<path style="abc"/>`, test.ErrPlain},
- }
-
- m := minify.New()
- m.AddFunc("text/css", func(_ *minify.M, w io.Writer, r io.Reader, _ map[string]string) error {
- return test.ErrPlain
- })
- for _, tt := range errorTests {
- t.Run(tt.svg, func(t *testing.T) {
- r := bytes.NewBufferString(tt.svg)
- w := &bytes.Buffer{}
- err := Minify(m, w, r, nil)
- test.T(t, err, tt.err)
- })
- }
-}
-
-////////////////////////////////////////////////////////////////
-
-func ExampleMinify() {
- m := minify.New()
- m.AddFunc("image/svg+xml", Minify)
- m.AddFunc("text/css", css.Minify)
-
- if err := m.Minify("image/svg+xml", os.Stdout, os.Stdin); err != nil {
- panic(err)
- }
-}