2017-11-30 08:14:40 -05:00
|
|
|
/**
|
|
|
|
* Package component
|
|
|
|
*/
|
|
|
|
|
|
|
|
import React from 'react';
|
|
|
|
import { mount } from 'enzyme';
|
2018-07-17 14:22:44 -05:00
|
|
|
import Package from '../../../../src/webui/components/Package/index';
|
2017-11-30 08:14:40 -05:00
|
|
|
import { BrowserRouter } from 'react-router-dom';
|
2018-09-06 14:26:54 -05:00
|
|
|
import Chip from '@material-ui/core/Chip';
|
2017-11-30 08:14:40 -05:00
|
|
|
|
2018-06-18 16:31:38 -05:00
|
|
|
/**
|
|
|
|
* Generates one month back date from current time
|
|
|
|
* @return {object} date object
|
|
|
|
*/
|
|
|
|
const dateOneMonthAgo = () => {
|
|
|
|
const date = new Date();
|
|
|
|
date.setMonth(date.getMonth() - 1);
|
|
|
|
return date;
|
|
|
|
}
|
|
|
|
|
2017-11-30 08:14:40 -05:00
|
|
|
describe('<Package /> component', () => {
|
2018-12-05 13:30:08 -05:00
|
|
|
test('should load the component', () => {
|
2017-11-30 08:14:40 -05:00
|
|
|
const props = {
|
|
|
|
name: 'verdaccio',
|
|
|
|
version: '1.0.0',
|
2018-06-18 16:31:38 -05:00
|
|
|
time: dateOneMonthAgo(),
|
2018-06-03 23:39:24 -05:00
|
|
|
license: 'MIT',
|
2017-11-30 08:14:40 -05:00
|
|
|
description: 'Private NPM repository',
|
2018-07-21 13:49:10 -05:00
|
|
|
author: 'Sam'
|
2017-11-30 08:14:40 -05:00
|
|
|
};
|
|
|
|
const wrapper = mount(
|
|
|
|
<BrowserRouter>
|
2018-09-06 14:26:54 -05:00
|
|
|
<Package {...props} />
|
2017-11-30 08:14:40 -05:00
|
|
|
</BrowserRouter>
|
|
|
|
);
|
|
|
|
|
2018-09-06 14:26:54 -05:00
|
|
|
const version =
|
|
|
|
wrapper.findWhere(node => node.is(Chip) && node.prop('label') === 'v1.0.0');
|
|
|
|
|
2017-11-30 08:14:40 -05:00
|
|
|
// integration expectations
|
|
|
|
expect(wrapper.find('a').prop('href')).toEqual('detail/verdaccio');
|
2018-06-03 23:39:24 -05:00
|
|
|
expect(wrapper.find('h1').text()).toEqual('verdaccio v1.0.0');
|
2018-09-06 14:26:54 -05:00
|
|
|
expect(version.exists()).toBe(true);
|
2017-11-30 08:14:40 -05:00
|
|
|
expect(
|
2018-06-03 23:39:24 -05:00
|
|
|
wrapper.find('div').filterWhere(n => n.prop('role') === 'author')
|
2017-11-30 08:14:40 -05:00
|
|
|
.text()
|
|
|
|
).toEqual('By: Sam');
|
|
|
|
expect(wrapper.find('p').text()).toEqual('Private NPM repository');
|
2018-06-03 23:39:24 -05:00
|
|
|
expect(wrapper.find('.license').text()).toMatch(/MIT/);
|
2018-06-18 16:34:29 -05:00
|
|
|
expect(wrapper.html()).toMatchSnapshot();
|
2017-11-30 08:14:40 -05:00
|
|
|
});
|
2018-07-21 13:49:10 -05:00
|
|
|
|
2018-12-05 13:30:08 -05:00
|
|
|
test('should load the component without author', () => {
|
2018-07-21 13:49:10 -05:00
|
|
|
const props = {
|
|
|
|
name: 'verdaccio',
|
|
|
|
version: '1.0.0',
|
|
|
|
time: dateOneMonthAgo(),
|
|
|
|
license: 'MIT',
|
|
|
|
description: 'Private NPM repository'
|
|
|
|
};
|
|
|
|
const wrapper = mount(
|
|
|
|
<BrowserRouter>
|
|
|
|
<Package {...props} />
|
|
|
|
</BrowserRouter>
|
|
|
|
);
|
|
|
|
|
|
|
|
// integration expectations
|
|
|
|
expect(
|
|
|
|
wrapper.find('div').filterWhere(n => n.prop('role') === 'author')
|
|
|
|
.text()
|
|
|
|
).toEqual('');
|
|
|
|
expect(wrapper.html()).toMatchSnapshot();
|
|
|
|
});
|
2017-11-30 08:14:40 -05:00
|
|
|
});
|