test: Adds tests for the FixedOrMetricControl component (#13705)

diff --git a/superset-frontend/spec/javascripts/explore/components/FixedOrMetricControl_spec.jsx b/superset-frontend/spec/javascripts/explore/components/FixedOrMetricControl_spec.jsx
deleted file mode 100644
index dae156c..0000000
--- a/superset-frontend/spec/javascripts/explore/components/FixedOrMetricControl_spec.jsx
+++ /dev/null
@@ -1,43 +0,0 @@
-/**
- * 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.
- */
-/* eslint-disable no-unused-expressions */
-import React from 'react';
-import { shallow } from 'enzyme';
-
-import TextControl from 'src/explore/components/controls/TextControl';
-import FixedOrMetricControl from 'src/explore/components/controls/FixedOrMetricControl';
-import MetricsControl from 'src/explore/components/controls/MetricControl/MetricsControl';
-
-const defaultProps = {
-  value: {},
-  datasource: {},
-};
-
-describe('FixedOrMetricControl', () => {
-  let wrapper;
-
-  beforeEach(() => {
-    wrapper = shallow(<FixedOrMetricControl {...defaultProps} />);
-  });
-
-  it('renders a TextControl and a SelectControl', () => {
-    expect(wrapper.find(TextControl)).toExist();
-    expect(wrapper.find(MetricsControl)).toExist();
-  });
-});
diff --git a/superset-frontend/src/explore/components/controls/FixedOrMetricControl/FixedOrMetricControl.test.tsx b/superset-frontend/src/explore/components/controls/FixedOrMetricControl/FixedOrMetricControl.test.tsx
new file mode 100644
index 0000000..6a2efd5
--- /dev/null
+++ b/superset-frontend/src/explore/components/controls/FixedOrMetricControl/FixedOrMetricControl.test.tsx
@@ -0,0 +1,105 @@
+/**
+ * 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 { render, screen } from 'spec/helpers/testing-library';
+import userEvent from '@testing-library/user-event';
+import FixedOrMetricControl from '.';
+
+const createProps = () => ({
+  datasource: {
+    columns: [{ column_name: 'Column A' }],
+    metrics: [{ metric_name: 'Metric A', expression: 'COUNT(*)' }],
+  },
+});
+
+test('renders with minimal props', () => {
+  render(<FixedOrMetricControl {...createProps()} />);
+  expect(screen.getByRole('button')).toBeInTheDocument();
+  expect(screen.getByText('5')).toBeInTheDocument();
+});
+
+test('renders with default value', () => {
+  render(
+    <FixedOrMetricControl
+      {...createProps()}
+      default={{ type: 'fix', value: 10 }}
+    />,
+  );
+  expect(screen.getByRole('button')).toBeInTheDocument();
+  expect(screen.getByText('10')).toBeInTheDocument();
+});
+
+test('renders with value', () => {
+  render(
+    <FixedOrMetricControl
+      {...createProps()}
+      default={{ type: 'fix', value: 10 }}
+      value={{ type: 'fix', value: 20 }}
+    />,
+  );
+  expect(screen.getByRole('button')).toBeInTheDocument();
+  expect(screen.getByText('20')).toBeInTheDocument();
+});
+
+test('renders with metric type', () => {
+  render(
+    <FixedOrMetricControl
+      {...createProps()}
+      value={{
+        type: 'metric',
+        value: {
+          label: 'Metric A',
+          expressionType: 'SQL',
+          sqlExpression: 'COUNT(*)',
+        },
+      }}
+    />,
+  );
+  expect(screen.getByRole('button')).toBeInTheDocument();
+  expect(screen.getByText('Metric A')).toBeInTheDocument();
+});
+
+test('triggers onChange', () => {
+  const onChange = jest.fn();
+  render(
+    <FixedOrMetricControl
+      {...createProps()}
+      value={{ type: 'fix', value: 10 }}
+      onChange={onChange}
+    />,
+  );
+  userEvent.click(screen.getByText('10'));
+  expect(onChange).not.toHaveBeenCalled();
+  userEvent.type(screen.getByRole('textbox'), '20');
+  expect(onChange).toHaveBeenCalled();
+});
+
+test('switches control type', () => {
+  render(
+    <FixedOrMetricControl
+      {...createProps()}
+      value={{ type: 'fix', value: 10 }}
+    />,
+  );
+  userEvent.click(screen.getByText('10'));
+  userEvent.click(screen.getByText('Based on a metric'));
+  expect(screen.getByText('metric:')).toBeInTheDocument();
+  userEvent.click(screen.getByText('Fixed'));
+  expect(screen.getByText('10')).toBeInTheDocument();
+});
diff --git a/superset-frontend/src/explore/components/controls/FixedOrMetricControl.jsx b/superset-frontend/src/explore/components/controls/FixedOrMetricControl/index.jsx
similarity index 94%
rename from superset-frontend/src/explore/components/controls/FixedOrMetricControl.jsx
rename to superset-frontend/src/explore/components/controls/FixedOrMetricControl/index.jsx
index c538f13..3400b92 100644
--- a/superset-frontend/src/explore/components/controls/FixedOrMetricControl.jsx
+++ b/superset-frontend/src/explore/components/controls/FixedOrMetricControl/index.jsx
@@ -22,10 +22,10 @@
 import { t } from '@superset-ui/core';
 import Label from 'src/components/Label';
 import Collapse from 'src/common/components/Collapse';
-import TextControl from './TextControl';
-import MetricsControl from './MetricControl/MetricsControl';
-import ControlHeader from '../ControlHeader';
-import PopoverSection from '../../../components/PopoverSection';
+import TextControl from 'src/explore/components/controls/TextControl';
+import MetricsControl from 'src/explore/components/controls/MetricControl/MetricsControl';
+import ControlHeader from 'src/explore/components/ControlHeader';
+import PopoverSection from 'src/components/PopoverSection';
 
 const controlTypes = {
   fixed: 'fix',
diff --git a/superset-frontend/src/explore/components/controls/MetricControl/MetricsControl.jsx b/superset-frontend/src/explore/components/controls/MetricControl/MetricsControl.jsx
index fbf0415..2230824 100644
--- a/superset-frontend/src/explore/components/controls/MetricControl/MetricsControl.jsx
+++ b/superset-frontend/src/explore/components/controls/MetricControl/MetricsControl.jsx
@@ -294,7 +294,7 @@
           null,
         )}
         datasource={this.props.datasource}
-        savedMetric={{}}
+        savedMetric={{ metric_name: '', expression: '' }}
         datasourceType={this.props.datasourceType}
         createNew
       >