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
.tests
.tools
import get_test_app
18 from mediagoblin
.tools
import text
20 def test_list_of_dicts_conversion():
22 When the user adds tags to a media entry, the string from the form is
23 converted into a list of tags, where each tag is stored in the database
24 as a dict. Each tag dict should contain the tag's name and slug. Another
25 function performs the reverse operation when populating a form to edit tags.
27 test_app
= get_test_app(dump_old_app
=False)
28 # Leading, trailing, and internal whitespace should be removed and slugified
29 assert text
.convert_to_tag_list_of_dicts('sleep , 6 AM, chainsaw! ') == [
30 {'name': u
'sleep', 'slug': u
'sleep'},
31 {'name': u
'6 AM', 'slug': u
'6-am'},
32 {'name': u
'chainsaw!', 'slug': u
'chainsaw'}]
34 # If the user enters two identical tags, record only one of them
35 assert text
.convert_to_tag_list_of_dicts('echo,echo') == [{'name': u
'echo',
38 # Make sure converting the list of dicts to a string works
39 assert text
.media_tags_as_string([{'name': u
'yin', 'slug': u
'yin'},
40 {'name': u
'yang', 'slug': u
'yang'}]) == \