コード例 #1
0
    def test_multipartMaxSize(self):
        """
        Check that the C{maxSize} parameter makes the parsing raise an
        exception if the data is too big.
        """
        ctype = http_headers.MimeType('multipart', 'form-data',
                                      (('boundary', '---weeboundary'),))
        content = """-----weeboundary\r
Content-Disposition: form-data; name="FileNameOne"; filename="myfilename"\r
Content-Type: text/html\r
\r
my great content wooo
and even more and more\r
-----weeboundary--\r
"""
        root = resource.Resource()
        request = SimpleRequest(
            server.Site(root), "GET", "/",
            http_headers.Headers({'content-type': ctype}), content)
        def cb(res):
            self.assertEquals(
                res.response.description,
                "Maximum length of 10 bytes exceeded.")
        return self.assertFailure(
            server.parsePOSTData(request, maxSize=10),
            http.HTTPError).addCallback(cb)
コード例 #2
0
ファイル: test_server.py プロジェクト: advatar/CalendarServer
    def test_multipart(self):
        """
        Test parsing data in multipart format: it should fill the C{files}
        attribute.
        """
        ctype = http_headers.MimeType('multipart', 'form-data',
                                      (('boundary', '---weeboundary'),))
        content = """-----weeboundary\r
Content-Disposition: form-data; name="FileNameOne"; filename="myfilename"\r
Content-Type: text/html\r
\r
my great content wooo\r
-----weeboundary--\r
"""
        root = resource.Resource()
        request = SimpleRequest(
            server.Site(root), "GET", "/",
            http_headers.Headers({'content-type': ctype}), content)

        def cb(ign):
            self.assertEquals(request.args, {})
            self.assertEquals(request.files.keys(), ['FileNameOne'])
            self.assertEquals(
                request.files.values()[0][0][:2],
                ('myfilename', http_headers.MimeType('text', 'html', {})))
            f = request.files.values()[0][0][2]
            self.assertEquals(f.read(), "my great content wooo")
        return server.parsePOSTData(request).addCallback(cb)
コード例 #3
0
    def test_multipart(self):
        """
        Test parsing data in multipart format: it should fill the C{files}
        attribute.
        """
        ctype = http_headers.MimeType('multipart', 'form-data',
                                      (('boundary', '---weeboundary'),))
        content = """-----weeboundary\r
Content-Disposition: form-data; name="FileNameOne"; filename="myfilename"\r
Content-Type: text/html\r
\r
my great content wooo\r
-----weeboundary--\r
"""
        root = resource.Resource()
        request = SimpleRequest(
            server.Site(root), "GET", "/",
            http_headers.Headers({'content-type': ctype}), content)
        def cb(ign):
            self.assertEquals(request.args, {})
            self.assertEquals(request.files.keys(), ['FileNameOne'])
            self.assertEquals(
                request.files.values()[0][0][:2],
                ('myfilename', http_headers.MimeType('text', 'html', {})))
            f = request.files.values()[0][0][2]
            self.assertEquals(f.read(), "my great content wooo")
        return server.parsePOSTData(request).addCallback(cb)
コード例 #4
0
ファイル: test_server.py プロジェクト: advatar/CalendarServer
    def test_multipartMaxSize(self):
        """
        Check that the C{maxSize} parameter makes the parsing raise an
        exception if the data is too big.
        """
        ctype = http_headers.MimeType('multipart', 'form-data',
                                      (('boundary', '---weeboundary'),))
        content = """-----weeboundary\r
Content-Disposition: form-data; name="FileNameOne"; filename="myfilename"\r
Content-Type: text/html\r
\r
my great content wooo
and even more and more\r
-----weeboundary--\r
"""
        root = resource.Resource()
        request = SimpleRequest(
            server.Site(root), "GET", "/",
            http_headers.Headers({'content-type': ctype}), content)

        def cb(res):
            self.assertEquals(
                res.response.description,
                "Maximum length of 10 bytes exceeded.")
        return self.assertFailure(
            server.parsePOSTData(request, maxSize=10),
            http.HTTPError).addCallback(cb)
