Repo for clean architecture workshop. Implementasjonen er inspirert av Clean Architecture fra https://blog.cleancoder.com/uncle-bob/2012/08/13/the-clean-architecture.html Basert på clean architecture workshopen laget av Henrik Wingerei og Espen Ekvang(https://github.com/henriwi/clean-architecture).
Strukturen i repoet i "src"-mappen er som følger:
- domain
Entiteter, valuetypes, aggregater - application
Applikasjonslogikk, query og command handlere - infrastructure
Database, eksterne tjenester, repsitorier - web
Controllere, dependency injection setup ++
Domain er den innerste delen av arkitekturen og skal derfor ikke referere til noe annet lag.
Application kan bare referere til Domain.
Infrastructure kan referere til Application og Domain.
Web er ytterst og kan dermed kjenne til alle lag.
- Maven
- JDK 17
- Editor (IntelliJ eller en annen valgfri editor)
For å kompilere: mvn clean package
- Åpne
CleanArchitectureWorkshopApplication
og kjøre main metoden
- Åpne en valgfri terminal hvor Maven er tilgjengelig
- Naviger til
web
og skrivmvn spring-boot:run
etterfulgt av enter:
~\clean-architecture\web> mvn spring-boot:run
Applikasjonen skal være tilgjengelig på http://localhost:5233
Hvis du ønsker å se på innholdet i databasen er den tilgjengelig gjennom følgende web console
- http://localhost:5233/h2-console
- JDBC URL:
jdbc:h2:file:./clean-architecture-h2-db
- Brukernavn:
sa
- Passord.
password
Det er opprettet flere samlinger med HTTP requests for å gjennomføre workshopen. Den letteste veien til mål er ved hjelp av Intellij, som støtter både fila med rene HTTP requests, samt OpenAPI fila. Alternativt har vi også en Postman-samling, og curl-kommandoer.
Kallene i clean-architecture-intellij-requests.http
kan kjøres direkte fra Intellij.
Etter at du har åpnet http-fila, husk å velg miljø i vinduet rett over filinnholdet, slik at variablene er ferdigutfylte.
I kommentar over hvert kall ligger tilsvarende curl-kall, om du ønsker å kjøre kallene via kommandolinja. CURL-kallene trenger bare at miljøvariabler er definert, for eksempel slik:
$ CUSTOMER_ID=1 curl --request GET "http://localhost:5233/customers/$CUSTOMER_ID"
eller definere variabelen for flere kommandoer i samme shell:
$ export CUSTOMER_ID=1
$ curl --request GET "http://localhost:5233/customers/$CUSTOMER_ID"
I fila clean-architecture-openapi.yaml
finner du en OpenApi-spec basert på Postman-fila.
Denne kan du importere i en støttet klient, og utføre kallene der.
Intellij skal være bundlet med en OpenApi plugin, slik at du kan kjøre kallene enkelt ved hjelp av Try it out
knappen.
Insomnia er et annet eksempel på et verktøy for API-testing.
clean-architecture-postman-collection.json
er en postman collection med ressurser som representerer de ulike use casene i workshopen.
Postman-samlingen benytter variabler i postman i enkelte av ressursene. Dersom man vil sette verdi på disse variablene så kan man gjøre det ved å:
- klikk på "Environments" i Postman
- i Environment-oversikten klikk på "Globals"
- legg til ny variabel, f.eks
customerId
sett initial value til f.feks 42 - trykk "Save"
Når man nå velger å benytte en ressurs i samlingen som krever
customerId
vil den automatisk hentes fra Globals i Postman.
- (En kunde skal kunne opprettes fra et navn, legal id, legal country.)
- (En kunde skal kunne hentes vha id)
- Alle kunder skal kunne hentes ut
- En kunde skal kunne få lagt til målepunkter (id, navn, addresse, strømsone).
- En kunde skal kunne si opp et målepunkt og beholde eventuelle andre målepunkter.
- En kunde skal kunne se detaljer om alle målepunktene sine (strømsone, anleggsaddresse, et egendefinert navn f.eks. «hytta», status, type).
- En kunde skal kunne se hva forbruket har vært på et gitt målepunkt i et gitt tidsrom.
Slides fra workshopen er tilgjengelig i mappen slides