summaryrefslogtreecommitdiffstats
path: root/devtools/client/accessibility/test/node/components/accessibility-row-value.test.js
blob: 5e73f0f18fe6cbedae64f7564d5636644547f88f (plain)
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
/* This Source Code Form is subject to the terms of the Mozilla Public
 * License, v. 2.0. If a copy of the MPL was not distributed with this
 * file, You can obtain one at http://mozilla.org/MPL/2.0/. */

"use strict";

const { mount } = require("enzyme");

const {
  createFactory,
} = require("resource://devtools/client/shared/vendor/react.js");
const Provider = createFactory(
  require("resource://devtools/client/shared/vendor/react-redux.js").Provider
);
const {
  mockAccessible,
  setupStore,
} = require("resource://devtools/client/accessibility/test/node/helpers.js");

const Badges = require("resource://devtools/client/accessibility/components/Badges.js");
const {
  REPS: { Rep },
} = require("resource://devtools/client/shared/components/reps/index.js");
const AuditController = require("resource://devtools/client/accessibility/components/AuditController.js");

const AccessibilityRowValueClass = require("resource://devtools/client/accessibility/components/AccessibilityRowValue.js");
const AccessibilityRowValue = createFactory(AccessibilityRowValueClass);

describe("AccessibilityRowValue component:", () => {
  it("basic render", () => {
    const store = setupStore({
      preloadedState: { ui: { supports: {} } },
    });
    const wrapper = mount(
      Provider(
        { store },
        AccessibilityRowValue({
          member: { object: mockAccessible() },
        })
      )
    );

    expect(wrapper.html()).toMatchSnapshot();
    const rowValue = wrapper.find(AccessibilityRowValueClass);
    expect(rowValue.children().length).toBe(1);
    const container = rowValue.childAt(0);
    expect(container.type()).toBe("span");
    expect(container.prop("role")).toBe("presentation");
    expect(container.children().length).toBe(2);
    expect(container.childAt(0).type()).toBe(Rep);
    const controller = container.childAt(1);
    expect(controller.type()).toBe(AuditController);
    expect(controller.children().length).toBe(1);
    expect(controller.childAt(0).type()).toBe(Badges);
  });
});