| /** |
| * 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 { ChartProps, supersetTheme } from '@superset-ui/core'; |
| import transformProps from '../../src/Tree/transformProps'; |
| import { EchartsTreeChartProps } from '../../src/Tree/types'; |
| |
| describe('EchartsTree transformProps', () => { |
| const formData = { |
| colorScheme: 'bnbColors', |
| datasource: '3__table', |
| granularity_sqla: 'ds', |
| metric: 'count', |
| id: 'id_column', |
| parent: 'relation_column', |
| name: 'name_column', |
| rootNodeId: '1', |
| }; |
| const chartPropsConfig = { |
| formData, |
| width: 800, |
| height: 600, |
| theme: supersetTheme, |
| }; |
| it('should transform when parent present before child', () => { |
| const queriesData = [ |
| { |
| colnames: ['id_column', 'relation_column', 'name_column', 'count'], |
| data: [ |
| { |
| id_column: '1', |
| relation_column: null, |
| name_column: 'root', |
| count: 10, |
| }, |
| { |
| id_column: '2', |
| relation_column: '1', |
| name_column: 'first_child', |
| count: 10, |
| }, |
| { |
| id_column: '3', |
| relation_column: '2', |
| name_column: 'second_child', |
| count: 10, |
| }, |
| { |
| id_column: '4', |
| relation_column: '3', |
| name_column: 'third_child', |
| count: 10, |
| }, |
| ], |
| }, |
| ]; |
| |
| const chartProps = new ChartProps({ ...chartPropsConfig, queriesData }); |
| expect(transformProps(chartProps as EchartsTreeChartProps)).toEqual( |
| expect.objectContaining({ |
| width: 800, |
| height: 600, |
| echartOptions: expect.objectContaining({ |
| series: expect.arrayContaining([ |
| expect.objectContaining({ |
| data: [ |
| { |
| name: 'root', |
| children: [ |
| { |
| name: 'first_child', |
| value: 10, |
| children: [ |
| { |
| name: 'second_child', |
| value: 10, |
| children: [ |
| { name: 'third_child', value: 10, children: [] }, |
| ], |
| }, |
| ], |
| }, |
| ], |
| }, |
| ], |
| }), |
| ]), |
| }), |
| }), |
| ); |
| }); |
| it('should transform when child is present before parent', () => { |
| const queriesData = [ |
| { |
| colnames: ['id_column', 'relation_column', 'name_column', 'count'], |
| data: [ |
| { |
| id_column: '1', |
| relation_column: null, |
| name_column: 'root', |
| count: 10, |
| }, |
| { |
| id_column: '2', |
| relation_column: '4', |
| name_column: 'second_child', |
| count: 20, |
| }, |
| { |
| id_column: '3', |
| relation_column: '4', |
| name_column: 'second_child', |
| count: 30, |
| }, |
| { |
| id_column: '4', |
| relation_column: '1', |
| name_column: 'first_child', |
| count: 40, |
| }, |
| ], |
| }, |
| ]; |
| |
| const chartProps = new ChartProps({ ...chartPropsConfig, queriesData }); |
| expect(transformProps(chartProps as EchartsTreeChartProps)).toEqual( |
| expect.objectContaining({ |
| width: 800, |
| height: 600, |
| echartOptions: expect.objectContaining({ |
| series: expect.arrayContaining([ |
| expect.objectContaining({ |
| data: [ |
| { |
| name: 'root', |
| children: [ |
| { |
| name: 'first_child', |
| value: 40, |
| children: [ |
| { |
| name: 'second_child', |
| value: 20, |
| children: [], |
| }, |
| { |
| name: 'second_child', |
| value: 30, |
| children: [], |
| }, |
| ], |
| }, |
| ], |
| }, |
| ], |
| }), |
| ]), |
| }), |
| }), |
| ); |
| }); |
| it('ignore node if not attached to root', () => { |
| const formData = { |
| colorScheme: 'bnbColors', |
| datasource: '3__table', |
| granularity_sqla: 'ds', |
| metric: 'count', |
| id: 'id_column', |
| parent: 'relation_column', |
| name: 'name_column', |
| rootNodeId: '2', |
| }; |
| const chartPropsConfig = { |
| formData, |
| width: 800, |
| height: 600, |
| theme: supersetTheme, |
| }; |
| const queriesData = [ |
| { |
| colnames: ['id_column', 'relation_column', 'name_column', 'count'], |
| data: [ |
| { |
| id_column: '1', |
| relation_column: null, |
| name_column: 'root', |
| count: 10, |
| }, |
| { |
| id_column: '2', |
| relation_column: '1', |
| name_column: 'first_child', |
| count: 10, |
| }, |
| { |
| id_column: '3', |
| relation_column: '2', |
| name_column: 'second_child', |
| count: 10, |
| }, |
| { |
| id_column: '4', |
| relation_column: '3', |
| name_column: 'third_child', |
| count: 20, |
| }, |
| ], |
| }, |
| ]; |
| |
| const chartProps = new ChartProps({ ...chartPropsConfig, queriesData }); |
| expect(transformProps(chartProps as EchartsTreeChartProps)).toEqual( |
| expect.objectContaining({ |
| width: 800, |
| height: 600, |
| echartOptions: expect.objectContaining({ |
| series: expect.arrayContaining([ |
| expect.objectContaining({ |
| data: [ |
| { |
| name: 'first_child', |
| children: [ |
| { |
| name: 'second_child', |
| value: 10, |
| children: [ |
| { |
| name: 'third_child', |
| value: 20, |
| children: [], |
| }, |
| ], |
| }, |
| ], |
| }, |
| ], |
| }), |
| ]), |
| }), |
| }), |
| ); |
| }); |
| it('should transform props if name column is not specified', () => { |
| const formData = { |
| colorScheme: 'bnbColors', |
| datasource: '3__table', |
| granularity_sqla: 'ds', |
| metric: 'count', |
| id: 'id_column', |
| parent: 'relation_column', |
| rootNodeId: '1', |
| }; |
| const chartPropsConfig = { |
| formData, |
| width: 800, |
| height: 600, |
| theme: supersetTheme, |
| }; |
| const queriesData = [ |
| { |
| colnames: ['id_column', 'relation_column', 'count'], |
| data: [ |
| { |
| id_column: '1', |
| relation_column: null, |
| count: 10, |
| }, |
| { |
| id_column: '2', |
| relation_column: '1', |
| count: 10, |
| }, |
| { |
| id_column: '3', |
| relation_column: '2', |
| count: 10, |
| }, |
| { |
| id_column: '4', |
| relation_column: '3', |
| count: 20, |
| }, |
| ], |
| }, |
| ]; |
| |
| const chartProps = new ChartProps({ ...chartPropsConfig, queriesData }); |
| expect(transformProps(chartProps as EchartsTreeChartProps)).toEqual( |
| expect.objectContaining({ |
| width: 800, |
| height: 600, |
| echartOptions: expect.objectContaining({ |
| series: expect.arrayContaining([ |
| expect.objectContaining({ |
| data: [ |
| { |
| name: '1', |
| children: [ |
| { |
| name: '2', |
| value: 10, |
| children: [ |
| { |
| name: '3', |
| value: 10, |
| children: [ |
| { |
| name: '4', |
| value: 20, |
| children: [], |
| }, |
| ], |
| }, |
| ], |
| }, |
| ], |
| }, |
| ], |
| }), |
| ]), |
| }), |
| }), |
| ); |
| }); |
| it('should find root node with null parent when root node name is not provided', () => { |
| const formData = { |
| colorScheme: 'bnbColors', |
| datasource: '3__table', |
| granularity_sqla: 'ds', |
| metric: 'count', |
| id: 'id_column', |
| parent: 'relation_column', |
| name: 'name_column', |
| }; |
| const chartPropsConfig = { |
| formData, |
| width: 800, |
| height: 600, |
| theme: supersetTheme, |
| }; |
| const queriesData = [ |
| { |
| colnames: ['id_column', 'relation_column', 'name_column', 'count'], |
| data: [ |
| { |
| id_column: '2', |
| relation_column: '4', |
| name_column: 'second_child', |
| count: 20, |
| }, |
| { |
| id_column: '3', |
| relation_column: '4', |
| name_column: 'second_child', |
| count: 30, |
| }, |
| { |
| id_column: '4', |
| relation_column: '1', |
| name_column: 'first_child', |
| count: 40, |
| }, |
| { |
| id_column: '1', |
| relation_column: null, |
| name_column: 'root', |
| count: 10, |
| }, |
| ], |
| }, |
| ]; |
| |
| const chartProps = new ChartProps({ ...chartPropsConfig, queriesData }); |
| expect(transformProps(chartProps as EchartsTreeChartProps)).toEqual( |
| expect.objectContaining({ |
| width: 800, |
| height: 600, |
| echartOptions: expect.objectContaining({ |
| series: expect.arrayContaining([ |
| expect.objectContaining({ |
| data: [ |
| { |
| name: 'root', |
| children: [ |
| { |
| name: 'first_child', |
| value: 40, |
| children: [ |
| { |
| name: 'second_child', |
| value: 20, |
| children: [], |
| }, |
| { |
| name: 'second_child', |
| value: 30, |
| children: [], |
| }, |
| ], |
| }, |
| ], |
| }, |
| ], |
| }), |
| ]), |
| }), |
| }), |
| ); |
| }); |
| }); |