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
18 from mediagoblin
.tools
.testing
import _activate_testing
23 def test_list_of_dicts_conversion(test_app
):
25 When the user adds tags to a media entry, the string from the form is
26 converted into a list of tags, where each tag is stored in the database
27 as a dict. Each tag dict should contain the tag's name and slug. Another
28 function performs the reverse operation when populating a form to edit tags.
30 # Leading, trailing, and internal whitespace should be removed and slugified
31 assert text
.convert_to_tag_list_of_dicts('sleep , 6 AM, chainsaw! ') == [
32 {'name': u
'sleep', 'slug': u
'sleep'},
33 {'name': u
'6 AM', 'slug': u
'6-am'},
34 {'name': u
'chainsaw!', 'slug': u
'chainsaw'}]
36 # If the user enters two identical tags, record only one of them
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'}]) == \