blob: 5fcee8a1b3812425c6d31288f0517f9eec816a2a [file] [log] [blame]
# coding=utf-8
#
# Licensed to the Apache Software Foundation (ASF) under one or more
# contributor license agreements. See the NOTICE file distributed with
# this work for additional information regarding copyright ownership.
# The ASF licenses this file to You 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.
#
from __future__ import absolute_import
from __future__ import print_function
import unittest
import mock
from apache_beam.testing.test_pipeline import TestPipeline
from apache_beam.testing.util import assert_that
from apache_beam.testing.util import equal_to
from . import map
def check_plants(actual):
# [START plants]
plants = [
'🍓Strawberry',
'🥕Carrot',
'🍆Eggplant',
'🍅Tomato',
'🥔Potato',
]
# [END plants]
assert_that(actual, equal_to(plants))
def check_plant_details(actual):
# [START plant_details]
plant_details = [
{'icon': '🍓', 'name': 'Strawberry', 'duration': 'perennial'},
{'icon': '🥕', 'name': 'Carrot', 'duration': 'biennial'},
{'icon': '🍆', 'name': 'Eggplant', 'duration': 'perennial'},
{'icon': '🍅', 'name': 'Tomato', 'duration': 'annual'},
{'icon': '🥔', 'name': 'Potato', 'duration': 'perennial'},
]
# [END plant_details]
assert_that(actual, equal_to(plant_details))
@mock.patch('apache_beam.Pipeline', TestPipeline)
# pylint: disable=line-too-long
@mock.patch('apache_beam.examples.snippets.transforms.element_wise.map.print', lambda elem: elem)
# pylint: enable=line-too-long
class MapTest(unittest.TestCase):
def test_map_simple(self):
map.map_simple(check_plants)
def test_map_function(self):
map.map_function(check_plants)
def test_map_lambda(self):
map.map_lambda(check_plants)
def test_map_multiple_arguments(self):
map.map_multiple_arguments(check_plants)
def test_map_tuple(self):
map.map_tuple(check_plants)
def test_map_side_inputs_singleton(self):
map.map_side_inputs_singleton(check_plants)
def test_map_side_inputs_iter(self):
map.map_side_inputs_iter(check_plants)
def test_map_side_inputs_dict(self):
map.map_side_inputs_dict(check_plant_details)
if __name__ == '__main__':
unittest.main()