Welcome to mirror list, hosted at ThFree Co, Russian Federation.

gitlab.com/gitlab-org/gitlab-foss.git - Unnamed repository; edit this file 'description' to name the repository.
summaryrefslogtreecommitdiff
diff options
context:
space:
mode:
Diffstat (limited to 'spec/frontend/vue_shared/components/number_to_human_size/number_to_human_size_spec.js')
-rw-r--r--spec/frontend/vue_shared/components/number_to_human_size/number_to_human_size_spec.js47
1 files changed, 47 insertions, 0 deletions
diff --git a/spec/frontend/vue_shared/components/number_to_human_size/number_to_human_size_spec.js b/spec/frontend/vue_shared/components/number_to_human_size/number_to_human_size_spec.js
new file mode 100644
index 00000000000..6dd22211c96
--- /dev/null
+++ b/spec/frontend/vue_shared/components/number_to_human_size/number_to_human_size_spec.js
@@ -0,0 +1,47 @@
+import { shallowMount } from '@vue/test-utils';
+import NumberToHumanSize from '~/vue_shared/components/number_to_human_size/number_to_human_size.vue';
+import { numberToHumanSize } from '~/lib/utils/number_utils';
+
+describe('NumberToHumanSize', () => {
+ /** @type {import('@vue/test-utils').Wrapper} */
+ let wrapper;
+
+ const createComponent = (props = {}) => {
+ wrapper = shallowMount(NumberToHumanSize, {
+ propsData: {
+ ...props,
+ },
+ });
+ };
+
+ it('formats the value', () => {
+ const value = 1024;
+ createComponent({ value });
+
+ const expectedValue = numberToHumanSize(value, 1);
+ expect(wrapper.text()).toBe(expectedValue);
+ });
+
+ it('handles number of fraction digits', () => {
+ const value = 1024 + 254;
+ const fractionDigits = 2;
+ createComponent({ value, fractionDigits });
+
+ const expectedValue = numberToHumanSize(value, fractionDigits);
+ expect(wrapper.text()).toBe(expectedValue);
+ });
+
+ describe('plain-zero', () => {
+ it('hides label for zero values', () => {
+ createComponent({ value: 0, plainZero: true });
+ expect(wrapper.text()).toBe('0');
+ });
+
+ it('shows text for non-zero values', () => {
+ const value = 163;
+ const expectedValue = numberToHumanSize(value, 1);
+ createComponent({ value, plainZero: true });
+ expect(wrapper.text()).toBe(expectedValue);
+ });
+ });
+});