2017-11-30 18:44:40 +05:30
|
|
|
/**
|
|
|
|
* Package component
|
|
|
|
*/
|
|
|
|
|
|
|
|
import React from 'react';
|
2018-12-13 19:05:47 +01:00
|
|
|
import { shallow } from 'enzyme';
|
2018-07-17 21:22:44 +02:00
|
|
|
import Package from '../../../../src/webui/components/Package/index';
|
2018-12-13 19:05:47 +01:00
|
|
|
import Tag from '../../../../src/webui/components/Tag/index';
|
|
|
|
import { Version, Wrapper, Field, OverviewItem } from '../../../../src/webui/components/Package/styles';
|
|
|
|
|
2017-11-30 18:44:40 +05:30
|
|
|
|
2018-06-18 23:31:38 +02:00
|
|
|
/**
|
|
|
|
* Generates one month back date from current time
|
|
|
|
* @return {object} date object
|
|
|
|
*/
|
2018-12-13 19:05:47 +01:00
|
|
|
const dateOneMonthAgo = () => new Date(1544377770747)
|
2018-06-18 23:31:38 +02:00
|
|
|
|
2017-11-30 18:44:40 +05:30
|
|
|
describe('<Package /> component', () => {
|
2018-12-14 23:57:52 +01:00
|
|
|
test.skip('should load the component', () => {
|
2017-11-30 18:44:40 +05:30
|
|
|
const props = {
|
|
|
|
name: 'verdaccio',
|
|
|
|
version: '1.0.0',
|
2018-06-18 23:31:38 +02:00
|
|
|
time: dateOneMonthAgo(),
|
2018-06-04 06:39:24 +02:00
|
|
|
license: 'MIT',
|
2017-11-30 18:44:40 +05:30
|
|
|
description: 'Private NPM repository',
|
2018-12-13 19:05:47 +01:00
|
|
|
author: {
|
|
|
|
name: 'Sam'
|
|
|
|
},
|
|
|
|
keywords: [
|
|
|
|
"verdaccio"
|
|
|
|
]
|
2017-11-30 18:44:40 +05:30
|
|
|
};
|
|
|
|
|
2018-12-13 19:05:47 +01:00
|
|
|
const wrapper = shallow(
|
2018-12-15 16:39:51 +01:00
|
|
|
<Package {...props} />
|
2017-11-30 18:44:40 +05:30
|
|
|
);
|
|
|
|
|
2018-09-06 21:26:54 +02:00
|
|
|
|
2017-11-30 18:44:40 +05:30
|
|
|
// integration expectations
|
2018-12-13 19:05:47 +01:00
|
|
|
|
|
|
|
// check link
|
|
|
|
expect(wrapper.find(Wrapper).prop('to')).toEqual(`detail/${props.name}`);
|
|
|
|
|
|
|
|
// check version
|
|
|
|
expect(wrapper.find(Version).prop('children')).toEqual(`v${props.version}`);
|
|
|
|
|
|
|
|
// TODO - REWRITE THE TEST
|
|
|
|
//expect(wrapper.find(Author).dive())
|
|
|
|
|
|
|
|
// check description
|
|
|
|
expect(wrapper.find(Field).someWhere(n => {
|
|
|
|
return (
|
2018-12-14 23:57:52 +01:00
|
|
|
n.children().first().get(0).props.children[0].props.text === 'Description' &&
|
2018-12-15 16:59:05 +01:00
|
|
|
n.children().childAt(1).containsMatchingElement(<span>{props.description}</span>)
|
2018-12-13 19:05:47 +01:00
|
|
|
)
|
|
|
|
})).toBe(true);
|
|
|
|
|
|
|
|
// check license
|
|
|
|
expect(wrapper.find(OverviewItem).someWhere(n => n.get(0).props.children[1] === props.license)).toBe(true);
|
|
|
|
|
|
|
|
// check keyword
|
|
|
|
expect(wrapper.find(Tag).prop('children')).toEqual(props.keywords[0]);
|
|
|
|
|
2017-11-30 18:44:40 +05:30
|
|
|
});
|
2018-07-21 20:49:10 +02:00
|
|
|
|
2018-12-15 00:23:30 +01:00
|
|
|
test.skip('should load the component without author', () => {
|
2018-07-21 20:49:10 +02:00
|
|
|
const props = {
|
|
|
|
name: 'verdaccio',
|
|
|
|
version: '1.0.0',
|
|
|
|
time: dateOneMonthAgo(),
|
|
|
|
license: 'MIT',
|
2018-12-13 19:05:47 +01:00
|
|
|
author: {
|
|
|
|
name: 'Anonymous',
|
|
|
|
email: '',
|
|
|
|
avatar: ''
|
|
|
|
},
|
2018-07-21 20:49:10 +02:00
|
|
|
description: 'Private NPM repository'
|
|
|
|
};
|
2018-12-13 19:05:47 +01:00
|
|
|
const wrapper = shallow(
|
2018-12-15 16:39:51 +01:00
|
|
|
<Package {...props} />
|
2018-07-21 20:49:10 +02:00
|
|
|
);
|
|
|
|
|
|
|
|
// integration expectations
|
|
|
|
expect(wrapper.html()).toMatchSnapshot();
|
|
|
|
});
|
2017-11-30 18:44:40 +05:30
|
|
|
});
|