summaryrefslogtreecommitdiffstats
path: root/addon-sdk/source/test/test-base64.js
blob: b969413f923e27cba6ebfd4c549f231b462ddf17 (plain)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
/* This Source Code Form is subject to the terms of the Mozilla Public
 * License, v. 2.0. If a copy of the MPL was not distributed with this
 * file, You can obtain one at http://mozilla.org/MPL/2.0/. */

"use strict";

const base64 = require("sdk/base64");

const text = "Awesome!";
const b64text = "QXdlc29tZSE=";

const utf8text = "\u2713 à la mode";
const badutf8text = "\u0013 à la mode";
const b64utf8text = "4pyTIMOgIGxhIG1vZGU=";

// 1 MB string
const longtext = 'fff'.repeat(333333);
const b64longtext = 'ZmZm'.repeat(333333);

exports["test base64.encode"] = function (assert) {
  assert.equal(base64.encode(text), b64text, "encode correctly")
}

exports["test base64.decode"] = function (assert) {
  assert.equal(base64.decode(b64text), text, "decode correctly")
}

exports["test base64.encode Unicode"] = function (assert) {

  assert.equal(base64.encode(utf8text, "utf-8"), b64utf8text,
    "encode correctly Unicode strings.")
}

exports["test base64.decode Unicode"] = function (assert) {

  assert.equal(base64.decode(b64utf8text, "utf-8"), utf8text,
    "decode correctly Unicode strings.")
}

exports["test base64.encode long string"] = function (assert) {

  assert.equal(base64.encode(longtext), b64longtext, "encode long strings")
}

exports["test base64.decode long string"] = function (assert) {

  assert.equal(base64.decode(b64longtext), longtext, "decode long strings")
}

exports["test base64.encode treats input as octet string"] = function (assert) {

  assert.equal(base64.encode("\u0066"), "Zg==",
    "treat octet string as octet string")
  assert.equal(base64.encode("\u0166"), "Zg==",
    "treat non-octet string as octet string")
  assert.equal(base64.encode("\uff66"), "Zg==",
    "encode non-octet string as octet string")
}

exports["test base64.encode with wrong charset"] = function (assert) {

  assert.throws(function() {
    base64.encode(utf8text, "utf-16");
  }, "The charset argument can be only 'utf-8'");

  assert.throws(function() {
    base64.encode(utf8text, "");
  }, "The charset argument can be only 'utf-8'");

  assert.throws(function() {
    base64.encode(utf8text, 8);
  }, "The charset argument can be only 'utf-8'");

}

exports["test base64.decode with wrong charset"] = function (assert) {

  assert.throws(function() {
    base64.decode(utf8text, "utf-16");
  }, "The charset argument can be only 'utf-8'");

  assert.throws(function() {
    base64.decode(utf8text, "");
  }, "The charset argument can be only 'utf-8'");

  assert.throws(function() {
    base64.decode(utf8text, 8);
  }, "The charset argument can be only 'utf-8'");

}

exports["test encode/decode Unicode without utf-8 as charset"] = function (assert) {

  assert.equal(base64.decode(base64.encode(utf8text)), badutf8text,
    "Unicode strings needs 'utf-8' charset or will be mangled"
  );

}

require("test").run(exports);