ReadWorld.io backend project using spring boot java using spring-security, spring-data-jpa
- ์ฐ์ํํ์ ๋ค ๊ธฐ์ ๋ถ๋ก๊ทธ | Todo list ๋ง๋ค๊ธฐ๋ ์ด์ ๊ทธ๋ง
- ์ฐ์ํํ์ ๋ค ๊ธฐ์ ๋ธ๋ก๊ทธ | Gradle ํ๋ก์ ํธ์ JaCoCo ์ค์ ํ๊ธฐ
- ์ฐ์ํํ์ ๋ค ๊ธฐ์ ๋ธ๋ก๊ทธ | ์ฐ๋ฆฐ Git-flow๋ฅผ ์ฌ์ฉํ๊ณ ์์ด์
- Github | Realworld.io
$ ./gradlew build bootRun$ docker run --rm -p 8080:8080 ghcr.io/raeperd/realworld-spring-boot-java:master- Dockerhub registry is here
- Container tags are simply branch name of this repository following git-flow strategy
After run application, you can try one of followings
$ ./doc/run-api-tests.shImport ./doc/Conduit.postman_collection.json in your postman application
And also, pure gradle test covers almost every line of code.
More details can be found in ./doc/README.md and original source
- Always
finalwhenever possible - Always package private class whenever possible
- Always test every package, class, method, instruction in codes
- Except for some boilerplate
equalsandhashcodemethod - This is validated by jacoco-gradle-plugin.
- Coverage verification in
./test.gradle
- Except for some boilerplate
- Try to avoid including additional dependencies as much as possible
- Implements JWT generation / validation logic without 3rd party library #3
- Try to maintain codes in domain package remain POJO
- Except for special spring annotations like
@Service,@Repository,@Transactional - Prohibit use of lombok in domain package
- Except for special spring annotations like
- Try to follow all modern best practices for spring-boot project
- You can open full diagram file in
realworld.drawiousing draw.io
- Separate password encoding logic out of User.
- User must be created with password encoder.
- Article contains other elements with
@Embeddedclasses - Try to reduce number of repositories.
- Prefer
@JoinTableto@JoinColumn
- Try not to use 3rd party library
- Serialization and Deserialization are seperated with interfaces
- Domain package contains interface, infrastructure code provide implementation
- Application package do stuff with spring-security logic
- Result of
./doc/run-api-tests.sh
- User class doing so many things now. It can be improved someway.
- Service classes can be divided into smaller services
- Test cases order can be improved
You can contact me with email or issue in this project




