Commit 65503f21 authored by Michal Čihař's avatar Michal Čihař

Add tests for template tags

...and add missing escaping there.
Signed-off-by: default avatarMichal Čihař <michal@cihar.com>
parent 0b7b5124
...@@ -581,9 +581,9 @@ def get_location_links(unit): ...@@ -581,9 +581,9 @@ def get_location_links(unit):
line = 0 line = 0
link = unit.translation.subproject.get_repoweb_link(filename, line) link = unit.translation.subproject.get_repoweb_link(filename, line)
if link is None: if link is None:
ret.append('%s' % location) ret.append(escape(location))
else: else:
ret.append('<a href="%s">%s</a>' % (link, location)) ret.append('<a href="%s">%s</a>' % (escape(link), escape(location)))
return mark_safe('\n'.join(ret)) return mark_safe('\n'.join(ret))
......
...@@ -18,7 +18,7 @@ ...@@ -18,7 +18,7 @@
# along with this program. If not, see <http://www.gnu.org/licenses/>. # along with this program. If not, see <http://www.gnu.org/licenses/>.
# #
''' '''
Testing of natural time conversion. Testing of template tags.
''' '''
import datetime import datetime
...@@ -26,7 +26,10 @@ from unittest import TestCase ...@@ -26,7 +26,10 @@ from unittest import TestCase
from django.utils import timezone from django.utils import timezone
from weblate.trans.templatetags.translations import naturaltime from weblate.trans.models import Unit, SubProject, Translation
from weblate.trans.templatetags.translations import (
naturaltime, get_location_links
)
TEST_DATA = ( TEST_DATA = (
(0, 'now'), (0, 'now'),
...@@ -62,6 +65,7 @@ TEST_DATA = ( ...@@ -62,6 +65,7 @@ TEST_DATA = (
class NaturalTimeTest(TestCase): class NaturalTimeTest(TestCase):
"""Testing of natural time conversion."""
def test_natural(self): def test_natural(self):
now = timezone.now() now = timezone.now()
for diff, expected in TEST_DATA: for diff, expected in TEST_DATA:
...@@ -73,3 +77,60 @@ class NaturalTimeTest(TestCase): ...@@ -73,3 +77,60 @@ class NaturalTimeTest(TestCase):
testdate, result, expected, testdate, result, expected,
) )
) )
class LocationLinksTest(TestCase):
def setUp(self):
self.unit = Unit(
translation=Translation(
subproject=SubProject()
)
)
def test_empty(self):
self.assertEqual(
get_location_links(self.unit),
''
)
def test_numeric(self):
self.unit.location = '123'
self.assertEqual(
get_location_links(self.unit),
'unit ID 123'
)
def test_filenames(self):
self.unit.location = 'f&oo.bar:123'
self.assertEqual(
get_location_links(self.unit),
'f&amp;oo.bar:123'
)
def test_filenames(self):
self.unit.location = 'foo.bar:123,bar.foo:321'
self.assertEqual(
get_location_links(self.unit),
'foo.bar:123\nbar.foo:321'
)
def test_repowebs(self):
self.unit.translation.subproject.repoweb = (
'http://example.net/%(file)s#L%(line)s'
)
self.unit.location = 'foo.bar:123,bar.foo:321'
self.assertEqual(
get_location_links(self.unit),
'<a href="http://example.net/foo.bar#L123">foo.bar:123</a>\n'
'<a href="http://example.net/bar.foo#L321">bar.foo:321</a>'
)
def test_repoweb(self):
self.unit.translation.subproject.repoweb = (
'http://example.net/%(file)s#L%(line)s'
)
self.unit.location = 'foo.bar:123'
self.assertEqual(
get_location_links(self.unit),
'<a href="http://example.net/foo.bar#L123">foo.bar:123</a>'
)
Markdown is supported
0%
or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment