mirror of
https://github.com/grafana/grafana.git
synced 2024-11-30 12:44:10 -06:00
tests
This commit is contained in:
parent
c2c3e15022
commit
84bbfe11ca
63
public/app/features/datasources/DashboardsTable.test.tsx
Normal file
63
public/app/features/datasources/DashboardsTable.test.tsx
Normal file
@ -0,0 +1,63 @@
|
||||
import React from 'react';
|
||||
import { shallow } from 'enzyme';
|
||||
import DashboardsTable, { Props } from './DashboardsTable';
|
||||
import { PluginDashboard } from '../../types';
|
||||
|
||||
const setup = (propOverrides?: object) => {
|
||||
const props: Props = {
|
||||
dashboards: [] as PluginDashboard[],
|
||||
onImport: jest.fn(),
|
||||
onRemove: jest.fn(),
|
||||
};
|
||||
|
||||
Object.assign(props, propOverrides);
|
||||
|
||||
return shallow(<DashboardsTable {...props} />);
|
||||
};
|
||||
|
||||
describe('Render', () => {
|
||||
it('should render component', () => {
|
||||
const wrapper = setup();
|
||||
|
||||
expect(wrapper).toMatchSnapshot();
|
||||
});
|
||||
|
||||
it('should render table', () => {
|
||||
const wrapper = setup({
|
||||
dashboards: [
|
||||
{
|
||||
dashboardId: 0,
|
||||
description: '',
|
||||
folderId: 0,
|
||||
imported: false,
|
||||
importedRevision: 0,
|
||||
importedUri: '',
|
||||
importedUrl: '',
|
||||
path: 'dashboards/carbon_metrics.json',
|
||||
pluginId: 'graphite',
|
||||
removed: false,
|
||||
revision: 1,
|
||||
slug: '',
|
||||
title: 'Graphite Carbon Metrics',
|
||||
},
|
||||
{
|
||||
dashboardId: 0,
|
||||
description: '',
|
||||
folderId: 0,
|
||||
imported: true,
|
||||
importedRevision: 0,
|
||||
importedUri: '',
|
||||
importedUrl: '',
|
||||
path: 'dashboards/carbon_metrics.json',
|
||||
pluginId: 'graphite',
|
||||
removed: false,
|
||||
revision: 1,
|
||||
slug: '',
|
||||
title: 'Graphite Carbon Metrics',
|
||||
},
|
||||
],
|
||||
});
|
||||
|
||||
expect(wrapper).toMatchSnapshot();
|
||||
});
|
||||
});
|
@ -1,7 +1,7 @@
|
||||
import React, { SFC } from 'react';
|
||||
import { PluginDashboard } from '../../types';
|
||||
|
||||
interface Props {
|
||||
export interface Props {
|
||||
dashboards: PluginDashboard[];
|
||||
onImport: (dashboard, overwrite) => void;
|
||||
onRemove: (dashboard) => void;
|
||||
|
@ -0,0 +1,29 @@
|
||||
import React from 'react';
|
||||
import { shallow } from 'enzyme';
|
||||
import { DataSourceDashboards, Props } from './DataSourceDashboards';
|
||||
import { DataSource, NavModel, PluginDashboard } from 'app/types';
|
||||
|
||||
const setup = (propOverrides?: object) => {
|
||||
const props: Props = {
|
||||
navModel: {} as NavModel,
|
||||
dashboards: [] as PluginDashboard[],
|
||||
dataSource: {} as DataSource,
|
||||
pageId: 1,
|
||||
importDashboard: jest.fn(),
|
||||
loadDataSource: jest.fn(),
|
||||
loadPluginDashboards: jest.fn(),
|
||||
removeDashboard: jest.fn(),
|
||||
};
|
||||
|
||||
Object.assign(props, propOverrides);
|
||||
|
||||
return shallow(<DataSourceDashboards {...props} />);
|
||||
};
|
||||
|
||||
describe('Render', () => {
|
||||
it('should render component', () => {
|
||||
const wrapper = setup();
|
||||
|
||||
expect(wrapper).toMatchSnapshot();
|
||||
});
|
||||
});
|
@ -0,0 +1,88 @@
|
||||
// Jest Snapshot v1, https://goo.gl/fbAQLP
|
||||
|
||||
exports[`Render should render component 1`] = `
|
||||
<table
|
||||
className="filter-table"
|
||||
>
|
||||
<tbody />
|
||||
</table>
|
||||
`;
|
||||
|
||||
exports[`Render should render table 1`] = `
|
||||
<table
|
||||
className="filter-table"
|
||||
>
|
||||
<tbody>
|
||||
<tr
|
||||
key="0-0"
|
||||
>
|
||||
<td
|
||||
className="width-1"
|
||||
>
|
||||
<i
|
||||
className="icon-gf icon-gf-dashboard"
|
||||
/>
|
||||
</td>
|
||||
<td>
|
||||
<span>
|
||||
Graphite Carbon Metrics
|
||||
</span>
|
||||
</td>
|
||||
<td
|
||||
style={
|
||||
Object {
|
||||
"textAlign": "right",
|
||||
}
|
||||
}
|
||||
>
|
||||
<button
|
||||
className="btn btn-secondary btn-small"
|
||||
onClick={[Function]}
|
||||
>
|
||||
Import
|
||||
</button>
|
||||
</td>
|
||||
</tr>
|
||||
<tr
|
||||
key="0-1"
|
||||
>
|
||||
<td
|
||||
className="width-1"
|
||||
>
|
||||
<i
|
||||
className="icon-gf icon-gf-dashboard"
|
||||
/>
|
||||
</td>
|
||||
<td>
|
||||
<a
|
||||
href=""
|
||||
>
|
||||
Graphite Carbon Metrics
|
||||
</a>
|
||||
</td>
|
||||
<td
|
||||
style={
|
||||
Object {
|
||||
"textAlign": "right",
|
||||
}
|
||||
}
|
||||
>
|
||||
<button
|
||||
className="btn btn-secondary btn-small"
|
||||
onClick={[Function]}
|
||||
>
|
||||
Update
|
||||
</button>
|
||||
<button
|
||||
className="btn btn-danger btn-small"
|
||||
onClick={[Function]}
|
||||
>
|
||||
<i
|
||||
className="fa fa-trash"
|
||||
/>
|
||||
</button>
|
||||
</td>
|
||||
</tr>
|
||||
</tbody>
|
||||
</table>
|
||||
`;
|
@ -0,0 +1,18 @@
|
||||
// Jest Snapshot v1, https://goo.gl/fbAQLP
|
||||
|
||||
exports[`Render should render component 1`] = `
|
||||
<div>
|
||||
<PageHeader
|
||||
model={Object {}}
|
||||
/>
|
||||
<div
|
||||
className="page-container page-body"
|
||||
>
|
||||
<DashboardsTable
|
||||
dashboards={Array []}
|
||||
onImport={[Function]}
|
||||
onRemove={[Function]}
|
||||
/>
|
||||
</div>
|
||||
</div>
|
||||
`;
|
Loading…
Reference in New Issue
Block a user