mirror of
https://github.com/apache/superset.git
synced 2026-04-09 03:16:07 +00:00
* feat: upgrade react-select v1.3.0 to v3.1.0 Upgrade `react-select`, replace `react-virtualized-select` with a custom solution implemented with `react-window`. Future plans include deprecate `react-virtualized` used in other places, too. Migrate all react-select related components to `src/Components/Select`. * Fix new list view * Fix tests * Address PR comments * Fix a flacky Cypress test * Adjust styles for Select in CRUD ListView * Fix loadOptions for owners select in chart PropertiesModal TODO: add typing support for AsyncSelect props. * Address PR comments; allow isMulti in SelectControl, too * Clean up NaN in table filter values * Fix flacky test
83 lines
2.7 KiB
JavaScript
83 lines
2.7 KiB
JavaScript
/**
|
|
* 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.
|
|
*/
|
|
import React from 'react';
|
|
import { shallow } from 'enzyme';
|
|
import { Button } from 'react-bootstrap';
|
|
import Select from 'src/components/Select';
|
|
import AddSliceContainer from 'src/addSlice/AddSliceContainer';
|
|
import VizTypeControl from 'src/explore/components/controls/VizTypeControl';
|
|
|
|
const defaultProps = {
|
|
datasources: [
|
|
{ label: 'my first table', value: '1__table' },
|
|
{ label: 'another great table', value: '2__table' },
|
|
],
|
|
};
|
|
|
|
describe('AddSliceContainer', () => {
|
|
let wrapper;
|
|
|
|
beforeEach(() => {
|
|
wrapper = shallow(<AddSliceContainer {...defaultProps} />);
|
|
});
|
|
|
|
it('uses table as default visType', () => {
|
|
expect(wrapper.state().visType).toBe('table');
|
|
});
|
|
|
|
it('renders a select and a VizTypeControl', () => {
|
|
expect(wrapper.find(Select)).toHaveLength(1);
|
|
expect(wrapper.find(VizTypeControl)).toHaveLength(1);
|
|
});
|
|
|
|
it('renders a button', () => {
|
|
expect(wrapper.find(Button)).toHaveLength(1);
|
|
});
|
|
|
|
it('renders a disabled button if no datasource is selected', () => {
|
|
expect(
|
|
wrapper.find(Button).dive().find('.btn[disabled=true]'),
|
|
).toHaveLength(1);
|
|
});
|
|
|
|
it('renders an enabled button if datasource is selected', () => {
|
|
const datasourceValue = defaultProps.datasources[0].value;
|
|
wrapper.setState({
|
|
datasourceValue,
|
|
datasourceId: datasourceValue.split('__')[0],
|
|
datasourceType: datasourceValue.split('__')[1],
|
|
});
|
|
expect(
|
|
wrapper.find(Button).dive().find('.btn[disabled=false]'),
|
|
).toHaveLength(1);
|
|
});
|
|
|
|
it('formats explore url', () => {
|
|
const datasourceValue = defaultProps.datasources[0].value;
|
|
wrapper.setState({
|
|
datasourceValue,
|
|
datasourceId: datasourceValue.split('__')[0],
|
|
datasourceType: datasourceValue.split('__')[1],
|
|
});
|
|
const formattedUrl =
|
|
'/superset/explore/?form_data=%7B%22viz_type%22%3A%22table%22%2C%22datasource%22%3A%221__table%22%7D';
|
|
expect(wrapper.instance().exploreUrl()).toBe(formattedUrl);
|
|
});
|
|
});
|