コード例 #5
0
    def test_maxFields(self):
        """
        Check that the C{maxSize} parameter makes the parsing raise an
        exception if the data contains too many fields.
        """
        ctype = http_headers.MimeType('multipart', 'form-data',
                                      (('boundary', '---xyz'),))
        content = """-----xyz\r
Content-Disposition: form-data; name="foo"\r
\r
Foo Bar\r
-----xyz\r
Content-Disposition: form-data; name="foo"\r
\r
Baz\r
-----xyz\r
Content-Disposition: form-data; name="file"; filename="filename"\r
Content-Type: text/html\r
\r
blah\r
-----xyz\r
Content-Disposition: form-data; name="file"; filename="filename"\r
Content-Type: text/plain\r
\r
bleh\r
-----xyz--\r
"""
        root = resource.Resource()
        request = SimpleRequest(server.Site(root), "GET", "/",
                http_headers.Headers({'content-type': ctype}), content)
        def cb(res):
            self.assertEquals(res.response.description,
                "Maximum number of fields 3 exceeded")
        return self.assertFailure(server.parsePOSTData(request, maxFields=3),
            http.HTTPError).addCallback(cb)
コード例 #6
0
    def http_POST(self, request):
        """
        Respond to a POST request.
        Reads and parses the incoming body data then calls L{render}.

        @param request: the request to process.
        @return: an object adaptable to L{iweb.IResponse}.
        """
        return server.parsePOSTData(
            request, self.maxMem, self.maxFields,
            self.maxSize).addCallback(lambda res: self.render(request))
コード例 #7
0
ファイル: test_server.py プロジェクト: advatar/CalendarServer
 def test_wrongContentType(self):
     """
     Check that a content-type not handled raise a C{http.HTTPError}.
     """
     ctype = http_headers.MimeType('application', 'foobar')
     content = "key=value&multiple=two+words&multiple=more%20words"
     root = resource.Resource()
     request = SimpleRequest(
         server.Site(root), "GET", "/",
         http_headers.Headers({'content-type': ctype}), content)
     return self.assertFailure(server.parsePOSTData(request), http.HTTPError)
コード例 #8
0
 def test_wrongContentType(self):
     """
     Check that a content-type not handled raise a C{http.HTTPError}.
     """
     ctype = http_headers.MimeType('application', 'foobar')
     content = "key=value&multiple=two+words&multiple=more%20words"
     root = resource.Resource()
     request = SimpleRequest(
         server.Site(root), "GET", "/",
         http_headers.Headers({'content-type': ctype}), content)
     return self.assertFailure(server.parsePOSTData(request), http.HTTPError)
コード例 #9
0
 def test_noContentType(self):
     """
     Parsing a request without content-type should succeed but should not
     fill the C{args} and C{files} attributes of the request.
     """
     root = resource.Resource()
     request = SimpleRequest(server.Site(root), "GET", "/", content="foo")
     def cb(ign):
         self.assertEquals(request.args, {})
         self.assertEquals(request.files, {})
     return server.parsePOSTData(request).addCallback(cb)
コード例 #10
0
ファイル: resource.py プロジェクト: nunb/calendarserver
    def http_POST(self, request):
        """
        Respond to a POST request.
        Reads and parses the incoming body data then calls L{render}.

        @param request: the request to process.
        @return: an object adaptable to L{iweb.IResponse}.
        """
        return server.parsePOSTData(
            request, self.maxMem, self.maxFields, self.maxSize
        ).addCallback(lambda res: self.render(request))
コード例 #11
0
 def test_noContentType(self):
     """
     Parsing a request without content-type should succeed but should not
     fill the C{args} and C{files} attributes of the request.
     """
     root = resource.Resource()
     request = SimpleRequest(server.Site(root), "GET", "/", content="foo")
     def cb(ign):
         self.assertEquals(request.args, {})
         self.assertEquals(request.files, {})
     return server.parsePOSTData(request).addCallback(cb)
