Skip to content

๐ŸคConvention

์ •์€์ด edited this page Jan 27, 2022 · 2 revisions

๐Ÿ“‹JIRA Convention

์ž‘์—…์œ ํ˜• Convention
  • Epic
    ํ•ด๋‹น ์ด์Šˆ์„ ํฌ๊ด„ํ•˜๋Š” ํฐ ๋‹จ์œ„์˜ ์—…๋ฌด
  • Story
    Epic์„ ์ˆ˜ํ–‰ํ•˜๊ธฐ ์œ„ํ•œ main ์—…๋ฌด
  • Sub-task
    Story๋ฅผ ์ˆ˜ํ–‰ํ•˜๊ธฐ ์œ„ํ•œ ๋ถ€์ž‘์—…
  • Task
    Epic์„ ์ˆ˜ํ–‰ํ•˜๊ธฐ ์œ„ํ•œ sub ์—…๋ฌด(๋ฌธ์„œ์ž‘์—…, ์กฐ์‚ฌ, ํ•™์Šต ๋“ฑ)

๐ŸฆŠ Git Convention

Git Flow - ๊ธฐ์กด์˜ git flow ๋ฐฉ์‹์„ ์œ ์ง€

Main branch

  • master ๋ฐฐํฌ ๊ฐ€๋Šฅํ•œ ์ƒํƒœ๋งŒ์„ ๊ด€๋ฆฌ ์•ˆ์ •๋œ ์ƒํƒœ
  • develop ํ†ตํ•ฉ ๋ธŒ๋žœ์น˜์˜ ์—ญํ• , ํ‰์†Œ develop ๋ธŒ๋žœ์น˜๋ฅผ ๊ธฐ๋ฐ˜์œผ๋กœ ๊ฐœ๋ฐœ ์ง„ํ–‰

Feature branch

  • ์ƒˆ๋กœ์šด ๊ธฐ๋Šฅ ๊ฐœ๋ฐœ ๋ฐ ๋ฒ„๊ทธ ์ˆ˜์ •์ด ํ•„์š”ํ•  ๋•Œ, develop ๋ธŒ๋žœ์น˜๋กœ๋ถ€ํ„ฐ ๋ถ„๊ธฐ
  • ๊ฐœ๋ฐœ์ด ์™„๋ฃŒ๋˜๋ฉด develop ๋ธŒ๋žœ์น˜๋กœ ๋ณ‘ํ•ฉํ•˜์—ฌ ๋‹ค๋ฅธ ์‚ฌ๋žŒ๋“ค๊ณผ ๊ณต์œ 

Release branch

  • ๋ฒ„๊ทธ๋ฅผ ์ˆ˜์ •ํ•˜๊ฑฐ๋‚˜ ์ƒˆ๋กœ์šด ๊ธฐ๋Šฅ์„ ํฌํ•จํ•œ ์ƒํƒœ๋กœ ๋ชจ๋“  ๊ธฐ๋Šฅ์ด ์ •์ƒ์ ์œผ๋กœ ๋™์ž‘ํ•˜๋Š”์ง€ ํ™•์ธ
  • ๋ฆด๋ฆฌ์ฆˆ๋ฅผ ์œ„ํ•œ ์ตœ์ข…์ ์ธ ๋ฒ„๊ทธ ์ˆ˜์ • ๋“ฑ์˜ ๊ฐœ๋ฐœ์„ ์ˆ˜ํ–‰ ํ›„ ๋ฐฐํฌ ๊ฐ€๋Šฅํ•œ ์ƒํƒœ๊ฐ€ ๋˜๋ฉด master ๋ธŒ๋žœ์น˜์— ๋ณ‘ํ•ฉ
  • ๋ฒ„๊ทธ ์‚ฌํ•ญ ์ˆ˜์ •์€ develop ๋ธŒ๋žœ์น˜์—๋„ ์ ์šฉํ•ด์•ผ ํ•˜๊ธฐ ๋•Œ๋ฌธ์—, ๋ณ‘ํ•ฉ ์ž‘์—… ์ˆ˜ํ–‰

Hotfix branch

  • ๋ฐฐํฌํ•œ ๋ฒ„์ „์— ๊ธด๊ธ‰ํ•˜๊ฒŒ ์ˆ˜์ •์„ ํ•ด์•ผ ํ•  ํ•„์š”๊ฐ€ ์žˆ์„ ๊ฒฝ์šฐ master ๋ธŒ๋žœ์น˜์—์„œ ๋ถ„๊ธฐํ•˜๋Š” ๋ธŒ๋žœ์น˜
  • master์—์„œ ๋ถ„๊ธฐํ•˜๋Š” ์ด์œ  ๋ฐฐํฌํ•œ ์†Œ์Šค์ฝ”๋“œ์— ํฐ ๋ฒ„๊ทธ๊ฐ€ ๋ฐœ์ƒ์‹œ, develop์—์„œ ์ˆ˜์ • ํ›„ ๋ฐฐํฌ๊ฐ€๋Šฅํ•œ ๋ฒ„์ „์„ ๋งŒ๋“ค๊ธฐ์—๋Š” ์‹œ๊ฐ„๋„ ๋งŽ์ด ์†Œ์š”๋˜๊ณ , ์•ˆ์ •์„ฑ์„ ๋ณด์žฅํ•˜๊ธฐ ์–ด๋ ค์›€ โ‡’ ์•ˆ์ •์„ฑ์ด ๋ณด์žฅ๋œ ๋ฐ”๋กœ ๋ฐฐํฌ๊ฐ€ ๊ฐ€๋Šฅํ•œ master ๋ธŒ๋žœ์น˜์—์„œ ๋ถ„๊ธฐ
  • ๋ฒ„๊ทธ ์‚ฌํ•ญ ์ˆ˜์ • ํ›„ , develop์—๋„ ๋ณ‘ํ•ฉํ•˜์—ฌ ๋ฒ„๊ทธ ์ˆ˜์ • ์‚ฌํ•ญ ๋ฐ˜์˜
