yukari/morty_test.go
asciimoo 9e1281027d [enh] add sanitizer benchmark
git-svn-id: file:///srv/svn/repo/yukari/trunk@22 f3bd38d9-da89-464d-a02a-eb04e43141b5
2016-10-30 16:51:27 +00:00

106 lines
2.3 KiB
Go

package main
import (
"bytes"
"net/url"
"testing"
)
type AttrTestCase struct {
AttrName []byte
AttrValue []byte
ExpectedOutput []byte
}
var attrTestData []*AttrTestCase = []*AttrTestCase{
&AttrTestCase{
[]byte("href"),
[]byte("./x"),
[]byte(` href="./?mortyurl=http%3A%2F%2F127.0.0.1%2Fx"`),
},
&AttrTestCase{
[]byte("src"),
[]byte("http://x.com/y"),
[]byte(` src="./?mortyurl=http%3A%2F%2Fx.com%2Fy"`),
},
&AttrTestCase{
[]byte("action"),
[]byte("/z"),
[]byte(` action="./?mortyurl=http%3A%2F%2F127.0.0.1%2Fz"`),
},
&AttrTestCase{
[]byte("onclick"),
[]byte("console.log(document.cookies)"),
nil,
},
}
func TestAttrSanitizer(t *testing.T) {
u, _ := url.Parse("http://127.0.0.1/")
rc := &RequestConfig{BaseURL: u}
for _, testCase := range attrTestData {
out := bytes.NewBuffer(nil)
sanitizeAttr(rc, out, testCase.AttrName, testCase.AttrValue, testCase.AttrValue)
res, _ := out.ReadBytes(byte(0))
if !bytes.Equal(res, testCase.ExpectedOutput) {
t.Errorf(
`Attribute parse error. Name: "%s", Value: "%s", Expected: %s, Got: %s`,
testCase.AttrName,
testCase.AttrValue,
testCase.ExpectedOutput,
res,
)
}
}
}
var BENCH_SIMPLE_HTML []byte = []byte(`<!doctype html>
<html>
<head>
<title>test</title>
</head>
<body>
<h1>Test heading</h1>
</body>
</html>`)
func BenchmarkSanitizeSimpleHTML(b *testing.B) {
u, _ := url.Parse("http://127.0.0.1/")
rc := &RequestConfig{BaseURL: u}
b.ResetTimer()
for i := 0; i < b.N; i++ {
out := bytes.NewBuffer(nil)
sanitizeHTML(rc, out, BENCH_SIMPLE_HTML)
}
}
var BENCH_COMPLEX_HTML []byte = []byte(`<!doctype html>
<html>
<head>
<noscript><meta http-equiv="refresh" content="0; URL=./xy"></noscript>
<title>test 2</title>
<script> alert('xy'); </script>
<link rel="stylesheet" href="./core.bundle.css">
<style>
html { background: url(./a.jpg); }
</style
</head>
<body>
<h1>Test heading</h1>
<img src="b.png" alt="imgtitle" />
<form action="/z">
<input type="submit" style="background: url(http://aa.bb/cc)" >
</form>
</body>
</html>`)
func BenchmarkSanitizeComplexHTML(b *testing.B) {
u, _ := url.Parse("http://127.0.0.1/")
rc := &RequestConfig{BaseURL: u}
b.ResetTimer()
for i := 0; i < b.N; i++ {
out := bytes.NewBuffer(nil)
sanitizeHTML(rc, out, BENCH_COMPLEX_HTML)
}
}