Commit a0328f9e authored by GitLab Bot's avatar GitLab Bot

Automatic merge of gitlab-org/gitlab master

parents 8fb4febb 1beb7ba9
...@@ -16,7 +16,3 @@ GitLab community members and their privileges/responsibilities. ...@@ -16,7 +16,3 @@ GitLab community members and their privileges/responsibilities.
| Contributor | Can make contributions to all GitLab public projects | Have a GitLab.com account | | Contributor | Can make contributions to all GitLab public projects | Have a GitLab.com account |
[List of current reviewers/maintainers](https://about.gitlab.com/handbook/engineering/projects/#gitlab-ce). [List of current reviewers/maintainers](https://about.gitlab.com/handbook/engineering/projects/#gitlab-ce).
---
[Return to Contributing documentation](index.md)
...@@ -36,7 +36,3 @@ In order to complete a product discovery issue in a release, you must complete t ...@@ -36,7 +36,3 @@ In order to complete a product discovery issue in a release, you must complete t
1. Modify the issue description in the product discovery issue to contain the final design. If it makes sense, the original information indicating the need for the design can be moved to a lower "Original Information" section. 1. Modify the issue description in the product discovery issue to contain the final design. If it makes sense, the original information indicating the need for the design can be moved to a lower "Original Information" section.
1. Copy the design to the description of the delivery issue for which the product discovery issue was created. Do not simply refer to the product discovery issue as a separate source of truth. 1. Copy the design to the description of the delivery issue for which the product discovery issue was created. Do not simply refer to the product discovery issue as a separate source of truth.
1. In some cases, a product discovery issue also identifies future enhancements that will not go into the issue that originated the product discovery issue. For these items, create new issues containing the designs to ensure they are not lost. Put the issues in the backlog if they are agreed upon as good ideas. Otherwise leave them for triage. 1. In some cases, a product discovery issue also identifies future enhancements that will not go into the issue that originated the product discovery issue. For these items, create new issues containing the designs to ensure they are not lost. Put the issues in the backlog if they are agreed upon as good ideas. Otherwise leave them for triage.
---
[Return to Contributing documentation](index.md)
...@@ -384,7 +384,7 @@ below will make it easy to manage this, without unnecessary overhead. ...@@ -384,7 +384,7 @@ below will make it easy to manage this, without unnecessary overhead.
1. If you don't agree with a set weight, discuss with other developers until 1. If you don't agree with a set weight, discuss with other developers until
consensus is reached about the weight consensus is reached about the weight
1. Issue weights are an abstract measurement of complexity of the issue. Do not 1. Issue weights are an abstract measurement of complexity of the issue. Do not
relate issue weight directly to time. This is called [anchoring](https://en.wikipedia.org/wiki/Anchoring) relate issue weight directly to time. This is called [anchoring](https://en.wikipedia.org/wiki/Anchoring_(cognitive_bias))
and something you want to avoid. and something you want to avoid.
1. Something that has a weight of 1 (or no weight) is really small and simple. 1. Something that has a weight of 1 (or no weight) is really small and simple.
Something that is 9 is rewriting a large fundamental part of GitLab, Something that is 9 is rewriting a large fundamental part of GitLab,
...@@ -476,7 +476,3 @@ should be of the same quality as those created ...@@ -476,7 +476,3 @@ should be of the same quality as those created
[in the usual manner](#technical-and-ux-debt) - in particular, the issue title [in the usual manner](#technical-and-ux-debt) - in particular, the issue title
**must not** begin with `Follow-up`! The creating maintainer should also expect **must not** begin with `Follow-up`! The creating maintainer should also expect
to be involved in some capacity when work begins on the follow-up issue. to be involved in some capacity when work begins on the follow-up issue.
---
[Return to Contributing documentation](index.md)
...@@ -242,7 +242,3 @@ See the dedicated [Python Development Guidelines](../python_guide/index.md). ...@@ -242,7 +242,3 @@ See the dedicated [Python Development Guidelines](../python_guide/index.md).
## Misc ## Misc
Code should be written in [US English](https://en.wikipedia.org/wiki/American_English). Code should be written in [US English](https://en.wikipedia.org/wiki/American_English).
---
[Return to Contributing documentation](index.md)
...@@ -123,7 +123,7 @@ may not be able to check out the wiki locally afterward. ...@@ -123,7 +123,7 @@ may not be able to check out the wiki locally afterward.
## Edit a wiki page ## Edit a wiki page
You need the [Developer role](../../permissions.md) or higher to edit a wiki page: You need at least the [Developer role](../../permissions.md) to edit a wiki page:
1. Go to your project or group and select **Wiki**. 1. Go to your project or group and select **Wiki**.
1. Go to the page you want to edit. 1. Go to the page you want to edit.
...@@ -138,7 +138,7 @@ For an example, read [Table of contents](../../markdown.md#table-of-contents). ...@@ -138,7 +138,7 @@ For an example, read [Table of contents](../../markdown.md#table-of-contents).
## Delete a wiki page ## Delete a wiki page
You need the [Maintainer role](../../permissions.md) or higher to delete a wiki page: You need at least the [Maintainer role](../../permissions.md) to delete a wiki page:
1. Go to your project or group and select **Wiki**. 1. Go to your project or group and select **Wiki**.
1. Go to the page you want to delete. 1. Go to the page you want to delete.
...@@ -148,7 +148,7 @@ You need the [Maintainer role](../../permissions.md) or higher to delete a wiki ...@@ -148,7 +148,7 @@ You need the [Maintainer role](../../permissions.md) or higher to delete a wiki
## Move a wiki page ## Move a wiki page
You need the [Developer role](../../permissions.md) or higher to move a wiki page: You need at least the [Developer role](../../permissions.md) to move a wiki page:
1. Go to your project or group and select **Wiki**. 1. Go to your project or group and select **Wiki**.
1. Go to the page you want to move. 1. Go to the page you want to move.
...@@ -203,7 +203,7 @@ Commits to wikis are not counted in [repository analytics](../../analytics/repos ...@@ -203,7 +203,7 @@ Commits to wikis are not counted in [repository analytics](../../analytics/repos
> [Introduced](https://gitlab.com/gitlab-org/gitlab/-/issues/23109) in GitLab 13.8, the sidebar can be customized by selecting the **Edit sidebar** button. > [Introduced](https://gitlab.com/gitlab-org/gitlab/-/issues/23109) in GitLab 13.8, the sidebar can be customized by selecting the **Edit sidebar** button.
You need Developer [permissions](../../permissions.md) or higher to customize the wiki You need at least the [Developer role](../../permissions.md) to customize the wiki
navigation sidebar. This process creates a wiki page named `_sidebar` which fully navigation sidebar. This process creates a wiki page named `_sidebar` which fully
replaces the default sidebar navigation: replaces the default sidebar navigation:
......
<script> <script>
import updateState from 'ee/subscriptions/graphql/mutations/update_state.mutation.graphql'; import updateState from 'ee/subscriptions/graphql/mutations/update_state.mutation.graphql';
import BillingAddress from 'ee/vue_shared/purchase_flow/components/checkout/billing_address.vue';
import ConfirmOrder from 'ee/vue_shared/purchase_flow/components/checkout/confirm_order.vue';
import PaymentMethod from 'ee/vue_shared/purchase_flow/components/checkout/payment_method.vue';
import { GENERAL_ERROR_MESSAGE } from 'ee/vue_shared/purchase_flow/constants'; import { GENERAL_ERROR_MESSAGE } from 'ee/vue_shared/purchase_flow/constants';
import createFlash from '~/flash'; import createFlash from '~/flash';
import { s__ } from '~/locale'; import { s__ } from '~/locale';
import AddonPurchaseDetails from './checkout/addon_purchase_details.vue'; import AddonPurchaseDetails from './checkout/addon_purchase_details.vue';
import BillingAddress from './checkout/billing_address.vue';
import ConfirmOrder from './checkout/confirm_order.vue';
import PaymentMethod from './checkout/payment_method.vue';
export default { export default {
components: { AddonPurchaseDetails, BillingAddress, PaymentMethod, ConfirmOrder }, components: { AddonPurchaseDetails, BillingAddress, PaymentMethod, ConfirmOrder },
......
<script> <script>
import { GlAlert, GlFormInput, GlSprintf } from '@gitlab/ui'; import { GlAlert, GlFormInput, GlSprintf } from '@gitlab/ui';
import { CI_MINUTES_PER_PACK } from 'ee/subscriptions/buy_minutes/constants'; import { CI_MINUTES_PER_PACK } from 'ee/subscriptions/buy_addons_shared/constants';
import { STEPS } from 'ee/subscriptions/constants'; import { STEPS } from 'ee/subscriptions/constants';
import updateState from 'ee/subscriptions/graphql/mutations/update_state.mutation.graphql'; import updateState from 'ee/subscriptions/graphql/mutations/update_state.mutation.graphql';
import stateQuery from 'ee/subscriptions/graphql/queries/state.query.graphql'; import stateQuery from 'ee/subscriptions/graphql/queries/state.query.graphql';
......
/* eslint-disable @gitlab/require-i18n-strings */ /* eslint-disable @gitlab/require-i18n-strings */
export const planTags = { export const planTags = {
CI_1000_MINUTES_PLAN: 'CI_1000_MINUTES_PLAN', CI_1000_MINUTES_PLAN: 'CI_1000_MINUTES_PLAN',
STORAGE_PLAN: 'STORAGE_PLAN',
}; };
/* eslint-enable @gitlab/require-i18n-strings */ /* eslint-enable @gitlab/require-i18n-strings */
export const CUSTOMER_CLIENT = 'customerClient'; export const CUSTOMER_CLIENT = 'customerClient';
......
...@@ -4,10 +4,10 @@ import { GlEmptyState } from '@gitlab/ui'; ...@@ -4,10 +4,10 @@ import { GlEmptyState } from '@gitlab/ui';
import * as Sentry from '@sentry/browser'; import * as Sentry from '@sentry/browser';
import StepOrderApp from 'ee/vue_shared/purchase_flow/components/step_order_app.vue'; import StepOrderApp from 'ee/vue_shared/purchase_flow/components/step_order_app.vue';
import { ERROR_FETCHING_DATA_HEADER, ERROR_FETCHING_DATA_DESCRIPTION } from '~/ensure_data'; import { ERROR_FETCHING_DATA_HEADER, ERROR_FETCHING_DATA_DESCRIPTION } from '~/ensure_data';
import Checkout from '../../buy_addons_shared/components/checkout.vue';
import OrderSummary from '../../buy_addons_shared/components/order_summary.vue';
import { planTags, CUSTOMER_CLIENT } from '../../buy_addons_shared/constants';
import plansQuery from '../../graphql/queries/plans.customer.query.graphql'; import plansQuery from '../../graphql/queries/plans.customer.query.graphql';
import { planTags, CUSTOMER_CLIENT } from '../constants';
import Checkout from './checkout.vue';
import OrderSummary from './order_summary.vue';
export default { export default {
name: 'BuyCIMinutesApp', name: 'BuyCIMinutesApp',
......
import Vue from 'vue'; import Vue from 'vue';
import ensureData from '~/ensure_data'; import ensureData from '~/ensure_data';
import apolloProvider from '../buy_addons_shared/graphql';
import { writeInitialDataToApolloCache } from '../buy_addons_shared/utils';
import App from './components/app.vue'; import App from './components/app.vue';
import apolloProvider from './graphql';
import { writeInitialDataToApolloCache } from './utils';
export default (el) => { export default (el) => {
if (!el) { if (!el) {
......
<script> <script>
import emptySvg from '@gitlab/svgs/dist/illustrations/security-dashboard-empty-state.svg';
import { GlEmptyState } from '@gitlab/ui';
import * as Sentry from '@sentry/browser';
import StepOrderApp from 'ee/vue_shared/purchase_flow/components/step_order_app.vue'; import StepOrderApp from 'ee/vue_shared/purchase_flow/components/step_order_app.vue';
import { ERROR_FETCHING_DATA_HEADER, ERROR_FETCHING_DATA_DESCRIPTION } from '~/ensure_data';
import Checkout from '../../buy_addons_shared/components/checkout.vue';
import OrderSummary from '../../buy_addons_shared/components/order_summary.vue';
import { planTags, CUSTOMER_CLIENT } from '../../buy_addons_shared/constants';
import plansQuery from '../../graphql/queries/plans.customer.query.graphql';
export default { export default {
name: 'BuyStorageApp',
components: { components: {
Checkout,
GlEmptyState,
OrderSummary,
StepOrderApp, StepOrderApp,
}, },
i18n: {
ERROR_FETCHING_DATA_HEADER,
ERROR_FETCHING_DATA_DESCRIPTION,
},
emptySvg,
data() {
return {
hasError: false,
};
},
apollo: {
plans: {
client: CUSTOMER_CLIENT,
query: plansQuery,
variables: {
tags: [planTags.STORAGE_PLAN],
},
update(data) {
if (!data?.plans?.length) {
this.hasError = true;
return null;
}
return data.plans;
},
error(error) {
this.hasError = true;
Sentry.captureException(error);
},
},
},
}; };
</script> </script>
<template> <template>
<step-order-app> <gl-empty-state
<template #checkout></template> v-if="hasError"
<template #order-summary></template> :title="$options.i18n.ERROR_FETCHING_DATA_HEADER"
:description="$options.i18n.ERROR_FETCHING_DATA_DESCRIPTION"
:svg-path="`data:image/svg+xml;utf8,${encodeURIComponent($options.emptySvg)}`"
/>
<step-order-app v-else-if="!$apollo.loading">
<template #checkout>
<checkout :plan="plans[0]" />
</template>
<template #order-summary>
<order-summary :plan="plans[0]" />
</template>
</step-order-app> </step-order-app>
</template> </template>
import Vue from 'vue'; import Vue from 'vue';
import ensureData from '~/ensure_data';
import apolloProvider from '../buy_addons_shared/graphql';
import { writeInitialDataToApolloCache } from '../buy_addons_shared/utils';
import App from './components/app.vue'; import App from './components/app.vue';
export default (el) => { export default (el) => {
if (!el) {
return null;
}
const extendedApp = ensureData(App, {
parseData: writeInitialDataToApolloCache.bind(null, apolloProvider),
data: el.dataset,
shouldLog: true,
});
return new Vue({ return new Vue({
el, el,
components: { apolloProvider,
App,
},
render(createElement) { render(createElement) {
return createElement(App); return createElement(extendedApp);
}, },
}); });
}; };
...@@ -4,6 +4,7 @@ import VueApollo from 'vue-apollo'; ...@@ -4,6 +4,7 @@ import VueApollo from 'vue-apollo';
import App from 'ee/subscriptions/buy_minutes/components/app.vue'; import App from 'ee/subscriptions/buy_minutes/components/app.vue';
import StepOrderApp from 'ee/vue_shared/purchase_flow/components/step_order_app.vue'; import StepOrderApp from 'ee/vue_shared/purchase_flow/components/step_order_app.vue';
import waitForPromises from 'helpers/wait_for_promises'; import waitForPromises from 'helpers/wait_for_promises';
import { planTags } from '../../../../../app/assets/javascripts/subscriptions/buy_addons_shared/constants';
import { createMockApolloProvider } from '../spec_helper'; import { createMockApolloProvider } from '../spec_helper';
const localVue = createLocalVue(); const localVue = createLocalVue();
...@@ -12,11 +13,10 @@ localVue.use(VueApollo); ...@@ -12,11 +13,10 @@ localVue.use(VueApollo);
describe('App', () => { describe('App', () => {
let wrapper; let wrapper;
function createComponent(options = {}) { function createComponent(apolloProvider) {
const { apolloProvider, propsData } = options;
return shallowMount(App, { return shallowMount(App, {
localVue, localVue,
propsData, propsData: { plan: planTags.CI_1000_MINUTES_PLAN },
apolloProvider, apolloProvider,
}); });
} }
...@@ -28,7 +28,7 @@ describe('App', () => { ...@@ -28,7 +28,7 @@ describe('App', () => {
describe('when data is received', () => { describe('when data is received', () => {
it('should display the StepOrderApp', async () => { it('should display the StepOrderApp', async () => {
const mockApollo = createMockApolloProvider(); const mockApollo = createMockApolloProvider();
wrapper = createComponent({ apolloProvider: mockApollo }); wrapper = createComponent(mockApollo);
await waitForPromises(); await waitForPromises();
expect(wrapper.findComponent(StepOrderApp).exists()).toBe(true); expect(wrapper.findComponent(StepOrderApp).exists()).toBe(true);
...@@ -41,7 +41,7 @@ describe('App', () => { ...@@ -41,7 +41,7 @@ describe('App', () => {
const mockApollo = createMockApolloProvider({ const mockApollo = createMockApolloProvider({
plansQueryMock: jest.fn().mockResolvedValue({ data: null }), plansQueryMock: jest.fn().mockResolvedValue({ data: null }),
}); });
wrapper = createComponent({ apolloProvider: mockApollo }); wrapper = createComponent(mockApollo);
await waitForPromises(); await waitForPromises();
expect(wrapper.findComponent(StepOrderApp).exists()).toBe(false); expect(wrapper.findComponent(StepOrderApp).exists()).toBe(false);
...@@ -52,7 +52,7 @@ describe('App', () => { ...@@ -52,7 +52,7 @@ describe('App', () => {
const mockApollo = createMockApolloProvider({ const mockApollo = createMockApolloProvider({
plansQueryMock: jest.fn().mockResolvedValue({ data: { plans: null } }), plansQueryMock: jest.fn().mockResolvedValue({ data: { plans: null } }),
}); });
wrapper = createComponent({ apolloProvider: mockApollo }); wrapper = createComponent(mockApollo);
await waitForPromises(); await waitForPromises();
expect(wrapper.findComponent(StepOrderApp).exists()).toBe(false); expect(wrapper.findComponent(StepOrderApp).exists()).toBe(false);
...@@ -63,7 +63,7 @@ describe('App', () => { ...@@ -63,7 +63,7 @@ describe('App', () => {
const mockApollo = createMockApolloProvider({ const mockApollo = createMockApolloProvider({
plansQueryMock: jest.fn().mockResolvedValue({ data: { plans: {} } }), plansQueryMock: jest.fn().mockResolvedValue({ data: { plans: {} } }),
}); });
wrapper = createComponent({ apolloProvider: mockApollo }); wrapper = createComponent(mockApollo);
await waitForPromises(); await waitForPromises();
expect(wrapper.findComponent(StepOrderApp).exists()).toBe(false); expect(wrapper.findComponent(StepOrderApp).exists()).toBe(false);
...@@ -76,7 +76,7 @@ describe('App', () => { ...@@ -76,7 +76,7 @@ describe('App', () => {
const mockApollo = createMockApolloProvider({ const mockApollo = createMockApolloProvider({
plansQueryMock: jest.fn().mockRejectedValue(new Error('An error happened!')), plansQueryMock: jest.fn().mockRejectedValue(new Error('An error happened!')),
}); });
wrapper = createComponent({ apolloProvider: mockApollo }); wrapper = createComponent(mockApollo);
await waitForPromises(); await waitForPromises();
expect(wrapper.findComponent(StepOrderApp).exists()).toBe(false); expect(wrapper.findComponent(StepOrderApp).exists()).toBe(false);
......
...@@ -2,8 +2,8 @@ import { GlAlert } from '@gitlab/ui'; ...@@ -2,8 +2,8 @@ import { GlAlert } from '@gitlab/ui';
import { createLocalVue } from '@vue/test-utils'; import { createLocalVue } from '@vue/test-utils';
import { merge } from 'lodash'; import { merge } from 'lodash';
import VueApollo from 'vue-apollo'; import VueApollo from 'vue-apollo';
import AddonPurchaseDetails from 'ee/subscriptions/buy_minutes/components/checkout/addon_purchase_details.vue'; import AddonPurchaseDetails from 'ee/subscriptions/buy_addons_shared/components/checkout/addon_purchase_details.vue';
import subscriptionsResolvers from 'ee/subscriptions/buy_minutes/graphql/resolvers'; import subscriptionsResolvers from 'ee/subscriptions/buy_addons_shared/graphql/resolvers';
import { STEPS } from 'ee/subscriptions/constants'; import { STEPS } from 'ee/subscriptions/constants';
import stateQuery from 'ee/subscriptions/graphql/queries/state.query.graphql'; import stateQuery from 'ee/subscriptions/graphql/queries/state.query.graphql';
import Step from 'ee/vue_shared/purchase_flow/components/step.vue'; import Step from 'ee/vue_shared/purchase_flow/components/step.vue';
......
import { mount, createLocalVue } from '@vue/test-utils'; import { mount, createLocalVue } from '@vue/test-utils';
import { merge } from 'lodash'; import { merge } from 'lodash';
import VueApollo from 'vue-apollo'; import VueApollo from 'vue-apollo';
import BillingAddress from 'ee/subscriptions/buy_minutes/components/checkout/billing_address.vue'; import { resolvers } from 'ee/subscriptions/buy_addons_shared/graphql/resolvers';
import { resolvers } from 'ee/subscriptions/buy_minutes/graphql/resolvers';
import { STEPS } from 'ee/subscriptions/constants'; import { STEPS } from 'ee/subscriptions/constants';
import stateQuery from 'ee/subscriptions/graphql/queries/state.query.graphql'; import stateQuery from 'ee/subscriptions/graphql/queries/state.query.graphql';
import BillingAddress from 'ee/vue_shared/purchase_flow/components/checkout/billing_address.vue';
import Step from 'ee/vue_shared/purchase_flow/components/step.vue'; import Step from 'ee/vue_shared/purchase_flow/components/step.vue';
import { stateData as initialStateData } from 'ee_jest/subscriptions/buy_minutes/mock_data'; import { stateData as initialStateData } from 'ee_jest/subscriptions/buy_minutes/mock_data';
import { createMockApolloProvider } from 'ee_jest/vue_shared/purchase_flow/spec_helper'; import { createMockApolloProvider } from 'ee_jest/vue_shared/purchase_flow/spec_helper';
......
...@@ -2,9 +2,9 @@ import { GlButton, GlLoadingIcon } from '@gitlab/ui'; ...@@ -2,9 +2,9 @@ import { GlButton, GlLoadingIcon } from '@gitlab/ui';
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 Api from 'ee/api'; import Api from 'ee/api';
import ConfirmOrder from 'ee/subscriptions/buy_minutes/components/checkout/confirm_order.vue';
import { STEPS } from 'ee/subscriptions/constants'; import { STEPS } from 'ee/subscriptions/constants';
import stateQuery from 'ee/subscriptions/graphql/queries/state.query.graphql'; import stateQuery from 'ee/subscriptions/graphql/queries/state.query.graphql';
import ConfirmOrder from 'ee/vue_shared/purchase_flow/components/checkout/confirm_order.vue';
import { GENERAL_ERROR_MESSAGE } from 'ee/vue_shared/purchase_flow/constants'; import { GENERAL_ERROR_MESSAGE } from 'ee/vue_shared/purchase_flow/constants';
import { stateData as initialStateData } from 'ee_jest/subscriptions/buy_minutes/mock_data'; import { stateData as initialStateData } from 'ee_jest/subscriptions/buy_minutes/mock_data';
import { createMockApolloProvider } from 'ee_jest/vue_shared/purchase_flow/spec_helper'; import { createMockApolloProvider } from 'ee_jest/vue_shared/purchase_flow/spec_helper';
......
import { mount, createLocalVue } from '@vue/test-utils'; import { mount, createLocalVue } from '@vue/test-utils';
import { merge } from 'lodash'; import { merge } from 'lodash';
import VueApollo from 'vue-apollo'; import VueApollo from 'vue-apollo';
import PaymentMethod from 'ee/subscriptions/buy_minutes/components/checkout/payment_method.vue'; import { resolvers } from 'ee/subscriptions/buy_addons_shared/graphql/resolvers';
import { resolvers } from 'ee/subscriptions/buy_minutes/graphql/resolvers';
import { STEPS } from 'ee/subscriptions/constants'; import { STEPS } from 'ee/subscriptions/constants';
import stateQuery from 'ee/subscriptions/graphql/queries/state.query.graphql'; import stateQuery from 'ee/subscriptions/graphql/queries/state.query.graphql';
import PaymentMethod from 'ee/vue_shared/purchase_flow/components/checkout/payment_method.vue';
import Step from 'ee/vue_shared/purchase_flow/components/step.vue'; import Step from 'ee/vue_shared/purchase_flow/components/step.vue';
import { stateData as initialStateData } from 'ee_jest/subscriptions/buy_minutes/mock_data'; import { stateData as initialStateData } from 'ee_jest/subscriptions/buy_minutes/mock_data';
import { createMockApolloProvider } from 'ee_jest/vue_shared/purchase_flow/spec_helper'; import { createMockApolloProvider } from 'ee_jest/vue_shared/purchase_flow/spec_helper';
......
...@@ -3,10 +3,10 @@ import { shallowMount, createLocalVue } from '@vue/test-utils'; ...@@ -3,10 +3,10 @@ import { shallowMount, createLocalVue } from '@vue/test-utils';
import AxiosMockAdapter from 'axios-mock-adapter'; import AxiosMockAdapter from 'axios-mock-adapter';
import { merge } from 'lodash'; import { merge } from 'lodash';
import VueApollo from 'vue-apollo'; import VueApollo from 'vue-apollo';
import Zuora from 'ee/subscriptions/buy_minutes/components/checkout/zuora.vue'; import { resolvers } from 'ee/subscriptions/buy_addons_shared/graphql/resolvers';
import { resolvers } from 'ee/subscriptions/buy_minutes/graphql/resolvers';
import { STEPS } from 'ee/subscriptions/constants'; import { STEPS } from 'ee/subscriptions/constants';
import stateQuery from 'ee/subscriptions/graphql/queries/state.query.graphql'; import stateQuery from 'ee/subscriptions/graphql/queries/state.query.graphql';
import Zuora from 'ee/vue_shared/purchase_flow/components/checkout/zuora.vue';
import { stateData as initialStateData } from 'ee_jest/subscriptions/buy_minutes/mock_data'; import { stateData as initialStateData } from 'ee_jest/subscriptions/buy_minutes/mock_data';
import { createMockApolloProvider } from 'ee_jest/vue_shared/purchase_flow/spec_helper'; import { createMockApolloProvider } from 'ee_jest/vue_shared/purchase_flow/spec_helper';
import axios from '~/lib/utils/axios_utils'; import axios from '~/lib/utils/axios_utils';
......
import { GlSprintf } from '@gitlab/ui'; import { GlSprintf } from '@gitlab/ui';
import SummaryDetails from 'ee/subscriptions/buy_minutes/components/order_summary/summary_details.vue'; import SummaryDetails from 'ee/subscriptions/buy_addons_shared/components/order_summary/summary_details.vue';
import { shallowMountExtended } from 'helpers/vue_test_utils_helper'; import { shallowMountExtended } from 'helpers/vue_test_utils_helper';
describe('SummaryDetails', () => { describe('SummaryDetails', () => {
......
import { shallowMount, createLocalVue } from '@vue/test-utils'; import { shallowMount, createLocalVue } from '@vue/test-utils';
import { merge } from 'lodash'; import { merge } from 'lodash';
import VueApollo from 'vue-apollo'; import VueApollo from 'vue-apollo';
import OrderSummary from 'ee/subscriptions/buy_minutes/components/order_summary.vue'; import OrderSummary from 'ee/subscriptions/buy_addons_shared/components/order_summary.vue';
import subscriptionsResolvers from 'ee/subscriptions/buy_minutes/graphql/resolvers'; import subscriptionsResolvers from 'ee/subscriptions/buy_addons_shared/graphql/resolvers';
import stateQuery from 'ee/subscriptions/graphql/queries/state.query.graphql'; import stateQuery from 'ee/subscriptions/graphql/queries/state.query.graphql';
import purchaseFlowResolvers from 'ee/vue_shared/purchase_flow/graphql/resolvers'; import purchaseFlowResolvers from 'ee/vue_shared/purchase_flow/graphql/resolvers';
import { import {
......
import Api from 'ee/api'; import Api from 'ee/api';
import * as SubscriptionsApi from 'ee/api/subscriptions_api'; import * as SubscriptionsApi from 'ee/api/subscriptions_api';
import { resolvers } from 'ee/subscriptions/buy_minutes/graphql/resolvers'; import { resolvers } from 'ee/subscriptions/buy_addons_shared/graphql/resolvers';
import { ERROR_FETCHING_COUNTRIES, ERROR_FETCHING_STATES } from 'ee/subscriptions/constants'; import { ERROR_FETCHING_COUNTRIES, ERROR_FETCHING_STATES } from 'ee/subscriptions/constants';
import createFlash from '~/flash'; import createFlash from '~/flash';
...@@ -49,7 +49,7 @@ const countries = [ ...@@ -49,7 +49,7 @@ const countries = [
const states = { California: 'CA' }; const states = { California: 'CA' };
describe('~/subscriptions/buy_minutes/graphql/resolvers', () => { describe('~/subscriptions/buy_addons_shared/graphql/resolvers', () => {
describe('Query', () => { describe('Query', () => {
describe('countries', () => { describe('countries', () => {
describe('on success', () => { describe('on success', () => {
......
import apolloProvider from 'ee/subscriptions/buy_minutes/graphql'; import apolloProvider from 'ee/subscriptions/buy_addons_shared/graphql';
import { writeInitialDataToApolloCache } from 'ee/subscriptions/buy_minutes/utils'; import { writeInitialDataToApolloCache } from 'ee/subscriptions/buy_addons_shared/utils';
import stateQuery from 'ee/subscriptions/graphql/queries/state.query.graphql'; import stateQuery from 'ee/subscriptions/graphql/queries/state.query.graphql';
import { mockNamespaces, mockParsedNamespaces } from './mock_data'; import { mockNamespaces, mockParsedNamespaces } from './mock_data';
......
...@@ -21,6 +21,12 @@ RSpec.describe ProjectCiCdSetting do ...@@ -21,6 +21,12 @@ RSpec.describe ProjectCiCdSetting do
end end
end end
describe '#job_token_scope_enabled' do
it 'is true by default' do
expect(described_class.new.job_token_scope_enabled).to be_truthy
end
end
describe '#default_git_depth' do describe '#default_git_depth' do
let(:default_value) { described_class::DEFAULT_GIT_DEPTH } let(:default_value) { described_class::DEFAULT_GIT_DEPTH }
......
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