blob: 6282f7b052d7bcaadd7f275465810816c9156f22 [file] [log] [blame]
kjellander@webrtc.org689cb302011-11-07 15:25:47 +00001#!/usr/bin/env python
2# Copyright (c) 2011 The WebRTC project authors. All Rights Reserved.
3#
4# Use of this source code is governed by a BSD-style license
5# that can be found in the LICENSE file in the root of the source
6# tree. An additional intellectual property rights grant can be found
7# in the file PATENTS. All contributing project authors may
8# be found in the AUTHORS file in the root of the source tree.
9
10__author__ = 'kjellander@webrtc.org (Henrik Kjellander)'
11
12import unittest
13import webrtc.data_helper
14
15class Test(unittest.TestCase):
16
17 def setUp(self):
18 # Simulate frame data from two different test runs, with 2 frames each.
19 self.frame_data_0 = [{'frame_number': 0, 'ssim': 0.5, 'psnr': 30.5},
20 {'frame_number': 1, 'ssim': 0.55, 'psnr': 30.55}]
21 self.frame_data_1 = [{'frame_number': 0, 'ssim': 0.6, 'psnr': 30.6},
22 {'frame_number': 0, 'ssim': 0.66, 'psnr': 30.66}]
23 self.all_data = [ self.frame_data_0, self.frame_data_1 ]
24
25 # Test with frame_number column in a non-first position sice we need to
26 # support reordering that to be able to use the gviz_api as we want.
27 self.type_description = {
28 'ssim': ('number', 'SSIM'),
29 'frame_number': ('number', 'Frame number'),
30 'psnr': ('number', 'PSRN'),
31 }
32 self.names = ["Test 0", "Test 1"]
kjellander@webrtc.org418bce52011-12-05 16:29:21 +000033 self.configurations = [
34 [{'name': 'name', 'value': 'Test 0'},
35 {'name': 'test_number', 'value': '13'},
36 {'name': 'input_filename', 'value': 'foreman_cif.yuv'},
37 ],
38 [{'name': 'name', 'value': 'Test 1'},
39 {'name': 'test_number', 'value': '5'},
40 {'name': 'input_filename', 'value': 'foreman_cif.yuv'},
41 ],
42 ]
43
kjellander@webrtc.org689cb302011-11-07 15:25:47 +000044 def testCreateData(self):
45 messages = []
46 helper = webrtc.data_helper.DataHelper(self.all_data, self.type_description,
47 self.names, messages)
48 description, data_table = helper.CreateData('ssim')
49 self.assertEqual(3, len(description))
50 self.assertTrue('frame_number' in description)
51 self.assertTrue('ssim_0' in description)
52 self.assertTrue('number' in description['ssim_0'][0])
53 self.assertTrue('Test 0' in description['ssim_0'][1])
54 self.assertTrue('ssim_1' in description)
55 self.assertTrue('number' in description['ssim_1'][0])
56 self.assertTrue('Test 1' in description['ssim_1'][1])
kjellander@webrtc.org418bce52011-12-05 16:29:21 +000057
58 self.assertEqual(0, len(messages))
59
kjellander@webrtc.org689cb302011-11-07 15:25:47 +000060 self.assertEquals(2, len(data_table))
61 row = data_table[0]
62 self.assertEquals(0, row['frame_number'])
63 self.assertEquals(0.5, row['ssim_0'])
64 self.assertEquals(0.6, row['ssim_1'])
65 row = data_table[1]
66 self.assertEquals(1, row['frame_number'])
67 self.assertEquals(0.55, row['ssim_0'])
68 self.assertEquals(0.66, row['ssim_1'])
69
70 description, data_table = helper.CreateData('psnr')
71 self.assertEqual(3, len(description))
72 self.assertTrue('frame_number' in description)
73 self.assertTrue('psnr_0' in description)
74 self.assertTrue('psnr_1' in description)
75 self.assertEqual(0, len(messages))
76
77 self.assertEquals(2, len(data_table))
78 row = data_table[0]
79 self.assertEquals(0, row['frame_number'])
80 self.assertEquals(30.5, row['psnr_0'])
81 self.assertEquals(30.6, row['psnr_1'])
82 row = data_table[1]
83 self.assertEquals(1, row['frame_number'])
84 self.assertEquals(30.55, row['psnr_0'])
85 self.assertEquals(30.66, row['psnr_1'])
86
87 def testGetOrdering(self):
88 """ Tests that the ordering help method returns a list with frame_number
89 first and the rest sorted alphabetically """
90 messages = []
91 helper = webrtc.data_helper.DataHelper(self.all_data, self.type_description,
92 self.names, messages)
93 description, data_table = helper.CreateData('ssim')
94 columns = helper.GetOrdering(description)
95 self.assertEqual(3, len(columns))
96 self.assertEqual(0, len(messages))
97 self.assertEqual('frame_number', columns[0])
98 self.assertEqual('ssim_0', columns[1])
99 self.assertEqual('ssim_1', columns[2])
100
kjellander@webrtc.org418bce52011-12-05 16:29:21 +0000101 def testCreateConfigurationTable(self):
102 messages = []
103 helper = webrtc.data_helper.DataHelper(self.all_data, self.type_description,
104 self.names, messages)
105 description, data = helper.CreateConfigurationTable(self.configurations)
106 self.assertEqual(3, len(description)) # 3 columns
107 self.assertEqual(2, len(data)) # 2 data sets
108 self.assertTrue(description.has_key('name'))
109 self.assertTrue(description.has_key('test_number'))
110 self.assertTrue(description.has_key('input_filename'))
111 self.assertEquals('Test 0', data[0]['name'])
112 self.assertEquals('Test 1', data[1]['name'])
113
kjellander@webrtc.org689cb302011-11-07 15:25:47 +0000114if __name__ == "__main__":
115 unittest.main()