Chromium Code Reviews
chromiumcodereview-hr@appspot.gserviceaccount.com (chromiumcodereview-hr) | Please choose your nickname with Settings | Help | Chromium Project | Gerrit Changes | Sign out
(760)

Side by Side Diff: pkg/matcher/lib/src/map_matchers.dart

Issue 807193003: Re-apply "Remove unittest and matcher from the repo." (Closed) Base URL: https://dart.googlecode.com/svn/branches/bleeding_edge/dart
Patch Set: Code review changes Created 6 years ago
Use n/p to move between diff chunks; N/P to move between comments. Draft comments are only viewable by you.
Jump to:
View unified diff | Download patch | Annotate | Revision Log
« no previous file with comments | « pkg/matcher/lib/src/iterable_matchers.dart ('k') | pkg/matcher/lib/src/numeric_matchers.dart » ('j') | no next file with comments »
Toggle Intra-line Diffs ('i') | Expand Comments ('e') | Collapse Comments ('c') | Show Comments Hide Comments ('s')
OLDNEW
(Empty)
1 // Copyright (c) 2012, the Dart project authors. Please see the AUTHORS file
2 // for details. All rights reserved. Use of this source code is governed by a
3 // BSD-style license that can be found in the LICENSE file.
4
5 library matcher.map_matchers;
6
7 import 'interfaces.dart';
8 import 'util.dart';
9
10 /// Returns a matcher which matches maps containing the given [value].
11 Matcher containsValue(value) => new _ContainsValue(value);
12
13 class _ContainsValue extends Matcher {
14 final _value;
15
16 const _ContainsValue(this._value);
17
18 bool matches(item, Map matchState) => item.containsValue(_value);
19 Description describe(Description description) =>
20 description.add('contains value ').addDescriptionOf(_value);
21 }
22
23 /// Returns a matcher which matches maps containing the key-value pair
24 /// with [key] => [value].
25 Matcher containsPair(key, value) =>
26 new _ContainsMapping(key, wrapMatcher(value));
27
28 class _ContainsMapping extends Matcher {
29 final _key;
30 final Matcher _valueMatcher;
31
32 const _ContainsMapping(this._key, Matcher this._valueMatcher);
33
34 bool matches(item, Map matchState) =>
35 item.containsKey(_key) &&
36 _valueMatcher.matches(item[_key], matchState);
37
38 Description describe(Description description) {
39 return description.add('contains pair ').addDescriptionOf(_key).
40 add(' => ').addDescriptionOf(_valueMatcher);
41 }
42
43 Description describeMismatch(item, Description mismatchDescription,
44 Map matchState, bool verbose) {
45 if (!item.containsKey(_key)) {
46 return mismatchDescription.add(" doesn't contain key ")
47 .addDescriptionOf(_key);
48 } else {
49 mismatchDescription.add(' contains key ').addDescriptionOf(_key).
50 add(' but with value ');
51 _valueMatcher.describeMismatch(item[_key], mismatchDescription,
52 matchState, verbose);
53 return mismatchDescription;
54 }
55 }
56 }
OLDNEW
« no previous file with comments | « pkg/matcher/lib/src/iterable_matchers.dart ('k') | pkg/matcher/lib/src/numeric_matchers.dart » ('j') | no next file with comments »

Powered by Google App Engine
This is Rietveld 408576698