Configuration¶
mockery uses spf13/viper under the hood for its configuration parsing.
Merging Precedence¶
The configuration applied to a specific mocked interface is merged according to the following precedence (in decreasing priority):
- Interface-specific config in
.mockery.yaml
- Package-specific config in
.mockery.yaml
- Command-line options
- Environment variables
- Top-level defaults in
.mockery.yaml
Formatting¶
If a parameter is named with-expecter
and we want a value of True
, then these are the formats for each source:
source | value |
---|---|
command line | --with-expecter=true |
Environment variable | MOCKERY_WITH_EXPECTER=True |
yaml | with-expecter: True |
Recommended Basic Config¶
Copy the recommended basic configuration to a file called .mockery.yaml
at the top-level of your repo:
with-expecter: true
packages:
github.com/your-org/your-go-project:
# place your package-specific config here
config:
interfaces:
# select the interfaces you want mocked
Foo:
# Modify package-level config for this specific interface (if applicable)
config:
mockery will search upwards from your current-working-directory up to the root path, so the same configuration should be able to follow you within your project.
See the features
section for more details on how the config is structured.
Parameter Descriptions¶
new style packages
config
The packages
config section is the new style of configuration. All old config semantics, including go:generate
and any config files lacking the packages
section is officially deprecated as of v2.31.0. Legacy semantics will be completely removed in v3.
Please see the features section for more details on how packages
works, including some example configuration.
Please see the migration docs for details on how to migrate your config.
name | templated | default | description |
---|---|---|---|
all |
false |
Generate all interfaces for the specified packages. | |
boilerplate-file |
"" |
Specify a path to a file that contains comments you want displayed at the top of all generated mock files. This is commonly used to display license headers at the top of your source code. | |
config |
"" |
Set the location of the mockery config file. | |
dir |
"mocks/{{.PackagePath}}" |
The directory where the mock file will be outputted to. | |
disable-config-search |
false |
Disable searching for configuration files | |
disable-version-string |
false |
Disable the version string in the generated mock files. | |
dry-run |
false |
Print the actions that would be taken, but don't perform the actions. | |
exclude |
[] |
Specify subpackages to exclude when using recursive: True |
|
exclude-regex |
"" |
When set along with include-regex , then interfaces which match include-regex but also match exclude-regex will not be generated. If all is set, or if include-regex is not set, then exclude-regex has no effect. |
|
filename |
"mock_{{.InterfaceName}}.go" |
The name of the file the mock will reside in. | |
include-auto-generated |
true |
Set to false if you need mockery to skip auto-generated files during its recursive package discovery. When set to true , mockery includes auto-generated files when determining if a particular directory is an importable package. |
|
include-regex |
"" |
When set, only interface names that match the expression will be generated. This setting is ignored if all: True is specified in the configuration. To further refine the interfaces generated, use exclude-regex . |
|
inpackage |
false |
When generating mocks alongside the original interfaces, you must specify inpackage: True to inform mockery that the mock is being placed in the same package as the original interface. |
|
log-level |
"info" |
Set the level of the logger | |
mock-build-tags |
"" |
Set the build tags of the generated mocks. Read more about the format. | |
mockname |
"Mock{{.InterfaceName}}" |
The name of the generated mock. | |
outpkg |
"{{.PackageName}}" |
Use outpkg to specify the package name of the generated mocks. |
|
packages |
null |
A dictionary containing configuration describing the packages and interfaces to generate mocks for. | |
print |
false |
Use print: True to have the resulting code printed out instead of written to disk. |
|
recursive |
false |
When set to true on a particular package, mockery will recursively search for all sub-packages and inject those packages into the config map. |
|
replace-type |
null |
Replaces aliases, packages and/or types during generation. | |
tags |
"" |
A space-separated list of additional build tags to load packages. | |
with-expecter |
true |
Use with-expecter: True to generate EXPECT() methods for your mocks. This is the preferred way to setup your mocks. |
Layouts¶
Using different configuration parameters, we can deploy our mocks on-disk in various ways. These are some common layouts:
layouts
filename: "mock_{{.InterfaceName}}.go"
dir: "mocks/{{.PackagePath}}"
mockname: "Mock{{.InterfaceName}}"
outpkg: "{{.PackageName}}"
If these variables aren't specified, the above values will be applied to the config options. This strategy places your mocks into a separate mocks/
directory.
Interface Description
name | value |
---|---|
InterfaceName |
MyDatabase |
PackagePath |
github.com/user/project/pkgName |
PackageName |
pkgName |
Output
The mock will be generated at:
The mock file will look like:
Warning
Mockery does not protect against modifying original source code. Do not generate mocks using this config with uncommitted code changes.
filename: "mock_{{.InterfaceName}}.go"
dir: "{{.InterfaceDir}}"
mockname: "Mock{{.InterfaceName}}"
outpkg: "{{.PackageName}}"
inpackage: True
Instead of the mocks being generated in a different folder, you may elect to generate the mocks alongside the original interface in your package. This may be the way most people define their configs, as it removes circular import issues that can happen with the default config.
For example, the mock might be generated along side the original source file like this:
Interface Description
name | value |
---|---|
InterfaceName |
MyDatabase |
PackagePath |
github.com/user/project/path/to/pkg |
PackagePathRelative |
path/to/pkg |
PackageName |
pkgName |
SourceFile |
./path/to/pkg/db.go |
Output
Mock file will be generated at:
The mock file will look like:
Templated Strings¶
mockery configuration makes use of the Go templating system.
Variables¶
Note
Templated variables are only available when using the packages
config feature.
Variables that are marked as being templated are capable of using mockery-provided template parameters.
name | description |
---|---|
InterfaceDir | The directory path of the original interface being mocked. This can be used as dir: "{{.InterfaceDir}}" to place your mocks adjacent to the original interface. This should not be used for external interfaces. |
InterfaceDirRelative | The directory path of the original interface being mocked, relative to the current working directory. If the path cannot be made relative to the current working directory, this variable will be set equal to PackagePath |
InterfaceFile | The file path of the original interface being mocked. NOTE: This option will only write one mock implementation to the output file. If multiple mocks are defined in your original file, only one mock will be written to the output. |
InterfaceName | The name of the original interface being mocked |
InterfaceNameCamel | Converts a string interface_name to InterfaceName . DEPRECATED: use {{ .InterfaceName | camelcase }} instead |
InterfaceNameLowerCamel | Converts InterfaceName to interfaceName . DEPRECATED: use {{ .InterfaceName | camelcase | firstLower }} instead |
InterfaceNameSnake | Converts InterfaceName to interface_name . DEPRECATED: use {{ .InterfaceName | snakecase }} instead |
InterfaceNameLower | Converts InterfaceName to interfacename . DEPRECATED: use {{ .InterfaceName | lower }} instead |
Mock | A string that is Mock if the interface is exported, or mock if it is not exported. Useful when setting the name of your mock to something like: mockname: "{{.Mock}}{{.InterfaceName}}" This way, the mock name will retain the exported-ness of the original interface. |
MockName | The name of the mock that will be generated. Note that this is simply the mockname configuration variable |
PackageName | The name of the package from the original interface |
PackagePath | The fully qualified package path of the original interface |
Functions¶
Note
Templated functions are only available when using the packages
config feature.
Template functions allow you to inspect and manipulate template variables.
All template functions are calling native Go functions under the hood, so signatures and return values matches the Go functions you are probably already familiar with.
To learn more about the templating syntax, please see the Go text/template
documentation
contains
string substrhasPrefix
string prefixhasSuffix
string suffixjoin
elems sepreplace
string old new nreplaceAll
string old newsplit
string sepsplitAfter
string sepsplitAfterN
string sep ntrim
string cutsettrimLeft
string cutsettrimPrefix
string prefixtrimRight
string cutsettrimSpace
stringtrimSuffix
string suffixlower
stringupper
stringcamelcase
stringsnakecase
stringkebabcase
stringfirstLower
stringfirstUpper
stringmatchString
patternquoteMeta
stringbase
stringclean
stringdir
stringexpandEnv
stringgetenv
string
Legacy config options¶
legacy configuration options
The legacy config options will be removed in v3 and are deprecated (but supported) in v2.
name | description |
---|---|
all |
It's common for a big package to have a lot of interfaces, so mockery provides all . This option will tell mockery to scan all files under the directory named by --dir ("." by default) and generates mocks for any interfaces it finds. This option implies recursive: True . |
boilerplate-file |
Specify a path to a file that contains comments you want displayed at the top of all generated mock files. This is commonly used to display license headers at the top of your source code. |
case |
mockery generates files using the casing of the original interface name. This can be modified by specifying case: underscore to format the generated file name using underscore casing. |
exclude |
This parameter is a list of strings representing path prefixes that should be excluded from mock generation. |
exported |
Use exported: True to generate public mocks for private interfaces. |
filename |
Use the filename and structname to override the default generated file and struct name. These options are only compatible with non-regular expressions in name , where only one mock is generated. |
inpackage-suffix |
When inpackage-suffix is set to True , mock files are suffixed with _mock instead of being prefixed with mock_ for InPackage mocks |
inpackage and keeptree |
For some complex repositories, there could be multiple interfaces with the same name but in different packages. In that case, inpackage allows generating the mocked interfaces directly in the package that it mocks. In the case you don't want to generate the mocks into the package but want to keep a similar structure, use the option keeptree . |
name |
The name option takes either the name or matching regular expression of the interface to generate mock(s) for. |
output |
mockery always generates files with the package mocks to keep things clean and simple. You can control which mocks directory is used by using output , which defaults to ./mocks . |
outpkg |
Use outpkg to specify the package name of the generated mocks. |
print |
Use print: True to have the resulting code printed out instead of written to disk. |
recursive |
Use the recursive option to search subdirectories for the interface(s). This option is only compatible with name . The all option implies recursive: True . |
replace-type source=destination |
Replaces aliases, packages and/or types during generation. |
testonly |
Prepend every mock file with _test.go . This is useful in cases where you are generating mocks inpackage but don't want the mocks to be visible to code outside of tests. |
with-expecter |
Use with-expecter: True to generate EXPECT() methods for your mocks. This is the prefervar(--md-code-hl-number-color) way to setup your mocks. |