mirror of
				https://github.com/python/cpython.git
				synced 2025-11-04 07:31:38 +00:00 
			
		
		
		
	
		
			
				
	
	
		
			80 lines
		
	
	
	
		
			2.9 KiB
		
	
	
	
		
			Python
		
	
	
	
	
	
			
		
		
	
	
			80 lines
		
	
	
	
		
			2.9 KiB
		
	
	
	
		
			Python
		
	
	
	
	
	
import unittest
 | 
						|
from test import support
 | 
						|
from io import StringIO
 | 
						|
import pstats
 | 
						|
from pstats import SortKey
 | 
						|
 | 
						|
 | 
						|
 | 
						|
class AddCallersTestCase(unittest.TestCase):
 | 
						|
    """Tests for pstats.add_callers helper."""
 | 
						|
 | 
						|
    def test_combine_results(self):
 | 
						|
        # pstats.add_callers should combine the call results of both target
 | 
						|
        # and source by adding the call time. See issue1269.
 | 
						|
        # new format: used by the cProfile module
 | 
						|
        target = {"a": (1, 2, 3, 4)}
 | 
						|
        source = {"a": (1, 2, 3, 4), "b": (5, 6, 7, 8)}
 | 
						|
        new_callers = pstats.add_callers(target, source)
 | 
						|
        self.assertEqual(new_callers, {'a': (2, 4, 6, 8), 'b': (5, 6, 7, 8)})
 | 
						|
        # old format: used by the profile module
 | 
						|
        target = {"a": 1}
 | 
						|
        source = {"a": 1, "b": 5}
 | 
						|
        new_callers = pstats.add_callers(target, source)
 | 
						|
        self.assertEqual(new_callers, {'a': 2, 'b': 5})
 | 
						|
 | 
						|
 | 
						|
class StatsTestCase(unittest.TestCase):
 | 
						|
    def setUp(self):
 | 
						|
        stats_file = support.findfile('pstats.pck')
 | 
						|
        self.stats = pstats.Stats(stats_file)
 | 
						|
 | 
						|
    def test_add(self):
 | 
						|
        stream = StringIO()
 | 
						|
        stats = pstats.Stats(stream=stream)
 | 
						|
        stats.add(self.stats, self.stats)
 | 
						|
 | 
						|
    def test_sort_stats_int(self):
 | 
						|
        valid_args = {-1: 'stdname',
 | 
						|
                      0: 'calls',
 | 
						|
                      1: 'time',
 | 
						|
                      2: 'cumulative'}
 | 
						|
        for arg_int, arg_str in valid_args.items():
 | 
						|
            self.stats.sort_stats(arg_int)
 | 
						|
            self.assertEqual(self.stats.sort_type,
 | 
						|
                             self.stats.sort_arg_dict_default[arg_str][-1])
 | 
						|
 | 
						|
    def test_sort_stats_string(self):
 | 
						|
        for sort_name in ['calls', 'ncalls', 'cumtime', 'cumulative',
 | 
						|
                    'filename', 'line', 'module', 'name', 'nfl', 'pcalls',
 | 
						|
                    'stdname', 'time', 'tottime']:
 | 
						|
            self.stats.sort_stats(sort_name)
 | 
						|
            self.assertEqual(self.stats.sort_type,
 | 
						|
                             self.stats.sort_arg_dict_default[sort_name][-1])
 | 
						|
 | 
						|
    def test_sort_stats_partial(self):
 | 
						|
        sortkey = 'filename'
 | 
						|
        for sort_name in ['f', 'fi', 'fil', 'file', 'filen', 'filena',
 | 
						|
                           'filenam', 'filename']:
 | 
						|
            self.stats.sort_stats(sort_name)
 | 
						|
            self.assertEqual(self.stats.sort_type,
 | 
						|
                             self.stats.sort_arg_dict_default[sortkey][-1])
 | 
						|
 | 
						|
    def test_sort_stats_enum(self):
 | 
						|
        for member in SortKey:
 | 
						|
            self.stats.sort_stats(member)
 | 
						|
            self.assertEqual(
 | 
						|
                    self.stats.sort_type,
 | 
						|
                    self.stats.sort_arg_dict_default[member.value][-1])
 | 
						|
 | 
						|
    def test_sort_starts_mix(self):
 | 
						|
        self.assertRaises(TypeError, self.stats.sort_stats,
 | 
						|
                          'calls',
 | 
						|
                          SortKey.TIME)
 | 
						|
        self.assertRaises(TypeError, self.stats.sort_stats,
 | 
						|
                          SortKey.TIME,
 | 
						|
                          'calls')
 | 
						|
 | 
						|
 | 
						|
if __name__ == "__main__":
 | 
						|
    unittest.main()
 |