/go-design-pattern

Contains go design pattern implementations in real life examples

Primary LanguageGoMIT LicenseMIT

Go Report Card Codecov

go-design-pattern

Contains all the design pattern implementation written in go, alongside the Clean Architecture

Clean Architecture

Source : cleancoders

According to Uncle Bob (Robert C. Martin), the Clean Architecture should achieve separation by dividing the software into layers. Each has at least one layer for business rules, and another for interfaces. In result it should produce system with these specifications:

  1. Independent of Frameworks. The architecture does not depend on the existence of some library of feature laden software. This allows you to use such frameworks as tools, rather than having to cram your system into their limited constraints.
  2. Testable. The business rules can be tested without the UI, Database, Web Server, or any other external element.
  3. Independent of UI. The UI can change easily, without changing the rest of the system. A Web UI could be replaced with a console UI, for example, without changing the business rules.
  4. Independent of Database. You can swap out Oracle or SQL Server, for Mongo, BigTable, CouchDB, or something else. Your business rules are not bound to the database.
  5. Independent of any external agency. In fact your business rules simply don’t know anything at all about the outside world.

Clean Architecture Diagram

alt text