Skip to content

Commit

Permalink
Closes #134 add tests to show all sanitize methods are roughly equal …
Browse files Browse the repository at this point in the history
…in time
  • Loading branch information
buro9 committed Jul 1, 2022
1 parent ed50dcc commit 9ef01f7
Showing 1 changed file with 63 additions and 0 deletions.
63 changes: 63 additions & 0 deletions sanitize_test.go
Expand Up @@ -30,6 +30,7 @@
package bluemonday

import (
"bytes"
"encoding/base64"
"net/url"
"regexp"
Expand Down Expand Up @@ -3711,6 +3712,68 @@ func TestIssue107(t *testing.T) {
wg.Wait()
}

func TestIssue134(t *testing.T) {
// Do all the methods work?
//
// Are all the times roughly consistent?
in := `<p style="width:100%;height:100%;background-image: url('')"></p>`
expected := `<p style="width:100%;height:100%;background-image: url(&#39;&#39;)"></p>`

p := UGCPolicy()
p.AllowAttrs("style").OnElements("p")

t.Run("Sanitize", func(t *testing.T) {
out := p.Sanitize(in)
if out != expected {
t.Errorf(
"test failed;\ninput : %s\noutput : %s\nexpected: %s",
in,
out,
expected,
)
}
})

t.Run("SanitizeReader", func(t *testing.T) {
out := p.SanitizeReader(strings.NewReader(in)).String()
if out != expected {
t.Errorf(
"test failed;\ninput : %s\noutput : %s\nexpected: %s",
in,
out,
expected,
)
}
})

t.Run("SanitizeBytes", func(t *testing.T) {
out := string(p.SanitizeBytes([]byte(in)))
if out != expected {
t.Errorf(
"test failed;\ninput : %s\noutput : %s\nexpected: %s",
in,
out,
expected,
)
}
})

t.Run("SanitizeReaderToWriter", func(t *testing.T) {
var buff bytes.Buffer
var out string
p.SanitizeReaderToWriter(strings.NewReader(in), &buff)
out = (&buff).String()
if out != expected {
t.Errorf(
"test failed;\ninput : %s\noutput : %s\nexpected: %s",
in,
out,
expected,
)
}
})
}

func TestIssue139(t *testing.T) {
// HTML escaping of attribute values appears to occur twice
tests := []test{
Expand Down

0 comments on commit 9ef01f7

Please sign in to comment.