Skip to content
New issue

Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.

By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.

Already on GitHub? Sign in to your account

Fix rendering X axis in TraceResultsScatterPlot - pass milliseconds to moment.js #274

Merged
merged 2 commits into from
Nov 18, 2018
Merged
Show file tree
Hide file tree
Changes from all commits
Commits
File filter

Filter by extension

Filter by extension

Conversations
Failed to load comments.
Loading
Jump to
Jump to file
Failed to load files.
Loading
Diff view
Diff view
Original file line number Diff line number Diff line change
Expand Up @@ -20,7 +20,7 @@ import { XYPlot, XAxis, YAxis, MarkSeries, Hint } from 'react-vis';
import { compose, withState, withProps } from 'recompose';

import { FALLBACK_TRACE_NAME } from '../../../constants';
import { formatDuration } from '../../../utils/date';
import { ONE_MILLISECOND, formatDuration } from '../../../utils/date';

import './react-vis.css';
import './ScatterPlot.css';
Expand All @@ -36,7 +36,11 @@ function ScatterPlotImpl(props) {
width={containerWidth}
height={200}
>
<XAxis title="Time" tickTotal={4} tickFormat={t => moment(t).format('hh:mm:ss a')} />
<XAxis
title="Time"
tickTotal={4}
tickFormat={t => moment(t / ONE_MILLISECOND).format('hh:mm:ss a')}
Copy link
Member

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

what does the moment() function do?

Copy link
Contributor Author

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

moment - is the main function of moment.js framework - https://momentjs.com/

It may accept different inputs (strings, Date objects, timestamps). Here it accepts timestamp (number of milliseconds since 1 January 1970 UTC)

Copy link
Member

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

Thanks.

While this may be an OK fix for this specific issue, I think a bigger problem is that we have to do that in the first place. I would expect the UI to have some domain model of the trace and expose the timestamps not in raw microseconds format, but in some structured representation, so that the presentation code wouldn't have to do these conversions all over the place.

/>
<YAxis title="Duration" tickTotal={3} tickFormat={t => formatDuration(t)} />
<MarkSeries
sizeRange={[3, 10]}
Expand Down Expand Up @@ -86,4 +90,6 @@ const ScatterPlot = compose(
}))
)(ScatterPlotImpl);

export { ScatterPlotImpl };

export default dimensions()(ScatterPlot);
Original file line number Diff line number Diff line change
Expand Up @@ -13,9 +13,44 @@
// limitations under the License.

import React from 'react';
import { shallow } from 'enzyme';
import { mount, shallow } from 'enzyme';
import { XAxis, YAxis } from 'react-vis';

import ScatterPlot from './ScatterPlot';
import ScatterPlot, { ScatterPlotImpl } from './ScatterPlot';
import { ONE_MILLISECOND } from '../../../utils/date';

const generateTimestamp = (hours, minutes, seconds) => {
const UTCMilliseconds = new Date(2018, 10, 13, hours, minutes, seconds).getTime();

return UTCMilliseconds * ONE_MILLISECOND;
};

const sampleData = [
{
x: generateTimestamp(22, 10, 17),
y: 1,
traceID: '576b0c2330db100b',
size: 1,
},
{
x: generateTimestamp(22, 10, 22),
y: 2,
traceID: '6fb42ddd88f4b4f2',
size: 1,
},
{
x: generateTimestamp(22, 10, 46),
y: 77707,
traceID: '1f7185d56ef5dc07',
size: 3,
},
{
x: generateTimestamp(22, 11, 6),
y: 80509,
traceID: '21ba1f993ceddd8f',
size: 3,
},
];

it('<ScatterPlot /> should render base case correctly', () => {
const wrapper = shallow(
Expand All @@ -31,3 +66,44 @@ it('<ScatterPlot /> should render base case correctly', () => {
);
expect(wrapper).toBeTruthy();
});

it('<ScatterPlotImpl /> should render X axis correctly', () => {
const wrapper = mount(
<ScatterPlotImpl
containerWidth={1200}
containerHeight={200}
data={sampleData}
onValueClick={() => null}
onValueOut={() => null}
onValueOver={() => null}
/>
);

const xAxisText = wrapper.find(XAxis).text();

expect(xAxisText).toContain('10:10:20 pm');
expect(xAxisText).toContain('10:10:30 pm');
expect(xAxisText).toContain('10:10:40 pm');
expect(xAxisText).toContain('10:10:50 pm');
expect(xAxisText).toContain('10:11:00 pm');
});

it('<ScatterPlotImpl /> should render Y axis correctly', () => {
const wrapper = mount(
<ScatterPlotImpl
containerWidth={1200}
containerHeight={200}
data={sampleData}
onValueClick={() => null}
onValueOut={() => null}
onValueOver={() => null}
/>
);

const yAxisText = wrapper.find(YAxis).text();

expect(yAxisText).toContain('20ms');
expect(yAxisText).toContain('40ms');
expect(yAxisText).toContain('60ms');
expect(yAxisText).toContain('80ms');
});