forked from rjsf-team/react-jsonschema-form
-
Notifications
You must be signed in to change notification settings - Fork 0
/
Copy pathTitleField_test.js
69 lines (56 loc) · 1.65 KB
/
TitleField_test.js
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
import React from "react";
import { expect } from "chai";
import TitleField from "../src/components/fields/TitleField";
import { createSandbox, createComponent } from "./test_utils";
describe("TitleField", () => {
let sandbox;
beforeEach(() => {
sandbox = createSandbox();
});
afterEach(() => {
sandbox.restore();
});
// For some reason, stateless components needs to be wrapped into a stateful
// one to be rendered into the document.
class TitleFieldWrapper extends React.Component {
constructor(props) {
super(props);
}
render() {
return <TitleField {...this.props} />;
}
}
it("should return a legend", () => {
const props = {
title: "Field title",
required: true,
};
const { node } = createComponent(TitleFieldWrapper, props);
expect(node.tagName).to.equal("LEGEND");
});
it("should have the expected id", () => {
const props = {
title: "Field title",
required: true,
id: "sample_id",
};
const { node } = createComponent(TitleFieldWrapper, props);
expect(node.id).to.equal("sample_id");
});
it("should include only title, when field is not required", () => {
const props = {
title: "Field title",
required: false,
};
const { node } = createComponent(TitleFieldWrapper, props);
expect(node.textContent).to.equal(props.title);
});
it("should add an asterisk to the title, when field is required", () => {
const props = {
title: "Field title",
required: true,
};
const { node } = createComponent(TitleFieldWrapper, props);
expect(node.textContent).to.equal(props.title + "*");
});
});