2019-01-15 18:53:27 -05:00
|
|
|
/**
|
|
|
|
* Licensed to the Apache Software Foundation (ASF) under one
|
|
|
|
* or more contributor license agreements. See the NOTICE file
|
|
|
|
* distributed with this work for additional information
|
|
|
|
* regarding copyright ownership. The ASF licenses this file
|
|
|
|
* to you under the Apache License, Version 2.0 (the
|
|
|
|
* "License"); you may not use this file except in compliance
|
|
|
|
* with the License. You may obtain a copy of the License at
|
|
|
|
*
|
|
|
|
* http://www.apache.org/licenses/LICENSE-2.0
|
|
|
|
*
|
|
|
|
* Unless required by applicable law or agreed to in writing,
|
|
|
|
* software distributed under the License is distributed on an
|
|
|
|
* "AS IS" BASIS, WITHOUT WARRANTIES OR CONDITIONS OF ANY
|
|
|
|
* KIND, either express or implied. See the License for the
|
|
|
|
* specific language governing permissions and limitations
|
|
|
|
* under the License.
|
|
|
|
*/
|
2018-02-02 13:28:38 -05:00
|
|
|
import React from 'react';
|
|
|
|
import { shallow } from 'enzyme';
|
|
|
|
|
2020-03-13 18:14:50 -04:00
|
|
|
import { ExploreChartHeader } from '../../../../src/explore/components/ExploreChartHeader';
|
2018-04-18 00:05:01 -04:00
|
|
|
import ExploreActionButtons from '../../../../src/explore/components/ExploreActionButtons';
|
|
|
|
import EditableTitle from '../../../../src/components/EditableTitle';
|
2018-02-02 13:28:38 -05:00
|
|
|
|
2019-12-18 19:17:48 -05:00
|
|
|
const stub = jest.fn(() => ({
|
|
|
|
then: () => {},
|
|
|
|
}));
|
2018-02-02 13:28:38 -05:00
|
|
|
const mockProps = {
|
2019-12-18 19:17:48 -05:00
|
|
|
actions: {
|
|
|
|
saveSlice: stub,
|
|
|
|
},
|
2018-02-02 13:28:38 -05:00
|
|
|
can_overwrite: true,
|
|
|
|
can_download: true,
|
|
|
|
isStarred: true,
|
2019-12-18 19:17:48 -05:00
|
|
|
slice: {
|
|
|
|
form_data: {
|
|
|
|
viz_type: 'line',
|
|
|
|
},
|
|
|
|
},
|
2018-02-02 13:28:38 -05:00
|
|
|
table_name: 'foo',
|
2019-12-18 19:17:48 -05:00
|
|
|
form_data: {
|
|
|
|
viz_type: 'table',
|
|
|
|
},
|
2018-02-02 13:28:38 -05:00
|
|
|
timeout: 1000,
|
|
|
|
chart: {
|
|
|
|
queryResponse: {},
|
|
|
|
},
|
|
|
|
};
|
|
|
|
|
|
|
|
describe('ExploreChartHeader', () => {
|
|
|
|
let wrapper;
|
|
|
|
beforeEach(() => {
|
|
|
|
wrapper = shallow(<ExploreChartHeader {...mockProps} />);
|
|
|
|
});
|
|
|
|
|
|
|
|
it('is valid', () => {
|
2019-11-27 17:02:48 -05:00
|
|
|
expect(React.isValidElement(<ExploreChartHeader {...mockProps} />)).toBe(
|
|
|
|
true,
|
|
|
|
);
|
2018-02-02 13:28:38 -05:00
|
|
|
});
|
|
|
|
|
|
|
|
it('renders', () => {
|
2018-10-15 16:10:18 -04:00
|
|
|
expect(wrapper.find(EditableTitle)).toHaveLength(1);
|
|
|
|
expect(wrapper.find(ExploreActionButtons)).toHaveLength(1);
|
2018-02-02 13:28:38 -05:00
|
|
|
});
|
2019-12-18 19:17:48 -05:00
|
|
|
|
|
|
|
it('should updateChartTitleOrSaveSlice for existed slice', () => {
|
|
|
|
const newTitle = 'New Chart Title';
|
|
|
|
wrapper.instance().updateChartTitleOrSaveSlice(newTitle);
|
2020-01-16 00:48:55 -05:00
|
|
|
expect(stub.call).toHaveLength(1);
|
2019-12-18 19:17:48 -05:00
|
|
|
expect(stub).toHaveBeenCalledWith(mockProps.slice.form_data, {
|
|
|
|
action: 'overwrite',
|
|
|
|
slice_name: newTitle,
|
|
|
|
});
|
|
|
|
});
|
|
|
|
|
|
|
|
it('should updateChartTitleOrSaveSlice for new slice', () => {
|
|
|
|
const newTitle = 'New Chart Title';
|
|
|
|
wrapper.setProps({ slice: undefined });
|
|
|
|
wrapper.instance().updateChartTitleOrSaveSlice(newTitle);
|
2020-01-16 00:48:55 -05:00
|
|
|
expect(stub.call).toHaveLength(1);
|
2019-12-18 19:17:48 -05:00
|
|
|
expect(stub).toHaveBeenCalledWith(mockProps.form_data, {
|
|
|
|
action: 'saveas',
|
|
|
|
slice_name: newTitle,
|
|
|
|
});
|
|
|
|
});
|
2018-02-02 13:28:38 -05:00
|
|
|
});
|