aboutsummaryrefslogtreecommitdiffstats
path: root/src/scenario/Matcher.js
diff options
context:
space:
mode:
authorMisko Hevery2010-08-10 11:46:37 -0700
committerMisko Hevery2010-08-10 11:46:37 -0700
commit8d635cfb876e844302f24b8d08744cf44d5e7070 (patch)
treeafa3c5531c38d81c000c69601648743878c726c5 /src/scenario/Matcher.js
parent7673b2a2b291a4fc627e1cbdb8201f116a97b016 (diff)
parent86c2ef87d5069f0836079e171c0f33efcf2b5d24 (diff)
downloadangular.js-8d635cfb876e844302f24b8d08744cf44d5e7070.tar.bz2
Merge branch 'master' of github.com:angular/angular.js
Diffstat (limited to 'src/scenario/Matcher.js')
-rw-r--r--src/scenario/Matcher.js21
1 files changed, 21 insertions, 0 deletions
diff --git a/src/scenario/Matcher.js b/src/scenario/Matcher.js
new file mode 100644
index 00000000..62f094c8
--- /dev/null
+++ b/src/scenario/Matcher.js
@@ -0,0 +1,21 @@
+function Matcher(scope, future, logger) {
+ var self = scope.$scenario = this;
+ this.logger = logger;
+ this.future = future;
+}
+
+Matcher.addMatcher = function(name, matcher) {
+ Matcher.prototype[name] = function(expected) {
+ var future = this.future;
+ $scenario.addFuture(
+ 'expect ' + future.name + ' ' + name + ' ' + expected,
+ function(done){
+ if (!matcher(future.value, expected))
+ throw "Expected " + expected + ' but was ' + future.value;
+ done();
+ }
+ );
+ };
+};
+
+Matcher.addMatcher('toEqual', function(a,b) { return a == b; });