1 # GNU MediaGoblin -- federated, autonomous media hosting
2 # Copyright (C) 2011, 2012 MediaGoblin contributors. See AUTHORS.
4 # This program is free software: you can redistribute it and/or modify
5 # it under the terms of the GNU Affero General Public License as published by
6 # the Free Software Foundation, either version 3 of the License, or
7 # (at your option) any later version.
9 # This program is distributed in the hope that it will be useful,
10 # but WITHOUT ANY WARRANTY; without even the implied warranty of
11 # MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
12 # GNU Affero General Public License for more details.
14 # You should have received a copy of the GNU Affero General Public License
15 # along with this program. If not, see <http://www.gnu.org/licenses/>.
17 from mediagoblin
.tools
import text
19 def test_list_of_dicts_conversion(test_app
):
21 When the user adds tags to a media entry, the string from the form is
22 converted into a list of tags, where each tag is stored in the database
23 as a dict. Each tag dict should contain the tag's name and slug. Another
24 function performs the reverse operation when populating a form to edit tags.
26 # Leading, trailing, and internal whitespace should be removed and slugified
27 assert text
.convert_to_tag_list_of_dicts('sleep , 6 AM, chainsaw! ') == [
28 {'name': u
'sleep', 'slug': u
'sleep'},
29 {'name': u
'6 AM', 'slug': u
'6-am'},
30 {'name': u
'chainsaw!', 'slug': u
'chainsaw'}]
32 # If the user enters two identical tags, record only one of them
33 assert text
.convert_to_tag_list_of_dicts('echo,echo') == [{'name': u
'echo',
36 # When checking for duplicates, use the slug, not the tag
37 assert text
.convert_to_tag_list_of_dicts('echo,#echo') == [{'name': u
'#echo',
40 # Make sure converting the list of dicts to a string works
41 assert text
.media_tags_as_string([{'name': u
'yin', 'slug': u
'yin'},
42 {'name': u
'yang', 'slug': u
'yang'}]) == \