import React from "react" import { shallow } from "enzyme" import { fromJS } from "immutable" import PrimitiveModel from "components/primitive-model" import ModelCollapse from "components/model-collapse" describe("", function () { const dummyComponent = () => null const components = { Markdown: dummyComponent, EnumModel: dummyComponent, Property: dummyComponent, "ModelCollapse" : ModelCollapse, } const props = { getComponent: c => components[c], getConfigs: () => ({ showExtensions: false }), name: "Name from props", depth: 1, schema: fromJS({ type: "string", title: "Custom model title" }), expandDepth: 1 } it("renders the schema's title", function () { // When const wrapper = shallow() const modelTitleEl = wrapper.find("ModelCollapse").prop("title").props.children.props.children expect(modelTitleEl).toEqual("Custom model title") }) it("falls back to the passed-in `name` prop for the title", function () { // When props.schema = fromJS({ type: "string" }) const wrapper = shallow() const modelTitleEl = wrapper.find("ModelCollapse").prop("title").props.children.props.children // Then expect(modelTitleEl).toEqual("Name from props") }) it("renders a collapsible header", function(){ const wrapper = shallow() const renderedModelCollapse = wrapper.find(ModelCollapse) expect(renderedModelCollapse.length).toEqual(1) }) })