live-response.jsx 3.3 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102
  1. import React from "react"
  2. import { fromJSOrdered } from "core/utils"
  3. import { shallow } from "enzyme"
  4. import Curl from "components/curl"
  5. import LiveResponse from "components/live-response"
  6. import ResponseBody from "components/response-body"
  7. describe("<LiveResponse/>", function(){
  8. let request = fromJSOrdered({
  9. credentials: "same-origin",
  10. headers: {
  11. accept: "application/xml"
  12. },
  13. url: "http://petstore.swagger.io/v2/pet/1"
  14. })
  15. let mutatedRequest = fromJSOrdered({
  16. credentials: "same-origin",
  17. headers: {
  18. accept: "application/xml",
  19. mutated: "header"
  20. },
  21. url: "http://mutated.petstore.swagger.io/v2/pet/1"
  22. })
  23. let requests = {
  24. request: request,
  25. mutatedRequest: mutatedRequest
  26. }
  27. const tests = [
  28. { showMutatedRequest: true, expected: { request: "mutatedRequest", requestForCalls: 0, mutatedRequestForCalls: 1 } },
  29. { showMutatedRequest: false, expected: { request: "request", requestForCalls: 1, mutatedRequestForCalls: 0 } }
  30. ]
  31. tests.forEach(function(test) {
  32. it("passes " + test.expected.request + " to Curl when showMutatedRequest = " + test.showMutatedRequest, function() {
  33. // Given
  34. let response = fromJSOrdered({
  35. status: 200,
  36. url: "http://petstore.swagger.io/v2/pet/1",
  37. headers: {
  38. "content-type": "application/xml"
  39. },
  40. text: "<response/>",
  41. duration: 50
  42. })
  43. let mutatedRequestForSpy = jest.fn().mockImplementation(function(mutatedRequest) { return mutatedRequest })
  44. let requestForSpy = jest.fn().mockImplementation(function(request) { return request })
  45. let components = {
  46. curl: Curl,
  47. responseBody: ResponseBody
  48. }
  49. let props = {
  50. response: response,
  51. specSelectors: {
  52. mutatedRequestFor: mutatedRequestForSpy,
  53. requestFor: requestForSpy,
  54. },
  55. pathMethod: [ "/one", "get" ],
  56. getComponent: (c) => {
  57. return components[c]
  58. },
  59. displayRequestDuration: true,
  60. getConfigs: () => ({ showMutatedRequest: test.showMutatedRequest })
  61. }
  62. // When
  63. let wrapper = shallow(<LiveResponse {...props}/>)
  64. // Then
  65. expect(mutatedRequestForSpy.calls.length).toEqual(test.expected.mutatedRequestForCalls)
  66. expect(requestForSpy.calls.length).toEqual(test.expected.requestForCalls)
  67. const curl = wrapper.find(Curl)
  68. expect(curl.length).toEqual(1)
  69. expect(curl.props().request).toBe(requests[test.expected.request])
  70. const expectedUrl = requests[test.expected.request].get("url")
  71. expect(wrapper.find("div.request-url pre.microlight").text()).toEqual(expectedUrl)
  72. let duration = wrapper.find("Duration")
  73. expect(duration.length).toEqual(1)
  74. expect(duration.props().duration).toEqual(50)
  75. expect(duration.html())
  76. .toEqual("<div><h5>Request duration</h5><pre class=\"microlight\">50 ms</pre></div>")
  77. let responseHeaders = wrapper.find("Headers")
  78. expect(duration.length).toEqual(1)
  79. expect(responseHeaders.props().headers.length).toEqual(1)
  80. expect(responseHeaders.props().headers[0].key).toEqual("content-type")
  81. expect(responseHeaders.html())
  82. .toEqual("<div><h5>Response headers</h5><pre class=\"microlight\"><span class=\"headerline\"> content-type: application/xml </span></pre></div>")
  83. })
  84. })
  85. })