Created TagCard test

This commit is contained in:
Alejandro Celaya 2018-11-01 13:34:31 +01:00
parent 53132fa900
commit 85cb849ba5
3 changed files with 59 additions and 35 deletions

View file

@ -115,8 +115,9 @@ export class ShortUrlsListComponent extends React.Component {
)); ));
} }
renderMobileOrderingControls() { render() {
return ( return (
<React.Fragment>
<div className="d-block d-md-none mb-3"> <div className="d-block d-md-none mb-3">
<SortingDropdown <SortingDropdown
items={SORTABLE_FIELDS} items={SORTABLE_FIELDS}
@ -125,13 +126,6 @@ export class ShortUrlsListComponent extends React.Component {
onChange={this.handleOrderBy} onChange={this.handleOrderBy}
/> />
</div> </div>
);
}
render() {
return (
<React.Fragment>
{this.renderMobileOrderingControls()}
<table className="table table-striped table-hover"> <table className="table table-striped table-hover">
<thead className="short-urls-list__header"> <thead className="short-urls-list__header">
<tr> <tr>

View file

@ -28,36 +28,20 @@ export default class TagCard extends React.Component {
return ( return (
<Card className="tag-card"> <Card className="tag-card">
<CardBody className="tag-card__body"> <CardBody className="tag-card__body">
<button <button className="btn btn-light btn-sm tag-card__btn tag-card__btn--last" onClick={toggleDelete}>
className="btn btn-light btn-sm tag-card__btn tag-card__btn--last"
onClick={toggleDelete}
>
<FontAwesomeIcon icon={deleteIcon} /> <FontAwesomeIcon icon={deleteIcon} />
</button> </button>
<button <button className="btn btn-light btn-sm tag-card__btn" onClick={toggleEdit}>
className="btn btn-light btn-sm tag-card__btn"
onClick={toggleEdit}
>
<FontAwesomeIcon icon={editIcon} /> <FontAwesomeIcon icon={editIcon} />
</button> </button>
<h5 className="tag-card__tag-title"> <h5 className="tag-card__tag-title">
<TagBullet tag={tag} /> <TagBullet tag={tag} />
<Link to={`/server/${currentServerId}/list-short-urls/1?tag=${tag}`}> <Link to={`/server/${currentServerId}/list-short-urls/1?tag=${tag}`}>{tag}</Link>
{tag}
</Link>
</h5> </h5>
</CardBody> </CardBody>
<DeleteTagConfirmModal <DeleteTagConfirmModal tag={tag} toggle={toggleDelete} isOpen={this.state.isDeleteModalOpen} />
tag={tag} <EditTagModal tag={tag} toggle={toggleEdit} isOpen={this.state.isEditModalOpen} />
toggle={toggleDelete}
isOpen={this.state.isDeleteModalOpen}
/>
<EditTagModal
tag={tag}
toggle={toggleEdit}
isOpen={this.state.isEditModalOpen}
/>
</Card> </Card>
); );
} }

46
test/tags/TagCard.test.js Normal file
View file

@ -0,0 +1,46 @@
import React from 'react';
import { shallow } from 'enzyme';
import { Link } from 'react-router-dom';
import TagCard from '../../src/tags/TagCard';
import TagBullet from '../../src/tags/helpers/TagBullet';
describe('<TagCard />', () => {
let wrapper;
beforeEach(() => {
wrapper = shallow(<TagCard tag="ssr" currentServerId="1" />);
});
afterEach(() => wrapper.unmount());
it('shows a TagBullet and a link to the list filtering by the tag', () => {
const link = wrapper.find(Link);
const bullet = wrapper.find(TagBullet);
expect(link.prop('to')).toEqual('/server/1/list-short-urls/1?tag=ssr');
expect(bullet.prop('tag')).toEqual('ssr');
});
it('displays delete modal when delete btn is clicked', (done) => {
const delBtn = wrapper.find('.tag-card__btn').at(0);
expect(wrapper.state('isDeleteModalOpen')).toEqual(false);
delBtn.simulate('click');
setImmediate(() => {
expect(wrapper.state('isDeleteModalOpen')).toEqual(true);
done();
});
});
it('displays edit modal when edit btn is clicked', (done) => {
const editBtn = wrapper.find('.tag-card__btn').at(1);
expect(wrapper.state('isEditModalOpen')).toEqual(false);
editBtn.simulate('click');
setImmediate(() => {
expect(wrapper.state('isEditModalOpen')).toEqual(true);
done();
});
});
});