WireMock
GoLand provides support for WireMock, a tool for stubbing HTTP services. Stubbing involves creating stubs or set responses to API calls that mimic real API behavior without the need for actual server communication.
This functionality relies on the WireMock plugin, which you need to install and enable.
Press CtrlAlt0S to open settings and then select Plugins.
Open the Marketplace tab, find the WireMock plugin, and click Install (restart the IDE if prompted).
If a JSON file is placed in the mappings folder or contains the "mappings"
key, GoLand recognizes it as a WireMock stub file and provides appropriate coding assistance.
In the Project tool window, right-click a folder (or press AltInsert) and select New | File.
In the New File dialog that opens, enter a name of the file. For example, you can enter
mappings/my-stub.json
, and GoLand will create the mappings folder and place the new file within it.Start typing a key to get suggestions for applicable keys and their quick documentation.
data:image/s3,"s3://crabby-images/b5848/b58489e5f5866ac71ad4c8c6b1460c863f9a8190" alt="Wiremock Coding Assistance Wiremock Coding Assistance"
Open the Endpoints tool window (View | Tool Windows | Endpoints).
Right-click an endpoint and select Generate WireMock Stubs.
data:image/s3,"s3://crabby-images/a3f42/a3f42dbffe6ee35f031d9d6b2a86b26a58f2df02" alt="Creating WireMock stub from Endpoints Creating WireMock stub from Endpoints"
The new stub file is saved as a scratch under Scratches and Consoles | WireMock Stubs.
Open an OpenAPI specification file.
Click
and select Generate WireMock Stubs.
data:image/s3,"s3://crabby-images/5c5e8/5c5e848aea7c2538e1d59e6af528c0b4321caf1f" alt="Creating WireMock stub from Endpoints Creating WireMock stub from Endpoints"
The new stub file is saved as a scratch under Scratches and Consoles | WireMock Stubs.
Open your stub file.
Click
in the upper-right part of the editor.
This will start the WireMock server, and you can see it running in the Services tool window (View | Tool Windows | Services or press Alt08).
data:image/s3,"s3://crabby-images/06836/06836ce2f0b42f02fc7f21938bbd09ef61679a54" alt="WireMock in Services WireMock in Services"
To customize how GoLand starts the WireMock server, you can modify the WireMock run configuration or create a new one.
Use the GoLand HTTP Client to send HTTP request to the WireMock server and preview responses.
Open your stub JSON file.
Place the caret at your endpoint URL, press AltEnter (Show Context Actions), and select Generate request in HTTP Client.
You can view the stub response in the Services tool window.
data:image/s3,"s3://crabby-images/b5c29/b5c29bfc6ea2fa6bfd0d8bfe9037ec0331d4e34f" alt="https://resources.jetbrains.com/help/img/idea/2024.3/wiremock_send_http_request.png"
GoLand provides coding assistance for templating language used in WireMock response templates. To use this feature, you need the Handlebars/Mustache plugin to be installed and enabled.
Open your stub JSON file.
In the upper-right part of the editor, click
(Use Handlebars Templates). If the Handlebars/Mustache plugin is not installed, the action will install it.
This will make GoLand treat JSON files placed in the __files
directory as response templates and provide appropriate Handlebars coding assistance including completion for Handlebars helpers.
data:image/s3,"s3://crabby-images/8ba16/8ba165a09d71fa0ea949f36ac37aa02b2663d851" alt="Enable support for Handlebars templates Enable support for Handlebars templates"
Create: Run | Edit Configurations | | WireMock
GoLand comes with a dedicated WireMock run configuration, which allows you to customize how to start the WireMock server.
data:image/s3,"s3://crabby-images/c8c06/c8c06acee91fff1f6a00fd9ed7cf7a74eda053aa" alt="WireMock run configuration WireMock run configuration"
- Enable global Handlebars templating
Render all response definitions using Handlebars templates by passing the
--global-response-templating
Wiremock command line option.
Specify which log files generated while running the application should be displayed in the console on the dedicated tabs of the Run tool window.
Select tasks to be performed before starting the selected run/debug configuration.
Thanks for your feedback!