PostMock is a powerful mocking framework that uses Postman.
It brings Postman into your application and provides the following capabilities:
- Mock any request with responses from Postman.
- View network calls linked to postman requests.
Find our public api collection in Postman called PostMock. Which we used in demo app inside.
data:image/s3,"s3://crabby-images/84d28/84d28bc0980f06fe974fa415e9ca37e14addbabf" alt="image"
data:image/s3,"s3://crabby-images/8e70f/8e70f09bbb80ad96c65b6737e618e32b2e66ed59" alt="image"
data:image/s3,"s3://crabby-images/bdc87/bdc87f936f8bedd2c065ee2a65cd5d22b9da4919" alt="image"
data:image/s3,"s3://crabby-images/e895f/e895f2bf537dade71432a7abaa326087b4f88a6d" alt="image"
data:image/s3,"s3://crabby-images/4a009/4a0091491d61aa3edf568fe75fb6404f015835e6" alt="image"
data:image/s3,"s3://crabby-images/0d63f/0d63fa3e0c55959c581b5706aeb347a627cb94b5" alt="image"
data:image/s3,"s3://crabby-images/76d1c/76d1ce7dc99ecf386d5399e6788ca589add8d89a" alt="image"
import PostMockSDK
struct ContentView: View {
var body: some View {
DogsList()
// Add PostMock button or use PostMockView direclty and add it to any view you wan't, or call it on shake.
.overlayPostMockButton()
.onAppear {
// Provide your POSTMAN_API_KEY and WORKSPACE_ID wich api collections you want to use
let config = PostMock.Config(apiKey: "<POSTMAN_API_KEY>",
workspaceID: "<WORKSPACE_ID>")
PostMock.shared.configurate(with: config)
/// Add some environment variables (optional), see description below
PostMock.shared.environment.set(key: "host",
scope: .request,
provider: { "https://dogapi.dog" })
}
}
}
You also need MockServer in Postman for api collection.
To match requests from the app to Postman requests, we can use templates or set a specific header x-postmock-request-id
to the request.
data:image/s3,"s3://crabby-images/9fa4a/9fa4a301e2cff499888268cda43b9c19500e9ce9" alt="image"
You can provide some variables to make the mock more specific.
data:image/s3,"s3://crabby-images/31996/31996f31f271c58cec88b0beb8a5f6b0b0081cb2" alt="image"
Some of these variables are global and are applied to any request containing the placeholder.
data:image/s3,"s3://crabby-images/83982/839821a8b900fbb55b0b5db910e00dfeca37e794" alt="image"
We set them up in the code:
PostMock.shared.environment.set(key: "host",
scope: .request,
provider: { "https://dogapi.dog" })
If you do not specify global variables like {{host}}
, they will be matched to any string.
It’s not a problem when you have only one host for requests.
You can mock some request in preview or tests. There is opportunity to set mock from code:
/// response id from postman
let mastiff200 = "1122734-8c545657-d643-4db4-b216-d16d699b27fa"
/// Default MockServer from workspace https://www.postman.com/universal-moon-430028/workspace/postmock
PostMock.shared.mockServer = MockServer(host: "0997c312-c8ea-435a-8ffd-4a98f4214024.mock.pstmn.io")
Mock
.request("GET", url: "{{host}}/api/v2/facts")
.with(responseID: .mastiff200)
.set()
PostMock.shared.mockIsEnabled = true