Skip to content
Snippets Groups Projects
test_caching.py 5.7 KiB
Newer Older
mads's avatar
mads committed
'''
Created on 08/11/2013

@author: mmpe
'''
from __future__ import unicode_literals
from __future__ import print_function
from __future__ import division
from __future__ import absolute_import
from future import standard_library
from collections import OrderedDict
Mads M. Pedersen's avatar
Mads M. Pedersen committed
import os
standard_library.install_aliases()
mads's avatar
mads committed
import multiprocessing
import time
import unittest
Mads M. Pedersen's avatar
Mads M. Pedersen committed
import numpy as np
mads's avatar
mads committed

from wetb.utils.timing import get_time
Mads M. Pedersen's avatar
Mads M. Pedersen committed
from wetb.utils.caching import cache_function, set_cache_property, cache_method,\
Mads M. Pedersen's avatar
Mads M. Pedersen committed
    cache_npsavez, cache_npsave, cache_npsavez_compressed
Mads M. Pedersen's avatar
Mads M. Pedersen committed
tfp = os.path.dirname(__file__) + "/test_files/"
mads's avatar
mads committed
class Example(object):
    def __init__(self, *args, **kwargs):
        object.__init__(self, *args, **kwargs)

        set_cache_property(self, "test", self.slow_function)
        set_cache_property(self, 'pool', lambda : multiprocessing.Pool(20))

    def slow_function(self):
        time.sleep(1)
        return 1
    
    @property
    @cache_function
    def test_cache_property(self):
        return self.slow_function()
mads's avatar
mads committed

    @cache_function
    def test_cache_function(self):
        return self.slow_function()

    @get_time
    def prop(self, prop):
        return getattr(self, prop)

    
    @cache_method(2)
    def test_cache_method1(self, x):
        time.sleep(1)
        return x

    @cache_method(2)
    def test_cache_method2(self, x):
        time.sleep(1)
        return x*2
mads's avatar
mads committed

Mads M. Pedersen's avatar
Mads M. Pedersen committed
@cache_npsave
Mads M. Pedersen's avatar
Mads M. Pedersen committed
def open_csv(filename):
    return np.loadtxt(filename)
mads's avatar
mads committed

Mads M. Pedersen's avatar
Mads M. Pedersen committed
@cache_npsavez
def open_csv2(filename):
    return np.loadtxt(filename), np.loadtxt(filename)

@cache_npsavez_compressed
def open_csv3(filename):
    return np.loadtxt(filename), np.loadtxt(filename)

mads's avatar
mads committed
def f(x):
    return x ** 2

class TestCacheProperty(unittest.TestCase):
    def setUp(self):
        pass

    def testcache_property_test(self):
        e = Example()
mads's avatar
mads committed
        self.assertAlmostEqual(e.prop("test")[1], 1, 1)
mads's avatar
mads committed
        self.assertAlmostEqual(e.prop("test")[1], 0, 2)
mads's avatar
mads committed
    def testcache_property_pool(self):
        e = Example()
mads's avatar
mads committed
        e.prop("pool")  #load pool
mads's avatar
mads committed
        self.assertAlmostEqual(e.prop("pool")[1], 0, places=4)
mads's avatar
mads committed
        #print (get_time(e.pool.map)(f, range(10)))
mads's avatar
mads committed
    def test_cache_function(self):
        e = Example()
mads's avatar
mads committed
        self.assertAlmostEqual(get_time(e.test_cache_function)()[1], 1, places=1)
        self.assertAlmostEqual(get_time(e.test_cache_function)()[1], 0, places=1)
        self.assertAlmostEqual(get_time(e.test_cache_function)(reload=True)[1], 1, places=1)
        self.assertAlmostEqual(get_time(e.test_cache_function)()[1], 0, places=1)
mads's avatar
mads committed
        e.clear_cache()
mads's avatar
mads committed
        self.assertAlmostEqual(get_time(e.test_cache_function)()[1], 1, places=1)
 
    def test_cache_function_with_arguments(self):
        e = Example()
        self.assertAlmostEqual(get_time(e.test_cache_method1)(3)[1], 1, places=1)
        self.assertAlmostEqual(get_time(e.test_cache_method1)(3)[1], 0, places=1)
        self.assertEqual(e.test_cache_method1(3), 3)
        self.assertAlmostEqual(get_time(e.test_cache_method1)(4)[1], 1, places=1)
        self.assertAlmostEqual(get_time(e.test_cache_method1)(3)[1], 0, places=1)
        self.assertAlmostEqual(get_time(e.test_cache_method1)(4)[1], 0, places=1)
        self.assertAlmostEqual(get_time(e.test_cache_method1)(5)[1], 1, places=1)
        self.assertAlmostEqual(get_time(e.test_cache_method1)(4)[1], 0, places=1)
        self.assertAlmostEqual(get_time(e.test_cache_method1)(5)[1], 0, places=1)
        self.assertAlmostEqual(get_time(e.test_cache_method1)(3)[1], 1, places=1)
        self.assertEqual(e.test_cache_method2(3), 6)
        self.assertEqual(e.test_cache_method1(3), 3)
        self.assertEqual(e.test_cache_method1(5), 5)
        self.assertAlmostEqual(get_time(e.test_cache_method1)(5)[1], 0, places=1)
         
    def test_cache_property(self):
        e = Example()
        t = time.time()
        e.test_cache_property
        self.assertAlmostEqual(time.time()-t, 1, places=1)
        t = time.time()
        e.test_cache_property
        self.assertAlmostEqual(time.time()-t, 0, places=1)
Mads M. Pedersen's avatar
Mads M. Pedersen committed
        
Mads M. Pedersen's avatar
Mads M. Pedersen committed
    def test_cache_save(self):
Mads M. Pedersen's avatar
Mads M. Pedersen committed
        if os.path.isfile(tfp+"test.npy"):
            os.remove(tfp+'test.npy')
        A = open_csv(tfp + "test.csv")
        self.assertTrue(os.path.isfile(tfp+"test.npy"))
        np.testing.assert_array_equal(A,np.loadtxt(tfp + "test.csv"))
        A[0]=-1
        np.save(tfp+"test.npy",A)
        B = open_csv(tfp + "test.csv")
        np.testing.assert_array_equal(A,B)
        os.remove(tfp+'test.npy')
Mads M. Pedersen's avatar
Mads M. Pedersen committed

    def test_cache_savez(self):
Mads M. Pedersen's avatar
Mads M. Pedersen committed
        npfilename = tfp+"test.npy.npz"
        func = open_csv2
        if os.path.isfile(npfilename):
            os.remove(npfilename)
        A = func(tfp + "test.csv")
        self.assertTrue(os.path.isfile(npfilename))
Mads M. Pedersen's avatar
Mads M. Pedersen committed
        np.testing.assert_array_equal(A[0],np.loadtxt(tfp + "test.csv"))
        A[0][0]=-1
Mads M. Pedersen's avatar
Mads M. Pedersen committed
        np.savez(npfilename,A[0],A[1])
        B = func(tfp + "test.csv")
Mads M. Pedersen's avatar
Mads M. Pedersen committed
        np.testing.assert_array_equal(A,B)
Mads M. Pedersen's avatar
Mads M. Pedersen committed
        os.remove(npfilename)
Mads M. Pedersen's avatar
Mads M. Pedersen committed
        
Mads M. Pedersen's avatar
Mads M. Pedersen committed
    def test_cache_savez_compressed(self):
Mads M. Pedersen's avatar
Mads M. Pedersen committed
        npfilename = tfp+"test.npy.c.npz"
Mads M. Pedersen's avatar
Mads M. Pedersen committed
        func = open_csv3
        if os.path.isfile(npfilename):
            os.remove(npfilename)
        A = func(tfp + "test.csv")
        self.assertTrue(os.path.isfile(npfilename))
        np.testing.assert_array_equal(A[0],np.loadtxt(tfp + "test.csv"))
Mads M. Pedersen's avatar
Mads M. Pedersen committed
        A[0][0]=-1
Mads M. Pedersen's avatar
Mads M. Pedersen committed
        np.savez(npfilename,A[0],A[1])
        B = func(tfp + "test.csv")
Mads M. Pedersen's avatar
Mads M. Pedersen committed
        np.testing.assert_array_equal(A,B)
Mads M. Pedersen's avatar
Mads M. Pedersen committed
        os.remove(npfilename)
mads's avatar
mads committed
if __name__ == "__main__":
    #import sys;sys.argv = ['', 'Test.testName']
    unittest.main()