模拟 API 响应时如何在单元测试中使用 JSON 文件
How can I use a JSON file within a Unit Test when mocking an API response
我想加载一个 JSON 文件并将其转换为数据作为单元测试的一部分。
这样我就可以断言我的服务如何处理响应,但是我不想用大量 json 块填充每个测试用例。我希望将文件保存在与测试用例相同的目录中,但是尝试 运行 测试会抛出异常,因为找不到文件。
func test_ViewDidLoad_CallsContentService() {
let contentExpectation = expectation(description: "FetchContentEntry")
let httpClient = HTTPClient()
let response = createURLResponse(forUrl: "https://foo.bar", withStatusCode: 200)
httpClient.session = MockURLSession(data: mockContentData, urlResponse: response, error: nil)
.....
}
我的文件被引用为
extension ContentSceneTests {
.........
var mockContentData: Data {
let data = try! Data(contentsOf: URL(fileURLWithPath: "./ContentResponse.json"), options: .alwaysMapped)
return data
}
}
文件彼此相邻,例如
ContentSceneTests.swift
ContentResponse.json
我在 XCTestCase
.
的扩展中做了类似的测试
你应该可以使用
var mockContentData: Data {
return getData(name: "ContentResponse")
}
func getData(name: String, withExtension: String = "json") -> Data {
let bundle = Bundle(for: type(of: self))
let fileUrl = bundle.url(forResource: name, withExtension: withExtension)
let data = try! Data(contentsOf: fileUrl!)
return data
}
我想加载一个 JSON 文件并将其转换为数据作为单元测试的一部分。
这样我就可以断言我的服务如何处理响应,但是我不想用大量 json 块填充每个测试用例。我希望将文件保存在与测试用例相同的目录中,但是尝试 运行 测试会抛出异常,因为找不到文件。
func test_ViewDidLoad_CallsContentService() {
let contentExpectation = expectation(description: "FetchContentEntry")
let httpClient = HTTPClient()
let response = createURLResponse(forUrl: "https://foo.bar", withStatusCode: 200)
httpClient.session = MockURLSession(data: mockContentData, urlResponse: response, error: nil)
.....
}
我的文件被引用为
extension ContentSceneTests {
.........
var mockContentData: Data {
let data = try! Data(contentsOf: URL(fileURLWithPath: "./ContentResponse.json"), options: .alwaysMapped)
return data
}
}
文件彼此相邻,例如
ContentSceneTests.swift
ContentResponse.json
我在 XCTestCase
.
你应该可以使用
var mockContentData: Data {
return getData(name: "ContentResponse")
}
func getData(name: String, withExtension: String = "json") -> Data {
let bundle = Bundle(for: type(of: self))
let fileUrl = bundle.url(forResource: name, withExtension: withExtension)
let data = try! Data(contentsOf: fileUrl!)
return data
}