- When formatting a generated mocks library, use the language version of the library with the mockito annotation.
- Ignore "must_be_immutable" warning in generated files. Mocks cannot be made immutable anyway, but this way users aren't prevented from using generated mocks altogether.
- Require Dart SDK ^3.6.0.
- Require
analyzer: '>=6.9.0 <8.0.0'
. - Require
dart_style: '>=2.3.7 <4.0.0'
, so that the current Dart language version can be passed toDartFormatter
. - Require
source_gen: ">=1.4.0 <3.0.0"
. - Add support for extension types.
- Add topics to
pubspec.yaml
. - Fix a bug where type aliases in type arguments were not correctly resolved.
- Fix a bug where record types were not correctly resolved.
- Use
posix
style for local imports. - Allow test_api ^0.7.0.
- Require analyzer 5.12.0, allow analyzer version 6.x;
- Add example of writing a class to mock function objects.
- Add support for the
build_extensions
build.yaml option - Require Dart >=3.1.0.
- Potentially breaking Changed default
String
value returned by nice mocks' unstubbed method to include some useful info. This could break the tests that relied on getting an emptyString
from unstubbed methods. - Remove deprecated
returnNullOnMissingStub
andOnMissingStub.returnNull
MockSpec
options.
- Require code_builder 4.5.0.
- Add support for records.
- Fixed the bug with missing imports for unused type alias arguments.
- Deprecate the
mixingIn
argument toMockSpec
. Best practice is to avoid any concrete implementation in classes which extendMock
. - Fixed generation for clashing type variable names.
- Require Dart >= 2.19.0.
- Require analyzer 5.11.0.
- Fail to generate mocks of
sealed
/base
/final
classes. - Add new
thenReturnInOrder
method to mock multiple calls to a single method in order. - Add
provideDummy
/provideDummyBuilder
functions for users to supply dummy values to Mockito, to cover cases where codegen can't create one. - Allow generating mocks for classes with methods/getters returning non-nullable unknown types.
- Fix nice mocks generation in mixed mode (generated code is pre null-safety, while mocked class is null-safe).
- Support typedef-aliased classes in
@GenerateMocks
and@GenerateNiceMocks
- Breaking Default
generate_for
totest/**
. Projects that are generating mocks for libraries outside of thetest/
directory should add an explicitgenerate_for
argument to include files with mock generating annotations. - Require Dart >= 2.17.0.
- Require analyzer 5.2.0.
- Support analyzer 5.0.0.
- Fix analyzer and code_builder dependencies.
- Reference
@GenerateNiceMocks
in documentation. - Allow generating a mock class which includes overriding members with private
types in their signature. Such members cannot be stubbed with mockito, and
will only be generated when specified in MockSpec
unsupportedMembers
. - Include
required
keyword in functions used as default return values.
- Introduce a new
MockSpec
parameter,onMissingStub
, which allows specifying three actions to take when a real call is made to a mock method with no matching stub. The two existing behaviors are the default behavior of throwing an exception, and the legacy behavior of returningnull
. A new behavior is also introduced: returning a legal default value. With this behavior, legal default values are returned for any given type. - Deprecate the
MockSpec
returnNullOnMissingStub
parameter in favor of the newonMissingStub
parameter. - Introduce a new
@GenerateNiceMocks
annotation, that uses the new "return a legal value" behavior for missing stubs. - Add
SmartFake
class to be used as a return values for unstubbed methods. It remembers where it was created and throws a descriptive error in case the fake is later used. - Include
required
keyword in function types to match overridden function types.
- Fix generation of methods with return type of
FutureOr<T>
for generic, potentially nullableT
. - Support
@GenerateMocks
annotations onimport
andexport
directives. - Support analyzer 4.x.
- In creating mocks for a pre-null-safe library, opt out of null safety in the generated code.
- Properly generate method overrides for methods with covariant parameters. #506
- Correctly generate a
toString
override method for pre-null safe libraries, for which the class-to-mock implementstoString
with additional parameters. - Improve messaging in a MissingStubError, directing to the docs for MockSpec.
- Fix incorrect error when trying to mock a method with a parameter with inner function types (like in type arguments) which are potentially non-nullable. #476
- Allow fallback generators to be applied for getters.
- Support generating a mock class for a class with members with non-nullable
unknown return types via a new parameter on
MockSpec
calledunsupportedMembers
. See NULL_SAFETY_README for details.
- Report when a class cannot be mocked because an inherited method or property accessor requires a private type. #446
- Do not needlessly implement
toString
unless the class-to-mock implementstoString
with additional parameters. #461 - Support analyzer 3.x.
- Fix type reference for nested, imported types found in type arguments on a custom class-to-mock. #469
- Bump minimum analyzer dependency to version 2.1.0.
- Ignore
camel_case_types
lint in generated code.
- Fix an issue generating the correct parameter default value given a constructor which redirects to a constructor declared in a separate library. #459
- Generate Fake classes with unique names. #441
- Implement methods which have been overridden in the mixin hierarchy properly. Previously, mixins were being applied in the wrong order, which could skip over one method that overrides another with a different signature. #456
- Use an empty list with a correct type argument for a fallback value for a method which returns Iterable. #445
- When selecting the library that should be imported in order to reference a type, prefer a library which exports the library in which the type is declared. This avoids some confusion with conditional exports. #443
- Properly reference types in overridden
toString
implementations. #438 - Override
toString
in a Fake implementation when the class-to-be-faked has a superclass which overridestoString
with additional parameters. #371 - Support analyzer 2.x.
- Allow two mocks of the same class (with different type arguments) to be specified with different fallback generators.
- Allow fallback generators on super types of a mocked class.
- Avoid
inference_failure_on_instance_creation
errors in generated code. - Ignore
implementation_imports
lint in generated code. - Support methods with
Function
andFuture<Function>
return types.
- Generate a proper mock class when the mocked class overrides
toString
,hashCode
, oroperator==
. #420 - Override
toString
implementation on generated Fakes in order to match the signature of an overriding method which adds optional parameters. #371 Properly type methods in a generated mock class which comes from a "custom mock" annotation referencing an implicit type. Given a method which references type variables defined on their enclosing class (for example,T
inclass Foo<T>
), mockito will now correctly referenceT
in generated code. #422
- Mock classes now implement a type's nested type arguments properly. #410
- Mock classes now implement API from a class's interface(s) (in addition to superclasses and mix ins). Thanks @markgravity. #404
- A MockSpec passed into a
@GenerateMocks
annotation'scustomMocks
list can now specify "fallback generators." These are functions which can be used to generate fake responses that mockito's code generation needs in order to return a value for a method with a generic return type. See NULL_SAFETY_README for details.
- Migrate Mockito codegen to null safety.
- Support mocking methods with typed_data List return types.
- Support mocking methods with return types declared in private SDK libraries
(such as HttpClient and WebSocket, declared in
dart:_http
). - Do not generate a fake for a class which is only used as a nullable type in a Future. #409
- Properly refer to type parameter bounds with import prefixes. #389
- Stop referring to private typedefs in generated code. #396
- Ignore
prefer_const_constructors
andavoid_redundant_argument_values
lint rule violations in generated code.
- Support the 0.4.x releases of
test_api
.
- Support 4.x releases of code_builder.
- Allow calling methods with void return types w/o stubbing. #367
- Add type argument to dummy
Future
return value. #380
- Support 1.x releases of source_gen.
- Support the latest build packages and dart_style.
- Update to the latest test_api.
- Fix mock generation of type which has a supertype which mixes in a mixin.
- Fix mock generation of method which returns a non-nullable generic function type.
verifyInOrder
now returns aList<VerificationResult>
which stores arguments which were captured in a call toverifiyInOrder
.- Breaking change: Remove the public constructor for
VerificationResult
. - Doesn't allow
verify
been used inside theverifyInOrder
.
- Fix generation of duplicate mock getters and setters from inherited classes.
- Fix generation of method with a parameter with a default value which includes a top-level function.
- Migrate example code to null safety.
- Breaking change: Change the error which is thrown if a method is called and no method stub was found, from NoSuchMethodError to MissingStubError.
- Breaking change:
Mock.noSuchMethod
's optional positional parameter, "returnValue" is changed to a named parameter, and a second named parameter is added. Any manual mocks which callMock.noSuchMethod
with a second positional argument will need to instead use the named parameter. - Allow real calls to mock methods which return
void
(like setters) orFuture<void>
, even if unstubbed.
- Fix
noSuchMethod
invocation of setters in generated mocks.
- Annotate overridden getters and setters with
@override
.
- Improve static analysis of generated code.
- Make implicit casts from dynamic in getters explicit.
- Fix issue with generated code which references a class declared in a part (#310).
- Fix an issue with generated mocks overriding methods from Object, such as
operator ==
(#306). - Fix an issue with relative imports in generated mocks.
- Migrate the core libraries and tests to null safety. The builder at
lib/src/builder.dart
opts out of null safety. - Add
http
back todev_dependencies
. It's used by the example. - Remove deprecated
typed
,typedArgThat
, andtypedCaptureThat
APIs.
- Allow using analyzer 0.40.
throwOnMissingStub
accepts an optional argument,exceptionBuilder
, which will be called to build and throw a custom exception when a missing stub is called.
- Introduce experimental code-generated mocks. This is primarily to support the new "Non-nullable by default" (NNBD) type system coming soon to Dart.
- Add an optional second parameter to
Mock.noSuchMethod
. This may break clients who use the Mock class in unconventional ways, such as overridingnoSuchMethod
on a class which extends Mock. To fix, or prepare such code, add a second parameter to such overridingnoSuchMethod
declaration. - Increase minimum Dart SDK to
2.7.0
. - Remove Fake class; export identical Fake class from the test_api package.
- Mark the unexported and accidentally public
setDefaultResponse
as deprecated. - Mark the not useful, and not generally used,
named
function as deprecated. - Produce a meaningful error message if an argument matcher is used outside of
stubbing (
when
) or verification (verify
anduntilCalled
).
- Add a
Fake
class for implementing a subset of a class API as overrides without misusing theMock
class.
-
Replace the dependency on the test package with a dependency on the new test_api package. This dramatically reduces mockito's transitive dependencies.
This bump can result in runtime errors when coupled with a version of the test package older than 1.4.0.
- Rollback the test_api part of the 3.0.1 release. This was breaking tests that use Flutter's current test tools, and will instead be released as part of Mockito 4.0.0.
- Replace the dependency on the test package with a dependency on the new test_api package. This dramatically reduces mockito's transitive dependencies.
- Internal improvements to tests and examples.
-
Deprecate the
typed
API; instead of wrapping other Mockito API calls, likeany
,argThat
,captureAny
, andcaptureArgThat
, with a call totyped
, the regular API calls are to be used by themselves. Passingany
andcaptureAny
as named arguments must be replaced withanyNamed()
andcaptureAnyNamed
, respectively. PassingargThat
andcaptureThat
as named arguments must include thenamed
parameter. -
Introduce a backward-and-forward compatible API to help users migrate to Mockito 3. See more details in the upgrading-to-mockito-3 doc.
-
thenReturn
now throws anArgumentError
if either aFuture
orStream
is provided.thenReturn
calls with futures and streams should be changed tothenAnswer
. See the README for more information. -
Support stubbing of void methods in Dart 2.
-
thenReturn
andthenAnswer
now support generics and infer the correct types from thewhen
call. -
Completely remove the mirrors implementation of Mockito (
mirrors.dart
). -
Fix compatibility with new noSuchMethod Forwarding feature of Dart 2. This is thankfully a mostly backwards-compatible change. This means that this version of Mockito should continue to work:
- with Dart
>=2.0.0-dev.16.0
, - with Dart 2 runtime semantics (i.e. with
dart --preview-dart-2
, or with Flutter Beta 3), and - with the new noSuchMethod Forwarding feature, when it lands in CFE, and when it lands in DDC.
This change, when combined with noSuchMethod Forwarding, will break a few code paths which do not seem to be frequently used. Two examples:
class A { int fn(int a, [int b]) => 7; } class MockA extends Mock implements A {} var a = new MockA(); when(a.fn(typed(any), typed(any))).thenReturn(0); print(a.fn(1));
This used to print
null
, because only one argument was passed, which did not match the two-argument stub. Now it will print0
, as the real call contains a value for both the required argument, and the optional argument.a.fn(1); a.fn(2, 3); print(verify(a.fn(typed(captureAny), typed(captureAny))).captured);
This used to print
[2, 3]
, because only the second call matched theverify
call. Now, it will print[1, null, 2, 3]
, as both real calls contain a value for both the required argument, and the optional argument. - with Dart
-
Upgrade package dependencies.
-
Throw an exception when attempting to stub a method on a Mock object that already exists.
- Add new feature to wait for an interaction:
untilCalled
. See the README for documentation. capture*
calls outside of averify*
call no longer capture arguments.- Some collections require stricter argument matching. For example, a stub like:
mock.methodWithListArgs([1,2,3].map((e) => e*2))
(note theIterable
argument) will no longer match the following stub:when(mock.methodWithListArgs([42])).thenReturn(7);
.
- Add documentation for
when
,verify
,verifyNever
,resetMockitoState
. - Expose
throwOnMissingStub
,resetMockitoState
. - Improve failure message for
verify
. - SDK version ceiling bumped to
<2.0.0-dev.infinity
to support Dart 2.0 development testing. - Add a Mockito + test package example at
test/example/iss
.
- Start using the new
InvocationMatcher
instead of the old matcher. - Change
throwOnMissingStub
back to invokingObject.noSuchMethod
:- It was never documented what the thrown type should be expected as.
- You can now just rely on
throwsNoSuchMethodError
if you want to catch it.
- Add a new
throwOnMissingStub
method to the API.
- Removed
mockito_no_mirrors.dart
- Remove export of
spy
and anydart:mirrors
based API frommockito.dart
. Users may import aspackage:mockito/mirrors.dart
going forward. - Deprecated
mockito_no_mirrors.dart
; replace withmockito.dart
. - Require Dart SDK
>=1.21.0 <2.0.0
to use generic methods.
- Add a new
thenThrow
method to the API. - Document
thenAnswer
in the README. - Add more dartdoc.
- Add a new
typed
API that is compatible with Dart Dev Compiler; documented in README.md.
- Move the reflection-based
spy
code into a private source file. Nowpackage:mockito/mockito.dart
includes this reflection-based API, and a newpackage:mockito/mockito_no_mirrors.dart
doesn't require mirrors.
- Equality matcher used by default to simplify matching collections as arguments. Should be non-breaking change in most cases, otherwise consider using
argThat(identical(arg))
.
- Added support for spy.
- Migrate from the unittest package to use the new test package.
- Format code using dartformat