mirror of
				https://github.com/zulip/zulip.git
				synced 2025-11-04 05:53:43 +00:00 
			
		
		
		
	Move upload-related tests to test_upload.py.
Move S3Test, FileUploadTest and SanitizeNameTests from test_external.py to test_upload.py.
This commit is contained in:
		
				
					committed by
					
						
						Tim Abbott
					
				
			
			
				
	
			
			
			
						parent
						
							c75c5fb3e1
						
					
				
				
					commit
					2d60a1d0f3
				
			
							
								
								
									
										99
									
								
								zerver/tests/test_upload.py
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										99
									
								
								zerver/tests/test_upload.py
									
									
									
									
									
										Normal file
									
								
							@@ -0,0 +1,99 @@
 | 
			
		||||
# -*- coding: utf-8 -*-
 | 
			
		||||
from __future__ import absolute_import
 | 
			
		||||
from django.conf import settings
 | 
			
		||||
from django.test import TestCase
 | 
			
		||||
from unittest import skip
 | 
			
		||||
 | 
			
		||||
from zerver.lib.test_helpers import AuthedTestCase
 | 
			
		||||
from zerver.lib.test_runner import slow
 | 
			
		||||
from zerver.lib.upload import sanitize_name
 | 
			
		||||
 | 
			
		||||
import ujson
 | 
			
		||||
from six.moves import urllib
 | 
			
		||||
 | 
			
		||||
from boto.s3.connection import S3Connection
 | 
			
		||||
from boto.s3.key import Key
 | 
			
		||||
from six.moves import StringIO
 | 
			
		||||
 | 
			
		||||
class FileUploadTest(AuthedTestCase):
 | 
			
		||||
    def test_multiple_upload_failure(self):
 | 
			
		||||
        """
 | 
			
		||||
        Attempting to upload two files should fail.
 | 
			
		||||
        """
 | 
			
		||||
        self.login("hamlet@zulip.com")
 | 
			
		||||
        fp = StringIO("bah!")
 | 
			
		||||
        fp.name = "a.txt"
 | 
			
		||||
        fp2 = StringIO("pshaw!")
 | 
			
		||||
        fp2.name = "b.txt"
 | 
			
		||||
 | 
			
		||||
        result = self.client.post("/json/upload_file", {'f1': fp, 'f2': fp2})
 | 
			
		||||
        self.assert_json_error(result, "You may only upload one file at a time")
 | 
			
		||||
 | 
			
		||||
    def test_no_file_upload_failure(self):
 | 
			
		||||
        """
 | 
			
		||||
        Calling this endpoint with no files should fail.
 | 
			
		||||
        """
 | 
			
		||||
        self.login("hamlet@zulip.com")
 | 
			
		||||
 | 
			
		||||
        result = self.client.post("/json/upload_file")
 | 
			
		||||
        self.assert_json_error(result, "You must specify a file to upload")
 | 
			
		||||
 | 
			
		||||
class S3Test(AuthedTestCase):
 | 
			
		||||
    # full URIs in public bucket
 | 
			
		||||
    test_uris = [] # type: List[str]
 | 
			
		||||
    # keys in authed bucket
 | 
			
		||||
    test_keys = [] # type: List[str]
 | 
			
		||||
 | 
			
		||||
    @slow(2.6, "has to contact external S3 service")
 | 
			
		||||
    @skip("Need S3 mock")
 | 
			
		||||
    def test_file_upload_authed(self):
 | 
			
		||||
        """
 | 
			
		||||
        A call to /json/upload_file should return a uri and actually create an object.
 | 
			
		||||
        """
 | 
			
		||||
        self.login("hamlet@zulip.com")
 | 
			
		||||
        fp = StringIO("zulip!")
 | 
			
		||||
        fp.name = "zulip.txt"
 | 
			
		||||
 | 
			
		||||
        result = self.client.post("/json/upload_file", {'file': fp})
 | 
			
		||||
        self.assert_json_success(result)
 | 
			
		||||
        json = ujson.loads(result.content)
 | 
			
		||||
        self.assertIn("uri", json)
 | 
			
		||||
        uri = json["uri"]
 | 
			
		||||
        base = '/user_uploads/'
 | 
			
		||||
        self.assertEquals(base, uri[:len(base)])
 | 
			
		||||
        self.test_keys.append(uri[len(base):])
 | 
			
		||||
 | 
			
		||||
        response = self.client.get(uri)
 | 
			
		||||
        redirect_url = response['Location']
 | 
			
		||||
 | 
			
		||||
        self.assertEquals("zulip!", urllib.request.urlopen(redirect_url).read().strip())
 | 
			
		||||
 | 
			
		||||
    def tearDown(self):
 | 
			
		||||
        # clean up
 | 
			
		||||
        return
 | 
			
		||||
        # TODO: un-deadden this code when we have proper S3 mocking.
 | 
			
		||||
        conn = S3Connection(settings.S3_KEY, settings.S3_SECRET_KEY)
 | 
			
		||||
        for uri in self.test_uris:
 | 
			
		||||
            key = Key(conn.get_bucket(settings.S3_BUCKET))
 | 
			
		||||
            key.name = urllib.parse.urlparse(uri).path[1:]
 | 
			
		||||
            key.delete()
 | 
			
		||||
            self.test_uris.remove(uri)
 | 
			
		||||
 | 
			
		||||
        for path in self.test_keys:
 | 
			
		||||
            key = Key(conn.get_bucket(settings.S3_AUTH_UPLOADS_BUCKET))
 | 
			
		||||
            key.name = path
 | 
			
		||||
            key.delete()
 | 
			
		||||
            self.test_keys.remove(path)
 | 
			
		||||
 | 
			
		||||
class SanitizeNameTests(TestCase):
 | 
			
		||||
    def test_file_name(self):
 | 
			
		||||
        self.assertEquals(sanitize_name(u'test.txt'), u'test.txt')
 | 
			
		||||
        self.assertEquals(sanitize_name(u'.hidden'), u'.hidden')
 | 
			
		||||
        self.assertEquals(sanitize_name(u'.hidden.txt'), u'.hidden.txt')
 | 
			
		||||
        self.assertEquals(sanitize_name(u'tarball.tar.gz'), u'tarball.tar.gz')
 | 
			
		||||
        self.assertEquals(sanitize_name(u'.hidden_tarball.tar.gz'), u'.hidden_tarball.tar.gz')
 | 
			
		||||
        self.assertEquals(sanitize_name(u'Testing{}*&*#().ta&&%$##&&r.gz'), u'Testing.tar.gz')
 | 
			
		||||
        self.assertEquals(sanitize_name(u'*testingfile?*.txt'), u'testingfile.txt')
 | 
			
		||||
        self.assertEquals(sanitize_name(u'snowman☃.txt'), u'snowman.txt')
 | 
			
		||||
        self.assertEquals(sanitize_name(u'테스트.txt'), u'테스트.txt')
 | 
			
		||||
        self.assertEquals(sanitize_name(u'~/."\`\?*"u0`000ssh/test.t**{}ar.gz'), u'.u0000sshtest.tar.gz')
 | 
			
		||||
		Reference in New Issue
	
	Block a user