File: base.py

package info (click to toggle)
graphite-web 1.2.1~pre2-1
  • links: PTS, VCS
  • area: main
  • in suites: forky, sid
  • size: 8,976 kB
  • sloc: javascript: 86,824; python: 25,420; makefile: 124; sh: 91; ruby: 74; perl: 24
file content (27 lines) | stat: -rw-r--r-- 852 bytes parent folder | download
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
from django.test import TestCase as OriginalTestCase
from graphite.worker_pool.pool import stop_pools


def is_unsafe_str(s):
    for symbol in '<>':
        if s.find(symbol) >= 0:
            return True
    return False


class TestCase(OriginalTestCase):
    def tearDown(self):
        stop_pools()

    # Assert that a response is unsanitized (for check XSS issues)
    def assertXSS(self, response, status_code=200, msg_prefix=''):
        if status_code is not None:
            self.assertEqual(
                response.status_code, status_code,
                msg_prefix + "Couldn't retrieve content: Response code was %d"
                " (expected %d)" % (response.status_code, status_code)
            )

        content = str(response.content)
        xss = is_unsafe_str(content)
        self.assertFalse(xss, msg=msg_prefix+content)