blob: 8231aee9ea4cc7d7b3bd74d24ecd4067785f42dd [file] [log] [blame]
// Licensed under the Apache License, Version 2.0 (the 'License'); you may not
// use this file except in compliance with the License. You may obtain a copy of
// the License at
//
// http://www.apache.org/licenses/LICENSE-2.0
//
// Unless required by applicable law or agreed to in writing, software
// distributed under the License is distributed on an 'AS IS' BASIS, WITHOUT
// WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. See the
// License for the specific language governing permissions and limitations under
// the License.
import React from 'react';
import {mount} from 'enzyme';
import {Breadcrumbs} from '../header-breadcrumbs';
describe('Breadcrumbs', () => {
it('should not inject dividers if 1 element present', () => {
const crumbs = [{name: 'pineapple'}];
let el = mount(
<div><Breadcrumbs crumbs={crumbs} /></div>
);
expect(el.find('.faux-header__breadcrumbs-divider').length).toBe(0);
});
it('should inject 2 dividers if 3 elements present', () => {
const crumbs = [
{name: 'pineapple'},
{name: 'mango'},
{name: 'guayaba'}
];
let el = mount(
<div><Breadcrumbs crumbs={crumbs} /></div>
);
expect(el.find('.faux-header__breadcrumbs-divider').length).toBe(2);
});
it('linked breadcrumbs are possible', () => {
const crumbs = [
{name: 'pineapple'},
{name: 'mango', link: 'http://example.com'},
{name: 'guayaba'}
];
let el = mount(
<div><Breadcrumbs crumbs={crumbs} /></div>
);
expect(el.find('.faux-header__breadcrumbs-link').length).toBe(1);
});
it('linked breadcrumbs are not created for non-linked elements', () => {
const crumbs = [
{name: 'pineapple'},
{name: 'mango'},
{name: 'guayaba'}
];
let el = mount(
<div><Breadcrumbs crumbs={crumbs} /></div>
);
expect(el.find('.faux-header__breadcrumbs-link').length).toBe(0);
});
});