Commit
  • commit convention : [์ด์Šˆ ๋ฒˆํ˜ธ] ๊ธฐ๋Šฅ ๋ถ„๋ฅ˜ : ์ƒ์„ธ์„ค๋ช…(ํ•œ๊ธ€)
  • git cz ์‚ฌ์šฉ

๐Ÿฆฆ MariaDB Convention

DB ๋„ค์ด๋ฐ ๊ทœ์น™ : ๐Ÿsnake_case

(ํ•œ ๋ฌธ์ž ๋‹จ์–ด๋งˆ๋‹ค _(์–ธ๋”๋ฐ”)๋ฅผ ๋ถ™์—ฌ์„œ ์˜๋ฏธ๋ฅผ ๋ถ€์—ฌํ•˜๋Š” ๋ฐฉ์‹)

  1. Table ๋ช… : {table๋ช…} ex. users
  2. Column ๋ช… : {table๋ช…}_{column์˜๋ฏธ} ex.user_uid, user_name, user_email, user_password
  3. ์•ฝ์–ด๋ฅผ ์ง€์–‘ํ•˜๊ณ  ํ’€๋„ค์ž„์„ ์‚ฌ์šฉ!!
  4. ๊ฐ€๋Šฅํ•œ ์˜ˆ์•ฝ์–ด๋Š” ํ”ผํ•˜๋Š” ๊ฒƒ์œผ๋กœ!! https://dev.mysql.com/doc/refman/5.7/en/keywords.html
  5. ๋ณต์ˆ˜ํ˜• ์‚ฌ์šฉ : ํ…Œ์ด๋ธ” ๋ช…
  6. ๋‹จ์ˆ˜ํ˜• ์‚ฌ์šฉ : ์ปฌ๋Ÿผ๋ช… ๋“ฑ
  7. PRIMARY KEY : auto increment์˜ ๊ฒฝ์šฐ _seq ์ ‘๋ฏธ์–ด๋ฅผ ์‚ฌ์šฉํ•œ๋‹ค.
  8. FOREIGN KEY : ์ž์‹์ปฌ๋Ÿผ ์ด๋ฆ„ ์•ž์— fk_ ์ ‘๋‘์–ด๋ฅผ ์‚ฌ์šฉํ•œ๋‹ค.
  9. boolean ์œ ํ˜•์˜ ์ปฌ๋Ÿผ์ด๋ฉด _flag ์ ‘๋ฏธ์–ด๋ฅผ ์‚ฌ์šฉํ•œ๋‹ค.
  10. date, datetime ์œ ํ˜•์˜ ์ปฌ๋Ÿผ์ด๋ฉด _date ์ ‘๋ฏธ์–ด๋ฅผ ์‚ฌ์šฉํ•œ๋‹ค.

๐ŸŒฑ Spring Boot Convention

  • ํด๋ž˜์Šค ๋ฐ ์ธํ„ฐํŽ˜์ด์Šค ์ด๋ฆ„ : Pascal Case

    1. ์ด๋ฆ„ ์ฒซ ๋ฒˆ์งธ๋Š” ๋Œ€๋ฌธ์ž๋กœ ์‹œ์ž‘
    2. ์ถ•์•ฝํ˜•์€ ์‚ฌ์šฉํ•˜์ง€ ์•Š์Œ
    3. DB Table ์ด๋ฆ„์„ ๊ธฐ๋ฐ˜์œผ๋กœ ex. ChallengeController, UserController, ChallengeRepository, ChallengeService
    4. ์ธํ„ฐํŽ˜์ด์Šค๋ฅผ ์ƒ์†๋ฐ›๋Š” ํด๋ž˜์Šค ์ด๋ฆ„ : ์ธํ„ฐํŽ˜์ด์Šค ์ด๋ฆ„ + Impl
      ex. ํด๋ž˜์Šค ์ด๋ฆ„ : UserServiceImpl / ์ธํ„ฐํŽ˜์ด์Šค ์ด๋ฆ„ : UserService
  • Method ๋ฐ ๋ณ€์ˆ˜ ์ด๋ฆ„ : camel Case

    1. ์ด๋ฆ„ ์ฒซ ๋ฒˆ์งธ ๊ธ€์ž๋Š” ์†Œ๋ฌธ์ž
    2. ์ถ•์•ฝํ˜•์€ ์‚ฌ์šฉํ•˜์ง€ ์•Š์Œ
Clone this wiki locally