Commit 1f60ca07 authored by Nathan Friend's avatar Nathan Friend Committed by David O'Regan

Restructure DORA 4 graphs

This commit updates the directory structure of the DORA 4 graphs in
preparation for these graphs to be displayed on both project and
group-level pages.
parent 98dd828e
...@@ -9,9 +9,8 @@ export default { ...@@ -9,9 +9,8 @@ export default {
GlTab, GlTab,
PipelineCharts, PipelineCharts,
DeploymentFrequencyCharts: () => DeploymentFrequencyCharts: () =>
import('ee_component/projects/pipelines/charts/components/deployment_frequency_charts.vue'), import('ee_component/dora/components/deployment_frequency_charts.vue'),
LeadTimeCharts: () => LeadTimeCharts: () => import('ee_component/dora/components/lead_time_charts.vue'),
import('ee_component/projects/pipelines/charts/components/lead_time_charts.vue'),
}, },
inject: { inject: {
shouldRenderDoraCharts: { shouldRenderDoraCharts: {
......
...@@ -4,6 +4,7 @@ import { GlColumnChart } from '@gitlab/ui/dist/charts'; ...@@ -4,6 +4,7 @@ import { GlColumnChart } from '@gitlab/ui/dist/charts';
import dateFormat from 'dateformat'; import dateFormat from 'dateformat';
import { getDateInPast } from '~/lib/utils/datetime_utility'; import { getDateInPast } from '~/lib/utils/datetime_utility';
import { __, s__, sprintf } from '~/locale'; import { __, s__, sprintf } from '~/locale';
import CiCdAnalyticsCharts from '~/vue_shared/components/ci_cd_analytics/ci_cd_analytics_charts.vue';
import { import {
DEFAULT, DEFAULT,
CHART_CONTAINER_HEIGHT, CHART_CONTAINER_HEIGHT,
...@@ -21,7 +22,6 @@ import { ...@@ -21,7 +22,6 @@ import {
} from '../constants'; } from '../constants';
import getPipelineCountByStatus from '../graphql/queries/get_pipeline_count_by_status.query.graphql'; import getPipelineCountByStatus from '../graphql/queries/get_pipeline_count_by_status.query.graphql';
import getProjectPipelineStatistics from '../graphql/queries/get_project_pipeline_statistics.query.graphql'; import getProjectPipelineStatistics from '../graphql/queries/get_project_pipeline_statistics.query.graphql';
import CiCdAnalyticsCharts from './ci_cd_analytics_charts.vue';
import StatisticsList from './statistics_list.vue'; import StatisticsList from './statistics_list.vue';
const defaultAnalyticsValues = { const defaultAnalyticsValues = {
......
<script> <script>
import { GlAreaChart } from '@gitlab/ui/dist/charts'; import { GlAreaChart } from '@gitlab/ui/dist/charts';
import ResizableChartContainer from '~/vue_shared/components/resizable_chart/resizable_chart_container.vue'; import ResizableChartContainer from '~/vue_shared/components/resizable_chart/resizable_chart_container.vue';
import { CHART_CONTAINER_HEIGHT } from '../constants'; import { CHART_CONTAINER_HEIGHT } from './constants';
export default { export default {
name: 'CiCdAnalyticsAreaChart', name: 'CiCdAnalyticsAreaChart',
......
...@@ -3,7 +3,7 @@ import * as Sentry from '@sentry/browser'; ...@@ -3,7 +3,7 @@ import * as Sentry from '@sentry/browser';
import * as DoraApi from 'ee/api/dora_api'; import * as DoraApi from 'ee/api/dora_api';
import createFlash from '~/flash'; import createFlash from '~/flash';
import { s__ } from '~/locale'; import { s__ } from '~/locale';
import CiCdAnalyticsCharts from '~/projects/pipelines/charts/components/ci_cd_analytics_charts.vue'; import CiCdAnalyticsCharts from '~/vue_shared/components/ci_cd_analytics/ci_cd_analytics_charts.vue';
import DoraChartHeader from './dora_chart_header.vue'; import DoraChartHeader from './dora_chart_header.vue';
import { import {
allChartDefinitions, allChartDefinitions,
......
...@@ -3,7 +3,7 @@ import * as DoraApi from 'ee/api/dora_api'; ...@@ -3,7 +3,7 @@ import * as DoraApi from 'ee/api/dora_api';
import createFlash from '~/flash'; import createFlash from '~/flash';
import { humanizeTimeInterval } from '~/lib/utils/datetime_utility'; import { humanizeTimeInterval } from '~/lib/utils/datetime_utility';
import { s__ } from '~/locale'; import { s__ } from '~/locale';
import CiCdAnalyticsCharts from '~/projects/pipelines/charts/components/ci_cd_analytics_charts.vue'; import CiCdAnalyticsCharts from '~/vue_shared/components/ci_cd_analytics/ci_cd_analytics_charts.vue';
import DoraChartHeader from './dora_chart_header.vue'; import DoraChartHeader from './dora_chart_header.vue';
import { import {
allChartDefinitions, allChartDefinitions,
......
// Jest Snapshot v1, https://goo.gl/fbAQLP // Jest Snapshot v1, https://goo.gl/fbAQLP
exports[`ee/projects/pipelines/charts/components/util.js lead time data returns the correct lead time chart data after all processing of the API response 1`] = ` exports[`ee/dora/components/util.js lead time data returns the correct lead time chart data after all processing of the API response 1`] = `
Array [ Array [
Object { Object {
"areaStyle": Object { "areaStyle": Object {
......
...@@ -5,7 +5,7 @@ import { useFixturesFakeDate } from 'helpers/fake_date'; ...@@ -5,7 +5,7 @@ import { useFixturesFakeDate } from 'helpers/fake_date';
import createFlash from '~/flash'; import createFlash from '~/flash';
import axios from '~/lib/utils/axios_utils'; import axios from '~/lib/utils/axios_utils';
import httpStatus from '~/lib/utils/http_status'; import httpStatus from '~/lib/utils/http_status';
import CiCdAnalyticsCharts from '~/projects/pipelines/charts/components/ci_cd_analytics_charts.vue'; import CiCdAnalyticsCharts from '~/vue_shared/components/ci_cd_analytics/ci_cd_analytics_charts.vue';
jest.mock('~/flash'); jest.mock('~/flash');
...@@ -29,13 +29,9 @@ describe('deployment_frequency_charts.vue', () => { ...@@ -29,13 +29,9 @@ describe('deployment_frequency_charts.vue', () => {
// that any calls to `new Date()` during module initialization use the fake date // that any calls to `new Date()` during module initialization use the fake date
beforeAll(async () => { beforeAll(async () => {
DeploymentFrequencyCharts = ( DeploymentFrequencyCharts = (
await import( await import('ee_component/dora/components/deployment_frequency_charts.vue')
'ee_component/projects/pipelines/charts/components/deployment_frequency_charts.vue'
)
).default;
DoraChartHeader = (
await import('ee/projects/pipelines/charts/components/dora_chart_header.vue')
).default; ).default;
DoraChartHeader = (await import('ee/dora/components/dora_chart_header.vue')).default;
}); });
let wrapper; let wrapper;
......
import DoraChartHeader from 'ee/projects/pipelines/charts/components/dora_chart_header.vue'; import DoraChartHeader from 'ee/dora/components/dora_chart_header.vue';
import { chartDescriptionText } from 'ee/projects/pipelines/charts/components/static_data/lead_time'; import { chartDescriptionText } from 'ee/dora/components/static_data/lead_time';
import { environmentTierDocumentationHref } from 'ee/projects/pipelines/charts/components/static_data/shared'; import { environmentTierDocumentationHref } from 'ee/dora/components/static_data/shared';
import { mountExtended } from 'helpers/vue_test_utils_helper'; import { mountExtended } from 'helpers/vue_test_utils_helper';
describe('dora_chart_header.vue', () => { describe('dora_chart_header.vue', () => {
......
...@@ -5,7 +5,7 @@ import { useFixturesFakeDate } from 'helpers/fake_date'; ...@@ -5,7 +5,7 @@ import { useFixturesFakeDate } from 'helpers/fake_date';
import createFlash from '~/flash'; import createFlash from '~/flash';
import axios from '~/lib/utils/axios_utils'; import axios from '~/lib/utils/axios_utils';
import httpStatus from '~/lib/utils/http_status'; import httpStatus from '~/lib/utils/http_status';
import CiCdAnalyticsCharts from '~/projects/pipelines/charts/components/ci_cd_analytics_charts.vue'; import CiCdAnalyticsCharts from '~/vue_shared/components/ci_cd_analytics/ci_cd_analytics_charts.vue';
jest.mock('~/flash'); jest.mock('~/flash');
...@@ -28,12 +28,8 @@ describe('lead_time_charts.vue', () => { ...@@ -28,12 +28,8 @@ describe('lead_time_charts.vue', () => {
// Import these components _after_ the date has been set using `useFakeDate`, so // Import these components _after_ the date has been set using `useFakeDate`, so
// that any calls to `new Date()` during module initialization use the fake date // that any calls to `new Date()` during module initialization use the fake date
beforeAll(async () => { beforeAll(async () => {
LeadTimeCharts = ( LeadTimeCharts = (await import('ee_component/dora/components/lead_time_charts.vue')).default;
await import('ee_component/projects/pipelines/charts/components/lead_time_charts.vue') DoraChartHeader = (await import('ee/dora/components/dora_chart_header.vue')).default;
).default;
DoraChartHeader = (
await import('ee/projects/pipelines/charts/components/dora_chart_header.vue')
).default;
}); });
let wrapper; let wrapper;
......
import { import { apiDataToChartSeries, buildNullSeriesForLeadTimeChart } from 'ee/dora/components/util';
apiDataToChartSeries,
buildNullSeriesForLeadTimeChart,
} from 'ee/projects/pipelines/charts/components/util';
const lastWeekData = getJSONFixture( const lastWeekData = getJSONFixture(
'api/dora/metrics/daily_lead_time_for_changes_for_last_week.json', 'api/dora/metrics/daily_lead_time_for_changes_for_last_week.json',
); );
describe('ee/projects/pipelines/charts/components/util.js', () => { describe('ee/dora/components/util.js', () => {
describe('apiDataToChartSeries', () => { describe('apiDataToChartSeries', () => {
it('transforms the data from the API into data the chart component can use', () => { it('transforms the data from the API into data the chart component can use', () => {
const apiData = [ const apiData = [
......
import { mount } from '@vue/test-utils'; import { mount } from '@vue/test-utils';
import CiCdAnalyticsAreaChart from '~/projects/pipelines/charts/components/ci_cd_analytics_area_chart.vue'; import CiCdAnalyticsAreaChart from '~/vue_shared/components/ci_cd_analytics/ci_cd_analytics_area_chart.vue';
import { transformedAreaChartData } from '../mock_data'; import { transformedAreaChartData } from '../mock_data';
describe('CiCdAnalyticsAreaChart', () => { describe('CiCdAnalyticsAreaChart', () => {
......
import { GlSegmentedControl } from '@gitlab/ui'; import { GlSegmentedControl } from '@gitlab/ui';
import { shallowMount } from '@vue/test-utils'; import { shallowMount } from '@vue/test-utils';
import { nextTick } from 'vue'; import { nextTick } from 'vue';
import CiCdAnalyticsAreaChart from '~/projects/pipelines/charts/components/ci_cd_analytics_area_chart.vue'; import CiCdAnalyticsAreaChart from '~/vue_shared/components/ci_cd_analytics/ci_cd_analytics_area_chart.vue';
import CiCdAnalyticsCharts from '~/projects/pipelines/charts/components/ci_cd_analytics_charts.vue'; import CiCdAnalyticsCharts from '~/vue_shared/components/ci_cd_analytics/ci_cd_analytics_charts.vue';
import { transformedAreaChartData, chartOptions } from '../mock_data'; import { transformedAreaChartData, chartOptions } from '../mock_data';
const DEFAULT_PROPS = { const DEFAULT_PROPS = {
...@@ -26,7 +26,7 @@ const DEFAULT_PROPS = { ...@@ -26,7 +26,7 @@ const DEFAULT_PROPS = {
], ],
}; };
describe('~/projects/pipelines/charts/components/ci_cd_analytics_charts.vue', () => { describe('~/vue_shared/components/ci_cd_analytics/ci_cd_analytics_charts.vue', () => {
let wrapper; let wrapper;
const createWrapper = (props = {}) => const createWrapper = (props = {}) =>
......
...@@ -2,11 +2,11 @@ import { GlColumnChart } from '@gitlab/ui/dist/charts'; ...@@ -2,11 +2,11 @@ import { GlColumnChart } from '@gitlab/ui/dist/charts';
import { createLocalVue, shallowMount } from '@vue/test-utils'; import { createLocalVue, shallowMount } from '@vue/test-utils';
import VueApollo from 'vue-apollo'; import VueApollo from 'vue-apollo';
import createMockApollo from 'helpers/mock_apollo_helper'; import createMockApollo from 'helpers/mock_apollo_helper';
import CiCdAnalyticsCharts from '~/projects/pipelines/charts/components/ci_cd_analytics_charts.vue';
import PipelineCharts from '~/projects/pipelines/charts/components/pipeline_charts.vue'; import PipelineCharts from '~/projects/pipelines/charts/components/pipeline_charts.vue';
import StatisticsList from '~/projects/pipelines/charts/components/statistics_list.vue'; import StatisticsList from '~/projects/pipelines/charts/components/statistics_list.vue';
import getPipelineCountByStatus from '~/projects/pipelines/charts/graphql/queries/get_pipeline_count_by_status.query.graphql'; import getPipelineCountByStatus from '~/projects/pipelines/charts/graphql/queries/get_pipeline_count_by_status.query.graphql';
import getProjectPipelineStatistics from '~/projects/pipelines/charts/graphql/queries/get_project_pipeline_statistics.query.graphql'; import getProjectPipelineStatistics from '~/projects/pipelines/charts/graphql/queries/get_project_pipeline_statistics.query.graphql';
import CiCdAnalyticsCharts from '~/vue_shared/components/ci_cd_analytics/ci_cd_analytics_charts.vue';
import { mockPipelineCount, mockPipelineStatistics } from '../mock_data'; import { mockPipelineCount, mockPipelineStatistics } from '../mock_data';
const projectPath = 'gitlab-org/gitlab'; const projectPath = 'gitlab-org/gitlab';
......
Markdown is supported
0%
or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment