Skip to content
Snippets Groups Projects
test_logfile.py 8.44 KiB
Newer Older
mads's avatar
mads committed
'''
Created on 18/11/2015

@author: MMPE
'''
from __future__ import unicode_literals
from __future__ import print_function
from __future__ import division
from __future__ import absolute_import
from io import open
from future import standard_library
standard_library.install_aliases()
mads's avatar
mads committed
import unittest
mads's avatar
mads committed
from wetb.hawc2.log_file import LogFile, \
    INITIALIZATION, SIMULATING, DONE, PENDING, UNKNOWN
mads's avatar
mads committed
import time
from wetb.hawc2 import log_file
import threading
import os
mads's avatar
mads committed
from wetb.hawc2.htc_file import HTCFile
mads's avatar
mads committed

def simulate(file, wait):
    with open(file, 'r') as fin:
        lines = fin.readlines()
    file = file + "_"
    with open(file, 'w'):
        pass
    time.sleep(.1)
    for l in lines:
        with open(file, 'a+') as fout:
            fout.write(l)
        if "Turbulence generation starts" in l or "Log file output" in l:
            time.sleep(0.2)
        time.sleep(wait)

mads's avatar
mads committed
class TestLogFile(unittest.TestCase):
mads's avatar
mads committed

mads's avatar
mads committed
    def setUp(self):
        unittest.TestCase.setUp(self)
        self.tfp = os.path.join(os.path.dirname(__file__), 'test_files/')  # test file path
mads's avatar
mads committed

mads's avatar
mads committed
    def test_from_htcfile(self):
        htcfile = HTCFile(self.tfp + 'logfiles/model/htc/dlc14_iec61400-1ed3/dlc14_wsp10_wdir000_s0000.htc',"../")
mads's avatar
mads committed
        logfile = LogFile.from_htcfile(htcfile, self.tfp + 'logfiles/model/')
mads's avatar
mads committed
        self.assertEqual(logfile.status, DONE)

mads's avatar
mads committed
    def test_missing_logfile(self):
mads's avatar
mads committed
        f = self.tfp + 'logfiles/missing.log'
mads's avatar
mads committed
        logfile = LogFile(f, 200)
mads's avatar
mads committed
        logfile.update_status()
        self.assertEqual(logfile.pct, 0)
        self.assertEqual(logfile.status, log_file.MISSING)
mads's avatar
mads committed
#    def test_is_file_open(self):
#        f = self.tfp + 'logfiles/test.log'
#        with open(f, 'a+'):
#            self.assertTrue(is_file_open(f))
#        with open(f, 'r'):
#            self.assertTrue(is_file_open(f))
#        self.assertFalse(is_file_open(f))
mads's avatar
mads committed

    def test_simulation_init_error(self):
mads's avatar
mads committed
        f = self.tfp + 'logfiles/init_error.log'
mads's avatar
mads committed
        logfile = LogFile(f, 2)
mads's avatar
mads committed
        logfile.update_status()
        self.assertEqual(logfile.pct, 100)
        self.assertEqual(logfile.status, DONE)
        self.assertEqual(logfile.errors, ['*** ERROR *** No line termination in command line            8'])
mads's avatar
mads committed

    def test_init(self):
mads's avatar
mads committed
        f = self.tfp + 'logfiles/init.log'
mads's avatar
mads committed
        logfile = LogFile(f, 200)
mads's avatar
mads committed
        logfile.update_status()
        self.assertEqual(logfile.pct, 0)
        self.assertEqual(logfile.status, INITIALIZATION)
        self.assertEqual(logfile.errors, [])
mads's avatar
mads committed

    def test_turbulence_generation(self):
mads's avatar
mads committed
        f = self.tfp + 'logfiles/turbulence_generation.log'
mads's avatar
mads committed
        logfile = LogFile(f, 200)
mads's avatar
mads committed
        logfile.update_status()
        self.assertEqual(logfile.pct, 0)
        self.assertEqual(logfile.status, INITIALIZATION)
        self.assertEqual(logfile.errors, [])
        self.assertEqual(logfile.lastline, "Turbulence generation starts ...")
mads's avatar
mads committed

    def test_simulation(self):
mads's avatar
mads committed
        f = self.tfp + 'logfiles/simulating.log'
mads's avatar
mads committed
        logfile = LogFile(f, 2)
mads's avatar
mads committed
        logfile.update_status()
        self.assertEqual(logfile.pct, 25)
        self.assertEqual(logfile.status, SIMULATING)
        self.assertEqual(logfile.errors, [])

mads's avatar
mads committed


    def test_finish(self):
mads's avatar
mads committed
        f = self.tfp + 'logfiles/finish.log'
mads's avatar
mads committed
        logfile = LogFile(f, 200)
mads's avatar
mads committed
        self.assertEqual(logfile.pct, 100)
        self.assertEqual(logfile.status, DONE)
        self.assertEqual(logfile.errors, [])
        self.assertEqual(logfile.elapsed_time, 0.8062344)
mads's avatar
mads committed
    def test_HAWC2Version(self):
mads's avatar
mads committed
        f = self.tfp + 'logfiles/finish.log'
mads's avatar
mads committed
        logfile = LogFile(f, 200)
        self.assertEqual(logfile.hawc2version, "HAWC2MB 11.8")

mads's avatar
mads committed

    def test_simulation_error(self):
mads's avatar
mads committed
        f = self.tfp + 'logfiles/simulation_error.log'
mads's avatar
mads committed
        logfile = LogFile(f, 2)
mads's avatar
mads committed
        self.assertEqual(logfile.pct, 100)
        self.assertEqual(logfile.status, DONE)
        self.assertEqual(logfile.errors, ['*** ERROR *** Error opening out .dat file'])
mads's avatar
mads committed

    def test_simulation_error2(self):
mads's avatar
mads committed
        f = self.tfp + 'logfiles/simulation_error2.log'
mads's avatar
mads committed
        logfile = LogFile(f, 2)
mads's avatar
mads committed
        self.assertEqual(logfile.pct, 100)
        self.assertEqual(logfile.status, DONE)
        self.assertEqual(logfile.errors[0], '*** ERROR *** Out of limits in user defined shear field - limit value used')
        self.assertEqual(logfile.error_str(), '30 x *** ERROR *** Out of limits in user defined shear field - limit value used')

mads's avatar
mads committed
    def check(self, logfilename, phases, end_status, end_errors=[]):
mads's avatar
mads committed
        logfile = LogFile(logfilename + "_", 2)
mads's avatar
mads committed
        logfile.clear()
mads's avatar
mads committed
        if os.path.isfile(logfile.filename):
            os.remove(logfile.filename)
        t = threading.Thread(target=simulate, args=(logfilename, 0.0001))
        t.start()
mads's avatar
mads committed
        last_status = None
        last_pct = 0
        while logfile.pct >= 0 and logfile.status != DONE:
            logfile.update_status()
            if logfile.status != last_status or logfile.pct != last_pct:
                last_status = logfile.status
                last_pct = logfile.pct
                if logfile.status in phases:
                    phases.remove(logfile.status)
mads's avatar
mads committed
            time.sleep(0.01)
mads's avatar
mads committed
        self.assertEqual(logfile.pct, 100)
        self.assertEqual(logfile.status, end_status)
        self.assertEqual(logfile.errors, end_errors)
mads's avatar
mads committed
        self.assertFalse(phases)
        t.join()
        os.remove(logfile.filename)


    def test_realtime_test(self):
mads's avatar
mads committed
        self.check(self.tfp + 'logfiles/finish.log',
mads's avatar
mads committed
                   phases=[PENDING, INITIALIZATION, SIMULATING, DONE],
mads's avatar
mads committed
                   end_status=DONE)
mads's avatar
mads committed

    def test_realtime_test2(self):
mads's avatar
mads committed
        self.check(self.tfp + 'logfiles/init_error.log',
mads's avatar
mads committed
           phases=[PENDING, INITIALIZATION, SIMULATING, DONE],
mads's avatar
mads committed
           end_status=DONE,
           end_errors=['*** ERROR *** No line termination in command line            8'])
mads's avatar
mads committed

    def test_realtime_test_simulation_error(self):
mads's avatar
mads committed
        self.check(self.tfp + 'logfiles/simulation_error.log',
mads's avatar
mads committed
                   [PENDING, INITIALIZATION, SIMULATING, DONE],
mads's avatar
mads committed
                   DONE, ['*** ERROR *** Error opening out .dat file'])
mads's avatar
mads committed

    def test_realtime_test_turbulence(self):
mads's avatar
mads committed
        self.check(self.tfp + 'logfiles/finish_turbulencegeneration.log',
mads's avatar
mads committed
                   phases=[PENDING, INITIALIZATION, SIMULATING, DONE],
                   end_status=DONE,
                   end_errors=[])


    def test_remaining(self):
mads's avatar
mads committed
        logfilename = self.tfp + 'logfiles/finish.log'
mads's avatar
mads committed
        logfile = LogFile(logfilename + "_", 2)
        logfile.clear()
        if os.path.isfile(logfile.filename):
            os.remove(logfile.filename)
        t = threading.Thread(target=simulate, args=(logfilename, 0.01))
        t.start()
        last_status = None
        last_pct = 0
        estimated_simulation_time = None
        while logfile.pct >= 0 and logfile.status != DONE:
            if estimated_simulation_time is None and logfile.remaining_time is not None:
mads's avatar
mads committed
                estimated_endtime = time.time() + logfile.remaining_time
mads's avatar
mads committed
            #print (logfile.pct, logfile.remaining_time, logfile.lastline)
            logfile.update_status()
            if logfile.status != last_status or logfile.pct != last_pct:
                last_status = logfile.status
                last_pct = logfile.pct
            time.sleep(0.1)
        t.join()
mads's avatar
mads committed
        self.assertLess(abs(time.time() - estimated_endtime), 0.15)
mads's avatar
mads committed
        os.remove(logfile.filename)


    def test_remaining_str(self):
        logfile = LogFile("f", 2)
        logfile.remaining_time = 5
        self.assertEqual(logfile.remaining_time_str(), "00:05")
        logfile.remaining_time = 60 + 5
        self.assertEqual(logfile.remaining_time_str(), "01:05")
        logfile.remaining_time = 3600 + 120 + 5
        self.assertEqual(logfile.remaining_time_str(), "1:02:05")


        htcfile = HTCFile(self.tfp + 'logfiles/model/htc/dlc14_iec61400-1ed3/dlc14_wsp10_wdir000_s0000.htc',"../")
        logfile = LogFile.from_htcfile(htcfile, self.tfp + 'logfiles/model/')
        self.assertEqual(logfile.status, DONE)
        logfile.reset()
        self.assertEqual(logfile.status, UNKNOWN)
        self.assertEqual(logfile.txt, "")
        logfile.update_status()
        self.assertEqual(logfile.status, DONE)
mads's avatar
mads committed


if __name__ == "__main__":
    #import sys;sys.argv = ['', 'Test.test_logfile']
    unittest.main()