Принцип YAGNI

Принцип «YAGNI» (англ. You Aren't Going to Need It — «Вам це не знадобиться») — процес і принцип проєктування, при якому основною метою та цінністю є відмова від додавання функціональності, в якій немає безпосередньої потреби. Цей принцип варто застосувати ще на етапі формування юзкейсів та UX-тестування на прототипах, оскільки це дозволяє визначити потрібні для користувачів елементи програми та усунути непотрібні функції з вимог до початку їхньої розробки.

Обґрунтування

Згідно з адептами принципу YAGNI, бажання писати код, який не потрібний прямо зараз, але може знадобитися в майбутньому, призводить до таких небажаних наслідків:

  • Витрачається час, який було б витрачено на додавання, тестування і поліпшення необхідної функціональності.
  • Нова функціональність має бути налагоджена, документована і підтримувана.
  • Нова функціональність обмежує те, що може бути зроблено в майбутньому, тому непотрібна функціональність може згодом перешкодити додаванню нової потрібної функціональності.
  • Поки функціональність справді не потрібна, важко повністю передбачити, що вона має робити, і протестувати її. Якщо нова функціональність ретельно не протестована, вона може неправильно працювати, коли вона згодом знадобиться.
  • Це призводить до того, що програмне забезпечення стає складнішим.
  • Якщо вся функціональність не документована, вона може так і залишитися невідомою користувачам.
  • Додавання нової функціональності може призвести до бажання ще новішої, приводячи до ефекту снігової кулі.

Див. також

Посилання