DDD Module: GeoLocation (Supporting Subdomain)
As a part of Simple Implementation of Modular DDD Technical Architecture Patterns in Go
.
A. Interface Layer (None)
B. DDD Modules:
- Geolocation - using DDD Layered Architecture Pattern (CRUD-GORM) [ d3ta-go/ddd-mod-geolocation ]
C. Common System Libraries [ d3ta-go/system ]:
- Configuration - using yaml
- Identity & Securities - using JWT, Casbin (RBAC)
- Initializer
- Email Sender - using SMTP
- Handler
- Migrations
- Utils
D. Databases
- MySQL (tested)
- PostgreSQL (untested)
- SQLServer (untested)
- SQLite3 (untested)
F. Persistent Caches
- Session/Token/JWT Cache (Redis, File, DB, etc) [tested: Redis]
- Indexer/Search Cache (ElasticSearch)
G. Messaging [to-do]
H. Logs [to-do]
1. Clone
$ git clone https://github.com/d3ta-go/ddd-mod-geolocation.git
2. Setup
a. copy `conf/config-sample.yaml` to `conf/config.yaml`
b. copy `conf/data/test-data-sample.yaml` to `conf/data/test-data.yaml`
c. setup your dependencies/requirements (e.g: database, redis, smtp, etc.)
3. Runing TDD on Development Stage
3.1. TDD: DB Migration Test
$ cd ddd-mod-geolocation
$ sh tdd/clean-testcache.sh
$ sh tdd/ut.db.migration.run-001.sh
$ sh tdd/ut.db.migration.rollback-001.sh
3.2. TDD: Functionality Test (unit test)
$ cd ddd-mod-geolocation
$ sh tdd/clean-testcache.sh
$ sh tdd/ut.db.migration.run-001.sh
$ sh tdd/ut.pkg.infra-layer.svc.rdbms-001.sh
$ sh tdd/ut.pkg.infra-layer.svc.indexer-001.sh
$ sh tdd/ut.pkg.app-layer.service-001.sh
$ sh tdd/ut.pkg.app-layer.application-001.sh
OR
$ cd ddd-mod-geolocation
$ sh tdd/run.tdd.sh
TDD Result Sample:
- MySQL Database:
- ElasticSearch: