File: run_tests.py

package info (click to toggle)
libitl 0.8.0-5
  • links: PTS, VCS
  • area: main
  • in suites: forky, sid
  • size: 1,632 kB
  • sloc: ansic: 3,150; python: 55; sh: 33; makefile: 4
file content (71 lines) | stat: -rwxr-xr-x 2,608 bytes parent folder | download | duplicates (3)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
#!/usr/bin/env python

# This script is used to test the new method implementation
# It does that by comparing the computed prayer times for specific
# locations on specific dates to the "official" times on these dates.
# "official" turns out to be a tricky one for locations in places
# that are in non-Muslim countries.

import sys
import os
import subprocess
import json
import datetime
import unittest

program_under_test=os.path.join("..", "build", "prayer")
locations="locations"
references="reference_times"
# We require all the computed times to be within 3 minutes
# of the reference values
threshold = datetime.timedelta(minutes=3)

class TestPrayerNewMethod(unittest.TestCase):
    def setUp(self):
        self.test_files = []
        for f in os.listdir(references):
            fn = os.path.join(references,f)
            if os.path.isfile(fn):
                self.test_files.append(fn)

    def test_locations(self):
        for f in self.test_files:
            fp = open(f)
            json_data = json.load(fp)
            fp.close()
            country = json_data["country"]
            location = json_data["location"]
            date = json_data["date"]
            timezone = json_data["tz"] # Not used for now
            dst = json_data["dst"]     # Not used for now
            command = program_under_test + \
                    " -d " + date + \
                    " -f " + \
                    os.path.join(locations, country, \
                            country + "-" + location + ".conf") + \
                    " -j"
            p = subprocess.Popen(command,
                    stdout=subprocess.PIPE,
                    stderr=subprocess.PIPE,
                    shell=True)
            (output, errors) = p.communicate()
            self.assertEqual(p.returncode, 0)
            self.assertEqual(errors, "")            
            ref_times = list(json_data["times"])
            computed_times = list(json.loads(output)["times"])
            self.assertEqual(len(ref_times), len(computed_times))
            for i in range(len(computed_times)):
                ref_x = ref_times[i].items()[0][1]
                comp_x = computed_times[i].items()[0][1]
                time_format = "%H:%M"
                t_r = datetime.datetime.strptime(ref_x, time_format)
                t_c = datetime.datetime.strptime(comp_x, time_format)
                if t_r > t_c:
                    tdelta = t_r - t_c
                else:
                    tdelta = t_c - t_r
                self.assertTrue(tdelta < threshold)

if __name__ == "__main__":
    unittest.main()