/* Any copyright is dedicated to the Public Domain. http://creativecommons.org/publicdomain/zero/1.0/ */ "use strict"; // Test utils. const expect = require("expect"); const { render, mount } = require("enzyme"); const sinon = require("sinon"); // React const { createFactory } = require("devtools/client/shared/vendor/react"); const Provider = createFactory(require("react-redux").Provider); const { setupStore } = require("devtools/client/webconsole/new-console-output/test/helpers"); // Components under test. const EvaluationResult = createFactory(require("devtools/client/webconsole/new-console-output/components/message-types/evaluation-result")); const { INDENT_WIDTH } = require("devtools/client/webconsole/new-console-output/components/message-indent"); // Test fakes. const { stubPreparedMessages } = require("devtools/client/webconsole/new-console-output/test/fixtures/stubs/index"); const serviceContainer = require("devtools/client/webconsole/new-console-output/test/fixtures/serviceContainer"); describe("EvaluationResult component:", () => { it("renders a grip result", () => { const message = stubPreparedMessages.get("new Date(0)"); const wrapper = render(EvaluationResult({ message })); expect(wrapper.find(".message-body").text()).toBe("Date 1970-01-01T00:00:00.000Z"); expect(wrapper.find(".message.log").length).toBe(1); }); it("renders an error", () => { const message = stubPreparedMessages.get("asdf()"); const wrapper = render(EvaluationResult({ message })); expect(wrapper.find(".message-body").text()) .toBe("ReferenceError: asdf is not defined[Learn More]"); expect(wrapper.find(".message.error").length).toBe(1); }); it("displays a [Learn more] link", () => { const store = setupStore([]); const message = stubPreparedMessages.get("asdf()"); serviceContainer.openLink = sinon.spy(); const wrapper = mount(Provider({store}, EvaluationResult({message, serviceContainer}) )); const url = "https://developer.mozilla.org/docs/Web/JavaScript/Reference/Errors/Not_defined"; const learnMore = wrapper.find(".learn-more-link"); expect(learnMore.length).toBe(1); expect(learnMore.prop("title")).toBe(url); learnMore.simulate("click"); let call = serviceContainer.openLink.getCall(0); expect(call.args[0]).toEqual(message.exceptionDocURL); }); it("has the expected indent", () => { const message = stubPreparedMessages.get("new Date(0)"); const indent = 10; let wrapper = render(EvaluationResult({ message, indent})); expect(wrapper.find(".indent").prop("style").width) .toBe(`${indent * INDENT_WIDTH}px`); wrapper = render(EvaluationResult({ message})); expect(wrapper.find(".indent").prop("style").width).toBe(`0`); }); it("has location information", () => { const message = stubPreparedMessages.get("1 + @"); const wrapper = render(EvaluationResult({ message })); const locationLink = wrapper.find(`.message-location`); expect(locationLink.length).toBe(1); expect(locationLink.text()).toBe("debugger eval code:1:4"); }); });