예제 #1
0
    def test_prints_signature(self):
        the_time = 1406143563.020043
        key = 'secret squirrel'
        expires = 3600
        path = '/v1/a/c/o'
        redirect = 'https://example.com/done.html'
        max_file_size = str(int(1024 * 1024 * 1024 * 3.14159))  # π GiB
        max_file_count = '3'

        expected_signature = hmac.new(
            key,
            "\n".join((
                path, redirect, max_file_size, max_file_count,
                str(int(the_time + expires)))),
            hashlib.sha1).hexdigest()

        out = StringIO()
        with mock.patch('swift.cli.form_signature.time', lambda: the_time):
            with mock.patch('sys.stdout', out):
                exitcode = form_signature.main([
                    '/path/to/swift-form-signature',
                    path, redirect, max_file_size,
                    max_file_count, str(expires), key])

        self.assertEqual(exitcode, 0)
        self.assertTrue("Signature: %s" % expected_signature
                        in out.getvalue())
        self.assertTrue("Expires: %d" % (the_time + expires,)
                        in out.getvalue())

        sig_input = ('<input type="hidden" name="signature" value="%s" />'
                     % expected_signature)
        self.assertTrue(sig_input in out.getvalue())
예제 #2
0
 def test_invalid_path_arg(self):
     out = six.StringIO()
     key = 'secret squirrel'
     with mock.patch('sys.stdout', out):
         exitcode = form_signature.main([
             '/path/to/swift-form-signature',
             '/v1/a/', '', '12', '34', '3600', key])
     self.assertNotEqual(exitcode, 0)
예제 #3
0
 def test_invalid_seconds_arg(self):
     out = six.StringIO()
     key = 'secret squirrel'
     with mock.patch('sys.stdout', out):
         exitcode = form_signature.main([
             '/path/to/swift-form-signature',
             '/v1/a/c/o', '', '12', '34',
             '-922337203685477580799999999999999', key])
     self.assertNotEqual(exitcode, 0)
예제 #4
0
 def test_invalid_path_arg(self):
     out = six.StringIO()
     key = 'secret squirrel'
     with mock.patch('sys.stdout', out):
         exitcode = form_signature.main([
             '/path/to/swift-form-signature', '/v1/a/', '', '12', '34',
             '3600', key
         ])
     self.assertNotEqual(exitcode, 0)
예제 #5
0
 def test_invalid_seconds_arg(self):
     out = six.StringIO()
     key = 'secret squirrel'
     with mock.patch('sys.stdout', out):
         exitcode = form_signature.main([
             '/path/to/swift-form-signature', '/v1/a/c/o', '', '12', '34',
             '-922337203685477580799999999999999', key
         ])
     self.assertNotEqual(exitcode, 0)
예제 #6
0
    def test_too_few_args(self):
        out = StringIO()
        with mock.patch('sys.stdout', out):
            exitcode = form_signature.main([
                '/path/to/swift-form-signature',
                '/v1/a/c/o', '', '12', '34', '3600'])

        self.assertNotEqual(exitcode, 0)
        usage = 'Syntax: swift-form-signature <path>'
        self.assertTrue(usage in out.getvalue())
예제 #7
0
    def test_prints_signature(self):
        the_time = 1406143563.020043
        key = 'secret squirrel'
        expires = 3600
        path = '/v1/a/c/o'
        redirect = 'https://example.com/done.html'
        max_file_size = str(int(1024 * 1024 * 1024 * 3.14159))  # π GiB
        max_file_count = '3'

        data = "\n".join((
            path, redirect, max_file_size, max_file_count,
            str(int(the_time + expires))))

        if six.PY3:
            data = data if isinstance(data, six.binary_type) else \
                data.encode('utf8')
            key = key if isinstance(key, six.binary_type) else \
                key.encode('utf8')

        expected_signature = hmac.new(key, data, hashlib.sha1).hexdigest()

        out = six.StringIO()
        with mock.patch('swift.cli.form_signature.time', lambda: the_time):
            with mock.patch('sys.stdout', out):
                exitcode = form_signature.main([
                    '/path/to/swift-form-signature',
                    path, redirect, max_file_size,
                    max_file_count, str(expires), key])

        self.assertEqual(exitcode, 0)
        self.assertIn("Signature: %s" % expected_signature,
                      out.getvalue())
        self.assertIn("Expires: %d" % (the_time + expires,),
                      out.getvalue())

        sig_input = ('<input type="hidden" name="signature" value="%s" />'
                     % expected_signature)
        self.assertIn(sig_input, out.getvalue())
예제 #8
0
    def test_prints_signature(self):
        the_time = 1406143563.020043
        key = 'secret squirrel'
        expires = 3600
        path = '/v1/a/c/o'
        redirect = 'https://example.com/done.html'
        max_file_size = str(int(1024 * 1024 * 1024 * 3.14159))  # π GiB
        max_file_count = '3'

        data = "\n".join((path, redirect, max_file_size, max_file_count,
                          str(int(the_time + expires))))

        if six.PY3:
            data = data if isinstance(data, six.binary_type) else \
                data.encode('utf8')
            key = key if isinstance(key, six.binary_type) else \
                key.encode('utf8')

        expected_signature = hmac.new(key, data, hashlib.sha1).hexdigest()

        out = six.StringIO()
        with mock.patch('swift.cli.form_signature.time', lambda: the_time):
            with mock.patch('sys.stdout', out):
                exitcode = form_signature.main([
                    '/path/to/swift-form-signature', path, redirect,
                    max_file_size, max_file_count,
                    str(expires), key
                ])

        self.assertEqual(exitcode, 0)
        self.assertIn("Signature: %s" % expected_signature, out.getvalue())
        self.assertIn("Expires: %d" % (the_time + expires, ), out.getvalue())

        sig_input = ('<input type="hidden" name="signature" value="%s" />' %
                     expected_signature)
        self.assertIn(sig_input, out.getvalue())