コード例 #12
0
 def test_urlencoded(self):
     """
     Test parsing data in urlencoded format: it should end in the C{args}
     attribute.
     """
     ctype = http_headers.MimeType('application', 'x-www-form-urlencoded')
     content = "key=value&multiple=two+words&multiple=more%20words"
     root = resource.Resource()
     request = SimpleRequest(server.Site(root), "GET", "/",
             http_headers.Headers({'content-type': ctype}), content)
     def cb(ign):
         self.assertEquals(request.files, {})
         self.assertEquals(request.args,
             {'multiple': ['two words', 'more words'], 'key': ['value']})
     return server.parsePOSTData(request).addCallback(cb)
コード例 #13
0
 def test_urlencoded(self):
     """
     Test parsing data in urlencoded format: it should end in the C{args}
     attribute.
     """
     ctype = http_headers.MimeType('application', 'x-www-form-urlencoded')
     content = "key=value&multiple=two+words&multiple=more%20words"
     root = resource.Resource()
     request = SimpleRequest(
         server.Site(root), "GET", "/",
         http_headers.Headers({'content-type': ctype}), content)
     def cb(ign):
         self.assertEquals(request.files, {})
         self.assertEquals(
             request.args,
             {'multiple': ['two words', 'more words'], 'key': ['value']})
     return server.parsePOSTData(request).addCallback(cb)
コード例 #14
0
    def test_multipartWithNoBoundary(self):
        """
        If the boundary type is not specified, parsing should fail with a
        C{http.HTTPError}.
        """
        ctype = http_headers.MimeType('multipart', 'form-data')
        content = """-----weeboundary\r
Content-Disposition: form-data; name="FileNameOne"; filename="myfilename"\r
Content-Type: text/html\r
\r
my great content wooo\r
-----weeboundary--\r
"""
        root = resource.Resource()
        request = SimpleRequest(
            server.Site(root), "GET", "/",
            http_headers.Headers({'content-type': ctype}), content)
        return self.assertFailure(server.parsePOSTData(request), http.HTTPError)
コード例 #15
0
    def test_otherErrors(self):
        """
        Test that errors durign parsing other than C{MimeFormatError} are
        propagated.
        """
        ctype = http_headers.MimeType('multipart', 'form-data',
                                      (('boundary', '---weeboundary'),))
        # XXX: maybe this is not a good example
        # parseContentDispositionFormData could handle this problem
        content = """-----weeboundary\r
Content-Disposition: form-data; name="FileNameOne"; filename="myfilename and invalid data \r
-----weeboundary--\r
"""
        root = resource.Resource()
        request = SimpleRequest(
            server.Site(root), "GET", "/",
            http_headers.Headers({'content-type': ctype}), content)
        return self.assertFailure(server.parsePOSTData(request), ValueError)
コード例 #16
0
ファイル: test_server.py プロジェクト: advatar/CalendarServer
    def test_otherErrors(self):
        """
        Test that errors durign parsing other than C{MimeFormatError} are
        propagated.
        """
        ctype = http_headers.MimeType('multipart', 'form-data',
                                      (('boundary', '---weeboundary'),))
        # XXX: maybe this is not a good example
        # parseContentDispositionFormData could handle this problem
        content = """-----weeboundary\r
Content-Disposition: form-data; name="FileNameOne"; filename="myfilename and invalid data \r
-----weeboundary--\r
"""
        root = resource.Resource()
        request = SimpleRequest(
            server.Site(root), "GET", "/",
            http_headers.Headers({'content-type': ctype}), content)
        return self.assertFailure(server.parsePOSTData(request), ValueError)
