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:
authorGitLab Bot <gitlab-bot@gitlab.com>2023-12-15 18:13:59 +0300
committerGitLab Bot <gitlab-bot@gitlab.com>2023-12-15 18:13:59 +0300
commitf9da8786f9421281e390d921333f8ff4c9941354 (patch)
tree88e44000c2abe0589cf3aee22861eb7a73146127 /spec/frontend/vue_shared/components
parenta19ad7fa983054d09b35c5fe0bdf853acc55a1bc (diff)
Add latest changes from gitlab-org/gitlab@master
Diffstat (limited to 'spec/frontend/vue_shared/components')
-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);
+ });
+ });
+});