import React from 'react';
import { mount } from 'enzyme';
import { describe, it, beforeEach } from 'mocha';
import { expect } from 'chai';
import Timer from '../../../javascripts/components/Timer';
import { now } from '../../../javascripts/modules/dates';
describe('Timer', () => {
let wrapper;
const mockedProps = {
startTime: now(),
endTime: null,
isRunning: true,
status: 'warning',
};
beforeEach(() => {
wrapper = mount();
});
it('is a valid element', () => {
expect(React.isValidElement()).to.equal(true);
});
it('componentWillMount starts timer after 30ms and sets state.clockStr', () => {
expect(wrapper.state().clockStr).to.equal('');
setTimeout(() => {
expect(wrapper.state().clockStr).not.equal('');
}, 31);
});
it('calls startTimer on mount', () => {
const startTimerSpy = sinon.spy(Timer.prototype, 'startTimer');
wrapper.mount();
expect(Timer.prototype.startTimer.calledOnce);
startTimerSpy.restore();
});
it('calls stopTimer on unmount', () => {
const stopTimerSpy = sinon.spy(Timer.prototype, 'stopTimer');
wrapper.unmount();
expect(Timer.prototype.stopTimer.calledOnce);
stopTimerSpy.restore();
});
it('renders a span with the correct class', () => {
expect(wrapper.find('span').hasClass('label-warning')).to.equal(true);
});
});