mirror of https://github.com/gogits/gogs.git
You can not select more than 25 topics
Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.
38 lines
1.2 KiB
38 lines
1.2 KiB
// Copyright 2017 The Gogs Authors. All rights reserved. |
|
// Use of this source code is governed by a MIT-style |
|
// license that can be found in the LICENSE file. |
|
|
|
package markup_test |
|
|
|
import ( |
|
"testing" |
|
|
|
. "github.com/smartystreets/goconvey/convey" |
|
|
|
. "github.com/gogs/gogs/pkg/markup" |
|
) |
|
|
|
func Test_Sanitizer(t *testing.T) { |
|
NewSanitizer() |
|
Convey("Sanitize HTML string and bytes", t, func() { |
|
testCases := []string{ |
|
// Regular |
|
`<a onblur="alert(secret)" href="http://www.google.com">Google</a>`, `<a href="http://www.google.com" rel="nofollow">Google</a>`, |
|
|
|
// Code highlighting class |
|
`<code class="random string"></code>`, `<code></code>`, |
|
`<code class="language-random ui tab active menu attached animating sidebar following bar center"></code>`, `<code></code>`, |
|
`<code class="language-go"></code>`, `<code class="language-go"></code>`, |
|
|
|
// Input checkbox |
|
`<input type="hidden">`, ``, |
|
`<input type="checkbox">`, `<input type="checkbox">`, |
|
`<input checked disabled autofocus>`, `<input checked="" disabled="">`, |
|
} |
|
|
|
for i := 0; i < len(testCases); i += 2 { |
|
So(Sanitize(testCases[i]), ShouldEqual, testCases[i+1]) |
|
So(string(SanitizeBytes([]byte(testCases[i]))), ShouldEqual, testCases[i+1]) |
|
} |
|
}) |
|
}
|
|
|