Commit 769e5236 authored by Jose Ivan Vargas's avatar Jose Ivan Vargas

Merge branch '349959-fix-ci-minutes-quota-chart-ordering' into 'master'

Expose new monthIso8601 GraphQL option to fix CI minutes usage sorting

See merge request gitlab-org/gitlab!78006
parents e96d6b96 43cd0bbd
...@@ -8955,6 +8955,7 @@ Represents the total number of issues and their weights for a particular day. ...@@ -8955,6 +8955,7 @@ Represents the total number of issues and their weights for a particular day.
| ---- | ---- | ----------- | | ---- | ---- | ----------- |
| <a id="ciminutesnamespacemonthlyusageminutes"></a>`minutes` | [`Int`](#int) | Total number of minutes used by all projects in the namespace. | | <a id="ciminutesnamespacemonthlyusageminutes"></a>`minutes` | [`Int`](#int) | Total number of minutes used by all projects in the namespace. |
| <a id="ciminutesnamespacemonthlyusagemonth"></a>`month` | [`String`](#string) | Month related to the usage data. | | <a id="ciminutesnamespacemonthlyusagemonth"></a>`month` | [`String`](#string) | Month related to the usage data. |
| <a id="ciminutesnamespacemonthlyusagemonthiso8601"></a>`monthIso8601` | [`ISO8601Date`](#iso8601date) | Month related to the usage data in ISO 8601 date format. |
| <a id="ciminutesnamespacemonthlyusageprojects"></a>`projects` | [`CiMinutesProjectMonthlyUsageConnection`](#ciminutesprojectmonthlyusageconnection) | CI minutes usage data for projects in the namespace. (see [Connections](#connections)) | | <a id="ciminutesnamespacemonthlyusageprojects"></a>`projects` | [`CiMinutesProjectMonthlyUsageConnection`](#ciminutesprojectmonthlyusageconnection) | CI minutes usage data for projects in the namespace. (see [Connections](#connections)) |
| <a id="ciminutesnamespacemonthlyusagesharedrunnersduration"></a>`sharedRunnersDuration` | [`Int`](#int) | Total numbers of minutes used by the shared runners in the namespace. | | <a id="ciminutesnamespacemonthlyusagesharedrunnersduration"></a>`sharedRunnersDuration` | [`Int`](#int) | Total numbers of minutes used by the shared runners in the namespace. |
<script> <script>
import { MONTHS } from '../constants'; import { formatDate } from '~/lib/utils/datetime_utility';
import getCiMinutesUsage from '../graphql/queries/ci_minutes.graphql'; import getCiMinutesUsage from '../graphql/queries/ci_minutes.graphql';
import MinutesUsageMonthChart from './minutes_usage_month_chart.vue'; import MinutesUsageMonthChart from './minutes_usage_month_chart.vue';
import MinutesUsageProjectChart from './minutes_usage_project_chart.vue'; import MinutesUsageProjectChart from './minutes_usage_project_chart.vue';
...@@ -24,21 +24,12 @@ export default { ...@@ -24,21 +24,12 @@ export default {
}, },
computed: { computed: {
minutesUsageDataByMonth() { minutesUsageDataByMonth() {
function monthIndex([name]) {
return Object.keys(MONTHS).indexOf(name.toLowerCase());
}
return this.ciMinutesUsage return this.ciMinutesUsage
.map((cur) => [cur.month, cur.minutes]) .slice()
.sort((a, b) => { .sort((a, b) => {
if (monthIndex(a) > monthIndex(b)) { return new Date(a.monthIso8601) - new Date(b.monthIso8601);
return 1; })
} .map((cur) => [formatDate(cur.monthIso8601, 'mmm yyyy'), cur.minutes]);
if (monthIndex(a) < monthIndex(b)) {
return -1;
}
return 0;
});
}, },
}, },
}; };
......
...@@ -2,6 +2,7 @@ query getCiMinutesUsage { ...@@ -2,6 +2,7 @@ query getCiMinutesUsage {
ciMinutesUsage { ciMinutesUsage {
nodes { nodes {
month month
monthIso8601
minutes minutes
projects { projects {
nodes { nodes {
......
...@@ -12,6 +12,9 @@ module Types ...@@ -12,6 +12,9 @@ module Types
field :month, ::GraphQL::Types::String, null: true, field :month, ::GraphQL::Types::String, null: true,
description: 'Month related to the usage data.' description: 'Month related to the usage data.'
field :month_iso8601, ::GraphQL::Types::ISO8601Date, method: :date, null: true,
description: 'Month related to the usage data in ISO 8601 date format.'
field :minutes, ::GraphQL::Types::Int, null: true, field :minutes, ::GraphQL::Types::Int, null: true,
method: :amount_used, method: :amount_used,
description: 'Total number of minutes used by all projects in the namespace.' description: 'Total number of minutes used by all projects in the namespace.'
......
...@@ -4,6 +4,7 @@ export const ciMinutesUsageMockData = { ...@@ -4,6 +4,7 @@ export const ciMinutesUsageMockData = {
nodes: [ nodes: [
{ {
month: 'June', month: 'June',
monthIso8601: '2021-06-01',
minutes: 5, minutes: 5,
projects: { projects: {
nodes: [ nodes: [
......
...@@ -4,6 +4,6 @@ require 'spec_helper' ...@@ -4,6 +4,6 @@ require 'spec_helper'
RSpec.describe GitlabSchema.types['CiMinutesNamespaceMonthlyUsage'] do RSpec.describe GitlabSchema.types['CiMinutesNamespaceMonthlyUsage'] do
it do it do
expect(described_class).to have_graphql_fields(:minutes, :month, :projects, :shared_runners_duration) expect(described_class).to have_graphql_fields(:minutes, :month, :month_iso8601, :projects, :shared_runners_duration)
end end
end end
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