 0a2928f810
			
		
	
	0a2928f810
	
	
	
		
			
			- Added a MapFunctorTask and ReduceFunctorTask to mimic the python builtin functions map and reduce, respectively Change-Id: I29cd1249e1671aedfd2d25460d746b8d2154df2b
		
			
				
	
	
		
			73 lines
		
	
	
		
			2.1 KiB
		
	
	
	
		
			Python
		
	
	
	
	
	
			
		
		
	
	
			73 lines
		
	
	
		
			2.1 KiB
		
	
	
	
		
			Python
		
	
	
	
	
	
| # -*- coding: utf-8 -*-
 | |
| 
 | |
| #    Copyright 2015 Hewlett-Packard Development Company, L.P.
 | |
| #
 | |
| #    Licensed under the Apache License, Version 2.0 (the "License"); you may
 | |
| #    not use this file except in compliance with the License. You may obtain
 | |
| #    a copy of the License at
 | |
| #
 | |
| #         http://www.apache.org/licenses/LICENSE-2.0
 | |
| #
 | |
| #    Unless required by applicable law or agreed to in writing, software
 | |
| #    distributed under the License is distributed on an "AS IS" BASIS, WITHOUT
 | |
| #    WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. See the
 | |
| #    License for the specific language governing permissions and limitations
 | |
| #    under the License.
 | |
| 
 | |
| import taskflow.engines as engines
 | |
| from taskflow.patterns import linear_flow
 | |
| from taskflow import task as base
 | |
| from taskflow import test
 | |
| 
 | |
| 
 | |
| def sum(x, y):
 | |
|     return x + y
 | |
| 
 | |
| multiply = lambda x, y: x * y
 | |
| 
 | |
| 
 | |
| class ReduceFunctorTaskTest(test.TestCase):
 | |
| 
 | |
|     def setUp(self):
 | |
|         super(ReduceFunctorTaskTest, self).setUp()
 | |
| 
 | |
|         self.flow_store = {
 | |
|             'a': 1,
 | |
|             'b': 2,
 | |
|             'c': 3,
 | |
|             'd': 4,
 | |
|             'e': 5,
 | |
|         }
 | |
| 
 | |
|     def test_sum_array(self):
 | |
|         expected = self.flow_store.copy()
 | |
|         expected.update({
 | |
|             'sum': 15
 | |
|         })
 | |
| 
 | |
|         requires = self.flow_store.keys()
 | |
|         provides = 'sum'
 | |
| 
 | |
|         flow = linear_flow.Flow("sum array flow")
 | |
|         flow.add(base.ReduceFunctorTask(sum, requires=requires,
 | |
|                                         provides=provides))
 | |
| 
 | |
|         result = engines.run(flow, store=self.flow_store)
 | |
|         self.assertDictEqual(expected, result)
 | |
| 
 | |
|     def test_multiply_array(self):
 | |
|         expected = self.flow_store.copy()
 | |
|         expected.update({
 | |
|             'product': 120
 | |
|         })
 | |
| 
 | |
|         requires = self.flow_store.keys()
 | |
|         provides = 'product'
 | |
| 
 | |
|         flow = linear_flow.Flow("square array flow")
 | |
|         flow.add(base.ReduceFunctorTask(multiply, requires=requires,
 | |
|                                         provides=provides))
 | |
| 
 | |
|         result = engines.run(flow, store=self.flow_store)
 | |
|         self.assertDictEqual(expected, result)
 |