summaryrefslogtreecommitdiffstats
path: root/utils/html_test.go
diff options
context:
space:
mode:
authorHarrison Healey <harrisonmhealey@gmail.com>2017-09-05 17:39:45 -0400
committerJoram Wilander <jwawilander@gmail.com>2017-09-05 17:39:45 -0400
commit6ca443a2556e5d4bade9a9ef7d6d877bf1d6fc45 (patch)
tree0feef921917b85f359f3ce2e44aacd6d61700d4d /utils/html_test.go
parent016b5daa1cde1a147701aafce94f67057fbb7aa6 (diff)
downloadchat-6ca443a2556e5d4bade9a9ef7d6d877bf1d6fc45.tar.gz
chat-6ca443a2556e5d4bade9a9ef7d6d877bf1d6fc45.tar.bz2
chat-6ca443a2556e5d4bade9a9ef7d6d877bf1d6fc45.zip
PLT-7522 Cleaned up translation of templates (#7351)
* PLT-7522 Cleaned up translation of templates * Added unit tests * Changed TranslateAsHtml to not be variadic
Diffstat (limited to 'utils/html_test.go')
-rw-r--r--utils/html_test.go53
1 files changed, 53 insertions, 0 deletions
diff --git a/utils/html_test.go b/utils/html_test.go
new file mode 100644
index 000000000..8dc70242a
--- /dev/null
+++ b/utils/html_test.go
@@ -0,0 +1,53 @@
+// Copyright (c) 2017-present Mattermost, Inc. All Rights Reserved.
+// See License.txt for license information.
+
+package utils
+
+import (
+ "html/template"
+ "testing"
+)
+
+func TestTranslateAsHtml(t *testing.T) {
+ TranslationsPreInit()
+
+ translateFunc := TfuncWithFallback("en")
+
+ expected := "To finish updating your email address for YOUR TEAM HERE, please click the link below to confirm this is the right address."
+ if actual := TranslateAsHtml(translateFunc, "api.templates.email_change_verify_body.info",
+ map[string]interface{}{"TeamDisplayName": "YOUR TEAM HERE"}); actual != template.HTML(expected) {
+ t.Fatalf("Incorrectly translated template, got %v, expected %v", actual, expected)
+ }
+
+ expected = "To finish updating your email address for &lt;b&gt;YOUR TEAM HERE&lt;/b&gt;, please click the link below to confirm this is the right address."
+ if actual := TranslateAsHtml(translateFunc, "api.templates.email_change_verify_body.info",
+ map[string]interface{}{"TeamDisplayName": "<b>YOUR TEAM HERE</b>"}); actual != template.HTML(expected) {
+ t.Fatalf("Incorrectly translated template, got %v, expected %v", actual, expected)
+ }
+}
+
+func TestEscapeForHtml(t *testing.T) {
+ input := "abc"
+ expected := "abc"
+ if actual := escapeForHtml(input).(string); actual != expected {
+ t.Fatalf("incorrectly escaped %v, got %v expected %v", input, actual, expected)
+ }
+
+ input = "<b>abc</b>"
+ expected = "&lt;b&gt;abc&lt;/b&gt;"
+ if actual := escapeForHtml(input).(string); actual != expected {
+ t.Fatalf("incorrectly escaped %v, got %v expected %v", input, actual, expected)
+ }
+
+ inputMap := map[string]interface{}{
+ "abc": "abc",
+ "123": "<b>123</b>",
+ }
+ expectedMap := map[string]interface{}{
+ "abc": "abc",
+ "123": "&lt;b&gt;123&lt;/b&gt;",
+ }
+ if actualMap := escapeForHtml(inputMap).(map[string]interface{}); actualMap["abc"] != expectedMap["abc"] || actualMap["123"] != expectedMap["123"] {
+ t.Fatalf("incorrectly escaped %v, got %v expected %v", inputMap, actualMap, expectedMap)
+ }
+}