gitlab-org--gitlab-foss/spec/frontend/serverless/components/missing_prometheus_spec.js

41 lines
1.1 KiB
JavaScript
Raw Normal View History

import { GlDeprecatedButton } from '@gitlab/ui';
2019-04-06 02:02:39 +00:00
import { shallowMount } from '@vue/test-utils';
import missingPrometheusComponent from '~/serverless/components/missing_prometheus.vue';
2019-04-06 02:02:39 +00:00
const createComponent = missingData =>
shallowMount(missingPrometheusComponent, {
propsData: {
clustersPath: '/clusters',
helpPath: '/help',
missingData,
},
});
2019-04-06 02:02:39 +00:00
describe('missingPrometheusComponent', () => {
let wrapper;
2019-04-06 02:02:39 +00:00
afterEach(() => {
wrapper.destroy();
2019-04-06 02:02:39 +00:00
});
it('should render missing prometheus message', () => {
wrapper = createComponent(false);
const { vm } = wrapper;
2019-04-06 02:02:39 +00:00
expect(vm.$el.querySelector('.state-description').innerHTML.trim()).toContain(
'Function invocation metrics require Prometheus to be installed first.',
);
expect(wrapper.find(GlDeprecatedButton).attributes('variant')).toBe('success');
2019-04-06 02:02:39 +00:00
});
it('should render no prometheus data message', () => {
wrapper = createComponent(true);
const { vm } = wrapper;
2019-04-06 02:02:39 +00:00
expect(vm.$el.querySelector('.state-description').innerHTML.trim()).toContain(
'Invocation metrics loading or not available at this time.',
);
});
});