123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596 |
- // Copyright 2020 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 app
- import (
- "testing"
- "github.com/stretchr/testify/assert"
- )
- func Test_ipynbSanitizer(t *testing.T) {
- p := ipynbSanitizer()
- tests := []struct {
- name string
- input string
- want string
- }{
- {
- name: "allow 'class' and 'data-prompt-number' attributes",
- input: `
- <div class="nb-notebook">
- <div class="nb-worksheet">
- <div class="nb-cell nb-markdown-cell">Hello world</div>
- <div class="nb-cell nb-code-cell">
- <div class="nb-input" data-prompt-number="4">
- </div>
- </div>
- </div>
- </div>
- `,
- want: `
- <div class="nb-notebook">
- <div class="nb-worksheet">
- <div class="nb-cell nb-markdown-cell">Hello world</div>
- <div class="nb-cell nb-code-cell">
- <div class="nb-input" data-prompt-number="4">
- </div>
- </div>
- </div>
- </div>
- `,
- },
- {
- name: "allow base64 encoded images",
- input: `
- <div class="nb-output" data-prompt-number="4">
- <img class="nb-image-output" src=""/>
- </div>
- `,
- want: `
- <div class="nb-output" data-prompt-number="4">
- <img class="nb-image-output" src=""/>
- </div>
- `,
- },
- {
- name: "prevent XSS",
- input: `
- <div class="nb-output" data-prompt-number="10">
- <div class="nb-html-output">
- <style>
- .output {
- align-items: center;
- background: #00ff00;
- }
- </style>
- <script>
- function test() {
- alert("test");
- }
- $(document).ready(test);
- </script>
- </div>
- </div>
- `,
- want: `
- <div class="nb-output" data-prompt-number="10">
- <div class="nb-html-output">
- </div>
- </div>
- `,
- },
- }
- for _, test := range tests {
- t.Run(test.name, func(t *testing.T) {
- assert.Equal(t, test.want, p.Sanitize(test.input))
- })
- }
- }
|