コード例 #17
0
ファイル: test_server.py プロジェクト: advatar/CalendarServer
    def test_multipartWithNoBoundary(self):
        """
        If the boundary type is not specified, parsing should fail with a
        C{http.HTTPError}.
        """
        ctype = http_headers.MimeType('multipart', 'form-data')
        content = """-----weeboundary\r
Content-Disposition: form-data; name="FileNameOne"; filename="myfilename"\r
Content-Type: text/html\r
\r
my great content wooo\r
-----weeboundary--\r
"""
        root = resource.Resource()
        request = SimpleRequest(
            server.Site(root), "GET", "/",
            http_headers.Headers({'content-type': ctype}), content)
        return self.assertFailure(server.parsePOSTData(request), http.HTTPError)
コード例 #18
0
    def test_mimeParsingError(self):
        """
        A malformed content should result in a C{http.HTTPError}.

        The tested content has an invalid closing boundary.
        """
        ctype = http_headers.MimeType('multipart', 'form-data',
                                      (('boundary', '---weeboundary'),))
        content = """-----weeboundary\r
Content-Disposition: form-data; name="FileNameOne"; filename="myfilename"\r
Content-Type: text/html\r
\r
my great content wooo\r
-----weeoundary--\r
"""
        root = resource.Resource()
        request = SimpleRequest(
            server.Site(root), "GET", "/",
            http_headers.Headers({'content-type': ctype}), content)
        return self.assertFailure(server.parsePOSTData(request), http.HTTPError)
コード例 #19
0
ファイル: test_server.py プロジェクト: advatar/CalendarServer
    def test_mimeParsingError(self):
        """
        A malformed content should result in a C{http.HTTPError}.

        The tested content has an invalid closing boundary.
        """
        ctype = http_headers.MimeType('multipart', 'form-data',
                                      (('boundary', '---weeboundary'),))
        content = """-----weeboundary\r
Content-Disposition: form-data; name="FileNameOne"; filename="myfilename"\r
Content-Type: text/html\r
\r
my great content wooo\r
-----weeoundary--\r
"""
        root = resource.Resource()
        request = SimpleRequest(
            server.Site(root), "GET", "/",
            http_headers.Headers({'content-type': ctype}), content)
        return self.assertFailure(server.parsePOSTData(request), http.HTTPError)
コード例 #20
0
    def test_maxFields(self):
        """
        Check that the C{maxSize} parameter makes the parsing raise an
        exception if the data contains too many fields.
        """
        ctype = http_headers.MimeType('multipart', 'form-data',
                                      (('boundary', '---xyz'),))
        content = """-----xyz\r
Content-Disposition: form-data; name="foo"\r
\r
Foo Bar\r
-----xyz\r
Content-Disposition: form-data; name="foo"\r
\r
Baz\r
-----xyz\r
Content-Disposition: form-data; name="file"; filename="filename"\r
Content-Type: text/html\r
\r
blah\r
-----xyz\r
Content-Disposition: form-data; name="file"; filename="filename"\r
Content-Type: text/plain\r
\r
bleh\r
-----xyz--\r
"""
        root = resource.Resource()
        request = SimpleRequest(
            server.Site(root), "GET", "/",
            http_headers.Headers({'content-type': ctype}), content)
        def cb(res):
            self.assertEquals(
                res.response.description,
                "Maximum number of fields 3 exceeded")
        return self.assertFailure(
            server.parsePOSTData(request, maxFields=3),
            http.HTTPError).addCallback(cb)
コード例 #21
0
 def http_POST(self, request):
     yield self.authorize(request, (davxml.Write(), ))
     yield parsePOSTData(request)
     code, msg = (yield self.processSubscription(request))
     returnValue(self.renderResponse(code, body=msg))
コード例 #22
0
ファイル: applepush.py プロジェクト: nunb/calendarserver
 def http_POST(self, request):
     yield self.authorize(request, (davxml.Write(),))
     yield parsePOSTData(request)
     code, msg = (yield self.processSubscription(request))
     returnValue(self.renderResponse(code, body=msg))