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
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
122
123
124
125
126
127
128
129
130
131
132
133
134
135
136
137
138
139
140
141
142
143
144
145
146
147
148
149
150
|
/* 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/. */
exports.testDefine = function(assert) {
let tiger = require('./modules/tiger');
assert.equal(tiger.name, 'tiger', 'name proprety was exported properly');
assert.equal(tiger.type, 'cat', 'property form other module exported');
};
exports.testDefineInoresNonFactory = function(assert) {
let mod = require('./modules/async2');
assert.equal(mod.name, 'async2', 'name proprety was exported properly');
assert.ok(mod.traditional2Name !== 'traditional2', '1st is ignored');
};
/* Disable test that require AMD specific functionality:
// define() that exports a function as the module value,
// specifying a module name.
exports.testDefExport = function(assert) {
var add = require('modules/add');
assert.equal(add(1, 1), 2, 'Named define() exporting a function');
};
// define() that exports function as a value, but is anonymous
exports.testAnonDefExport = function (assert) {
var subtract = require('modules/subtract');
assert.equal(subtract(4, 2), 2,
'Anonymous define() exporting a function');
}
// using require([], function () {}) to load modules.
exports.testSimpleRequire = function (assert) {
require(['modules/blue', 'modules/orange'], function (blue, orange) {
assert.equal(blue.name, 'blue', 'Simple require for blue');
assert.equal(orange.name, 'orange', 'Simple require for orange');
assert.equal(orange.parentType, 'color',
'Simple require dependency check for orange');
});
}
// using nested require([]) calls.
exports.testSimpleRequireNested = function (assert) {
require(['modules/blue', 'modules/orange', 'modules/green'],
function (blue, orange, green) {
require(['modules/orange', 'modules/red'], function (orange, red) {
assert.equal(red.name, 'red', 'Simple require for red');
assert.equal(red.parentType, 'color',
'Simple require dependency check for red');
assert.equal(blue.name, 'blue', 'Simple require for blue');
assert.equal(orange.name, 'orange', 'Simple require for orange');
assert.equal(orange.parentType, 'color',
'Simple require dependency check for orange');
assert.equal(green.name, 'green', 'Simple require for green');
assert.equal(green.parentType, 'color',
'Simple require dependency check for green');
});
});
}
// requiring a traditional module, that uses async, that use traditional and
// async, with a circular reference
exports.testMixedCircular = function (assert) {
var t = require('modules/traditional1');
assert.equal(t.name, 'traditional1', 'Testing name');
assert.equal(t.traditional2Name, 'traditional2',
'Testing dependent name');
assert.equal(t.traditional1Name, 'traditional1', 'Testing circular name');
assert.equal(t.async2Name, 'async2', 'Testing async2 name');
assert.equal(t.async2Traditional2Name, 'traditional2',
'Testing nested traditional2 name');
}
// Testing define()(function(require) {}) with some that use exports,
// some that use return.
exports.testAnonExportsReturn = function (assert) {
var lion = require('modules/lion');
require(['modules/tiger', 'modules/cheetah'], function (tiger, cheetah) {
assert.equal('lion', lion, 'Check lion name');
assert.equal('tiger', tiger.name, 'Check tiger name');
assert.equal('cat', tiger.type, 'Check tiger type');
assert.equal('cheetah', cheetah(), 'Check cheetah name');
});
}
// circular dependency
exports.testCircular = function (assert) {
var pollux = require('modules/pollux'),
castor = require('modules/castor');
assert.equal(pollux.name, 'pollux', 'Pollux\'s name');
assert.equal(pollux.getCastorName(),
'castor', 'Castor\'s name from Pollux.');
assert.equal(castor.name, 'castor', 'Castor\'s name');
assert.equal(castor.getPolluxName(), 'pollux',
'Pollux\'s name from Castor.');
}
// test a bad module that asks for exports but also does a define() return
exports.testBadExportAndReturn = function (assert) {
var passed = false;
try {
var bad = require('modules/badExportAndReturn');
} catch(e) {
passed = /cannot use exports and also return/.test(e.toString());
}
assert.equal(passed, true, 'Make sure exports and return fail');
}
// test a bad circular dependency, where an exported value is needed, but
// the return value happens too late, a module already asked for the exported
// value.
exports.testBadExportAndReturnCircular = function (assert) {
var passed = false;
try {
var bad = require('modules/badFirst');
} catch(e) {
passed = /after another module has referenced its exported value/
.test(e.toString());
}
assert.equal(passed, true, 'Make sure return after an exported ' +
'value is grabbed by another module fails.');
}
// only allow one define call per file.
exports.testOneDefine = function (assert) {
var passed = false;
try {
var dupe = require('modules/dupe');
} catch(e) {
passed = /Only one call to define/.test(e.toString());
}
assert.equal(passed, true, 'Only allow one define call per module');
}
// only allow one define call per file, testing a bad nested define call.
exports.testOneDefineNested = function (assert) {
var passed = false;
try {
var dupe = require('modules/dupeNested');
} catch(e) {
passed = /Only one call to define/.test(e.toString());
}
assert.equal(passed, true, 'Only allow one define call per module');
}
*/
require('sdk/test').run(exports);
|