forked from marcuswestin/store.js
-
Notifications
You must be signed in to change notification settings - Fork 1
/
test.html
112 lines (97 loc) · 4.03 KB
/
test.html
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
<!DOCTYPE html>
<head>
<title>jquery.store.js test</title>
<style type="text/css">
body { margin: 50px; font-family: helvetica; color: #333; }
div { color: green; }
#errorOutput div { color: red; }
</style>
<script src="json.js"></script>
<script src="jquery-1.4.3.js"></script>
<script src="jquery.store.js"></script>
</head>
<body>
tests for <a href="http://github.com/whitmer/jquery.store.js">jquery.store.js</a>
<div id="errorOutput"></div>
<script>
(function() {
var doc = document,
errorOutput = doc.getElementById('errorOutput'),
testFailed = false,
isSecondPass = (doc.location.hash == '#secondPass')
function outputError(msg) { errorOutput.appendChild(doc.createElement('div')).innerHTML = msg }
function assert(truthy, msg) {
if (!truthy) {
outputError((isSecondPass ? 'second' : 'first') + ' pass bad assert: ' + msg);
testFailed = true
}
}
function doFirstPass() {
$.store.clear()
$.store.set('foo', 'bar')
assert($.store.get('foo') == 'bar', "stored key 'foo' not equal to stored value 'bar'")
$.store.remove('foo')
assert($.store.get('foo') == null, "removed key 'foo' not null")
$.store.set('foo', 'bar1')
$.store.set('foo', 'bar2')
assert($.store.get('foo') == 'bar2', "key 'foo' is not equal to second value set 'bar2'")
$.store.set('foo', 'bar')
$.store.set('bar', 'foo')
$.store.remove('foo')
assert($.store.get('bar') == 'foo', "removing key 'foo' also removed key 'bar'")
$.store.set('foo', 'bar')
$.store.set('bar', 'foo')
$.store.clear()
assert($.store.get('foo') == null && $.store.get('bar') == null, "keys foo and bar not cleared after store cleared")
$.store.transact('foosact', function(val) {
assert(typeof val == 'object', "new key is not an object at beginning of transaction")
val.foo = 'foo'
})
$.store.transact('foosact', function(val) {
assert(val.foo == 'foo', "first transaction did not register")
val.bar = 'bar'
})
assert($.store.get('foosact').bar == 'bar', "second transaction did not register")
$.store.set('foo', { name: 'marcus', arr: [1,2,3] })
assert(typeof $.store.get('foo') == 'object', "type of stored object 'foo' is not 'object'")
assert($.store.get('foo') instanceof Object, "stored object 'foo' is not an instance of Object")
assert($.store.get('foo').name == 'marcus', "property 'name' of stored object 'foo' is not 'marcus'")
assert($.store.get('foo').arr instanceof Array, "Array property 'arr' of stored object 'foo' is not an instance of Array")
assert($.store.get('foo').arr.length == 3, "The length of Array property 'arr' stored on object 'foo' is not 3")
$.store.remove('circularReference')
var circularOne = {}
var circularTwo = { one:circularOne }
circularOne.two = circularTwo
var threw = false
try { $.store.set('circularReference', circularOne) }
catch(e) { threw = true }
assert(threw, "storing object with circular reference did not throw")
assert(!$.store.get('circularReference'), "attempting to store object with circular reference which should have faile affected store state")
// The following stored values get tested in doSecondPass after a page reload
$.store.set('firstPassFoo', 'bar')
$.store.set('firstPassObj', { woot: true })
}
function doSecondPass() {
assert($.store.get('firstPassFoo') == 'bar', "first pass key 'firstPassFoo' not equal to stored value 'bar'")
$.store.clear()
assert($.store.get('firstPassFoo') == null, "first pass key 'firstPassFoo' not null after store cleared")
}
try {
if (isSecondPass) { doSecondPass() }
else { doFirstPass() }
} catch(e) {
assert(false, 'Tests should not throw: "' + JSON.stringify(e) + '"')
}
if (!testFailed) {
if (!isSecondPass) {
doc.location.hash = '#secondPass'
doc.location.reload()
} else {
doc.location.hash = '#'
doc.body.appendChild(doc.createElement('div')).innerHTML = 'Tests passed'
}
}
})()
</script>
</body>
</html>