mirror of
				https://github.com/f-droid/fdroidserver.git
				synced 2025-11-04 06:30:27 +03:00 
			
		
		
		
	include test cases for python getsig replacement
This includes the old getsig.java since that is the canonical implementation of that algorithm. fixes #5 https://gitlab.com/fdroid/fdroidserver/issues/5
This commit is contained in:
		
							parent
							
								
									d74235564f
								
							
						
					
					
						commit
						18db382c47
					
				
					 8 changed files with 97 additions and 0 deletions
				
			
		| 
						 | 
				
			
			@ -24,8 +24,14 @@ include examples/config.py
 | 
			
		|||
include examples/fdroid-icon.png
 | 
			
		||||
include examples/makebs.config.py
 | 
			
		||||
include examples/opensc-fdroid.cfg
 | 
			
		||||
include tests/getsig/run.sh
 | 
			
		||||
include tests/getsig/make.sh
 | 
			
		||||
include tests/getsig/getsig.java
 | 
			
		||||
include tests/getsig/getsig.class
 | 
			
		||||
include tests/run-tests
 | 
			
		||||
include tests/update.TestCase
 | 
			
		||||
include tests/urzip.apk
 | 
			
		||||
include tests/urzip-badsig.apk
 | 
			
		||||
include wp-fdroid/AndroidManifest.xml
 | 
			
		||||
include wp-fdroid/android-permissions.php
 | 
			
		||||
include wp-fdroid/readme.txt
 | 
			
		||||
| 
						 | 
				
			
			
 | 
			
		|||
| 
						 | 
				
			
			@ -92,6 +92,15 @@ cd $WORKSPACE
 | 
			
		|||
./hooks/pre-commit
 | 
			
		||||
 | 
			
		||||
 | 
			
		||||
#------------------------------------------------------------------------------#
 | 
			
		||||
echo_header "test python getsig replacement"
 | 
			
		||||
 | 
			
		||||
cd $WORKSPACE/tests/getsig
 | 
			
		||||
./make.sh
 | 
			
		||||
cd $WORKSPACE/tests
 | 
			
		||||
./update.TestCase
 | 
			
		||||
 | 
			
		||||
 | 
			
		||||
#------------------------------------------------------------------------------#
 | 
			
		||||
echo_header "create a source tarball and use that to build a repo"
 | 
			
		||||
 | 
			
		||||
| 
						 | 
				
			
			
 | 
			
		|||
							
								
								
									
										82
									
								
								tests/update.TestCase
									
										
									
									
									
										Executable file
									
								
							
							
						
						
									
										82
									
								
								tests/update.TestCase
									
										
									
									
									
										Executable file
									
								
							| 
						 | 
				
			
			@ -0,0 +1,82 @@
 | 
			
		|||
#!/usr/bin/env python2
 | 
			
		||||
# -*- coding: utf-8 -*-
 | 
			
		||||
 | 
			
		||||
# http://www.drdobbs.com/testing/unit-testing-with-python/240165163
 | 
			
		||||
 | 
			
		||||
import inspect
 | 
			
		||||
import optparse
 | 
			
		||||
import os
 | 
			
		||||
import sys
 | 
			
		||||
import unittest
 | 
			
		||||
 | 
			
		||||
localmodule = os.path.realpath(os.path.join(
 | 
			
		||||
        os.path.dirname(inspect.getfile(inspect.currentframe())),
 | 
			
		||||
        '..'))
 | 
			
		||||
print('localmodule: ' + localmodule)
 | 
			
		||||
if localmodule not in sys.path:
 | 
			
		||||
    sys.path.insert(0,localmodule)
 | 
			
		||||
 | 
			
		||||
import fdroidserver.common
 | 
			
		||||
import fdroidserver.update
 | 
			
		||||
from fdroidserver.common import FDroidPopen, SilentPopen
 | 
			
		||||
 | 
			
		||||
class UpdateTest(unittest.TestCase):
 | 
			
		||||
    '''fdroid update'''
 | 
			
		||||
 | 
			
		||||
    def javagetsig(self, apkfile):
 | 
			
		||||
        getsig_dir = os.path.join(os.path.dirname(__file__), 'getsig')
 | 
			
		||||
        if not os.path.exists(getsig_dir + "/getsig.class"):
 | 
			
		||||
            logging.critical("getsig.class not found. To fix: cd '%s' && ./make.sh" % getsig_dir)
 | 
			
		||||
            sys.exit(1)
 | 
			
		||||
        p = FDroidPopen(['java', '-cp', os.path.join(os.path.dirname(__file__), 'getsig'),
 | 
			
		||||
                         'getsig', os.path.join(os.getcwd(), apkfile)])
 | 
			
		||||
        sig = None
 | 
			
		||||
        for line in p.output.splitlines():
 | 
			
		||||
            if line.startswith('Result:'):
 | 
			
		||||
                sig = line[7:].strip()
 | 
			
		||||
                break
 | 
			
		||||
        if p.returncode == 0:
 | 
			
		||||
            return sig
 | 
			
		||||
        else:
 | 
			
		||||
            return None
 | 
			
		||||
        
 | 
			
		||||
    def testGoodGetsig(self):
 | 
			
		||||
        apkfile = os.path.join(os.path.dirname(__file__), 'urzip.apk')
 | 
			
		||||
        sig = self.javagetsig(apkfile)
 | 
			
		||||
        self.assertIsNotNone(sig, "sig is None")
 | 
			
		||||
        pysig = fdroidserver.update.getsig(apkfile)
 | 
			
		||||
        self.assertIsNotNone(pysig, "pysig is None")        
 | 
			
		||||
        self.assertEquals(sig, fdroidserver.update.getsig(apkfile),
 | 
			
		||||
                          "python sig not equal to java sig!")
 | 
			
		||||
        self.assertEquals(len(sig), len(pysig),
 | 
			
		||||
                          "the length of the two sigs are different!")
 | 
			
		||||
        try:
 | 
			
		||||
            self.assertEquals(sig.decode('hex'), pysig.decode('hex'),
 | 
			
		||||
                              "the length of the two sigs are different!")
 | 
			
		||||
        except TypeError as e:
 | 
			
		||||
            print e
 | 
			
		||||
            self.assertTrue(False, 'TypeError!')
 | 
			
		||||
 | 
			
		||||
    def testBadGetsig(self):
 | 
			
		||||
        apkfile = os.path.join(os.path.dirname(__file__), 'urzip-badsig.apk')
 | 
			
		||||
        sig = self.javagetsig(apkfile)
 | 
			
		||||
        self.assertIsNone(sig, "sig should be None: " + str(sig))
 | 
			
		||||
        pysig = fdroidserver.update.getsig(apkfile)
 | 
			
		||||
        self.assertIsNone(pysig, "python sig should be None: " + str(sig))
 | 
			
		||||
 | 
			
		||||
        apkfile = os.path.join(os.path.dirname(__file__), 'urzip-badcert.apk')
 | 
			
		||||
        sig = self.javagetsig(apkfile)
 | 
			
		||||
        self.assertIsNone(sig, "sig should be None: " + str(sig))
 | 
			
		||||
        pysig = fdroidserver.update.getsig(apkfile)
 | 
			
		||||
        self.assertIsNone(pysig, "python sig should be None: " + str(sig))
 | 
			
		||||
 | 
			
		||||
 | 
			
		||||
if __name__ == "__main__":
 | 
			
		||||
    parser = optparse.OptionParser()
 | 
			
		||||
    parser.add_option("-v", "--verbose", action="store_true", default=False,
 | 
			
		||||
                      help="Spew out even more information than normal")
 | 
			
		||||
    (fdroidserver.common.options, args) = parser.parse_args(['--verbose'])
 | 
			
		||||
 | 
			
		||||
    newSuite = unittest.TestSuite()
 | 
			
		||||
    newSuite.addTest(unittest.makeSuite(UpdateTest))
 | 
			
		||||
    unittest.main()
 | 
			
		||||
							
								
								
									
										
											BIN
										
									
								
								tests/urzip-badcert.apk
									
										
									
									
									
										Normal file
									
								
							
							
						
						
									
										
											BIN
										
									
								
								tests/urzip-badcert.apk
									
										
									
									
									
										Normal file
									
								
							
										
											Binary file not shown.
										
									
								
							
							
								
								
									
										
											BIN
										
									
								
								tests/urzip-badsig.apk
									
										
									
									
									
										Normal file
									
								
							
							
						
						
									
										
											BIN
										
									
								
								tests/urzip-badsig.apk
									
										
									
									
									
										Normal file
									
								
							
										
											Binary file not shown.
										
									
								
							
		Loading…
	
	Add table
		Add a link
		
	
		Reference in a new issue