Skip to content

Commit

Permalink
chore: numberToHangul 테스트 커버리지 보강
Browse files Browse the repository at this point in the history
  • Loading branch information
po4tion committed Nov 28, 2024
1 parent 2e5967c commit 0c86568
Show file tree
Hide file tree
Showing 2 changed files with 12 additions and 5 deletions.
7 changes: 7 additions & 0 deletions src/numberToHangul/numberToHangul.spec.ts
Original file line number Diff line number Diff line change
Expand Up @@ -40,4 +40,11 @@ describe('numberToHangul', () => {
expect(numberToHangul(1_234)).toBe('천이백삼십사');
expect(numberToHangul(9_999)).toBe('구천구백구십구');
});

test('유효하지 않은 숫자에 대한 오류 처리', () => {
expect(() => numberToHangul(-1)).toThrow('유효한 0 이상의 정수를 입력해주세요.');
expect(() => numberToHangul(-12345)).toThrow('유효한 0 이상의 정수를 입력해주세요.');
expect(() => numberToHangul(NaN)).toThrow('유효한 0 이상의 정수를 입력해주세요.');
expect(() => numberToHangul(Infinity)).toThrow('유효한 0 이상의 정수를 입력해주세요.');
});
});
10 changes: 5 additions & 5 deletions src/numberToHangul/numberToHangul.ts
Original file line number Diff line number Diff line change
@@ -1,6 +1,10 @@
import { HANGUL_CARDINAL, HANGUL_DIGITS, HANGUL_NUMBERS } from '@/_internal/constants';

export function numberToHangul(input: number, options?: { spacing?: boolean }): string {
if (!Number.isFinite(input) || Number.isNaN(input) || !Number.isInteger(input) || input < 0) {
throw new Error('유효한 0 이상의 정수를 입력해주세요.');
}

if (input === 0) {
return '영';
}
Expand All @@ -11,6 +15,7 @@ export function numberToHangul(input: number, options?: { spacing?: boolean }):

while (remainingDigits.length > 0) {
const currentPart = remainingDigits.slice(-4);
console.log('currentPart: ', currentPart);

koreanParts.unshift(`${numberToKoreanUpToThousand(Number(currentPart))}${HANGUL_DIGITS[placeIndex]}`);

Expand All @@ -29,10 +34,6 @@ export function numberToHangul(input: number, options?: { spacing?: boolean }):
}

function numberToKoreanUpToThousand(num: number): string {
if (num < 0 || num > 9999) {
throw new Error('0 이상 9999 이하의 숫자만 입력 가능합니다.');
}

const koreanDigits = num
.toString()
.split('')
Expand All @@ -42,5 +43,4 @@ function numberToKoreanUpToThousand(num: number): string {
.join('');

return koreanDigits.replace(//, '천').replace(//, '백').replace(//, '십') || '';

}

0 comments on commit 0c86568

Please sign in to comment.