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

Side by Side Diff: pkg/mock/lib/mock.dart

Issue 1115483002: remove pkg/mock (Closed) Base URL: https://dart.googlecode.com/svn/branches/bleeding_edge/dart
Patch Set: Created 5 years, 7 months 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/mock/LICENSE ('k') | pkg/mock/lib/src/action.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 /**
6 * A simple mocking/spy library.
7 *
8 * To create a mock objects for some class T, create a new class using:
9 *
10 * class MockT extends Mock implements T {};
11 *
12 * Then specify the [Behavior] of the Mock for different methods using
13 * [when] (to select the method and parameters) and then the [Action]s
14 * for the [Behavior] by calling [thenReturn], [alwaysReturn], [thenThrow],
15 * [alwaysThrow], [thenCall] or [alwaysCall].
16 *
17 * [thenReturn], [thenThrow] and [thenCall] are one-shot so you would
18 * typically call these more than once to specify a sequence of actions;
19 * this can be done with chained calls, e.g.:
20 *
21 * m.when(callsTo('foo')).
22 * thenReturn(0).thenReturn(1).thenReturn(2);
23 *
24 * [thenCall] and [alwaysCall] allow you to proxy mocked methods, chaining
25 * to some other implementation. This provides a way to implement 'spies'.
26 *
27 * For getters and setters, use "get foo" and "set foo"-style arguments
28 * to [callsTo].
29 *
30 * You can disable logging for a particular [Behavior] easily:
31 *
32 * m.when(callsTo('bar')).logging = false;
33 *
34 * You can then use the mock object. Once you are done, to verify the
35 * behavior, use [getLogs] to extract a relevant subset of method call
36 * logs and apply [Matchers] to these through calling [verify].
37 *
38 * A Mock can be given a name when constructed. In this case instead of
39 * keeping its own log, it uses a shared log. This can be useful to get an
40 * audit trail of interleaved behavior. It is the responsibility of the user
41 * to ensure that mock names, if used, are unique.
42 *
43 * Limitations:
44 *
45 * * only positional parameters are supported (up to 10);
46 * * to mock getters you will need to include parentheses in the call
47 * (e.g. m.length() will work but not m.length).
48 *
49 * Here is a simple example:
50 *
51 * class MockList extends Mock implements List {};
52 *
53 * List m = new MockList();
54 * m.when(callsTo('add', anything)).alwaysReturn(0);
55 *
56 * m.add('foo');
57 * m.add('bar');
58 *
59 * getLogs(m, callsTo('add', anything)).verify(happenedExactly(2));
60 * getLogs(m, callsTo('add', 'foo')).verify(happenedOnce);
61 * getLogs(m, callsTo('add', 'isNull)).verify(neverHappened);
62 *
63 * Note that we don't need to provide argument matchers for all arguments,
64 * but we do need to provide arguments for all matchers. So this is allowed:
65 *
66 * m.when(callsTo('add')).alwaysReturn(0);
67 * m.add(1, 2);
68 *
69 * But this is not allowed and will throw an exception:
70 *
71 * m.when(callsTo('add', anything, anything)).alwaysReturn(0);
72 * m.add(1);
73 *
74 * Here is a way to implement a 'spy', which is where we log the call
75 * but then hand it off to some other function, which is the same
76 * method in a real instance of the class being mocked:
77 *
78 * class Foo {
79 * bar(a, b, c) => a + b + c;
80 * }
81 *
82 * class MockFoo extends Mock implements Foo {
83 * Foo real;
84 * MockFoo() {
85 * real = new Foo();
86 * this.when(callsTo('bar')).alwaysCall(real.bar);
87 * }
88 * }
89 *
90 * However, there is an even easier way, by calling [Mock.spy], e.g.:
91 *
92 * var foo = new Foo();
93 * var spy = new Mock.spy(foo);
94 * print(spy.bar(1, 2, 3));
95 *
96 * Spys created with Mock.spy do not have user-defined behavior;
97 * they are simply proxies, and thus will throw an exception if
98 * you call [when]. They capture all calls in the log, so you can
99 * do assertions on their history, such as:
100 *
101 * spy.getLogs(callsTo('bar')).verify(happenedOnce);
102 *
103 * [pub]: http://pub.dartlang.org
104 */
105
106 library mock;
107
108 export 'src/action.dart';
109 export 'src/behavior.dart';
110 export 'src/call_matcher.dart';
111 export 'src/log_entry.dart';
112 export 'src/log_entry_list.dart';
113 export 'src/mock.dart';
114 export 'src/responder.dart';
115 export 'src/result_matcher.dart';
116 export 'src/result_set_matcher.dart';
117 export 'src/times_matcher.dart';
OLDNEW
« no previous file with comments | « pkg/mock/LICENSE ('k') | pkg/mock/lib/src/action.dart » ('j') | no next file with comments »

Powered by Google App Engine
This is Rietveld 408576698